1. Field of the Invention
The invention relates to a memory device and a method for accessing the memory device, and more particularly to a memory device and a method for accessing the memory device with high security to protect data information stored in the memory device.
2. Description of the Related Art
The trend of recent semiconductor device developing is that high density non-volatile memory has been expected to replace some part of the huge external storage device market of computers, because of large storage and low power dissipation. However, data, software, computer program or high confidential information stored in the non-volatile memory, for example, read-only memory (ROM), may be stolen easily by some kinds of method. The method usually is so called “Chip De-cap” or “Dump ROM Code”. The technology of Chip De-cap comprises removing the package of chip and probing the particular data pins for the data information stored in the memory. The technology of Dump ROM Code comprises issuing an instruction to retrieve binary code via I/O ports and reversing binary code to assembly code by a revering program.
In other word, security of the non-volatile memory is desired for each one company/user. Also, it is trend to design a memory device with high security in memory industry.
The present invention provides a memory device. An exemplary embodiment of the memory device comprises an address encoding selector for selecting one of plurality of encoding circuits which encodes a first address into a second address, a data decoding selector for selecting one of plurality of decoding circuits which decodes a first data corresponding to the second address into a second data and a non-volatile memory, coupled to the address encoding selector and the data decoding selector, for storing the first data.
The present invention also provides another memory device. An exemplary embodiment of the memory device comprises an address encoding selector for selecting one of plurality of encoding circuits which encodes a first address into a second address, the encoding circuits having N types of encoding functions, a data decoding selector for selecting one of plurality of decoding circuits which decodes a first data corresponding to the second address into a second data, the decoding circuits having M types of decoding functions and a non-volatile memory, coupled to the address encoding selector and the data decoding selector, for storing the first data; wherein the non-volatile memory being a read-only memory (ROM).
A method for accessing the memory device is also provided. An exemplary embodiment of the method comprises the following steps. Encoding a first address into a second address by an address encoding selector, and decoding a first data corresponding to the second address into a second data by a data decoding selector, wherein the first data being stored in the non-volatile memory.
A detailed description is given in the following embodiments with reference to the accompanying drawings.
The invention can be more fully understood by reading the subsequent detailed description and examples with references made to the accompanying drawings, wherein:
Several exemplary embodiments of the invention are described with reference to
The invention discloses a memory device and a method for accessing the memory device.
Referring to
The memory device comprises an address encoding selector 1, a non-volatile memory 2, for example, read-only memory, and a data decoding selector 3. The non-volatile memory 2 coupled to the address encoding selector 1 and the data decoding selector 3. The address encoding selector 1 receives an address (first address) provided by a software address generator (not shown) and transmits an encoded address (second address) provided by a software data generator to the non-volatile memory 2. An encoded data (first data) corresponding to the encoded address is received by the data decoding selector 3 and a data (second data) is output from the data decoding selector 3.
In addition to read-only memory, the non-volatile memory 2 may be a mask programmable read-only memory (mask ROM), an electrically erasable programmable read-only memory (EEPROM), an erasable programmable read-only memory (EPROM) or a flash programmable read-only memory (Flash ROM).
Referring to
The address encoding selector 1 comprises an address encoding de-multiplexer 11, a plurality of encoding circuits 12 (1st encoder, 2nd encoder . . . Nth encoder) and an address encoding multiplexer 13. The address encoding de-multiplexer 11 directs address to one of the encoding circuits 12 by a selection signal Addr_option1. In the other hand, the address encoding multiplexer 13 outputs encoded address by a selection signal Addr_option2 selecting the output of one of the encoding circuits 12.
It is noted that each one of the encoding circuits 12 may has a special/different encoding function. Thus, plurality of encoding circuits 12 may have N encoding functions for encoding address. Furthermore, the possibility of correctly providing the encoded address to the non-volatile memory 2 is 1/N2 when there is no correlation between the signal Addr_option1 and the signal Addr_option2.
Referring to
The data decoding selector 3 comprises a data decoding de-multiplexer 31, a plurality of decoding circuits 32 (1st decoder, 2nd decoder . . . Mth decoder) and a data decoding multiplexer 33. The data decoding de-multiplexer 31 directs encoded data to one of the decoding circuits 32 by a selection signal Data_option1. In the other hand, the data decoding multiplexer 33 outputs data by a selection signal Data_option2 for selecting the output of one of the decoding circuits 32.
It is noted that each one of the decoding circuits 32 may has a special/different decoding function. Thus, plurality of decoding circuits 32 may have M decoding functions for decoding data. Moreover, the possibility of correctly outputting the data is 1/M2 when there is no correlation between the signal Data_option1 and the signal Data_option2.
According to
Referring to
The address encoding de-multiplexer 11 and the address encoding multiplexer 13 are the same as that shown in
Referring to
The data decoding de-multiplexer 31 and the data decoding multiplexer 33 are the same as that shown in
Referring to
For example, capacity of the non-volatile memory is 4×4 bits, the decimal address starts from 0 to 3, and binary data 0000, 0001, 0010, 0011 stored in the non- volatile memory. It is found that the decimal address 0 corresponds to binary data 0000, the decimal address 1 corresponds to binary data 0001, the decimal address 2 corresponds to binary data 0010 and the decimal address 3 corresponds to binary data 0011 before encoding.
Now, the decimal address 0 is encoded into 2, the decimal address 1 is encoded into 3, the decimal address 2 is encoded into 1 and the decimal address 3 is encoded into 0.
Referring to
It is found that the encoded decimal address 2 (decimal address 0) still corresponds to the binary data 0000, the relationship is not changed. Also, the encoded decimal address 3 (decimal address 1) still corresponds to the binary data 0001. The encoded decimal address 1 (decimal address 2) still corresponds to the binary data 0010 and the encoded decimal address 0 (decimal address 3) still corresponds to the binary data 0011.
Referring to
Now, the binary data 0011 is encoded to, for example, the complement 1100 as encoded binary data. The binary data 0010 is encoded to 1101, the binary data 0000 is encoded to 1111 and the binary data 0001 is encoded to 1110.
Referring to
It is found that the encoded decimal address 0 corresponds to encoded binary data 1100, the encoded decimal address 1 corresponds to encoded binary data 1101, the encoded decimal address 2 corresponds to encoded binary data 1111 and the encoded decimal address 3 corresponds to encoded binary data 1110. The relationship between decimal address and binary data is the same as the relationship between encoded decimal address and encoded binary data. According to
Referring to
The encoding circuits 15 comprises a real encoder (1st real encoder) and three fake encoders (1st fake encoder, 2nd fake encoder and 3rd fake encoder), wherein the 1st real encoder performs encoding function as described in the
Referring to
The fake encoders may be implemented as
Referring to
The decoding circuits 35 comprises a real decoder (1st real decoder) and three fake decoders (1st fake decoder, 2nd fake decoder and 3rd fake decoder), wherein the 1st real decoder performs decoding function as described in the
Referring to
The 1st fake decoder decodes 1100 to 0110, 1101 to 0111, 1111 to 1111 and 1110 to 1110. Following by description of
Referring to
The 2nd fake decoder decodes 1100 to 0110, 1101 to 0110, 1111 to 1111 and 1110 to 0111. Following by description of
Referring to
The 3rd fake decoder decodes 1100 to 1011, 1101 to 1111, 1111 to 1011 and 1110 to 1111. Following by description of
Referring to
The encryption file 4 generated by a software comprises a header 41, address and data of non-volatile memory 42 and a mask 43. The header 41 comprises type of the software, encoding function for address and decoding function for data. The address and data of non-volatile memory 42 is so called ROM code. The mask 43 comprises information about addr_op1, addr_op2, data_op1 and data_op2.
The mask 43 may be implemented by transistor circuits which is similar to a switch. It could be a part of Place and Route (P&R). The process of Place and Route comprises Floor Planning, Placement and Routing. Designers could arrange the mask everywhere he wants in the P&R to confuse copiers.
Methods and systems of the present disclosure, or certain aspects or portions of embodiments thereof, may take the form of program code (i.e., instructions) embodied in media, such as floppy diskettes, CD-ROMS, hard drives, firmware, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing embodiments of the disclosure. The methods and apparatus of the present disclosure may also be embodied in the form of program code transmitted over some transmission medium, such as electrical wiring or cabling, through fiber optics, or via any other form of transmission, wherein, when the program code is received and loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing and embodiment of the disclosure. When implemented on a general-purpose processor, the program code combines with the processor to provide a unique apparatus that operates analogously to specific logic circuits.
While the invention has been described by way of example and in terms of the preferred embodiments, it is to be understood that the invention is not limited to the disclosed embodiments. To the contrary, it is intended to cover various modifications and similar arrangements (as would be apparent to those skilled in the art). Therefore, the scope of the appended claims should be accorded the broadest interpretation so as to encompass all such modifications and similar arrangements.
Number | Date | Country | Kind |
---|---|---|---|
096102108 | Jan 2007 | TW | national |