This application claims priority under 35 U.S.C. § 119 to an application entitled “FUSION MEMORY DEVICE AND METHOD” filed in the Korean Intellectual Property Office on Sep. 8, 2006 and assigned Serial No. 2006-0087076, the contents of which are incorporated herein by reference.
1. Field of the Invention
The present invention relates generally to a fusion memory and, in particular, to a fusion memory device and a method that is capable of storing binary data in a compressed format and reading out the compressed binary data in a decompressed format.
2. Description of the Related Art
A fusion memory is a device integrating different types of memories and logics on a single chip. The fusion memory is advantageous in that system specific software can be provided with the system memory. With the combination of a high density memory, logic, and software availability, the fusion memory is expected to lead the mobile device market facing new demands in a digital convergence era.
Mobile devices such as cellular phones integrate different features such as digital broadcast receiver, camera, MP3 player, and Bluetooth. Such functional convergence of a mobile device increases the size of the system software, firmware, and user data, requiring large memory space. Thus, the fusion memory should be designed for efficiently storing the large binary data.
In the conventional fusion memory, however, the system software, firmware, and user data are stored in the form of raw binary data and results in a memory shortage. Accordingly, there has been a need for efficient memory management technology with a binary data compression/decompression logic.
The present invention has been made in an effort to solve the above problems. The present invention provides a fusion memory device and a method that is capable of storing binary data in a compressed format.
The present invention also provides a fusion memory device and a method that is capable of recovering original binary data from a compressed data stored in the fusion memory.
In accordance with an aspect of the present invention, a fusion memory device of the present invention includes a main memory for storing data in a compressed format; a secondary memory for buffering binary data to be written within and read from the main memory; and a memory controller having a pair of compressor and decompressor and controlling, in a writing mode, the secondary memory to buffer the binary data downloaded from a host device and the compressor to compress the binary data buffered with the secondary memory, and controlling, in a reading mode, the secondary memory to buffer the binary data read out from the main memory within the secondary memory and the decompressor to decompress the binary data buffered within the secondary memory.
In accordance with another aspect of the present invention, a fusion memory device of the present invention includes a main memory including a pseudo NOR mapping area and a host memory mapping area; a secondary memory for buffering binary data downloaded from a host device and read out from the main memory; and a memory controller for controlling the main memory and secondary memory, in a writing mode, to read out the downloaded binary data from the secondary memory and to write the read binary data within the main memory via a NAND interface and, in a reading mode, to read out the binary data from main memory to be accessed by the host device, wherein the binary data stored within the host mapping region of the main memory is read out to the host device via the NAND interface, and the binary data stored within the pseudo NOR mapping area is read out via the NAND interface and buffered within the secondary memory with an address converted for the host device to read out the buffered binary data from the secondary memory via the NOR interface.
In accordance with another aspect of the present invention, a fusion memory device of the present invention includes a main memory including a pseudo NOR mapping area and a host memory mapping area for storing data compressed depending on data types; a secondary memory for buffering the data to be written within or read out from the main memory; and a memory controller including a pair of compressor and decompressor, the memory controller controlling, in a writing mode, to buffer the binary data downloaded from a host device within the secondary memory, compress the buffered binary data through use of the compressor, and write the compressed binary data with a corresponding mapping area of the main memory via a NAND interface; and controlling, in a reading mode, to read out the binary data from the main memory via the NAND interface and buffer the read data within the secondary memory, recover the binary data from a compressed format through use of the decompressor, output the data derived from the host memory mapping area to the host interface via the NAND interface, convert an address of the data derived from the pseudo NOR mapping area for allowing NOR interface access, and buffer the data within the secondary memory with the converted address such that the host device can read out the data from the secondary memory via the NOR interface.
In accordance with another aspect of the present invention, a device includes a host device and a fusion memory device. The fusion memory device includes a main memory including a pseudo NOR mapping area and a host memory mapping area, a secondary memory for buffering binary data to be read from and written with the main memory, and a memory controller including a pair of compressor and decompressor and controlling, in a writing mode, the secondary memory to buffer the binary data downloaded from the host device and the compressor to compressing the binary data buffered with the secondary memory, and controlling, in a reading mode, the secondary memory to buffer the binary data read out from the main memory within the secondary memory and the decompressor to decompress the binary data buffered within the secondary memory. The host device includes a host memory for storing the data read out from the main memory, and a host controller for controlling the host device to transmit control information including address information to the fusion memory device, write, in the writing mode, the binary data within the main memory via the NAND interface, read, in the reading mode, the binary data from the host memory mapping area of the main memory via the NAND interface and from the pseudo NOR mapping area via the NOR interface.
In accordance with another aspect of the present invention, a method for accessing a fusion memory device including a main memory and a secondary memory for buffering binary data to be read from and written to the main memory includes buffering, in a writing mode, binary data downloaded from a host device within the secondary memory; compressing the binary data; writing the compressed binary data read out from the secondary memory within the main memory; buffering, in a reading mode, the compressed binary data read out from the main memory within the secondary memory; decompressing the compressed binary data; and outputting the binary data read out from the secondary memory to the host device.
In accordance with another aspect of the present invention, a method for accessing a fusion memory device including a main memory having a pseudo NOR mapping area and a host memory mapping area and a secondary memory for buffering binary data to be read from and written to the main memory includes buffering, in a writing mode, binary data downloaded from a host device within the secondary memory; writing the binary memory read out from the secondary memory within the main memory via a NAND interface; and reading out, in a reading mode, the binary data from the main memory to the host device, the binary memory stored within the host memory mapping region being read out via the NAND interface, and the binary memory stored within the pseudo NOR mapping area being read out via the NAND interface, an address of the binary data read out from the pseudo NOR mapping area being converted and buffered within the secondary memory with the secondary memory such that the host device can read out the binary memory buffered within the secondary memory via NOR interface with reference to the converted address.
In accordance with another aspect of the present invention, a method for accessing a fusion memory device including a main memory having a pseudo NOR mapping area and a host memory mapping area and a secondary memory for buffering binary data to be read from and written to the main memory includes buffering, in a writing mode, binary data download from a host device within the secondary memory, compressing the binary data, and writing the compressed binary data within one of the mapping areas of the main memory via a NAND interface; and reading out, in a reading mode, compressed binary data from the main memory, buffering the compressed binary data within the secondary memory, decompressing the compressed binary data, determining whether the decompressed binary data is read out from the host memory mapping area, outputting, when the decompressed binary data is read out from the host memory mapping area, the decompressed to the host device via the NAND interface, determining, when the decompressed binary data is read out from the pseudo NOR mapping area, converting, when the decompressed binary data is read out from the pseudo NOR mapping area, an address of the decompressed binary data into a NOR interface accessible address, and notifying the NOR interface accessible address to the host device.
The above and other objects, features and advantages of the present invention will become more apparent from the following detailed description when taken in conjunction with the accompanying drawings, in which:
Preferred embodiments of the present invention are described with reference to the accompanying drawings in detail. The same reference numbers are used throughout the drawings to refer to the same or like parts. Detailed descriptions of well-known functions and structures incorporated herein may be omitted to avoid obscuring the subject matter of the present invention.
Types of memory and units of data processing and compression/decompression are provided to enable a clear and consistent understanding of the detailed description and the claims. Unless otherwise noted, terms are to be understood according conventional usage by those skilled in the relevant art.
In the following preferred embodiments, the term “fusion memory” means a memory device integrated with different types of memory and non-memory with specific logics on a single chip in addition to a main memory. The term “code” means a unit of binary data by which system software and firmware are stored within the main memory of the fusion memory device. The term “user data” means all kinds of data, except for the codes, stored within the main memory of the fusion memory device. The term “binary data” represents all kinds of data including the codes and user data stored within the main memory of the fusion memory device. The term “memory controller” indicates a component for compressing/decompressing the binary data and controlling an access to the binary data stored within main memory with a NAND or NOR interface.
The main memory of the fusion memory device is provided with processing an execution space and storage space for executing and storing the codes (software and firmware) and user data. In an embodiment of the present invention, the fusion memory device is provided with logic for compressing and storing the binary data including the software, firmware, and user data within the main memory and decompressing the compressed data to be output in the form of binary data. The fusion memory device enables large amount of binary data greater than physical storage space of the memory to be stored and loaded.
In an embodiment of the present invention, the fusion memory device is provided with a compressor/decompressor unit embedded in the main memory so as to efficiently manage the storage space with fast compression/decompression operations.
The fusion memory device according to an embodiment of the present invention is provided with a storage region accessed through a NOR interface and a storage region accessed through a NAND interface such that the fusion memory device can access the binary data store in the different memory regions through the NAND or NOR interface under the control of an external device.
As described above, a fusion memory device is the memory device integrated with the main memory, secondary memory, non-memory, and/or a logic on a single chip. The logic can be a pure logic, a Central Processing Unit (CPU), a Microprocessing Unit (MPU), or a combination thereof. In the embodiments of the present invention, it is assumed that a memory controller is provided with a compressor/decompressor implemented in the form of a logic.
The fusion memory can be implemented with a combination of different types of memories. OneNAND memory is a well-known fusion memory commercialized by Samsung Electronics Co. Ltd. OneNAND memory is implemented by integrating a high density NAND flash cell and a high speed static random access memory (SRAM) with a logic circuit on a signal chip. OneNAND memory has advantages of a large storage, high-speed data read/write capability of NAND flash memory, and byte access capability of NOR flash memory. OneNAND memory has a sustained read and write speed faster than the NAND and NOR memories while maintaining a capacity data storage. With these advantages, OneNAND memory is expected to be used in a growing number of applications including mobile handsets, computers, digital cameras, and digital broadcast receivers.
In the following embodiments, a fusion memory device is assumed as OneNAND device in which a memory controller is provided with a compressor/decompressor for efficiently managing the memory by compressing/decompressing the binary data. However, the present invention is not limited to OneNAND device, but can be applied to all kinds of fusion memory devices. In the following embodiments, it is assumed that the host device of a fusion memory device is a mobile terminal. The mobile terminal can be any of electronic devices having information processing functions such as communication and multimedia functions.
Referring to
The main memory 130 is structured as a NAND flash cell array for storing binary data and divided into a system data region and a user data region. The system data region can be provided with a pseudo NOR mapping area and a RAM mapping area. The system data region is used for storing the codes of the system software and firmware, and the user data region is used for storing user data. The secondary memory 120 is used for converting the binary data of the pseudo NOR mapping area and acts as a buffer of the main memory 130. The memory controller 110 compresses the input binary data and stores the compressed data within the main memory 130. Also, the memory controller 110 reads out the binary data by decompressing the compressed data from the main memory 130. The memory controller 110 is provided with a compressor/decompressor for compressing the binary data and decompressing the compressed binary data.
As described above, the binary data include the codes representing the system software and firmware or the user data. For a mobile terminal equipped with the fusion memory device 100, the memory controller 110 can be configured such that the compressor/decompressor performs compression/decompression as following.
The code can be any of text code, read only (RO) data, read and writable (RW) data, and resource. The text code is a pure program code, the RO data is a constant data of which value cannot be changeable during the execution, the RW data is a data of which value can be changeable during the execution, and the resource can be any of a font, background image, bell sound, and string for use in the mobile terminal. The text code can be a program instruction, and the RO, RW, and resource can be application data. The compression ranges of the program instruction and application data are distinguishably set according to their characteristics and managed in the form of a table for use in data compression/decompres sion process.
The user data is data generated while the mobile terminal executes applications. The user data includes a phonebook, short message service (SMS) message, multimedia message service (MMS) message, e-mail message service (EMS) message, personal information management (PIM) data, call log, and multimedia data including still picture, motion picture, and audio data. By storing the user data in a compressed format, the storage efficiency of the main memory 130 can be improved. The user data compression can be performed with different compression schemes showing a highest compression efficiency according to the types of the user data.
By implementing the fusion memory device 100 with the compressor/decompressor within the memory controller 110, the main memory 130 can be efficiently managed. Since the main memory 130 stored the binary data in the compressed format, it is possible to conserve the storage space of both the system data region and the user data region of the main memory 130. In other words, the system data region can store the more codes or the conserved space can be used for storing the user data.
Referring to
A software module 200 is provided with software of the host device 300 that includes applications 230, memory control software 210 for controlling the operations of the fusion memory device 100, and compression/decompression control software 220 for controlling the compression/decompression of the binary data stored in the fusion memory device 100.
As sown in
The main memory 130 of the fusion memory device 100 can be a NAND flash memory. The binary data are stored within the NAND flash memory in unit of page and erased from the NAND flash memory in unit of block. The page and block can be set with respective sizes (for example, 512 bytes per page and 32 pages per block). The NAND flash memory should be erased before storing the binary data. Accordingly, the memory controller 110 erases the address region of the main memory 130 in unit of block and the writes the binary data in unit of page.
The memory 130 of the fusion memory device 100 consists of a system data region and a user data region, and the system data region is divided into the pseudo NOR mapping area and the RAM mapping area. Here, the host controller 310 can access the binary data stored in the system data region through a NOR interface or NAND interface. To write the binary data into the system data region of the main memory 130, the memory controller 110 uses the NAND interface. The binary data stored within the pseudo NOR mapping area of the system data region is read through the NOR interface and the binary data stored within the RAM mapping area of the system data region is read through the NAND interface.
The NOR interface allows accessing the binary data in unit of byte, and the NAND interface allows accessing the binary data in unit of page. The fusion memory device 100 performs compression on the binary data to be stored within the main memory 130 and performs decompression on the compressed data to be read out.
Referring to
In transferring the codes (for example, the system software or firmware) stored in the host memory 320 to the main memory 130, the memory controller 110 accesses the target code stored within the host memory 320, compresses the code read out from the host memory 320, and stores the compressed code within the system data region of the main memory 130. In
In loading the code stored in the system data region of the main memory 130, the memory controller 110 accesses the compressed code stored in the system data region of the main memory 130, decompresses the compressed code to recover the raw code through use of the decompressor 470, and loads the recovered code onto the host memory 320. In
In transferring the user data stored within the host memory 320 to the main memory 130 of the fusion memory device 100, the memory controller 110 accesses read out the binary data stored in the host memory 320, compress the binary data read out from the host memory 320, and stores the compressed data within the user data region of the main memory 130.
In reading out the user data from the user data region of the main memory 130, the memory controller 110 accesses the compressed user data stored in the user data region of the main memory 130, decompresses the compressed user data to recover the raw user data through use of the decompressor 470, and stores the recovered user data within the host memory 320.
As described above, the fusion memory device 100 compresses the user data and then stores the user data within the user data region of the main memory 130 in the compressed format. When it is required to load the user data, the fusion memory device 100 reads out the compressed user data from the user data region of the main memory 130, performs decompression on the compressed user data to recover the raw user data, and loads the user data on the host memory 320.
As depicted in
The host controller 310 can be configured to access the binary data stored within the fusion memory device 100 through the NOR interface and the NAND interface. Accordingly, the host controller 310 can control the fusion memory device 100 to operate as the program memory of the host device 300 and the data memory for storing the user data requiring large storage space. The memory controller 110 accesses the codes stored within the system data region through the NAND interface and NOR interface under the control of the host controller 310. In the codes to be stored within the pseudo NOR mapping area of the system data region, the memory controller 110 stores the codes downloaded from the host controller 310 within the pseudo NOR mapping region of the system data region of the main memory 130. In accessing the codes stored within the pseudo NOR mapping area, the memory controller 110 reads the code stored in the pseudo NOR mapping area of the main memory 130 through the NAND interface and converts the address of the code to be read through the NOR interface. Sequentially, the memory controller 110 buffers the code within the secondary memory 120 and reports this to the host controller 310. Accordingly, the host controller 310 accesses the code stored in the second memory 120 through the NOR interface.
In storing the code within the RAM mapping area, the memory controller 110 stores the coded downloaded from the host controller 310 within the RAM mapping area of the system data region of the main memory 130. In accessing the code stored within the RAM mapping area, the memory controller 110 reads the code stored in the RAM mapping area of the main memory through the NAND interface such that the host controller 310 stores the code read by the memory controller 110 within the host memory 320 through the NAND interface.
Referring to
The host memory map 330 is provided with a RAM region having a system and user data regions 335 and 337 for the system and user data region of the host memory 320, and a pseudo NOR region 333 for the pseudo NOR mapping area of the system data region. Here, the RAM region 335 and 337 is a real space for use when the host controller 310 accesses the RAM mapping area 135 and the user data region 137 of the main memory 130 of the fusion memory device 100, and the pseudo NOR region 333 is a virtual space for use when the host controller 310 accesses the pseudo NOR mapping area 133 of the main memory 130 of the fusion memory device 100. The host memory map 330 includes the pseudo NOR region 333 for accessing the pseudo NOR mapping area 133 of the fusion memory 100 and the RAM region 335 and 337 of the physical host memory 320.
The fusion memory device 100 includes a memory controller 110, a first secondary memory 123, a second secondary memory 125, and a main memory 130. The memory controller 110 accesses the binary data stored within the main memory 130 through the NOR interface and NAND interface under the control of the host controller 310 and performs compression/decompression of the binary data. The memory controller 110 is provided with a compressor 460 for compressing the binary data to be stored within the main memory 130 and a decompressor 470 for decompressing the compressed binary data read out from the main memory 130. The memory controller 110 also is provided with a buffer for buffering the compressed binary data read out from the main memory 130 in unit of page such that the memory controller 100 can write the binary data within the mapping region through the NAND interface. The memory controller 110 controls the compressed data to be read through the NAND interface or the NOR interface according to the characteristics of the mapping areas of the main memory 130.
The secondary memories 123 and 125 can be implemented with two separate memories or can be implemented with a single memory having two separated regions. In this embodiment, it is assumed that the first and second secondary memories 123 and 125 are integrated into a package of the fusion memory device 100. The second secondary memory 125 buffers the binary data downloaded in a writing mode and the compressed data read out from the main memory 130 in the reading mode. The first secondary memory 123 buffers, in the writing mode, the compressed data to be written into the main memory 130 through the NAND interface, and buffers, in the reading mode, the decompressed code to be read from the pseudo NOR mapping area through the NOR interface. The secondary memories 123 and 125 can be implemented with a RAM. The main memory 130 includes a system data region for storing the codes and a user data region 137 for storing the user data. The system data region includes a pseudo NOR mapping area 133 in which the codes are accessed through the NOR interface and a RAM mapping area 135 in which the codes are accessed through the NAND interface. In a binary data writing mode, the memory controller 110 writes the data within the main memory 130 in unit of page. To buffer the data, the memory controller 110 may use a buffer having a page size or use the secondary memories 123 and 125. In this embodiment, it is assumed that the secondary memories 123 and 125 are used for buffering the data. Here, the binary data to be written are buffered within the first secondary memory 123.
The fusion memory device 100 has been described with an implementation with the compressor 460 and decompressor 470 in this embodiment. However, the fusion memory device 100 can be implemented, without the compressor and decompressor, by dividing the main memory 130 into a system data region and user data region and dividing the system data region into a NOR interface access region and a NAND interface access region. Also, the fusion memory device 100 can be implemented with the compressor 460 and the decompressor 470 such that the main memory 130 can be accessed through only one of the NAND interface or the NOR interface. The operations of three types of fusion memory device 100 configured as above are described hereinafter.
The operation of a fusion memory device 100 implemented with a pair of compressor 460 and decompressor 470 and the main memory 130 having a NAND interface access region and a NOR interface access region is described hereinafter.
In the writing mode, when the host controller 310 downloads the code to be stored, the memory controller 110 of the fusion memory device 100 controls the second secondary memory 125 to buffer the downloaded code. Next, the memory controller 110 controls the compressor 460 to compress the code output from the second secondary memory 125 in a predetermined compression scheme and controls the first secondary memory 123 (or an internal buffer of the memory controller 110) to buffer the compressed code. Also, the memory controller 110 reads out the compressed code from the first secondary memory 123 in unit of page and writes the compressed code within the pseudo NOR mapping area 133 or the RAM mapping area 135 of the main memory 130 via the NAND interface. In accessing the code stored within the pseudo NOR mapping area 133, the memory controller 110 reads out the code from the pseudo NOR mapping area 133 via the NAND interface so as to be buffered within the second secondary memory 125. Next, the memory controller 110 controls the decompressor 470 to decompress the compressed code, realigns the decompressed code to be accessed via the NOR interface, and stores the realigned code within the first secondary memory 123. At this time, the host controller 310 accesses the code stored within the first secondary memory 123 via the NOR interface. The code accessed via the NOR interface is directly processed by the host controller 310. In the code stored within the RAM mapping area of the main memory 130, the memory controller 110 reads out the code from the RAM mapping area of the main memory 130 via the NAND interface, buffers the code within the second secondary memory 125, and controls the decompressor 470 to decompress the code such that the host controller 310 accesses the decompressed code via NAND interface and stores the code read out from the second secondary memory 125 within the host memory 320 corresponding to the RAM region 355 of the host memory map 330 as a real memory region. Consequently, the host controller 310 reads out the code from the host memory 320.
The operation of the fusion memory device 100 implemented with a main memory having a NAND interface access region and a NOR interface access region without a compressor and decompressor.
In this case, the fusion memory device 100 stores the downloaded binary data within a corresponding area of the main memory 130 via the NAND interface and reads out the binary data via the interface for the mapping area. In the case that the fusion memory device 100 operates in the writing mode, the host controller 310 downloads the code to be stored, and the memory controller 110 of the fusion memory device 100 writes the downloaded code within the pseudo NOR mapping area or the RAM mapping area of the main memory 130. In operating in reading mode, the memory controller 110 reads out the code stored within the pseudo NOR mapping area via NAND interface and reassigns the address such that the code is stored within one of the secondary memories 123 and 125 to be accessed via the NOR interface. The host controller 310 reads out the code stored within the secondary memories 123 and 125 via the NOR interface and processes the code. The code accessed via the NOR interface is directly processed by the host controller 310. In accessing the code stored within the RAM mapping area of the main memory 130, the memory controller 110 reads out the code from the RAM mapping area of the main memory 130 via the NAND interface, and the host controller 310 stores the code within the host memory 320 via the NAND interface. Consequently, the host controller 310 reads out the code from the host memory 320 and processes the code.
The operation of the fusion memory device 100 implemented with a pair of compressor and decompressor and a main memory having distinguishable interface access areas.
In the writing mode, the host controller 310 downloads the code to be stored, and the memory controller 110 of the fusion memory device 100 controls the second secondary memory 125 to buffer the downloaded code and controls the compressor 460 to compress the code read out from the second secondary memory 125 such that the compressed code is buffered within the first secondary memory 123 (or an internal buffer provided in the memory controller). The memory controller 110 accesses the compressed code stored within the first secondary memory 123 in unit of page and writes the code within the main memory 130 via the NAND interface. In reading out the code from the main memory 130, the memory controller 110 buffers the code read from the main memory 130 within the second secondary memory 125 and controls the decompressor 470 to decompress the compressed to recover the code. Consequently, the host controller 310 reads out the code from the fusion memory 100.
The operation of a fusion memory implemented with a pair of compressor and decompressor and a main memory having a system data region and a user data region, the system data region including a pseudo NOR mapping area and a RAM mapping area, is described hereinafter in more detail.
In
In downloading a code within the fusion memory device 100, the memory control software 210 checks a size and address of the code for determining where to store the code in the main memory 130 and sets a flag for a compression scheme of the compressor/decompressor control software 220. Next, the host controller 310 temporarily stores the code within the host memory 320. Here, the code can be stored within the pseudo NOR mapping area 133 and/or the RAM mapping area 135. The code can be entirely stored within the pseudo NOR mapping area 133 or the RAM mapping area 135 or partially stored within the pseudo NOR mapping area 133 and RAM mapping area 135.
A host memory map 330 matches the pseudo NOR region 333, as a virtual region, and the RAM region of the host memory 320. The host controller 310 transfers the code stored within the host memory 320 to the fusion memory device 100 through a bus in cooperation with the memory control software 210. At this time, the memory control software 210 generates control information on a compression scheme and instructing the memory controller 110 of the fusion memory device 100 to store the compressed code within the pseudo NOR mapping area 133 and/or the RAM mapping area 135.
Upon receiving the control information, the memory controller 110 of the fusion memory device 100 operates such that the downloaded code is buffered within the second secondary memory 125 and the compressor 460 to compress the code read out from the second secondary memory 125 in the compression scheme and write the compressed code within the first secondary memory 123 (or an internal buffer of the memory controller 110). The memory controller 110 writes the compressed code read out from the first secondary memory 123 within a location of the main memory 130 via the NAND interface. Also, the compressed code can be stored within the main memory 130 without a buffering process. The storage location of the compressed code can be any of the pseudo NOR mapping area 133 or the RAM mapping area 135. After the compressed code is normally stored within the system data region of the main memory 130, the memory controller 110 reports the storage result to the host controller 310 such that the host controller 310 performs a next process.
The host controller 310 transfers the code stored within the host memory 320 to the fusion memory device 100 in such manner. The memory controller 110 compresses the binary data of the transferred code in a predetermined compression scheme, stores the compressed code within a predetermined mapping area of the main memory 130, and reports the storage result to the host controller 310. This procedure is repeated until the target codes are completely transferred. Since the code is stored within the system data region of the main memory 130 in the compressed format, the fusion memory device 100 can improve the storage efficiency.
When the code is stored within the main memory 130 of the fusion memory device 100, the compression scheme and storage address of the code are determined under the control of the host controller 310. The fusion memory device 100 buffers and compresses the code transferred from the host device and stores the compressed code within a mapping area of the main memory 130 via the NAND interface. The mapping area can be the pseudo NOR mapping area 133 or the RAM mapping area 135. In this embodiment, it is assumed that the code is compressed in an identical compression scheme regardless of the mapping areas and stored within the pseudo NOR mapping area 133 and/or the RAM mapping area 135 via the NAND interface.
In one embodiment, the code stored within the pseudo NOR mapping area 133 of the main memory 130 is accessed via the NOR interface to be read out, and the code stored within the RAM mapping area 135 is accessed via the NAND interface to be read out. The pseudo NOR mapping area 133 and RAM mapping area 135 access operations are sequentially described hereinafter.
When an access event occurs for executing a code stored within the system data region of the main memory 130, the control controller 310 checks whether the code is stored within the pseudo NOR mapping area 133 or the RAM mapping area 135. When it is determined that the code is stored within the pseudo NOR mapping area 133, the host controller 310 executes the memory control software 210 such that the memory control software 210 operates to read out the code from the pseudo NOR mapping area 133. The memory control software 210 receives a flag indicating the compression scheme assigned for the code stored at a corresponding address and transfers the control information on the address, command, and compression scheme to the memory controller 110 of the fusion memory device 100. When the control information is received, the memory controller 110 analyzes the control information and sets the code access scheme and decompression scheme of the decompressor 470 on the basis of the analysis result. Next, the memory controller 110 reads the code stored at the corresponding address of the pseudo NOR mapping area 133 of the main memory 130 via the NAND interface and stores the code within the second secondary memory 125. The decompressor 470 performs decompression on the compressed code read out from the second secondary memory 125. Consequently, the memory controller 110 converts the address of the code so as to be read out via the NOR interface such that the code is buffered within the first secondary memory 123. Here, the host controller 310 accesses the code stored within the first secondary memory 123 and processes the code in unit of byte.
As described above, the memory controller 110 of the fusion memory device 110 reads out the code from an address, via the NAND interface, indicated by a read command generated by the host controller 310 and stores the code within the second secondary memory 125. The code is recovered and then buffered within the first secondary memory 123 such that the host controller 310 to access via the NOR interface in unit of byte. The host controller 310 accesses the first secondary memory 123 and processes the code read out via the NOR interface. Here, the code is read out from the first secondary memory 123 and processed by the host controller 310.
In reading the code from the pseudo NOR mapping area 133, the memory controller 110 of the fusion memory device 100 reads out the code from the pseudo NOR mapping area 133 via the NAND interface and stores the code within the second secondary memory 125 such that the code is decompressed by the decompressor 470 and then buffered within the second secondary memory 125. Next, the memory controller 110 converts the address of the code within the second secondary memory 125 and stores the code within the first secondary memory 123 such that the host controller 310 accesses the code via the NOR interface. The address conversion and storage result are reported to the host controller 310 such that the host controller 310 reads out the code from the first secondary memory 123 via the NOR interface and processes the code. The code stored within the pseudo NOR mapping area 133 can be a program. In this case, the host controller 310 reads out the code from the secondary memory 120 of the fusion memory device 100 without buffering within the host memory 320. Accordingly, the fusion memory 100 can access the code via the NOR interface with the host device while accessing its main memory 130 via the NAND interface. By configuring to operate as above, the fusion memory device 100 has the advantages of the large memory capability of the NAND flash memory and high speed data access of the NOR flash memory.
Referring to
As described above, when the read access event is detected, the host controller 310 checks where the target data to be read is located, i.e., in the pseudo NOR mapping area 133 or the RAM mapping area 135. The host controller 310 executes the memory control software 220 such that the memory control software 220 checks the compression scheme flag and outputs control information including the address, commands, and compression scheme for the data to the memory controller 110 of the fusion memory 100. Upon receiving the control information, the memory controller 110 of the fusion memory device 100 analyzes the control information to determine whether the data are stored in a compressed format. When the data is stored in a compressed format, the memory controller 110 controls the decompressor 470 to decompress the compressed data according to the access interface of the main memory 130 and the decompression flag. The memory controller 110 reads out the code stored at the address of the RAM mapping area 135 of the main memory 130 via the NAND interface and stores the code within the second secondary memory 125. Next, the decompressor 470 performs decompression on the code read out from the second secondary memory 125. After the code is decompressed, the memory controller 110 reports a decompression result to the host controller 310 such that the host controller 310 reads out the code from the second secondary memory 125 via the NAND interface and stores the code within the host memory 320.
Repeating the above procedure, the host controller 310 reads out the code from the RAM mapping area 135 of the main memory 130 of the fusion memory device 100 and writes the code within the host memory 320. At this time, the fusion memory device 100 reads out the code from the RAM mapping area 135, stores the code read out from the RAM mapping area within the second secondary memory 125, decompresses the code read out from the second secondary memory 125, and assigns an address of the RAM region 335 of the host memory map 330. The host controller 310 reads out the code from the address of the RAM region 335 via the NAND interface and stores the code within the host memory 320.
As described above, the memory controller 110 of the fusion memory device 100 reads out the code from the RAM mapping region 135 via the NAND interface, stores the code within the second secondary memory 125, and controls the decompressor 470 to decompress the code read out from the second secondary memory 125. Next, the memory controller 110 reports the decompression result to the host controller 310 such that the host controller 310 reads out the code from the fusion memory device 100 via the NAND interface and stores the code within the host memory 320. In this manner, the fusion memory device 100 allows the host device to access fusion memory device 100 via NAND interface while it accesses the main memory 130 via the NAND interface, too.
Referring to
In the user data writing mode, the user data can be stored within the user data region 137 of the main memory 130 in a specific format. In this embodiment, the user data is stored in the form of a file system. When a data write request is input by a user, a file system application 230 stores the user data within the host memory 320 and informs the memory control software 210 of the storage result such that the memory control software 210 outputs a data write command to the fusion memory device 100. At this time, the memory control software 220 sets a compression flag on the basis of the information received from a compressor/decompressor control software 220 and transfers the user data to memory controller 110 of the fusion memory device 100 with the flag and file name assigned for the user data.
Upon receiving the user data, the memory controller 110 of the fusion memory device 100 sets the compressor 460 according to a compression scheme indicated by the compression flag and controls such that the user data to be buffered within the second secondary memory 125. The user data buffered within the second secondary memory 125 is read out to be compressed by the compressor 460 in the compression scheme and then buffered within the first secondary memory 123. Next, the compressed user data are read out from the first secondary memory 123 and written at a specific address of the user data region 137 of the main memory 130 with the file name notified by the memory control software 210 via the NAND interface under the control of the memory controller 110. In such manner, the user data is written within the user data region 137 of the main memory 130 in the form of a compressed file, and the storage result is notified to the memory control software 210 by the memory controller 110.
Repeating the above procedure, the user data of the host device 300 are transferred to the fusion memory device 100 via the NAND interface and written within the user data region of the main memory 130 of the fusion memory device 100.
In the user reading mode, the user data is written from the user data region 137 of the main memory 130 of the fusion memory device 100.
When a data read request is input by the user for reading out a specific user data, the file application 230 assigns a buffer region to the host memory 320 for storing the user data, and the memory control software 210 outputs a data read command to the fusion memory device 100. At this time, the compressor/decompressor control software 220 generates sets a compression flag and transfers the compression flag to the memory control software 210. The memory control software 210 transmits a set of commands to the memory controller 110 of the fusion memory device 100 for reading out the user data. When the commands are received, the memory controller 110 sets the decompressor 470 according to the compression flag and controls such that the requested user data are to be read out from the user data region 137 of the main memory 130 via the NAND interface and buffered within the second secondary memory 125. At this time, the decompressor 470 decompresses the compressed user data read out from the second secondary memory such that the host controller 310 stores the user data output from the decompressor 470 within the host memory 320.
The user data compression can be performed in a compression scheme different from that for the code compression. In this case, the compressor-decompressor pairs can be independently structured for processing the user data and code, separately. The compressor can be implemented with a code compression module and a data compression module, and the decompressor can be implemented with a code decompressor and a data decompressor.
Referring to
The memory controller 110 includes a core controller 410 for controlling general operations of the memory controller 110, an embedded file system controller 420 for managing the user data within the user data region of the main memory 130, a NOR interface controller 430 for controlling the NOR interface access to the NOR mapping region of the main memory 130, an Error Correction Code (ECC) controller 440 for performing the ECC, an information detector 450 for detecting information on the compression flag and address in association with the binary data access, a compressor for compressing the binary data to be stored within the main memory 130, and a decompressor 470 for decompression the compressed data read out from the main memory 130.
Referring to
Referring to
The core controller 410 determines the compression/decompression scheme of the binary data accessed on the basis of the output of the information detector 450 and the position of the binary data to be accessed in the main memory 130 on the basis of the output of the file system controller 420. Next, the core controller 410 controls such that the binary data is compressed according to the compression scheme and the compressed binary data is written within one of the pseudo NOR mapping area 133, RAM mapping area 135, and user data area of the main memory 130 according to the converted address information. The core controller 410 can be implemented with a page buffer for writing the compressed data within the main memory 130 via the NAND interface. In this case, the core controller 410 controls such that the data compressed by the compressor 460 is buffered within the page buffer and the data read out from the page buffer is written in a corresponding area of the main memory 130 via the NAND interface. In this embodiment, it is assumed that the page buffering is performed with the first secondary memory 123. In the binary reading mode, the core controller 410 accesses the compressed binary data stored within an area (pseudo NOR mapping area, RAM mapping area, or file system area) of the main memory 130 and controls the decompressor 470 to decompress the compressed binary data read out from the corresponding area according to the compression scheme.
Codes reading and writing procedures of the above structured fusion memory device are described hereinafter.
The core controller 410 analyzes the output of the information detector 450 and determines whether a binary data read command or binary data write command is input. When a binary data write command is input, the core controller 410 checks a target storage area (pseudo NOR mapping area, RAM mapping area, and file system area) and compression scheme on the basis of the compression flag and converted address output from the information detector 450. Next, the core controller 410 controls the secondary memory 120 to buffer the binary data and controls the compressor 460 compresses the binary data read out from the secondary memory 120. Sequentially, the core controller 410 controls such that the compressed binary data is stored within an area corresponding to the converted address. At this time, the binary data (code or user data) are stored within the corresponding area of the main memory 130 via the NAND interface. Concerning to the pseudo NOR mapping area 133 and the RAM mapping area 135 of the main memory 130, the code is stored via the NAND interface.
When a binary data read command is input, the core controller 410 analyzes the flag and address detected by the information detector 450 and checks the area of the main memory 130 for reading out the binary data and decompression scheme. When the binary data is stored within the pseudo NOR mapping area 133, the core controller 410 reads out the binary data from the pseudo NOR mapping area 133 of the main memory 130 via the NAND interface and stores the binary data within the secondary memory 120 such that the decompressor 470 decompresses the compressed binary data read out from the secondary memory 120. Next, the core controller 410 controls the NOR interface controller 430 to buffer the decompressed binary data within the secondary memory 120 such that the host controller 310 reads the buffered binary data via the NOR interface. The NOR interface controller 430 converts the address of the decompressed binary data and stores the secondary memory 120 such that the host controller 310 to access in unit of byte. When the binary data is stored within the RAM mapping area 135, the core controller 410 reads out the binary data from the RAM mapping region of the main memory 130 and stores the binary data within the secondary memory 120 such that the decompressor 470 decompresses the binary data read out from the secondary memory 120. The host controller 310 reads the binary data via the NAND interface and stores the binary data within the host memory 320.
User data reading and writing procedures of the above-structured fusion memory device are described hereinafter.
When a user data write command is input, the information detector 450 detects a target address of the main memory 130 and compression information for storing the user data and transfers the address and compression information to the file system controller 420. The file system controller 420 checks the type of the user data (file system) and outputs the compression information and storage location information to the core controller 410. The core controller 410 sets the compressor 460 with a compression scheme determined on the basis of the compression information and buffers the user data downloaded for the host device within the secondary memory 120. At this time, the compressor 460 compresses the user data read out from the secondary memory 120 according to the compression scheme and the core controller 410 writes the compressed user data within the user data region of the main memory 130 via the NAND interface.
When a user data read command is input, the information detector 450 detects information on the storage location of the main memory 130 and decompression scheme outputs the address and decompression information to the file system controller 420. The file system controller 420 forwards the address and decompression information to the core controller 410. The core controller 410 determines the decompression scheme according to the decompression information, reads out the user data from the address of the user data region of the main memory 130, and stores the user data within the secondary memory 120. The decompressor 470 decompresses the compressed user data and notifies the host device of the decompression completion such that the host device reads out the buffered user data and stores the user data within the host memory 310.
In the above descriptions, the data reading and writing procedures of the fusion memory device implemented with different types of compressors and decompressor are explained. However, the fusion memory device can be implemented with a pair of compressor and decompressor for a specific data type.
The structures and operation of the compressor 460 and decompressor 470 are described hereinafter in more detail.
The compressor 460 and decompressor 470 can operate in a normal compression/decompression method. The structures and operation of the compressor 460 and decompressor 470 of the present invention are described with reference to FIGS. 18 to 23.
In
In the following description, an exception handling is acceptable when there is no domain block of which data is not identical with that of the range block. In this case, the raw data is used without compression. A global table is a fixed entry table in which the difference value is used as an index. A local table is a floating entry table in which the difference value between the frequent range block and domain block is used as an index. A searching range is for searching for a domain block in the range block. A forward search is of testing the macroblocks positioned prior to the range block in the searching range. A backward search is of testing the macroblocks to the range block. The term “binary data” is used for the program data and user data.
Preferably, the compressor and decompressor for processing the binary data have high compression and decompression rates. The higher the compression rate of the compressor is, the lower the compression/decompression speed of the compressor/decompressor. In this embodiment, how to improve the compression rate and decompression speed is described in association with the domain block search procedure.
The compressor 460 according to an embodiment of the present invention uses an entropy coding on the difference value of the range block and domain block and a cost table-based coding in which a cost table is selectively used according to a cost obtained from the difference value.
The former compression method searches for the domain blocks in the searching range in the forward and backward directions and performs the entropy coding on the difference with an identical or most similar domain block. In a case that the range block differs from all the domain blocks in the searching range, the exception handling may be used.
The latter compression method has the characteristics as following.
First, the compressor 460 performs the search in the forward and backward directions as comparing the range block with the domain blocks (i.e., the macro blocks positioned before the range block) in the searching range in the forward and backward directions and selects a domain block having the lowest cost.
Second, in compressing the range block similar to the domain block, the compression rate and speed can be improved by using the table. For this purpose, the compressor 460 calculates the cost while comparing the binary data of the range block with those of the domain blocks in the searching range. There can be a fixed global table and a floating local table. The cost table is matched to the index of the global table or the local table according to the cost value. The global table is a table stored the frequently used data and the data are not changed. The local table is a table which is formed with the data frequently used during the compression process and it is stored following the binary data after the data compression has completed.
Finally, the compressor 460 compresses the binary data in unit of macroblock, and performs an exception handling when there is no domain block identical with or similar to the range block in the searching range (i.e., in a case that there is no short block identical with the short block of the range block). The exception handling is performed without compression the binary data of the range block for adjusting the decompression rate and speed.
The binary data compression method according to an embodiment of the present invention searches for the binary data of the macro block in the forward and backward direction without reduction of the compression speed, whereby improving the compression rate. Also, by efficiently storing the compression information is within the global table and local table, the compression rate can be improved. Furthermore, the macroblock whose compression rate is bad is processed with the exception handling method, whereby the compression rate and decompression speed can be adjusted.
The entropy compression method and the table-based compression method are described hereinafter in sequential order.
In
Referring to
The coder 540 analyzes the outputs of the comparator 530, outputs values of the distance and difference between the range block and domain blocks, and selects the lowest values of the distance and difference as the compressed data information. As described above, the range block may consist of more than two short blocks. The coder 540 compares the binary data of the range block with those of the domain blocks in the searching range and selects at least one of the short blocks of which binary data is identical with that of the range block. Next, the coder 540 stores the distance and difference between the range block and the selected domain block as the compressed data of the range block.
However, there can be uncompressed range block data. For example, in the case that the short block data constituting the range block are not identical with the short block binary data of the domain blocks in the searching range, the range block is processed as the exceptional data block. When the compression cost of the range block is greater than a threshold value, the binary data of the range block is stored without compression. In this case, the coder 540 stores the binary data of the range block within the secondary memory 120 as it is.
The coder 540 may use a distance flag and a difference flag according to whether the distance and differences values vary. In a case that the current range block has a distance value identical with that of the previous range block, a distance flag indicating that there is no distance change is used. In the meantime, when the current range block has a distance value different from that of the previous range block, a distance flag indicating that there is a distance change and distance value are used.
When there is a domain block of which data is identical with that of the range block, a difference flag indicating that there is no difference between the range block and domain block. When there is a domain block of which data is not identical with but similar to that of the current range block, a difference flag indicating that there the data are different and a difference value indicating how much different from each other. In this embodiment, the distance and difference flags are set to “0” for indicating no distance change and no difference, and set to “1” for indicating the distance change and difference between the blocks. The distance flag and value are called as the distance information and the difference flag and value are called as the difference information, hereinafter.
Referring to
The 0 of the difference information “0,1, C XOR B” is the difference flag indicating that first short blocks of the range block and domain block are identical with each other, the 1 is the difference flag indicating that second short blocks of the range block and domain blocks are different from each other, and C XOR B is a difference value.
Also, a domain block identical with or mostly similar to the range block [18:19] having the data D and F in the searching range is the domain block [7:8] having the data D and F. In this case, the distance between the range block [18:19] and the domain block [7:8] is “1,11” and the difference is “0,0.”
As another example, a domain block similar to and close to the range block [20:21] having the data A and H in the searching range is the domain block [9:10] having the data A and B. In this case, the distance is “0”, since the previous range block [18:19] having the same data D and F, and the difference is “0,1,H XOR B.”
As another example, a domain block identical with or mostly similar to the range block [22:23] having the data A and B in the searching range is the domain block [11,12] having the data A and B. In this case, the distance between the blocks is “0” and the distance is “0,0.”
Accordingly, the compression on the macroblocks [16-23] can be informed as Table 1. Table 1 shows compressed data information for the compressor which does not use the table. In a case that the compressor 460 performs compression using the table, the compressor 460 can use the compressed data information stored with the difference values “C XOR B” and “H XOR B” as the indexes within the global table. In a case that the global table has difference value index of “C XOR B” and “H XOR B”, the compressor 460 can use the compression data stored with the difference value as the indexes within the floating table.
The data compressed as above are buffered within the secondary memory 120, and the buffered compressed data are stored within a specific area (pseudo NOR mapping area, RAM mapping area, and user mapping area) of the main memory under the control of the core controller 410. The compressed data can be read out from the main memory 130 and buffered within the secondary memory 120 such that the decompressor 470 decompresses the compressed data read out from the secondary memory 120.
In
Referring to
Referring to
Referring to
The loader 610 loads the binary data downloaded from an external device. The binary data is loaded in unit of a specific data size (compression frame size) suitable for the coder 640. The coder 640 performs compression in unit of data size called compression data size. The loader 610 loads the binary data of which size is smaller than the size of the secondary memory 120 and the entire binary data loaded on the secondary memory can be a compression frame or segmented to be fit for the compression frame size.
The searcher 620 determines a searching range of the binary data of the compression frame and checks the range blocks. Next, the searcher 620 compares the range block with the domain blocks in the searching range to calculate the costs and determines the distance information and cost value of the domain block with of which cost is the lowest. The search operation is performed in the forward and backward direction while comparing the range block and the domain blocks in the searching range. After the difference value between the range block and each domain block is calculated, the searcher 620 generates information on the distance and difference between the range block and the domain block when the range block and the domain block are identical with each other. On the other hand, when the range block and the domain block differ from each other, the searcher 620 calculates a cost using the distance and difference information. The searcher 620 can be provided with a cost table. The cost table is structured such that the cost values calculated on the basis of the difference values between the range block and the domain blocks are mapped to the indexes of a global table or a floating table. The searcher 620 generates the difference values by comparing the data of the range block and the respective domain blocks in the forward searching process. Also, the searcher 620 stores the cost values generated during the backward direction and compares the cost values with the previously stored reference cost. When the current cost is lower than that of the reference cost, the reference cost is updated, and otherwise, maintains the reference cost. Repeating this process, a domain block with which the lowest cost is obtained is found. The searcher 620 outputs the distance information and cost between the range block and the domain block that generates the lowest cost to the coder 640. This operation is repeated until all the range blocks are processed.
The coder 640 may be provided with a global table (fixed table) and/or a local table (floating table). The global table and local table can be buffered within the secondary memory 120. The global table can be buffered within a specific region of the secondary memory 120 when the binary data to be compressed is downloaded. Also, the local table generated while compressing the binary data can be buffered within a specific region of the secondary memory 120. The global table is built with the costs calculated with the differences frequently appear while compressing the binary data and the costs calculated during the binary data compression are used as the compressed data information. The global table is a fixed table built with the experimentally measured values. The local table is built by calculating the costs on the basis of the differences frequently appear during the binary data compression and the costs calculated during the binary data compression are used as the compression data information. The local table is a variable table and used only for compression and decompression on the corresponding binary data. The global and local tables are similar to the cost table. The cost table uses the differences between the blocks as the indexes and stores the cost values at the index positions, and the global and local tables are indexed and the difference values between the blocks are stored at the index positions.
In the following description, it is assumed that both the global and local tables are used for compressing the binary data. However, the binary data compression can be performed with one of the global and local tables.
The coder 640 checks the data (comparison data of the range block and domain block) stored at a position of the index corresponding to the cost value and processes the index of the corresponding data as coding data. The cost can be calculated, at the searcher 620, on the basis of the difference information of the range block and domain block. In this embodiment, the searcher 620 calculates the cost using the cost table. The searcher 620 transfers the distance information (distance flag and distance value) and the cost value to the coder 640. The coder 640 checks the data with reference to the cost value and compresses the data as the binary data of the corresponding range block.
The operations of the searcher 620 and coder 640 are described hereinafter in more detail. In this embodiment, it is assumed that the range block consists of at least two short blocks. The searcher 620 calculates the difference between the range block and domain block and obtains the cost from the difference. When the difference between range block and domain block is 0, i.e. the range block and domain block are identical with each other, the cost value becomes 0 (or the lowest cost value). When at least one short block of the range block is identical with at least one short block of the domain block, the cost value is calculated using the difference values between the rest short blocks of the range block and domain block. The coder 640 compares the cost value to the coding threshold value and refers, when the cost value obtained between the range block and the domain block is less than the coding threshold value, to the global table and/or local table. The cost values can be used as the index of the global and local tables, and the coding value obtained from the short blocks different from each other can be the calculated cost value. When all the short blocks of the range block and the domain blocks give respective difference values, i.e. all the pairs of the corresponding short blocks of the range and domain blocks are different from each other, the cost value calculated by the searcher 620 becomes greater than the coding threshold value. In this case, the coder 640 processes the range block as an exceptional data block.
Referring to
Performing the above procedure, the searcher 620 calculates the distance information and costs between the range block and the respective domain blocks in the searching range and stores the distance information and cost value obtained with the domain block giving the lower cost. The searcher 620 calculates the distance information and cost of the range block in association with the domain blocks while searching in the forward direction (i.e. range block is sequentially compared with the respective domain blocks in the forward direction), and updates the cost whenever a lower cost is detected while searching in the backward direction. When the currently calculated cost is less than the previously calculated cost, the searcher 620 stores the distance information and cost obtained with the current domain block, and otherwise, the searcher 620 maintains the distance information and cost obtained with the previous domain block. Repeating the above operations, the searcher 620 stores the distance information and cost of the range block in association with the domain block which gives the lowest cost in the searching range.
The searcher 620 may generate a local table. When a difference value (distance value of the range block and the main block) is appeared over a predetermined number of times (for example, 3 times) in spite of no registration to the global table, the difference value is registered to the local table. Preferably, the cost of the local table is set to a value greater than that of the global table. The difference value may be registered to the cost table. In this case, although the difference value is not registered to the global table, it is possible to improve the efficiency of the compression by registering the frequently appeared distance value to the cost table.
After completion of the searching process, the searcher 620 transfers the distance information and cost to the coder 640 at step 683.
In
Next, the searcher 620 calculates the cost on the basis of the distance values. In a case that the binary data of the short blocks constituting the domain block are identical with those of the range block are identical (4th and 5th short blocks in
When the distance information and cost are received, the coder 640 performs compression on the binary data of the range block on the basis of the distance information and cost.
Referring to
After processing the exceptional data blocks, a searcher 713 sets a searching range, loads the domain blocks belonging to the search range, compares the macroblocks, calculates the costs according to the distance information and difference value obtained in relation to the range block, and transfers the lowest cost value and a distance information on the domain block generating the lowest cost to the coder 640.
The coder 640 compares the binary data of the range block and the domain block and determines whether the binary data are identical with each other (cost=0) (S715). The binary data of the rang block and the domain block are identical with each other, the searcher 620 encodes the binary data of the range block with the distance information and the difference flag to generate the compressed data and buffers compressed data within the second secondary memory 125 (719). When the binary data of the range block and the binary data of the selected domain block are identical with each other, the coder 640 generates a compressed data of the range block represented by the distance information between the range block and the domain block.
When there is no domain block of which binary data is identical with that of the range block (cost≠0), the coder 640 checks the cost at step 721 and retrieves the global table using the cost at step 723. The cost is checked for determining whether the cost exists in the global table and/or local table. Next, the coder 640 checks whether the cost value exists in the global table at step 725. When the cost value exists in the global table, the coder 640 stores the distance information and difference information within the second secondary memory 125 at step 719. The distance information may include the distance flag and distance value of the range block relative to the corresponding domain block, and the difference (3 information may include the cost value, i.e. the value stored within the global table. When the cost value does not exist in the global table, the coder 640 searches for the cost value in the local table at step 727 and determines whether the cost value exists in the local table at step 729. When the cost value exists in the local table, the coder 640 stores the distance information and the difference information within the second secondary memory 125 at step 719. When the cost value is not 0 and exists in the global table or the local table, the coder 640 encodes to compress the binary data of the range block with the distance and difference information obtained relative to the domain block and stores the compressed data within the second secondary memory 125.
When it is determined that the cost value does not exist in the local memory at step 729, the coder 640 activates the exception handler 650 such that the exception handler 650 generates an exception handling flag at step 731 and stores the binary data of the range block with the exception handling flag at step 733. When the range block is not identical with any of domain blocks in the searching range and the cost value does not exist in any of the global and local tables, the coder 640 stores the uncompressed binary data with the exception handling flag generated by the exception handler 650.
As described above, the coder 640 may store the binary data of the range block within the second secondary memory 125 without compression. For example, when the binary data of the short blocks constituting the range block are not found in any of the short blocks of the domain blocks of the searching range or the cost of the short block of which binary data are determined to be identical with those of any of the short block of the range block is high, the range block is handled as an exceptional data block. When the compression cost of the range block is greater than a predetermined threshold value (i.e. the cost value does not exist in the global and local tables), the binary data of the range block is stored without being compressed. In this case, the coder 640 notifies the exceptional data block to the exception handler 650 such that the exception handler 650 stores the binary data of the range block within the secondary memory 120. The exception handler 650 can be integrated into the coder 640.
The compressor 460 repeats the compression operation as above described and stores the compressed binary data of the range blocks within the second secondary memory 125. The compressed data stored within the second secondary memory 125 may include the distance information, difference information, and exceptional data blocks. The compressed data stored within the second secondary memory 125 can be expressed as Table 2.
As described above, the searcher 620 and the coder 640 perform indexing the first domain block to the domain block at which the sum of the costs is lowest that are positioned prior to the range block in the searching range, compares the binary data of the indexed domain blocks with the binary data of the range block, and compresses the range block on the basis of the compression result. In
In the meantime, in a case that the domain blocks such as the first domain block [6,7] and fifth domain block [2,3] that have no short block identical with the short blocks of the range block, the sum of the costs become greater than the coding threshold value. In a case that the short blocks of all the domain blocks in the search range are not identical with the short blocks of the range block, i.e. when the sum of the cost exceeds the threshold value, the coder 640 regards the range block as the exceptional data block.
In the domain block of which one short block is identical with one of the short blocks constituting the range block, such as second domain block [5,6], fourth domain block [3,4], sixth domain block [1,2], and seventh domain block [0, 1], the sum of the costs is less than the coding threshold value. With such blocks, the coder 640 calculates the sum of the costs obtained between the range block and the respective domain blocks and determines the distance and difference values obtained relative to the domain block which gives the lowest cost sum as the compressed data. In a case that the coder 640 is provided with the global table and/or local table, the coder 640 matches the difference value to an index so as to retrieve the information indicated by the index within the table as the data and stores the index. In this case, the compressed data of the range block may include the distance information relative to the corresponding domain block and the table information.
In the above descriptions, the threshold value of the cost can be changed. In a case that the block has a length of 16 bits, when the cost is greater than 65536; the block is regarded as an exceptional data block so as to skip compression, and otherwise, a compression process is applied.
Referring to
The loader 660 loads the compressed data read out from the secondary memory 120 and the global and local tables required for decompressing the compressed data at corresponding regions. The compressed data is composed of the distance information, difference information, and exceptional data block as shown in Table 2. The distance information is composed of the distance flag and distance value and the difference information is composed of the difference flag and cost value. The flag detector 670 detects the distance and difference information and transfers the detected information to the decoder 680. When the distance and difference information is received, the decoder 680 analyzes the distance information and determines the position of a domain block relative to the range block on the basis of the distance flag and distance value. The decoder 680 also determines the difference value between the range block and domain block on the basis of the difference flag and cost value. Consequently, the decoder 680 performs decoding on the compressed data to recover the range block through the XOR operation with the domain block. When an exception handling flag is detected at the flag detector 670, the decoder 680 activates the exception handler 690 such that the exception handler 690 handles the data of the range block. In this case, the exception handler 690 outputs the range block as it is. Although the exception handler 690 is depicted as a separate element in
In
In this embodiment, the exceptional data blocks are recovered at first and then the compressed data of the range blocks are decompressed on the basis of the distance information and difference information. However, the compressed data recovery procedure can proceed to decompress the compressed range blocks and then recover the exceptional data blocks.
The decoder 680 loads the global and local tables used for compressing the binary data and checks a start point of the compression frame at step 753. Next, the decoder 680 checks whether an exception flag is set at step 755. When an exception flag is set, the decoder 680 checks the position of the exceptional data block and processes the exceptional data block at step 791 such that the recovered data are placed at the position of the range block within the second secondary memory 125. Repeating these operations, the binary data of the exceptional data block is recovered to be buffered within the second secondary memory 125.
After completely recovering the binary data of the exceptional data blocks, the decoder 680 checks the distance information and determines whether a distance flag is set at step 757. When a distance flag is set, the decoder 680 searches for a domain block at a position moved as much as the distance value. When it is determined that the same distance flag is set again, i.e., the distance value is not changed from the previous status, the decoder 680 does not move the search position.
In the case that the distance flag is set, the decoder 680 calculates the position of the current range block at step 759, checks the distance value of the distance information at step 761, and selects a domain block located at a block position distant as much as the distance value from the current range block at step 763. In the case that the distance flag is reset, the decoder 680 selects a block distant as much as the distance value calculated for the previously recovered range block at step 757. The decoder 680 checks the distance information and selects, when the distance flag is set, the domain block distant as much as the distance value from the current range block as the reference domain block and selects, when the distance flag is reset, a reference domain block while maintaining the previous distance value.
After selecting the reference domain block using the distance information, the decoder 680 reads the difference flag at step 765 and checks the status of the difference flag. When it is determined that the difference flag is reset, the decoder reads the binary data of the reference domain block for the binary data of the range block at step 771 and stores the binary data within the second secondary memory 125. The reset status of the difference flag means that the binary data of the range block and the reference domain block are identical with each other. Accordingly, the decoder 680 recovers the binary data of the range block by copying the binary data of the reference domain block.
When it is determined that the different flag is set, the decoder 680 reads the difference value of the difference information at step 781. The difference value can be a cost value generated in the compression process, and the cost value can be an index of the global table or local table. Accordingly, the decoder 680 loads the difference value as an index of the table at step 781 and looks up the index in the cost tables at step 783. The cost value (index) is searched in the global table at first and then, when the index is not retrieved in the global table, in the local table. During the table look-up, the decoder 680 determines whether the index matched the cost value is found at step 785. When the index matched the cost value is found, the decoder 680 reads reference data from the table with the index so as to recover the range block at step 787 and stores the recovered data within the secondary memory 120 at step 773. When the index matching the cost is not found in the tables, the decoder 680 performs error processing. As described above, when the difference flag is set, the decoder 680 uses the cost value of the difference information as the index of the table and reads the data indicated by the index for recovering the binary data of the range block through the XOR operation with the domain block.
By repeating these operations, the binary data of the compressed range blocks are recovered on the basis of the distance information and difference information. In summary, the binary data of the compressed range block is recovered by checking the distance and difference information, and selecting a reference domain block on the basis of the distance information, and processing the binary data of the reference domain block on the basis of the difference information.
The binary data (code and user data) read and write operations of the fusion memory according to an exemplary embodiment of the present invention are described hereinafter in more detail. In the following descriptions, it is assumed that the compressor and decompressor are structured as shown in
In a binary data writing mode, the binary data downloaded from the host controller 310 is buffered within the second secondary memory 125 in unit of compression frame under the control of the core controller 410. The compressor 460 extracts the binary data of the range block from the buffered data, defines the domain blocks, calculates the distance information and difference information on the domain blocks, generates compressed data using the distance and difference information obtained relative to the domain block which gives the lowest cost, and buffers the compressed data within the first secondary memory 123 (or the internal buffer of the core controller 410). The core controller 410 writes the buffered compressed data within a specific region of the main memory 130 via the NAND interface. In the following description, it is assumed that the compressed data are buffered within the first secondary memory 123.
In a binary data reading mode, the core controller 410 reads out the compressed data from a corresponding area of the main memory 130 such that the compressed data are stored within the second secondary memory 125. At this time, the decompressor 470 analyzes the distance and difference information of the compressed data buffered within the second secondary memory 125 and selects a domain block on the basis of the distance and different information and recovers the original binary data on the basis of the difference value obtained in relation with the selected domain block. When the compressed data is a code written in the pseudo NOR mapping area 133 of the main memory 130, the code decompressed by the decompressor 460 is buffered within the first secondary memory 123 such that the host controller 310 reads out the code. When the compressed data is a code or user data written in the RAM mapping area or the user mapping area, the core controller 410 notifies the data type to the host controller 310 such that the host controller 310 reads the decompressed code or data via the NAND interface and stores the decompressed code or user data within the host memory 320.
Referring to
When control information for writing the code is generated by the memory control software 210 of the host controller 310, the information detector 450 extracts an address and compression flag from the control information and transfers the extracted address and compression flag to the core controller 410. When the address and compression flag are received, the core controller 410 controls to set the compressor 460 with a compression scheme appropriated for the code. The compressor can be configured as shown in
The code can be a program (including firmware and software) of the host device 300 and store within the pseudo NOR mapping area 133 and/or the RAM mapping area 135. As shown in
The code transmitted by the host controller 310 is buffered within the second secondary memory 125. The buffered code is provided to the compressor 460 in unit of compression frame. The compressor 460 performs compression on the code read out from the second secondary memory 125. The compressor 460 loads the code of a range block to be compressed, determines a searching range, examines the domain blocks arranged in the searching range in the forward and backward directions. The compressor 460 compares the range block with the respective domain blocks arranged in the searching range and calculates the distances and differences between the range block and the respective domain blocks; generates compressed data using the distance and difference obtained relative to the domain block which results in the lowest cost; and stores the compressed data within the first secondary memory 123. By repeating these operations, the compressor 460 loads the range block code, compares the range block and the domain blocks arranged in the searching range, calculates the distances and differences between the range block and the respective domain blocks, generates the compressed data using the distance and difference obtained relative to the domain block which results in the lowest cost, and stores the compressed data within the first secondary memory 123. The compressor 460 can be implemented with a global table and/or a local table. In this case, the compressor 460 translates the differences into the cost values that are used as table indexes.
The compressed data buffered within the first secondary memory 123 are read out to be stored within the corresponding area of the main memory 130 under the control of the core controller 410. The core controller 410 assigns an address for the pseudo NOR mapping area 133 or the RAM mapping area 135 of the main memory 130 and writes the compressed code read out from the first secondary memory 123 within the area corresponding to the address via NAND interface. When the compressed code is written in the main memory 130, the ECC controller 440 accesses the ECC information in the main memory 130 and determines whether the compressed code is normally stored. When it is determined that the compressed code is normally stored, the ECC controller 440 notifies the normal storage result to the core controller 410, and the core controller 410 forwards the normal storage result to the host controller 310.
Upon receiving the normal storage result, the host controller 310 transfers the next code to be compressed to the fusion memory device 100. The core controller 410 controls such that the code received from the host controller 310 within the second secondary memory 125 and controls the compressor 460 to compress the code read out from the second secondary memory 125. The compressed code is written within the corresponding area of the main memory under the control of the core controller 410. By repeating these operations, the memory controller 110 of the fusion memory device 100 compresses the codes transmitted by the host device 300 and stores with the system data region of the main memory 130 via the NAND interface.
Referring to
When control information for reading the code stored within the pseudo NOR mapping area 133 is received from the host controller 310, the information detector 450 extracts an address and compression flag from the control information and transfers the address and compression flag to the core controller 410. When the address and compression flag are received, the core controller 410 transmits the address to the NOR interface controller 430 for reading the code stored within the pseudo NOR mapping area 133. Upon receiving the address, the NOR interface controller 430 maps the address to a position of the code within the pseudo NOR mapping area 133 and generates a command for reading the code. The ECC controller 440 reads the ECC from the main memory 130 to generate ECC information and determines whether there is no error. When there is no error, the ECC controller 440 notifies the result to the core controller 410. The core controller 410 sets the decompressor 470 with a decompression scheme for decompressing the compressed code and controls such that the compressed code read out from the pseudo NOR mapping area 133 of the main memory 130 is buffered within the second secondary memory 125. Accordingly, the decompressor 470 configured as shown in
When it is notified that the decompression is successfully completed, the core controller 410 notifies the NOR interface controller 430 of the complete decompression such that the NOR interface controller 430 reads the compressed code stored within the pseudo NOR mapping area 133 of the main memory 130 and buffers the code within the second secondary memory 125. The decompressor 460 decompresses the compressed code buffered within the second secondary memory 125. The core controller 410 reads the decompressed code from the second secondary memory 125 and writes the code within the first secondary memory 123, and the NOR interface controller 430 converts the address of the code buffered within the first secondary memory 123 into other type of address such that the host controller 310 can read the code via the NOR interface. The host controller 310 reads and processes the code from the first secondary memory 123.
By repeating these operations, the fusion memory device 100 recovers the code read out from the pseudo NOR mapping area 133 of the main memory 130, converts the address of the code such that the host device 300 reads and processes the code at the converted address.
Referring to
When control information for reading the code stored within the RAM mapping area 135 of the main memory 130 is received from the host controller 310, the information detector 450 extracts an address and compression flag from the control information and transfers the address and compression flag to the core controller 410. When the address and compression flag are received, the core controller 410 checks a position of the RAM mapping area 135, at which the code is stored, with reference to the address and generates a command for reading the code. At this time, the ECC controller 440 reads the ECC from the main memory 130 to generate the ECC information and determines whether the code has been errorlessly stored. When it is determined that the code has been stored errorlessly, the ECC controller 440 notifies the core controller 410 of the errorless storage.
When it is determined that the code is errorless, the core controller 410 sets the decompressor 470 with a decompression scheme and reads the code stored from the RAM mapping area 135 of the main memory 130 and writes the code within the second secondary memory 125. The decompressor 470, configured as in
By repeating these operations, the fusion memory device 100 decompresses the compressed code stored within the RAM mapping area 135 of the main memory 130 and processes the code to be read by the host device 300.
Referring to
When control information for writing the user data within the user data region 137 of the main memory 130 is received from the host controller 310, the information detector 450 extracts an address and compression flag from the control information and transfers the address and compression flag to the file system controller 420. When the address and compression flag are received, the file system controller 420 forwards with address and compression flag to the core controller 410, and the core controller 410 sets the compressor 460 with a compression scheme on the basis of the compression flag. The file system controller 420 also reads out the user data from the host memory 320 and writes the user data within the second secondary memory 125. The user data are stored within the second secondary memory 125 after being processed to be fit for a specific file system (for example, a File Allocation Table (FAT)).
After being buffered within the second secondary memory 125, the user data is compressed by the compressor 460 and read out to be buffered within the first secondary memory 123, and the compressor 460 notifies the core controller 410 of the compression result. The user data compression process can be performed in the same manner as in the code compression process in
By repeating these operations, the main memory controller 110 of the fusion memory device 100 compresses the user data downloaded from the host device and writes the compressed user data within the user data region 137 of the main memory 130.
Referring to
When control information for reading the user data from the user data region 137 of the main memory 130 is received from the host controller 310, the information detector 450 extracts an address and compression flag from the control information and transfers the address and compression flag to the file system controller 420. When the address and compression flag are received, the file system controller 420 forwards the address and compression flag to the core controller 410, and the core controller 410 maps the address to a position of the user data region 137 at which the target user data is stored and generates a command for reading the user data. At this time, the ECC controller 440 generates an ECC information by reading the ECC from the main memory 130 and determines whether the target user data has been normally stored on the basis of the ECC information. When it is determined that the target user data has been normally stored, the ECC controller 440 notifies the core controller 410 that the user data is normally stored, such that the core controller 410 sets the decompressor 470 with a decompression scheme and controls the decompressor 470 to decompress the user data read out from the user data region 137 of the main memory 130 to be buffered within the second secondary memory 125, and notifies the decompression result to the core controller 410. The decompression scheme used for recovering the user data can be identical with that used for recovering the code as shown in
While the invention has been shown and described with reference to a certain preferred embodiment thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the spirit and scope of the invention as defined by the appended claims.
As described above, the fusion memory device of the present invention is advantageous for efficient storage management since the binary data are stored in a compressed data format. Also, the fusion memory device of the present invention is advantageous to efficiently manage reading/writing operations for different types of binary data by providing a system data region and user data region that are, respectively, accessed via NOR interface and NAND interface.
Number | Date | Country | Kind |
---|---|---|---|
2006-0087076 | Sep 2006 | KR | national |