US20080215847A1 - Secure yet flexible system architecture for secure devices with flash mass storage memory - Google Patents
Secure yet flexible system architecture for secure devices with flash mass storage memory Download PDFInfo
- Publication number
- US20080215847A1 US20080215847A1 US12/122,412 US12241208A US2008215847A1 US 20080215847 A1 US20080215847 A1 US 20080215847A1 US 12241208 A US12241208 A US 12241208A US 2008215847 A1 US2008215847 A1 US 2008215847A1
- Authority
- US
- United States
- Prior art keywords
- firmware
- memory
- secure
- mass storage
- stored
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/14—Protection against unauthorised use of memory or access to memory
- G06F12/1408—Protection against unauthorised use of memory or access to memory by using cryptography
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/10—Protecting distributed programs or content, e.g. vending or licensing of copyrighted material ; Digital rights management [DRM]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/70—Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer
- G06F21/78—Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure storage of data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/20—Employing a main memory using a specific memory technology
- G06F2212/202—Non-volatile memory
- G06F2212/2022—Flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2221/00—Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/21—Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/2107—File encryption
Definitions
- the present application is generally related to the operation of flash based mass storage devices, and in particular those with copy protection of secure content.
- Flash based mass storage devices are used to store very large amounts of content, such as pictures and music or software programs. Examples of these mass storage devices include memory cards, universal serial bus (“USB”) flash drives, flash based music and/or video players, and other portable computing devices that rely on flash for the mass storage of content or files.
- USB universal serial bus
- Flash memory has a limited number of read/write cycles, and a great deal of research and development has gone into distributing the cycles among the flash memory cells in order to maximize the lifespan and reliability of the devices.
- wear leveling techniques such as those taught in U.S. Pat. No. 6,230,233 entitled “Wear Leveling Techniques For Flash EEPROM Systems” to Lofgren et al., U.S. Pat. No. 5,268,870 entitled “Flash EEPROM System and Intelligent Programming and Erasing Methods Therefore” to Harari, PCT Publication No.
- WO2004040578A2 entitled “Wear Leveling In Non-Volatile Storage Systems” to Chang et al.
- U.S. Patent Publication No. 20040083335A1 entitled “Automated Wear Leveling In Non-Volatile Storage Systems” to Gonzalez et al., which are hereby incorporated by this reference in their entireties, are commonly implemented in these devices. These techniques generally involve changing the logical/physical mapping so that physical locations of the memory are used roughly the same amount.
- the present invention allows a device to be both secure in operation and flexible in terms of functionality. This means functionality can be tailored to users' desires and added over time all the while maintaining a high level of security. Therefore the device can be used to store confidential and limited access information such as transactional data and copyrighted artistic works.
- the present invention also allows for the device to boot quickly and reliably while still providing for reliable long term data storage through the use of wear leveling techniques where appropriate.
- Firmware that is not authentic, and that may potentially compromise the security of the device will not be executed.
- An indication of the authenticity is verified before execution.
- multiple different levels of such indications are provided and are associated with the particular controller of the device that created the indications.
- one or more of the different levels of indications can be verified. Without the properly associated indication the firmware will not be executed.
- Another aspect of the present invention is that this security is achieved despite the fact that the device utilizes readily available memory without built in security for the mass storage of the data, including the firmware.
- FIG. 1A is a schematic diagram of secure device 100 A, an embodiment of the present invention.
- FIG. 1B is a schematic diagram of secure device 100 B, an embodiment of the present invention.
- FIG. 2 is a diagram illustrating various pieces of firmware in a portion of memory space 108 .
- FIG. 3 is a schematic diagram illustrating software structure and hardware access according an embodiment of the present invention.
- FIG. 4 is a flowchart illustrating some steps of firmware integrity verification.
- FIG. 5 is a flowchart of operation of an embodiment of the present invention.
- FIG. 6 is a flowchart illustrating integrity checking of physically stored data such as the firmware 200 .
- FIG. 7 is a flowchart illustrating integrity checking of logically stored data such as user files and the application firmware 202 A, B, . . . X.
- Devices incorporating flash memory for mass storage purposes must store large amounts of content that is written and read relatively often. For instance, digital photo and music libraries are regularly updated by users of such devices. With the increase of protected content and the desire to protect content generally, such devices must also provide robust security to prevent unauthorized copying of such “secure” or protected content. At the same time, security should not come at the cost of flexibility.
- the present invention provides for a device that allows functionality to be added over time, while maintaining a high level of security. This flexibility is essential in a world where devices are expected to provide ever increasing functionality.
- a secure device is one that protects the contents of the device from unauthorized copying or alteration.
- Secure content includes any content or data that it is desirable to safeguard from unauthorized copying or tampering.
- artistic content must also be secured from access and copying by those other than the owner or other authorized persons.
- a hacker may try to gain access to the content via data buses, or by directly accessing the mass storage memory.
- directly accessing the memory storage unit was difficult as the memory storage unit was often protected by placing it an environment that was logistically hard to access.
- Smart Cards utilized programmable read only memories (PROMS) that incorporated a small amount of non volatile memory that was made secure in part by physically isolating it from access.
- PROMS programmable read only memories
- unsecure mass storage memory that is, among other things, more standardized, readily available, and/or economical.
- An unsecure memory or storage unit is one where authorization is not required in order to gain (read/write) access to the (encrypted or unencrypted) data stored therein, or one where there are no built in protection mechanisms that prevent copying of the stored data. While this memory may be packaged in a multi functional package with other non-memory components such as a processor, it is commonly in the form of a dedicated memory package with one or more memory chips.
- a device or system incorporating mass storage flash memory utilizes a processor to control the data storage and retrieval operations of the memory.
- a processor is part of a controller and is often referred to as a controller.
- a controller executes software instructions to control the device.
- the software that runs and controls the hardware of a device is often referred to as firmware.
- the firmware is typically executed from random access memory (RAM) after having been copied from some other memory where it is normally stored. Shadowing or copying to RAM is advantageous because although flash is easily updated it is slower and not inherently executable because it does not have random access capability, and because read only memory is not easily updated.
- firmware In the case where some amount of security is to be provided in the firmware, there must be some mechanism to prevent execution of the other than the proper firmware that has the requisite security mechanisms. This is especially true when the firmware is stored in an unsecure memory. As mentioned above, it is the firmware that controls the operation of the device, and therefore it is not a simple matter to have the firmware essentially protect itself. Nor is it a simple matter to protect execution of compromised or unauthentic firmware when such firmware is stored in an otherwise unsecure memory package.
- the present invention provides for a secure system with mass storage capability even though it uses unsecure memory for the mass storage unit. Furthermore, it creates a secure system where the firmware for running the secure system is stored in the unsecure memory. In order to be able to store the firmware in the unsecure mass storage memory, the present invention employs a system that prevents execution of inauthentic firmware.
- FIG. 1A illustrates secure device (“SD”) 100 A, an embodiment of the present invention.
- SD 100 A comprises a secure controller 104 and unsecure memory 108 .
- Memory 108 is preferably flash type memory and is used for mass storage purposes. This means that the memory is used for general purpose storage of user files, such as audio, video, and picture files, among other things. It is a principal memory storage unit of device 108 and can be used to store any type of file a user wishes to store in it. It is designed to allow a user to frequently update and access his library of files.
- a mass storage memory is generally larger than other random access memory (“RAM”) and read only memory (“ROM”) that SD 100 A may also comprise (not shown) in this and other embodiments.
- RAM random access memory
- ROM read only memory
- SD 100 A may also comprise (not shown) in this and other embodiments.
- a mass storage memory is distinct from code storage devices that are designed to store comparatively small amounts of operating code that are infrequently updated.
- a ROM or flash memory may be used as a code storage device, but it should be understood that a code storage device is different in purpose and generally in size than a mass storage device.
- SD 100 A also comprises a data or memory bus 106 and a host bus 102 .
- SD 100 A may be a complete electronic device such as a digital camera or music player, cellular telephone etc. It may also have the form factor of a memory card or universal serial bus (“USB”) drive designed to be used in conjunction with any type of processor controlled electronic device.
- USB universal serial bus
- the embodiments may often be referred to as a memory card, but it should be understood that such reference is to a preferred embodiment and should not limit the scope of the present invention which is defined by the appended claims.
- SD Secure Digital
- Data and commands are communicated to and from SD 100 A via host bus 102 .
- the host which is not shown, may be a personal computer or other electronic device.
- Secure controller 104 controls the read and write operations to and from unsecure memory 108 via memory bus 106 . In doing so, it also limits access to the contents of the unsecure memory 108 .
- the firmware that runs the device is stored in unsecure memory 108 .
- This firmware which will be described in more detail later with regard to FIGS. 2-7 , in conjunction with controller 104 , provides the security that makes device 100 A a secure device. Therefore, it is essential that the firmware that is executed by secure controller 104 is authentic, or the security of the system could be compromised.
- FIG. 1B illustrates secure device 100 B.
- Secure controller 104 comprises cryptographic engine 110 , one or more encryption keys 112 stored in a non volatile memory of controller 104 , and an indication 114 of the device operating state that is also stored in a non volatile memory of controller 104 .
- numerous states or life cycle phases are entered and passed through during the life of the card. Depending on the phase, logic in the card enables or disables the encryption engine, controls access to hardware (before and after card assembly) and software testing mechanisms, and controls key generation.
- the cryptographic engine 110 is hardware based and can encrypt and/or decrypt data as it passes through secure controller 104 .
- data encrypted with a first encryption algorithm as it arrives at the controller from host bus 102 can be decrypted and then encrypted with a second algorithm before it is sent to flash memory 108 via data bus 106 .
- data encrypted in memory 108 can be decrypted by engine 110 and passed in a decrypted state over host bus 102 although it is preferably in an encrypted format as it passes over host bust 102 so as to avoid potential unauthorized copying of the data.
- the cryptographic engine 110 may comprise numerous sub engines and is capable of utilizing numerous encryption standards and algorithms. Examples of the various encryption techniques and algorithms include: Message Authentication Codes (“MACs”); Data Encryption Standard (“DES”), Triple DES, Advanced Encryption Standard (“AES”), RSA and Diffie-Helman that are often used in a Public Key Infrastructure (“PKI”), and other hash based encryption such as SHA-1 and MD5.
- MACs Message Authentication Codes
- DES Data Encryption Standard
- AES Advanced Encryption Standard
- PKI Public Key Infrastructure
- the encryption engine may use other currently available algorithms and techniques and others yet to be developed or well accepted, and the aforementioned list is only meant to provide some examples.
- a Message Authentication Code is a hash computed from a message and some secret data. It is difficult to forge without knowing the secret data.
- the MAC is computed using an algorithm based on the DES or AES ciphers, which use a secret key.
- the secret key 112 or one or more keys derived from the secret key are stored in controller 104 , and therefore the hash or message authentication code created by the controller is associated with that controller, and cannot be duplicated by another controller. Therefore hash values from a particular controller are associated with the controller and can act as a type of signature of the controller and device, because the signature is unique and cannot be duplicated.
- RFC 3566 The AES - XCBC - MAC -96 Algorithm and Its Use With IPsec by Sheila Frankel, NIST—National Institute of Standards and Technology, 820 West Diamond Ave, Room 677, Gaithersburg, Md. 20899, available at http://www.faqs.org/rfcs/rfc3566.html; Performance Comparison of Message Authentication Code ( MAC ) Algorithms for the Internet Protocol Security ( IPSEC ) by Janaka Deepakumara, Howard M. Heys and R.
- FIG. 2 is an illustration of the memory space of the flash memory 108 that includes firmware 200 that runs devices 100 A or 100 B.
- the system firmware 200 comprises a boot loader (BLR) portion 200 a that resides in flash memory 108 and is preferably not changeable, and system firmware 200 b that resides in flash memory 108 and can be changed from time to time if necessary.
- BLR boot loader
- the size of system firmware 200 is larger than the RAM module it is executed from, so the system firmware is divided into smaller portions referred to as overlays.
- Each overlay preferably has its own hash value and within system firmware 200 is a table 200 c of those hash values. Table 200 c is not loaded as part of system firmware 200 b , but the pre-stored values are compared with calculated values as will be discussed in more detail below.
- MAC hash value
- MAC hash value
- SHA-1 values are currently preferable.
- SHA-1 digests may alternatively be used in place of MAC values, and vice versa.
- the advantage of using MAC values is that they are associated with the hardware and the key of the hardware that created them. While SHA-1 values can be created for a given data set simply based upon the data itself, MAC values cannot be recreated without the key, and thus provide for more robust security. Specifically, because key 104 (or a key derived therefrom) stored in the non volatile memory of encryption engine 110 must be used to create the MAC values, another processor cannot be utilized to recreate the MAC values. For example, a hacker cannot use another processor outside of the system to duplicate the firmware and the associated MAC values.
- the hash values themselves can be encrypted one or more times.
- a MAC entry that protects the MAC table 200 c 2 is created so even if a hacker finds a way to switch or alter the firmware and recalculate the appropriate MACs, he is still facing a problem because he must calculate the MAC of MACs (or MAC of SHA-1s).
- the MAC of MACs is again encrypted and stored in another (different) memory field, for example the non volatile memory of encryption engine 110 or the controller 104 . This multi-level distributed hierarchy ensures that the signatures cannot be forged, or rather, that a forged signature will not be accepted as authentic.
- the system would then check one level up the hierarchy and see if the MAC of table 200 c indicates that table 200 c has not been tampered with. If the stored MAC of the table does not match the calculated MAC, this indicates a problem with the authenticity. However, if the MAC of table 200 c has also been altered to match the replaced table 200 c , then the system would verify the signature in error. This error is avoided by storing a copy of the MAC of table 200 C in another (inaccessible) memory, and comparing the copy in the other (inaccessible) memory with the value in the flash memory 108 . If the values do not match, this indicates an authenticity problem. Although only a few levels were illustrated, this multi-level distributed structure may have numerous levels and incorporate numerous different memories depending on the size and complexity of the firmware to be protected.
- This multi-level distributed hierarchy employed in conjunction with the overlay structure of the firmware also results in a very efficient and rapid authentication process. Dividing the firmware into overlays and signing each overlay greatly speeds up the overall authentication process. This is because it is much faster to verify the signature of a smaller amount of code. In order to calculate a hash value, all of the data for which the hash is to be calculated must be read. The larger the portion of firmware to be read, the longer it will take to calculate the signature, and then verify that the signature is authentic. Calculating the signature for a large amount of data is potentially very time consuming and inefficient.
- firmware applications 202 A . . . X shown as APP FW 1, 2 . . . X, and, of course, user files (not shown).
- the firmware applications may be configured differently for various product configurations. The number and type of these applications will vary from one product to another.
- the firmware applications are also preferably divided into overlays if the applications are larger than the RAM module.
- a map of the application firmware overlays 201 A indicates the location in memory of the various overlays.
- a table of hash values (SHA-1 digests or MAC values etc.) 201 B for the various firmware applications, encrypted with a secret key, which may be secret key 104 or a key derived from secret key 104 is also stored in the flash memory.
- a firmware application is akin to other applications that run on a base system, e.g. a word processing application in the Windows® environment running on the Windows® operating system.
- flash memory cells have a limited lifetime and the cells degrade with each read and write operation. Therefore data in the flash memory is generally moved from time to time in order to distribute the read and write operations evenly among the cells and distribute the “wear” evenly amongst the cells. This wear leveling, along with all read/write operations, is controlled by the firmware 200 , and in particular by the system firmware 200 B. In order to be able to easily move data, the data is logically stored. This means that a logical address is mapped to a physical address, and that while the logical address remains the same, it can be mapped to a different physical address. Again, this logical to physical mapping is carried out by the system firmware.
- firmware it presents some difficulty if the firmware is in charge of moving itself. This is especially true when the firmware is responsible for copy protection of the data in the flash memory, and should therefore preferably be verified as authentic before execution. Also, while it is true that the system firmware may be updated from time to time, it will be written very infrequently when compared with other data stored in the flash memory 108 . Therefore, the firmware 200 , including the boot loader 200 a is physically (without logical mapping) written to and read from flash memory 108 .
- the application firmware provides additional functionality not present in the system firmware, and may be loaded into the device at any time. It is unknown how much application firmware may be loaded into the device, and when each application may be loaded. Therefore space within the physical partition is not allocated and the application firmware is stored in the logical partition 214 and logically addressed like any other user files and data in the flash memory 108 .
- FIG. 3 illustrates the functional structure of the software of the device and how it accesses the mass storage memory 108 .
- the preferred embodiments comprise flash type memory for mass storage memory 108 and for simplicity, during this description of the preferred embodiments the terms may be used interchangeably.
- the portion of the software that is concerned with flash memory operations is referred to generally as the back end, while the portion of the software that involves the applications and the user interface is known as the front end.
- Firmware applications 202 A, 202 B . . . 202 X run on top of firmware 200 which includes system firmware 200 B.
- the BLR 200 a is a separate component of firmware 200 , the BLR bootstraps the system firmware and may in essence generally be thought of as part of system firmware 200 .
- the system firmware 200 has physical sector address routines or block 206 and logical/physical mapper or mapping routines 208 .
- the mass storage memory 108 is partitioned into physical storage area 212 and logical storage area 214 .
- Physical/logical partition 216 is used to illustrate the division or partitioning of the mass storage memory 108 into areas 212 and 214 . Each of areas 212 and 216 can be further partitioned into smaller areas, and it is common in the art to use the term partitions to refer to these smaller areas also.
- the physical sector access routines or functional block 206 controls reading and writing in the physical area or partition 212
- the logical/physical mapper block controls reading and writing in the logical storage area 214 .
- Firmware 200 including system firmware 200 B, is stored in physical area 212 .
- Application firmware 202 A . . . X is stored in logical area 214 where the user files are also stored.
- the application firmware and all other data in logical area 214 is moved around from time to time by the wear leveling routines of the system firmware.
- the firmware is signed. This is typically done at the time of loading of the firmware, but a signed record can be updated by overwriting the record with a new one.
- the signature comprises one or more hash values of at least a portion of the firmware.
- the hash values are preferably of the MAC variety, because, as discussed earlier, a MAC value is created with a key used with and/or stored within the controller that created the MAC value, and cannot be recreated by another processor. Each portion or piece of firmware may be signed using a different key.
- BLR 200 A may be signed with a first key, while system firmware 200 B is signed with a second key.
- Various portions (e.g. overlays) of firmware 200 can also be signed with various different keys.
- each piece of application firmware 202 A . . . X can be signed with a different key.
- Hash values for BLR 200 A are stored and calculated in a unique process that is described in copending application entitled “Hardware Driver Integrity Check Of Memory Card Controller Firmware” to Micky Holtzman et al. having attorney docket number SNDK.408US2. Please refer to that application for further information on that process.
- the firmware can only be signed in certain states, and unsigned firmware cannot be executed.
- state 150 (not shown), which is the secure operating state that the device will generally be in while in the hands of the consumer, firmware update and signing will not be allowed. This prevents installation of substitute firmware that may not be authentic.
- the system in that embodiment only enables the encryption engine to sign the firmware in states other than the secure state.
- updating of the firmware is allowed in the field (i.e. while in state 150 ) as long as the firmware is signed before it is loaded and that signature can be verified by the card.
- the source of the firmware can also be identified and verified, as well as verifying the signature of the firmware itself.
- the firmware should be supplied by a trusted entity before it is loaded, and in a preferred embodiment the trust is established using a public key infrastructure (“PKI”) certificate.
- PKI public key infrastructure
- This certificate could be in addition to or alternatively in lieu of the hash based signature.
- the encryption engine would sign the firmware.
- a secure connection can be established with the supplier of the firmware.
- the secure connection would be encrypted to protect the data passing between the device and the supplier.
- the secure connection would preferably be encrypted according to the aforementioned AES standard, but could employ any known encryption standard.
- the system firmware is broken up into overlays of smaller size so that each overly can be loaded into RAM for execution.
- a map 200 c 1 of the various overlays is stored in the flash memory.
- Each overlay is individually signed.
- a table 200 c 2 of the signatures, which are preferably MAC values, is also stored in the flash memory as part of firmware 200 .
- the system or device 200 allocates sufficient room in the RAM for complete table 200 c 2 to be loaded, and the entire table is loaded and resident in RAM during operation of the device.
- Each firmware application 202 A . . . X is also broken up into overlays, and each overlay is likewise signed.
- key dependent hash e.g. MAC
- Table 201 B contains the signatures for each application firmware overlay in map 201 A.
- a one sector buffer is pre-allocated in the RAM as a workspace for the application firmware signatures.
- each overlay of any of the firmware can rely on one signature.
- one signature could be used for all the firmware.
- the size of the overlays or portions to be signed may also vary. Referring again to FIG. 4 , after the firmware is signed in step 304 as described above, each signature is verified in step 308 . When each piece, e.g. each overlay, of the firmware is read from the flash memory, it passes through the encryption engine 110 , and the hash value of the piece is created “on the fly” by the encryption engine.
- This calculated value is compared to the stored value, and if the values do not match there is a problem with the authenticity of the piece of the firmware. If there is a match, then the next level of the hierarchical structure described earlier with regard to FIG. 2 will preferably be checked. Preferably all the levels will be checked as will the copy stored in the additional memory. As mentioned previously, this distributed hierarchical structure assures that the firmware and signature are authentic.
- FIG. 5 is a flowchart illustrating firmware execution.
- the system verifies the signature of the boot loader portion (“BLR”). This can be done as mentioned above in regard to the system firmware, but is preferably done in another process described in a co-pending application entitled “Hardware Driver Integrity Check of Memory Card Controller Firmware” to Micky Holtzman et al. with attorney docket No. SNDK.408US2.
- BLR boot loader portion
- FIG. 6 is a flowchart illustrating the reading and verification of firmware 200 , which is stored in the physical storage area 212 . This corresponds to steps 504 and 508 of FIG. 5 .
- step 604 the data (firmware in this case) is read from the physical address where it is stored. Again, this physical read is performed without any logical mapping beforehand.
- step 604 hash value(s) are created for the firmware. These value(s) are temporarily stored in a register of the controller.
- step 608 the value(s) calculated in step 606 are compared with the stored value(s).
- the stored value(s) are in tables in the flash memory, and may themselves be encrypted.
- FIG. 7 is a flowchart illustrating the reading and verification of the firmware applications 202 A . . . X.
- step 704 the data is read from the logical address where it is stored. This comprises requesting logically addressed data from the system firmware in step 704 A. It also comprises step 704 B where the system firmware then maps the logical address with its corresponding physical address at that given time.
- hash values are calculated for the overlay or other quantity of firmware in step 706 .
- the calculated has value(s) are compared with the stored hash value(s).
- the stored hash values are in tables in the flash memory and may themselves be encrypted.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Software Systems (AREA)
- Multimedia (AREA)
- Technology Law (AREA)
- Storage Device Security (AREA)
Abstract
A device with mass storage capability that uses a readily available non secure memory for the mass storage but has firmware (and hardware) that provides security against unauthorized copying of data. This is true even though the firmware itself is stored in the non secure mass storage memory, and therefore potentially vulnerable to hacking. An indication of the authenticity of the firmware must be present before it will be executed by the device. This protects the device contents from unauthorized duplication or tampering. Additional functionality can be added to the device with additional firmware applications, and the authenticity of those additional applications will also be verified before they will be executed. This further prevents unauthorized copying or tampering of secure content through any mechanisms that may be unscrupulously introduced. Any data within the mass storage memory may also be encrypted.
Description
- This application claims priority to provisional Application No. 60/717,164 entitled “Secure Yet Flexible System Architecture for Secure Devices With Flash Mass Storage Memory” filed Sep. 14, 2005 to Micky Holtzman et al.
- This application is related to the following applications, each of which is hereby incorporated by this reference in its entirety: “Methods Used in a Secure Yet Flexible System Architecture for Secure Devices With Flash Mass Storage Memory” to Micky Holtzman et al., Attorney Docket No.: SNDK.470US2; “Method of Hardware Driver Integrity Check Of Memory Card Controller Firmware” to Micky Holtzman et al., application Ser. No. 11/284,623, Attorney Docket No. SNDK.
408US 1; “Hardware Driver Integrity Check Of Memory Card Controller Firmware” to Micky Holtzman et al., application Ser. No. 11/285,600, Attorney Docket No. SNDK.408US2; “Methods Used in a Secure Memory Card With Life Cycle Phases” to Micky Holtzman, et al. Attorney Docket No. SNDK.383US2; and “Secure Memory Card With Life Cycle Phases” to Micky Holtzman et al., Attorney Docket No. SNDK.383US3. - The present application is generally related to the operation of flash based mass storage devices, and in particular those with copy protection of secure content.
- Flash based mass storage devices are used to store very large amounts of content, such as pictures and music or software programs. Examples of these mass storage devices include memory cards, universal serial bus (“USB”) flash drives, flash based music and/or video players, and other portable computing devices that rely on flash for the mass storage of content or files.
- User files are frequently updated and modified. This is particularly the case when dealing with photos, music, and documents. Flash memory has a limited number of read/write cycles, and a great deal of research and development has gone into distributing the cycles among the flash memory cells in order to maximize the lifespan and reliability of the devices. For instance, wear leveling techniques such as those taught in U.S. Pat. No. 6,230,233 entitled “Wear Leveling Techniques For Flash EEPROM Systems” to Lofgren et al., U.S. Pat. No. 5,268,870 entitled “Flash EEPROM System and Intelligent Programming and Erasing Methods Therefore” to Harari, PCT Publication No. WO2004040578A2 entitled “Wear Leveling In Non-Volatile Storage Systems” to Chang et al., and U.S. Patent Publication No. 20040083335A1, entitled “Automated Wear Leveling In Non-Volatile Storage Systems” to Gonzalez et al., which are hereby incorporated by this reference in their entireties, are commonly implemented in these devices. These techniques generally involve changing the logical/physical mapping so that physical locations of the memory are used roughly the same amount.
- In addition, as the usage of flash based mass storage devices is proliferating, the number of different things that can be done with them is also increasing.
- Therefore, there exists a need for a new device operating system architecture that provides flexibility to store and run a wide range of firmware that can be updated and changed to accommodate the range of increasing functionality. In addition to being flexible, this architecture must provide a highly secure and reliable environment for both firmware and content. As is always the case, all of this should be done for the lowest possible cost, using standard components whenever possible.
- The present invention allows a device to be both secure in operation and flexible in terms of functionality. This means functionality can be tailored to users' desires and added over time all the while maintaining a high level of security. Therefore the device can be used to store confidential and limited access information such as transactional data and copyrighted artistic works.
- The present invention also allows for the device to boot quickly and reliably while still providing for reliable long term data storage through the use of wear leveling techniques where appropriate.
- Firmware that is not authentic, and that may potentially compromise the security of the device will not be executed. An indication of the authenticity is verified before execution. In a preferred embodiment, multiple different levels of such indications are provided and are associated with the particular controller of the device that created the indications. In this preferred embodiment, one or more of the different levels of indications can be verified. Without the properly associated indication the firmware will not be executed.
- Another aspect of the present invention is that this security is achieved despite the fact that the device utilizes readily available memory without built in security for the mass storage of the data, including the firmware.
-
FIG. 1A is a schematic diagram of secure device 100A, an embodiment of the present invention. -
FIG. 1B is a schematic diagram of secure device 100B, an embodiment of the present invention. -
FIG. 2 is a diagram illustrating various pieces of firmware in a portion ofmemory space 108. -
FIG. 3 is a schematic diagram illustrating software structure and hardware access according an embodiment of the present invention. -
FIG. 4 is a flowchart illustrating some steps of firmware integrity verification. -
FIG. 5 is a flowchart of operation of an embodiment of the present invention. -
FIG. 6 is a flowchart illustrating integrity checking of physically stored data such as thefirmware 200. -
FIG. 7 is a flowchart illustrating integrity checking of logically stored data such as user files and theapplication firmware 202A, B, . . . X. - Devices incorporating flash memory for mass storage purposes must store large amounts of content that is written and read relatively often. For instance, digital photo and music libraries are regularly updated by users of such devices. With the increase of protected content and the desire to protect content generally, such devices must also provide robust security to prevent unauthorized copying of such “secure” or protected content. At the same time, security should not come at the cost of flexibility. The present invention provides for a device that allows functionality to be added over time, while maintaining a high level of security. This flexibility is essential in a world where devices are expected to provide ever increasing functionality.
- A secure device is one that protects the contents of the device from unauthorized copying or alteration. Secure content includes any content or data that it is desirable to safeguard from unauthorized copying or tampering. In addition to billing, transaction and other traditionally confidential personal information, artistic content must also be secured from access and copying by those other than the owner or other authorized persons.
- Depending on the architecture of the device, a hacker may try to gain access to the content via data buses, or by directly accessing the mass storage memory. In some prior devices, directly accessing the memory storage unit was difficult as the memory storage unit was often protected by placing it an environment that was logistically hard to access. For instance, Smart Cards utilized programmable read only memories (PROMS) that incorporated a small amount of non volatile memory that was made secure in part by physically isolating it from access.
- However, it is desirable to utilize unsecure mass storage memory, that is, among other things, more standardized, readily available, and/or economical. An unsecure memory or storage unit is one where authorization is not required in order to gain (read/write) access to the (encrypted or unencrypted) data stored therein, or one where there are no built in protection mechanisms that prevent copying of the stored data. While this memory may be packaged in a multi functional package with other non-memory components such as a processor, it is commonly in the form of a dedicated memory package with one or more memory chips.
- Typically, a device or system incorporating mass storage flash memory utilizes a processor to control the data storage and retrieval operations of the memory. Such a processor is part of a controller and is often referred to as a controller. A controller executes software instructions to control the device. The software that runs and controls the hardware of a device is often referred to as firmware. The firmware is typically executed from random access memory (RAM) after having been copied from some other memory where it is normally stored. Shadowing or copying to RAM is advantageous because although flash is easily updated it is slower and not inherently executable because it does not have random access capability, and because read only memory is not easily updated.
- In the case where some amount of security is to be provided in the firmware, there must be some mechanism to prevent execution of the other than the proper firmware that has the requisite security mechanisms. This is especially true when the firmware is stored in an unsecure memory. As mentioned above, it is the firmware that controls the operation of the device, and therefore it is not a simple matter to have the firmware essentially protect itself. Nor is it a simple matter to protect execution of compromised or unauthentic firmware when such firmware is stored in an otherwise unsecure memory package.
- The present invention provides for a secure system with mass storage capability even though it uses unsecure memory for the mass storage unit. Furthermore, it creates a secure system where the firmware for running the secure system is stored in the unsecure memory. In order to be able to store the firmware in the unsecure mass storage memory, the present invention employs a system that prevents execution of inauthentic firmware.
- Reference will now be made to preferred embodiments depicted in the figures.
FIG. 1A illustrates secure device (“SD”) 100A, an embodiment of the present invention. SD 100A comprises asecure controller 104 andunsecure memory 108. -
Memory 108 is preferably flash type memory and is used for mass storage purposes. This means that the memory is used for general purpose storage of user files, such as audio, video, and picture files, among other things. It is a principal memory storage unit ofdevice 108 and can be used to store any type of file a user wishes to store in it. It is designed to allow a user to frequently update and access his library of files. A mass storage memory is generally larger than other random access memory (“RAM”) and read only memory (“ROM”) that SD 100A may also comprise (not shown) in this and other embodiments. Also, as a general file storage device, a mass storage memory is distinct from code storage devices that are designed to store comparatively small amounts of operating code that are infrequently updated. A ROM or flash memory may be used as a code storage device, but it should be understood that a code storage device is different in purpose and generally in size than a mass storage device. - SD 100A also comprises a data or
memory bus 106 and ahost bus 102. SD 100A may be a complete electronic device such as a digital camera or music player, cellular telephone etc. It may also have the form factor of a memory card or universal serial bus (“USB”) drive designed to be used in conjunction with any type of processor controlled electronic device. For simplicity in describing SD100A and the other embodiments depicted in the figures, the embodiments may often be referred to as a memory card, but it should be understood that such reference is to a preferred embodiment and should not limit the scope of the present invention which is defined by the appended claims. Currently, the preferred form factor for a memory card in which the present invention is especially useful is the well known Secure Digital (“SD”) Card. - Data and commands are communicated to and from SD100A via
host bus 102. The host, which is not shown, may be a personal computer or other electronic device.Secure controller 104 controls the read and write operations to and fromunsecure memory 108 viamemory bus 106. In doing so, it also limits access to the contents of theunsecure memory 108. As mentioned above, the firmware that runs the device is stored inunsecure memory 108. This firmware, which will be described in more detail later with regard toFIGS. 2-7 , in conjunction withcontroller 104, provides the security that makes device 100A a secure device. Therefore, it is essential that the firmware that is executed bysecure controller 104 is authentic, or the security of the system could be compromised. - Ensuring the authenticity of the firmware is much more difficult when it is in an unsecure memory. However, given that the
unsecure memory 108 is used for mass storage purposes, it is quite large and is easily updated. Therefore, it makes sense to use the capacity of the unsecure memory to store the firmware. This may eliminate or a least reduce the size of a code storage device dedicated to storing the firmware. Alternatively it reduces the need for such storage within the controller. This cost saving is important in a competitive market. There are 3 main paths to the contents stored in memory 108: reading the contents of thememory 108 directly; monitoring the signals onbus 102; and monitoring the signals onbus 106. Even though any or all of the information in theunsecure memory 108 or onbuses -
FIG. 1B illustrates secure device 100B.Secure controller 104 comprisescryptographic engine 110, one ormore encryption keys 112 stored in a non volatile memory ofcontroller 104, and anindication 114 of the device operating state that is also stored in a non volatile memory ofcontroller 104. In certain embodiments of the invention, numerous states or life cycle phases are entered and passed through during the life of the card. Depending on the phase, logic in the card enables or disables the encryption engine, controls access to hardware (before and after card assembly) and software testing mechanisms, and controls key generation. These phases not only allow both the hardware and software of the card to be thoroughly tested before and after manufacture, but also make it virtually impossible to access the encrypted keys and thus the encrypted content when the card is in a secure phase, the operating phase that the card is in when it is shipped to the user. For more information on the states or life cycle phases please refer to an application having attorney docket No. SNDK.383US3 “Secure Memory Card With Life Cycle Phases” to Micky Holtzman et al., which is hereby incorporated by this reference in its entirety. - The
cryptographic engine 110 is hardware based and can encrypt and/or decrypt data as it passes throughsecure controller 104. For example, data encrypted with a first encryption algorithm as it arrives at the controller fromhost bus 102 can be decrypted and then encrypted with a second algorithm before it is sent toflash memory 108 viadata bus 106. Of course, data encrypted inmemory 108 can be decrypted byengine 110 and passed in a decrypted state overhost bus 102 although it is preferably in an encrypted format as it passes over host bust 102 so as to avoid potential unauthorized copying of the data. - The
cryptographic engine 110, also referred to asencryption engine 110, may comprise numerous sub engines and is capable of utilizing numerous encryption standards and algorithms. Examples of the various encryption techniques and algorithms include: Message Authentication Codes (“MACs”); Data Encryption Standard (“DES”), Triple DES, Advanced Encryption Standard (“AES”), RSA and Diffie-Helman that are often used in a Public Key Infrastructure (“PKI”), and other hash based encryption such as SHA-1 and MD5. The encryption engine may use other currently available algorithms and techniques and others yet to be developed or well accepted, and the aforementioned list is only meant to provide some examples. - A Message Authentication Code is a hash computed from a message and some secret data. It is difficult to forge without knowing the secret data. The MAC is computed using an algorithm based on the DES or AES ciphers, which use a secret key. The
secret key 112, or one or more keys derived from the secret key are stored incontroller 104, and therefore the hash or message authentication code created by the controller is associated with that controller, and cannot be duplicated by another controller. Therefore hash values from a particular controller are associated with the controller and can act as a type of signature of the controller and device, because the signature is unique and cannot be duplicated. - Although the aforementioned standards and various other algorithms and/or standards are well known to those skilled in cryptography, the following publications are informative and are hereby incorporated by reference in their entireties: RFC 3566—The AES-XCBC-MAC-96 Algorithm and Its Use With IPsec by Sheila Frankel, NIST—National Institute of Standards and Technology, 820 West Diamond Ave, Room 677, Gaithersburg, Md. 20899, available at http://www.faqs.org/rfcs/rfc3566.html; Performance Comparison of Message Authentication Code (MAC) Algorithms for the Internet Protocol Security (IPSEC) by Janaka Deepakumara, Howard M. Heys and R. Venkatesan, Electrical and Computer Engineering, Memorial University of Newfoundland, St. John's, NL, Canada, A1B3S7 available at http://www.engr.mun.ca/˜howard/PAPERS/necec—2003b.pdf; and Comments to NIST concerning AES Modes of Operations: A Suggestion for Handling Arbitrary-Length Messages with the CBC MAC by John Black, University of Nevada, Reno, Phillip Rogaway, University of California at Davis, available at http://csrc.nist.gov/CryptoToolkit/modes/proposedmodes/xcbc-mac/xcbc-mac-spec.pdf.
-
FIG. 2 is an illustration of the memory space of theflash memory 108 that includesfirmware 200 that runs devices 100A or 100B. Thesystem firmware 200 comprises a boot loader (BLR) portion 200 a that resides inflash memory 108 and is preferably not changeable, andsystem firmware 200 b that resides inflash memory 108 and can be changed from time to time if necessary. The size ofsystem firmware 200 is larger than the RAM module it is executed from, so the system firmware is divided into smaller portions referred to as overlays. Each overlay preferably has its own hash value and withinsystem firmware 200 is a table 200 c of those hash values. Table 200 c is not loaded as part ofsystem firmware 200 b, but the pre-stored values are compared with calculated values as will be discussed in more detail below. Any hash value can be used, but MAC or SHA-1 values are currently preferable. Generally, SHA-1 digests may alternatively be used in place of MAC values, and vice versa. The advantage of using MAC values is that they are associated with the hardware and the key of the hardware that created them. While SHA-1 values can be created for a given data set simply based upon the data itself, MAC values cannot be recreated without the key, and thus provide for more robust security. Specifically, because key 104 (or a key derived therefrom) stored in the non volatile memory ofencryption engine 110 must be used to create the MAC values, another processor cannot be utilized to recreate the MAC values. For example, a hacker cannot use another processor outside of the system to duplicate the firmware and the associated MAC values. - As a further security precaution, the hash values themselves can be encrypted one or more times. In the example of MAC values, a MAC entry that protects the MAC table 200 c 2 is created so even if a hacker finds a way to switch or alter the firmware and recalculate the appropriate MACs, he is still facing a problem because he must calculate the MAC of MACs (or MAC of SHA-1s). Furthermore, in one embodiment the MAC of MACs is again encrypted and stored in another (different) memory field, for example the non volatile memory of
encryption engine 110 or thecontroller 104. This multi-level distributed hierarchy ensures that the signatures cannot be forged, or rather, that a forged signature will not be accepted as authentic. As an illustration, if one were to access theflash memory 108 and replace the firmware and table 200 c, the system would then check one level up the hierarchy and see if the MAC of table 200 c indicates that table 200 c has not been tampered with. If the stored MAC of the table does not match the calculated MAC, this indicates a problem with the authenticity. However, if the MAC of table 200 c has also been altered to match the replaced table 200 c, then the system would verify the signature in error. This error is avoided by storing a copy of the MAC of table 200C in another (inaccessible) memory, and comparing the copy in the other (inaccessible) memory with the value in theflash memory 108. If the values do not match, this indicates an authenticity problem. Although only a few levels were illustrated, this multi-level distributed structure may have numerous levels and incorporate numerous different memories depending on the size and complexity of the firmware to be protected. - This multi-level distributed hierarchy employed in conjunction with the overlay structure of the firmware also results in a very efficient and rapid authentication process. Dividing the firmware into overlays and signing each overlay greatly speeds up the overall authentication process. This is because it is much faster to verify the signature of a smaller amount of code. In order to calculate a hash value, all of the data for which the hash is to be calculated must be read. The larger the portion of firmware to be read, the longer it will take to calculate the signature, and then verify that the signature is authentic. Calculating the signature for a large amount of data is potentially very time consuming and inefficient.
- Also stored within the flash memory are
various firmware applications 202A . . . X, shown asAPP FW application firmware overlays 201A indicates the location in memory of the various overlays. A table of hash values (SHA-1 digests or MAC values etc.) 201B for the various firmware applications, encrypted with a secret key, which may be secret key 104 or a key derived fromsecret key 104, is also stored in the flash memory. A firmware application is akin to other applications that run on a base system, e.g. a word processing application in the Windows® environment running on the Windows® operating system. - As discussed in the background, flash memory cells have a limited lifetime and the cells degrade with each read and write operation. Therefore data in the flash memory is generally moved from time to time in order to distribute the read and write operations evenly among the cells and distribute the “wear” evenly amongst the cells. This wear leveling, along with all read/write operations, is controlled by the
firmware 200, and in particular by thesystem firmware 200B. In order to be able to easily move data, the data is logically stored. This means that a logical address is mapped to a physical address, and that while the logical address remains the same, it can be mapped to a different physical address. Again, this logical to physical mapping is carried out by the system firmware. - It presents some difficulty if the firmware is in charge of moving itself. This is especially true when the firmware is responsible for copy protection of the data in the flash memory, and should therefore preferably be verified as authentic before execution. Also, while it is true that the system firmware may be updated from time to time, it will be written very infrequently when compared with other data stored in the
flash memory 108. Therefore, thefirmware 200, including the boot loader 200 a is physically (without logical mapping) written to and read fromflash memory 108. - The application firmware provides additional functionality not present in the system firmware, and may be loaded into the device at any time. It is unknown how much application firmware may be loaded into the device, and when each application may be loaded. Therefore space within the physical partition is not allocated and the application firmware is stored in the
logical partition 214 and logically addressed like any other user files and data in theflash memory 108. -
FIG. 3 illustrates the functional structure of the software of the device and how it accesses themass storage memory 108. As mentioned before, the preferred embodiments comprise flash type memory formass storage memory 108 and for simplicity, during this description of the preferred embodiments the terms may be used interchangeably. The portion of the software that is concerned with flash memory operations is referred to generally as the back end, while the portion of the software that involves the applications and the user interface is known as the front end.Firmware applications firmware 200 which includessystem firmware 200B. Although the BLR 200 a is a separate component offirmware 200, the BLR bootstraps the system firmware and may in essence generally be thought of as part ofsystem firmware 200. Thesystem firmware 200 has physical sector address routines or block 206 and logical/physical mapper ormapping routines 208. Themass storage memory 108 is partitioned intophysical storage area 212 andlogical storage area 214. Physical/logical partition 216 is used to illustrate the division or partitioning of themass storage memory 108 intoareas areas functional block 206 controls reading and writing in the physical area orpartition 212, and the logical/physical mapper block controls reading and writing in thelogical storage area 214. -
Firmware 200, includingsystem firmware 200B, is stored inphysical area 212.Application firmware 202A . . . X is stored inlogical area 214 where the user files are also stored. The application firmware and all other data inlogical area 214 is moved around from time to time by the wear leveling routines of the system firmware. - The authenticity of all of the firmware is preferably checked before it is executed. This is done because, as discussed earlier, the
mass storage memory 108 does not have its own built in protection mechanisms. The flowchart ofFIG. 4 applies to any piece of firmware, including application firmware. Instep 304, the firmware is signed. This is typically done at the time of loading of the firmware, but a signed record can be updated by overwriting the record with a new one. The signature comprises one or more hash values of at least a portion of the firmware. The hash values are preferably of the MAC variety, because, as discussed earlier, a MAC value is created with a key used with and/or stored within the controller that created the MAC value, and cannot be recreated by another processor. Each portion or piece of firmware may be signed using a different key. For example, BLR 200A may be signed with a first key, whilesystem firmware 200B is signed with a second key. Various portions (e.g. overlays) offirmware 200 can also be signed with various different keys. As another example, each piece ofapplication firmware 202A . . . X can be signed with a different key. - Hash values for BLR 200A are stored and calculated in a unique process that is described in copending application entitled “Hardware Driver Integrity Check Of Memory Card Controller Firmware” to Micky Holtzman et al. having attorney docket number SNDK.408US2. Please refer to that application for further information on that process.
- In one preferred embodiment involving the aforementioned life cycle phases or states, the firmware can only be signed in certain states, and unsigned firmware cannot be executed. In particular, in state 150 (not shown), which is the secure operating state that the device will generally be in while in the hands of the consumer, firmware update and signing will not be allowed. This prevents installation of substitute firmware that may not be authentic. The system in that embodiment only enables the encryption engine to sign the firmware in states other than the secure state. In other embodiments, updating of the firmware is allowed in the field (i.e. while in state 150) as long as the firmware is signed before it is loaded and that signature can be verified by the card. The source of the firmware can also be identified and verified, as well as verifying the signature of the firmware itself. The firmware should be supplied by a trusted entity before it is loaded, and in a preferred embodiment the trust is established using a public key infrastructure (“PKI”) certificate. This certificate could be in addition to or alternatively in lieu of the hash based signature. For example, if trust is established (by the certificate in this illustrative embodiment) then the encryption engine would sign the firmware. As another added precaution, a secure connection can be established with the supplier of the firmware. The secure connection would be encrypted to protect the data passing between the device and the supplier. The secure connection would preferably be encrypted according to the aforementioned AES standard, but could employ any known encryption standard.
- As mentioned previously, the system firmware is broken up into overlays of smaller size so that each overly can be loaded into RAM for execution. A map 200 c 1 of the various overlays is stored in the flash memory. Each overlay is individually signed. A table 200 c 2 of the signatures, which are preferably MAC values, is also stored in the flash memory as part of
firmware 200. The system ordevice 200 allocates sufficient room in the RAM for complete table 200 c 2 to be loaded, and the entire table is loaded and resident in RAM during operation of the device. - Each
firmware application 202A . . . X is also broken up into overlays, and each overlay is likewise signed. Currently, as with the system firmware, it is preferable to calculate key dependent hash (e.g. MAC) values to sign the firmware applications, although as mentioned previously, other hash values may be used. Table 201B contains the signatures for each application firmware overlay inmap 201A. A one sector buffer is pre-allocated in the RAM as a workspace for the application firmware signatures. - Although it is preferable to sign each overlay of any of the firmware because this prevents replacement of a piece of firmware that may have critical decision making functionality, any amount of firmware can rely on one signature. For example, although not preferred, one signature could be used for all the firmware. Furthermore, the size of the overlays or portions to be signed may also vary. Referring again to
FIG. 4 , after the firmware is signed instep 304 as described above, each signature is verified instep 308. When each piece, e.g. each overlay, of the firmware is read from the flash memory, it passes through theencryption engine 110, and the hash value of the piece is created “on the fly” by the encryption engine. This calculated value is compared to the stored value, and if the values do not match there is a problem with the authenticity of the piece of the firmware. If there is a match, then the next level of the hierarchical structure described earlier with regard toFIG. 2 will preferably be checked. Preferably all the levels will be checked as will the copy stored in the additional memory. As mentioned previously, this distributed hierarchical structure assures that the firmware and signature are authentic. -
FIG. 5 is a flowchart illustrating firmware execution. Instep 504, the system verifies the signature of the boot loader portion (“BLR”). This can be done as mentioned above in regard to the system firmware, but is preferably done in another process described in a co-pending application entitled “Hardware Driver Integrity Check of Memory Card Controller Firmware” to Micky Holtzman et al. with attorney docket No. SNDK.408US2. After the signature of the BLR has been verified it is executed instep 506. Next instep 508 the system verifies the signature of the system firmware. It then executes it instep 510. If any application firmware is present, its signature is verified instep 512 and then once verified it is executed instep 514. This is done for each piece of application firmware. As mentioned above, any of the verification steps 506, 508, and 510 are preferably done for each overlay of the entity being verified before or as it is loaded into the RAM. -
FIG. 6 is a flowchart illustrating the reading and verification offirmware 200, which is stored in thephysical storage area 212. This corresponds tosteps FIG. 5 . Instep 604 the data (firmware in this case) is read from the physical address where it is stored. Again, this physical read is performed without any logical mapping beforehand. Next, instep 604, hash value(s) are created for the firmware. These value(s) are temporarily stored in a register of the controller. Next instep 608 the value(s) calculated instep 606 are compared with the stored value(s). In the embodiments described, the stored value(s) are in tables in the flash memory, and may themselves be encrypted. -
FIG. 7 is a flowchart illustrating the reading and verification of thefirmware applications 202A . . . X. Instep 704 the data is read from the logical address where it is stored. This comprises requesting logically addressed data from the system firmware instep 704A. It also comprisesstep 704B where the system firmware then maps the logical address with its corresponding physical address at that given time. After the data (firmware in this case) is read, hash values are calculated for the overlay or other quantity of firmware instep 706. Then instep 708 the calculated has value(s) are compared with the stored hash value(s). Again, in the embodiments described the stored hash values are in tables in the flash memory and may themselves be encrypted. - Although the various aspects of the present invention have been described with respect to exemplary embodiments thereof, it will be understood that the present invention is entitled to protection within the full scope of the appended claims.
Claims (4)
1. A flash memory based device comprising:
a mass storage repository comprising flash memory;
a first level of the firmware stored in a physical access partition of the mass storage repository;
a second level of the firmware stored in a logical access partition of the mass storage repository;
a logical to physical interface routine that maps logical addresses to physical addresses in the logical access partition; and
a controller that executes the first level of firmware in the physical access partition without use of the logical to physical interface routine, but executes the second level of firmware through the logical to physical interface routine.
2. The flash memory based device of claim 1 , wherein the logical to physical interface routine is part of the first level of firmware.
3. The flash memory based device of claim 2 , wherein a location of the second level of firmware is mapped by the first level of firmware.
4-26. (canceled)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/122,412 US20080215847A1 (en) | 2005-09-14 | 2008-05-16 | Secure yet flexible system architecture for secure devices with flash mass storage memory |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US71716405P | 2005-09-14 | 2005-09-14 | |
US11/317,339 US20070061597A1 (en) | 2005-09-14 | 2005-12-22 | Secure yet flexible system architecture for secure devices with flash mass storage memory |
US12/122,412 US20080215847A1 (en) | 2005-09-14 | 2008-05-16 | Secure yet flexible system architecture for secure devices with flash mass storage memory |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/317,339 Division US20070061597A1 (en) | 2005-09-14 | 2005-12-22 | Secure yet flexible system architecture for secure devices with flash mass storage memory |
Publications (1)
Publication Number | Publication Date |
---|---|
US20080215847A1 true US20080215847A1 (en) | 2008-09-04 |
Family
ID=40006403
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/317,341 Expired - Fee Related US7934049B2 (en) | 2005-09-14 | 2005-12-22 | Methods used in a secure yet flexible system architecture for secure devices with flash mass storage memory |
US11/317,339 Abandoned US20070061597A1 (en) | 2005-09-14 | 2005-12-22 | Secure yet flexible system architecture for secure devices with flash mass storage memory |
US12/122,412 Abandoned US20080215847A1 (en) | 2005-09-14 | 2008-05-16 | Secure yet flexible system architecture for secure devices with flash mass storage memory |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/317,341 Expired - Fee Related US7934049B2 (en) | 2005-09-14 | 2005-12-22 | Methods used in a secure yet flexible system architecture for secure devices with flash mass storage memory |
US11/317,339 Abandoned US20070061597A1 (en) | 2005-09-14 | 2005-12-22 | Secure yet flexible system architecture for secure devices with flash mass storage memory |
Country Status (3)
Country | Link |
---|---|
US (3) | US7934049B2 (en) |
CN (1) | CN101273363B (en) |
TW (1) | TW200731108A (en) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7536540B2 (en) | 2005-09-14 | 2009-05-19 | Sandisk Corporation | Method of hardware driver integrity check of memory card controller firmware |
US7743409B2 (en) | 2005-07-08 | 2010-06-22 | Sandisk Corporation | Methods used in a mass storage device with automated credentials loading |
US20100174851A1 (en) * | 2009-01-08 | 2010-07-08 | Micron Technology, Inc. | Memory system controller |
WO2014177904A1 (en) * | 2013-04-29 | 2014-11-06 | Freescale Semiconductor, Inc. | Memory controller |
US20160261412A1 (en) * | 2015-03-04 | 2016-09-08 | Avaya Inc. | Two-Step Authentication And Activation of Quad Small Form Factor Pluggable (QFSP+) Transceivers |
Families Citing this family (165)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2837944B1 (en) * | 2002-03-26 | 2004-07-09 | Oberthur Card Syst Sa | METHOD AND DEVICE FOR AUTOMATIC VALIDATION OF A COMPUTER PROGRAM USING CRYPTOGRAPHY FUNCTIONS |
DE102004013176B4 (en) * | 2004-03-17 | 2007-09-06 | Atmel Germany Gmbh | Method and device for executing a program |
EP1870814B1 (en) | 2006-06-19 | 2014-08-13 | Texas Instruments France | Method and apparatus for secure demand paging for processor devices |
US8112618B2 (en) | 2004-04-08 | 2012-02-07 | Texas Instruments Incorporated | Less-secure processors, integrated circuits, wireless communications apparatus, methods and processes of making |
DE102004062592B3 (en) * | 2004-12-24 | 2006-06-08 | Leica Microsystems Jena Gmbh | Disk-shaped substrate testing system, has suction unit arranged at side of housing and spaced from mounting plate, and opening provided in suction unit, where opening has width that corresponds to distance of plate to wall of housing |
US8321686B2 (en) * | 2005-02-07 | 2012-11-27 | Sandisk Technologies Inc. | Secure memory card with life cycle phases |
US8108691B2 (en) * | 2005-02-07 | 2012-01-31 | Sandisk Technologies Inc. | Methods used in a secure memory card with life cycle phases |
US8423788B2 (en) * | 2005-02-07 | 2013-04-16 | Sandisk Technologies Inc. | Secure memory card with life cycle phases |
US7934049B2 (en) | 2005-09-14 | 2011-04-26 | Sandisk Corporation | Methods used in a secure yet flexible system architecture for secure devices with flash mass storage memory |
US20070239748A1 (en) * | 2006-03-29 | 2007-10-11 | Smith Ned M | Management of reference data for platform verification |
US9680686B2 (en) * | 2006-05-08 | 2017-06-13 | Sandisk Technologies Llc | Media with pluggable codec methods |
US20070260615A1 (en) * | 2006-05-08 | 2007-11-08 | Eran Shen | Media with Pluggable Codec |
US7971071B2 (en) * | 2006-05-24 | 2011-06-28 | Walkoe Wilbur J | Integrated delivery and protection device for digital objects |
US20090240955A1 (en) * | 2006-05-31 | 2009-09-24 | Datamark Technologies Pte Ltd. | Secure media storage device and method of securing media storage devices |
EP1870813B1 (en) * | 2006-06-19 | 2013-01-30 | Texas Instruments France | Page processing circuits, devices, methods and systems for secure demand paging and other operations |
US20080126705A1 (en) * | 2006-08-08 | 2008-05-29 | Fabrice Jogand-Coulomb | Methods Used In A Portable Mass Storage Device With Virtual Machine Activation |
US7725614B2 (en) * | 2006-08-08 | 2010-05-25 | Sandisk Corporation | Portable mass storage device with virtual machine activation |
US8356178B2 (en) * | 2006-11-13 | 2013-01-15 | Seagate Technology Llc | Method and apparatus for authenticated data storage |
US8200961B2 (en) * | 2006-11-19 | 2012-06-12 | Igware, Inc. | Securing a flash memory block in a secure device system and method |
US8151082B2 (en) * | 2007-12-06 | 2012-04-03 | Fusion-Io, Inc. | Apparatus, system, and method for converting a storage request into an append data storage command |
US8161353B2 (en) | 2007-12-06 | 2012-04-17 | Fusion-Io, Inc. | Apparatus, system, and method for validating that a correct data segment is read from a data storage device |
KR101490327B1 (en) | 2006-12-06 | 2015-02-05 | 퓨전-아이오, 인크. | Apparatus, system and method for command management of solid-state storage using bank interleaving |
US8423794B2 (en) * | 2006-12-28 | 2013-04-16 | Sandisk Technologies Inc. | Method and apparatus for upgrading a memory card that has security mechanisms for preventing copying of secure content and applications |
WO2008117520A1 (en) * | 2007-03-28 | 2008-10-02 | Panasonic Corporation | Memory controller, nonvolatile memory system and host device |
KR101424971B1 (en) * | 2007-04-06 | 2014-08-13 | 삼성전자주식회사 | Method for protecting contents of UMS device using time information and apparatus therefor |
US8560823B1 (en) * | 2007-04-24 | 2013-10-15 | Marvell International Ltd. | Trusted modular firmware update using digital certificate |
US20080301466A1 (en) * | 2007-05-30 | 2008-12-04 | Mediatek Inc. | Methods for program verification and apparatuses using the same |
TWI377576B (en) * | 2007-08-22 | 2012-11-21 | Security flash memory with an apparatus for encryption and decryption, and method for accessing security flash memory | |
US8452967B2 (en) * | 2007-08-31 | 2013-05-28 | Microsoft Corporation | Using flash storage device to prevent unauthorized use of software |
US20090113116A1 (en) * | 2007-10-30 | 2009-04-30 | Thompson E Earle | Digital content kiosk and methods for use therewith |
US8898477B2 (en) * | 2007-11-12 | 2014-11-25 | Gemalto Inc. | System and method for secure firmware update of a secure token having a flash memory controller and a smart card |
US8245101B2 (en) | 2007-12-27 | 2012-08-14 | Sandisk Enterprise Ip Llc | Patrol function used in flash storage controller to detect data errors |
US8479013B2 (en) * | 2008-01-18 | 2013-07-02 | Photonic Data Security, Llc | Secure portable data transport and storage system |
US20090193261A1 (en) * | 2008-01-25 | 2009-07-30 | Mediatek Inc. | Apparatus and method for authenticating a flash program |
US20090199014A1 (en) * | 2008-02-04 | 2009-08-06 | Honeywell International Inc. | System and method for securing and executing a flash routine |
US7962684B2 (en) * | 2008-02-14 | 2011-06-14 | Sandisk Corporation | Overlay management in a flash memory storage device |
FR2930065A1 (en) * | 2008-04-11 | 2009-10-16 | Thales Sa | Smart card data securing method for computer ticketing system, involves decrypting encrypted seal variable, disassembling variable for obtaining seals corresponding to data, and verifying coherence of each seal with corresponding data |
US8838924B2 (en) * | 2008-05-24 | 2014-09-16 | Via Technologies, Inc. | Microprocessor having internal secure memory |
US8819839B2 (en) * | 2008-05-24 | 2014-08-26 | Via Technologies, Inc. | Microprocessor having a secure execution mode with provisions for monitoring, indicating, and managing security levels |
US8675868B1 (en) | 2008-07-01 | 2014-03-18 | Maxim Integrated Products, Inc. | Encrypting an address-dependent value along with code to prevent execution or use of moved code |
US8171206B2 (en) * | 2008-07-22 | 2012-05-01 | Sandisk Technologies Inc. | Avoidance of self eviction caused by dynamic memory allocation in a flash memory storage device |
US8332931B1 (en) * | 2008-09-04 | 2012-12-11 | Marvell International Ltd. | Processing commands according to authorization |
US9653004B2 (en) | 2008-10-16 | 2017-05-16 | Cypress Semiconductor Corporation | Systems and methods for downloading code and data into a secure non-volatile memory |
US20100318720A1 (en) | 2009-06-16 | 2010-12-16 | Saranyan Rajagopalan | Multi-Bank Non-Volatile Memory System with Satellite File System |
WO2011080720A2 (en) * | 2009-12-31 | 2011-07-07 | Infinite Memory Ltd. | Methods circuits apparatuses and systems for secure content duplication distribution and access |
US8365041B2 (en) | 2010-03-17 | 2013-01-29 | Sandisk Enterprise Ip Llc | MLC self-raid flash data protection scheme |
US9069688B2 (en) | 2011-04-15 | 2015-06-30 | Sandisk Technologies Inc. | Dynamic optimization of back-end memory system interface |
KR101719395B1 (en) | 2010-07-13 | 2017-03-23 | 샌디스크 테크놀로지스 엘엘씨 | Dynamic optimization of back-end memory system interface |
US8464135B2 (en) | 2010-07-13 | 2013-06-11 | Sandisk Technologies Inc. | Adaptive flash interface |
US8613074B2 (en) | 2010-09-30 | 2013-12-17 | Micron Technology, Inc. | Security protection for memory content of processor main memory |
JP5372049B2 (en) * | 2011-02-04 | 2013-12-18 | 株式会社東芝 | Memory system |
US9501399B2 (en) | 2011-02-04 | 2016-11-22 | Kabushiki Kaisha Toshiba | Memory system capable of controlling wireless communication function |
JP5395824B2 (en) | 2011-02-16 | 2014-01-22 | 株式会社東芝 | Memory system |
US8910020B2 (en) | 2011-06-19 | 2014-12-09 | Sandisk Enterprise Ip Llc | Intelligent bit recovery for flash memory |
US8909982B2 (en) | 2011-06-19 | 2014-12-09 | Sandisk Enterprise Ip Llc | System and method for detecting copyback programming problems |
US8938658B2 (en) | 2011-11-07 | 2015-01-20 | Sandisk Enterprise Ip Llc | Statistical read comparison signal generation for memory systems |
US8954822B2 (en) | 2011-11-18 | 2015-02-10 | Sandisk Enterprise Ip Llc | Data encoder and decoder using memory-specific parity-check matrix |
US9048876B2 (en) | 2011-11-18 | 2015-06-02 | Sandisk Enterprise Ip Llc | Systems, methods and devices for multi-tiered error correction |
US8924815B2 (en) | 2011-11-18 | 2014-12-30 | Sandisk Enterprise Ip Llc | Systems, methods and devices for decoding codewords having multiple parity segments |
US8281119B1 (en) * | 2011-11-22 | 2012-10-02 | Google Inc. | Separate normal firmware and developer firmware |
US8856536B2 (en) * | 2011-12-15 | 2014-10-07 | GM Global Technology Operations LLC | Method and apparatus for secure firmware download using diagnostic link connector (DLC) and OnStar system |
CN102726027B (en) * | 2011-12-28 | 2014-05-21 | 华为技术有限公司 | Secret key transmission method and device during pre-boot under full-disk encryption of virtual machine |
KR101869059B1 (en) | 2012-02-28 | 2018-06-20 | 삼성전자주식회사 | Storage device and memory controller thereof |
KR101975027B1 (en) | 2012-05-04 | 2019-05-03 | 삼성전자주식회사 | System on chip, operation method thereof, and devices having the same |
US9699263B1 (en) | 2012-08-17 | 2017-07-04 | Sandisk Technologies Llc. | Automatic read and write acceleration of data accessed by virtual machines |
CN107977573B (en) | 2012-10-19 | 2021-10-01 | 迈克菲有限公司 | Method and system for secure disk access control |
US9881161B2 (en) | 2012-12-06 | 2018-01-30 | S-Printing Solution Co., Ltd. | System on chip to perform a secure boot, an image forming apparatus using the same, and method thereof |
US9501398B2 (en) | 2012-12-26 | 2016-11-22 | Sandisk Technologies Llc | Persistent storage device with NVRAM for staging writes |
US9612948B2 (en) | 2012-12-27 | 2017-04-04 | Sandisk Technologies Llc | Reads and writes between a contiguous data block and noncontiguous sets of logical address blocks in a persistent storage device |
US9239751B1 (en) | 2012-12-27 | 2016-01-19 | Sandisk Enterprise Ip Llc | Compressing data from multiple reads for error control management in memory systems |
US9003264B1 (en) | 2012-12-31 | 2015-04-07 | Sandisk Enterprise Ip Llc | Systems, methods, and devices for multi-dimensional flash RAID data protection |
US9454420B1 (en) | 2012-12-31 | 2016-09-27 | Sandisk Technologies Llc | Method and system of reading threshold voltage equalization |
US20140237263A1 (en) * | 2013-02-19 | 2014-08-21 | Kabushiki Kaisha Toshiba | Nonvolatile semiconductor memory device and memory system using the same |
US9329928B2 (en) | 2013-02-20 | 2016-05-03 | Sandisk Enterprise IP LLC. | Bandwidth optimization in a non-volatile memory system |
US9214965B2 (en) | 2013-02-20 | 2015-12-15 | Sandisk Enterprise Ip Llc | Method and system for improving data integrity in non-volatile storage |
US9223982B2 (en) * | 2013-03-01 | 2015-12-29 | Intel Corporation | Continuation of trust for platform boot firmware |
US9870830B1 (en) | 2013-03-14 | 2018-01-16 | Sandisk Technologies Llc | Optimal multilevel sensing for reading data from a storage medium |
US9136877B1 (en) | 2013-03-15 | 2015-09-15 | Sandisk Enterprise Ip Llc | Syndrome layered decoding for LDPC codes |
US9244763B1 (en) | 2013-03-15 | 2016-01-26 | Sandisk Enterprise Ip Llc | System and method for updating a reading threshold voltage based on symbol transition information |
US9092350B1 (en) | 2013-03-15 | 2015-07-28 | Sandisk Enterprise Ip Llc | Detection and handling of unbalanced errors in interleaved codewords |
US9236886B1 (en) | 2013-03-15 | 2016-01-12 | Sandisk Enterprise Ip Llc | Universal and reconfigurable QC-LDPC encoder |
US9367246B2 (en) | 2013-03-15 | 2016-06-14 | Sandisk Technologies Inc. | Performance optimization of data transfer for soft information generation |
US9009576B1 (en) | 2013-03-15 | 2015-04-14 | Sandisk Enterprise Ip Llc | Adaptive LLR based on syndrome weight |
US10049037B2 (en) | 2013-04-05 | 2018-08-14 | Sandisk Enterprise Ip Llc | Data management in a storage system |
US9170941B2 (en) | 2013-04-05 | 2015-10-27 | Sandisk Enterprises IP LLC | Data hardening in a storage system |
US9116774B2 (en) * | 2013-05-14 | 2015-08-25 | Sandisk Technologies Inc. | Firmware updates for multiple product configurations |
US9159437B2 (en) | 2013-06-11 | 2015-10-13 | Sandisk Enterprise IP LLC. | Device and method for resolving an LM flag issue |
US9043517B1 (en) | 2013-07-25 | 2015-05-26 | Sandisk Enterprise Ip Llc | Multipass programming in buffers implemented in non-volatile data storage systems |
US9384126B1 (en) | 2013-07-25 | 2016-07-05 | Sandisk Technologies Inc. | Methods and systems to avoid false negative results in bloom filters implemented in non-volatile data storage systems |
US9524235B1 (en) | 2013-07-25 | 2016-12-20 | Sandisk Technologies Llc | Local hash value generation in non-volatile data storage systems |
US9639463B1 (en) | 2013-08-26 | 2017-05-02 | Sandisk Technologies Llc | Heuristic aware garbage collection scheme in storage systems |
US9235509B1 (en) | 2013-08-26 | 2016-01-12 | Sandisk Enterprise Ip Llc | Write amplification reduction by delaying read access to data written during garbage collection |
US9442670B2 (en) | 2013-09-03 | 2016-09-13 | Sandisk Technologies Llc | Method and system for rebalancing data stored in flash memory devices |
US9519577B2 (en) | 2013-09-03 | 2016-12-13 | Sandisk Technologies Llc | Method and system for migrating data between flash memory devices |
KR20150033895A (en) | 2013-09-25 | 2015-04-02 | 삼성전자주식회사 | crum chip mauntable in comsumable unit, image forming apparatus for authentificating the crum chip, and method thereof |
US9158349B2 (en) | 2013-10-04 | 2015-10-13 | Sandisk Enterprise Ip Llc | System and method for heat dissipation |
US9323637B2 (en) | 2013-10-07 | 2016-04-26 | Sandisk Enterprise Ip Llc | Power sequencing and data hardening architecture |
US9442662B2 (en) | 2013-10-18 | 2016-09-13 | Sandisk Technologies Llc | Device and method for managing die groups |
US9298608B2 (en) | 2013-10-18 | 2016-03-29 | Sandisk Enterprise Ip Llc | Biasing for wear leveling in storage systems |
US9436831B2 (en) | 2013-10-30 | 2016-09-06 | Sandisk Technologies Llc | Secure erase in a memory device |
US9263156B2 (en) | 2013-11-07 | 2016-02-16 | Sandisk Enterprise Ip Llc | System and method for adjusting trip points within a storage device |
US9244785B2 (en) | 2013-11-13 | 2016-01-26 | Sandisk Enterprise Ip Llc | Simulated power failure and data hardening |
US9152555B2 (en) | 2013-11-15 | 2015-10-06 | Sandisk Enterprise IP LLC. | Data management with modular erase in a data storage system |
US9703816B2 (en) | 2013-11-19 | 2017-07-11 | Sandisk Technologies Llc | Method and system for forward reference logging in a persistent datastore |
US9520197B2 (en) | 2013-11-22 | 2016-12-13 | Sandisk Technologies Llc | Adaptive erase of a storage device |
US9141291B2 (en) | 2013-11-26 | 2015-09-22 | Sandisk Technologies Inc. | Adaptive context disbursement for improved performance in non-volatile memory systems |
US9122636B2 (en) | 2013-11-27 | 2015-09-01 | Sandisk Enterprise Ip Llc | Hard power fail architecture |
US9520162B2 (en) | 2013-11-27 | 2016-12-13 | Sandisk Technologies Llc | DIMM device controller supervisor |
US9280429B2 (en) | 2013-11-27 | 2016-03-08 | Sandisk Enterprise Ip Llc | Power fail latching based on monitoring multiple power supply voltages in a storage device |
US9582058B2 (en) | 2013-11-29 | 2017-02-28 | Sandisk Technologies Llc | Power inrush management of storage devices |
US9250676B2 (en) | 2013-11-29 | 2016-02-02 | Sandisk Enterprise Ip Llc | Power failure architecture and verification |
US9092370B2 (en) | 2013-12-03 | 2015-07-28 | Sandisk Enterprise Ip Llc | Power failure tolerant cryptographic erase |
US9235245B2 (en) | 2013-12-04 | 2016-01-12 | Sandisk Enterprise Ip Llc | Startup performance and power isolation |
US20150169901A1 (en) * | 2013-12-12 | 2015-06-18 | Sandisk Technologies Inc. | Method and Systems for Integrity Checking a Set of Signed Data Sections |
US9129665B2 (en) | 2013-12-17 | 2015-09-08 | Sandisk Enterprise Ip Llc | Dynamic brownout adjustment in a storage device |
US9549457B2 (en) | 2014-02-12 | 2017-01-17 | Sandisk Technologies Llc | System and method for redirecting airflow across an electronic assembly |
US9497889B2 (en) | 2014-02-27 | 2016-11-15 | Sandisk Technologies Llc | Heat dissipation for substrate assemblies |
US9703636B2 (en) | 2014-03-01 | 2017-07-11 | Sandisk Technologies Llc | Firmware reversion trigger and control |
US9519319B2 (en) | 2014-03-14 | 2016-12-13 | Sandisk Technologies Llc | Self-supporting thermal tube structure for electronic assemblies |
US9348377B2 (en) | 2014-03-14 | 2016-05-24 | Sandisk Enterprise Ip Llc | Thermal isolation techniques |
US9485851B2 (en) | 2014-03-14 | 2016-11-01 | Sandisk Technologies Llc | Thermal tube assembly structures |
US9390814B2 (en) | 2014-03-19 | 2016-07-12 | Sandisk Technologies Llc | Fault detection and prediction for data storage elements |
US9454448B2 (en) | 2014-03-19 | 2016-09-27 | Sandisk Technologies Llc | Fault testing in storage devices |
US9448876B2 (en) | 2014-03-19 | 2016-09-20 | Sandisk Technologies Llc | Fault detection and prediction in storage devices |
US9626400B2 (en) | 2014-03-31 | 2017-04-18 | Sandisk Technologies Llc | Compaction of information in tiered data structure |
US9626399B2 (en) | 2014-03-31 | 2017-04-18 | Sandisk Technologies Llc | Conditional updates for reducing frequency of data modification operations |
US9390021B2 (en) | 2014-03-31 | 2016-07-12 | Sandisk Technologies Llc | Efficient cache utilization in a tiered data structure |
US9697267B2 (en) | 2014-04-03 | 2017-07-04 | Sandisk Technologies Llc | Methods and systems for performing efficient snapshots in tiered data structures |
US11030122B2 (en) * | 2014-04-08 | 2021-06-08 | Micron Technology, Inc. | Apparatuses and methods for securing an access protection scheme |
TWI730941B (en) * | 2014-04-09 | 2021-06-21 | 南韓商Ictk控股有限公司 | Apparatus and method for authenticating |
US9384128B2 (en) | 2014-04-18 | 2016-07-05 | SanDisk Technologies, Inc. | Multi-level redundancy code for non-volatile memory controller |
US9093160B1 (en) | 2014-05-30 | 2015-07-28 | Sandisk Technologies Inc. | Methods and systems for staggered memory operations |
US10162748B2 (en) | 2014-05-30 | 2018-12-25 | Sandisk Technologies Llc | Prioritizing garbage collection and block allocation based on I/O history for logical address regions |
US9070481B1 (en) | 2014-05-30 | 2015-06-30 | Sandisk Technologies Inc. | Internal current measurement for age measurements |
US9645749B2 (en) | 2014-05-30 | 2017-05-09 | Sandisk Technologies Llc | Method and system for recharacterizing the storage density of a memory device or a portion thereof |
US9703491B2 (en) | 2014-05-30 | 2017-07-11 | Sandisk Technologies Llc | Using history of unaligned writes to cache data and avoid read-modify-writes in a non-volatile storage device |
US10372613B2 (en) | 2014-05-30 | 2019-08-06 | Sandisk Technologies Llc | Using sub-region I/O history to cache repeatedly accessed sub-regions in a non-volatile storage device |
US10656842B2 (en) | 2014-05-30 | 2020-05-19 | Sandisk Technologies Llc | Using history of I/O sizes and I/O sequences to trigger coalesced writes in a non-volatile storage device |
US10656840B2 (en) | 2014-05-30 | 2020-05-19 | Sandisk Technologies Llc | Real-time I/O pattern recognition to enhance performance and endurance of a storage device |
US10114557B2 (en) | 2014-05-30 | 2018-10-30 | Sandisk Technologies Llc | Identification of hot regions to enhance performance and endurance of a non-volatile storage device |
US10146448B2 (en) | 2014-05-30 | 2018-12-04 | Sandisk Technologies Llc | Using history of I/O sequences to trigger cached read ahead in a non-volatile storage device |
US8891303B1 (en) | 2014-05-30 | 2014-11-18 | Sandisk Technologies Inc. | Method and system for dynamic word line based configuration of a three-dimensional memory device |
US9652381B2 (en) | 2014-06-19 | 2017-05-16 | Sandisk Technologies Llc | Sub-block garbage collection |
TW201604778A (en) * | 2014-07-29 | 2016-02-01 | Acaia Corp | Firmware updating method of Bluetooth electronic scale |
US9678760B2 (en) | 2014-08-01 | 2017-06-13 | Samsung Electronics Co., Ltd. | Memory card and storage system having authentication program and method for operating thereof |
KR102218202B1 (en) | 2014-08-01 | 2021-02-23 | 삼성전자주식회사 | Semiconductor device |
US9443601B2 (en) | 2014-09-08 | 2016-09-13 | Sandisk Technologies Llc | Holdup capacitor energy harvesting |
US10387652B2 (en) * | 2015-04-17 | 2019-08-20 | Hewlett Packard Enterprise Development Lp | Firmware map data |
TWI607912B (en) * | 2016-10-14 | 2017-12-11 | 光陽工業股份有限公司 | Program updating method and system of vehicle |
JP6785205B2 (en) | 2017-09-21 | 2020-11-18 | キオクシア株式会社 | Memory system and control method |
JP2019079464A (en) | 2017-10-27 | 2019-05-23 | 東芝メモリ株式会社 | Memory system and control method |
JP6982468B2 (en) | 2017-10-27 | 2021-12-17 | キオクシア株式会社 | Memory system and control method |
US11537389B2 (en) | 2017-12-12 | 2022-12-27 | Infineon Technologies LLC | Memory devices, systems, and methods for updating firmware with single memory device |
US10552145B2 (en) * | 2017-12-12 | 2020-02-04 | Cypress Semiconductor Corporation | Memory devices, systems, and methods for updating firmware with single memory device |
US10715321B2 (en) | 2017-12-22 | 2020-07-14 | Micron Technology, Inc. | Physical unclonable function using message authentication code |
US10906506B2 (en) | 2017-12-28 | 2021-02-02 | Micron Technology, Inc. | Security of user data stored in shared vehicles |
US10924277B2 (en) * | 2018-01-25 | 2021-02-16 | Micron Technology, Inc. | Certifying authenticity of stored code and code updates |
EP3769253A4 (en) * | 2018-03-23 | 2021-12-01 | Micron Technology, INC. | AUTHENTICATION MODIFICATION OF A STORAGE DEVICE |
US10778661B2 (en) | 2018-04-27 | 2020-09-15 | Micron Technology, Inc. | Secure distribution of secret key using a monotonic counter |
CN109446815B (en) * | 2018-09-30 | 2020-12-25 | 华为技术有限公司 | Management method and device for basic input/output system firmware and server |
US10809925B2 (en) | 2019-01-28 | 2020-10-20 | Macronix International Co., Ltd. | Configurable security memory region |
TWI760884B (en) * | 2020-07-16 | 2022-04-11 | 慧榮科技股份有限公司 | Method and apparatus for data reads in host performance acceleration mode |
US11544186B2 (en) | 2020-07-16 | 2023-01-03 | Silicon Motion, Inc. | Method and apparatus for data reads in host performance acceleration mode |
US11544185B2 (en) | 2020-07-16 | 2023-01-03 | Silicon Motion, Inc. | Method and apparatus for data reads in host performance acceleration mode |
US11429545B2 (en) | 2020-07-16 | 2022-08-30 | Silicon Motion, Inc. | Method and apparatus for data reads in host performance acceleration mode |
Citations (94)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4590552A (en) * | 1982-06-30 | 1986-05-20 | Texas Instruments Incorporated | Security bit for designating the security status of information stored in a nonvolatile memory |
US4797853A (en) * | 1985-11-15 | 1989-01-10 | Unisys Corporation | Direct memory access controller for improved system security, memory to memory transfers, and interrupt processing |
US4907268A (en) * | 1986-11-03 | 1990-03-06 | Enigma Logic, Inc. | Methods and apparatus for controlling access to information processed a multi-user-accessible digital computer |
US5006823A (en) * | 1988-10-28 | 1991-04-09 | Thomson-Csf | Microwave phase shifter with 0 or π phase shift |
US5129074A (en) * | 1988-09-22 | 1992-07-07 | Hitachi Vlsi Engineering Corporation | Data string storage device and method of storing and retrieving data strings |
US5293424A (en) * | 1992-10-14 | 1994-03-08 | Bull Hn Information Systems Inc. | Secure memory card |
US5319765A (en) * | 1990-11-29 | 1994-06-07 | Mitsubishi Denki Kabushiki Kaisha | Semiconductor memory unit utilizing a security code generator for selectively inhibiting memory access |
US5327563A (en) * | 1992-11-13 | 1994-07-05 | Hewlett-Packard | Method for locking software files to a specific storage device |
US5404485A (en) * | 1993-03-08 | 1995-04-04 | M-Systems Flash Disk Pioneers Ltd. | Flash file system |
US5422460A (en) * | 1991-07-19 | 1995-06-06 | Whirlpool Europe B.V. | Glass ceramic cooking hob with a reflecting surface arranged in a position corresponding with a light and/or heat generator, in particular a halogen lamp cooled by air circulation |
US5530862A (en) * | 1992-11-18 | 1996-06-25 | Canon Kabushiki Kaisha | In an interactive network board, method and apparatus for loading independently executable modules in prom |
US5596738A (en) * | 1992-01-31 | 1997-01-21 | Teac Corporation | Peripheral device control system using changeable firmware in a single flash memory |
US5606660A (en) * | 1994-10-21 | 1997-02-25 | Lexar Microsystems, Inc. | Method and apparatus for combining controller firmware storage and controller logic in a mass storage system |
US5629513A (en) * | 1994-03-04 | 1997-05-13 | Gemplus Card International | Method for the functioning of a chip card, and chip card in accordance therewith |
US5710639A (en) * | 1996-01-25 | 1998-01-20 | Kuznicki; William Joseph | Scan line compressed facsimile communication system |
US5857020A (en) * | 1995-12-04 | 1999-01-05 | Northern Telecom Ltd. | Timed availability of secured content provisioned on a storage medium |
US5860082A (en) * | 1996-03-28 | 1999-01-12 | Datalight, Inc. | Method and apparatus for allocating storage in a flash memory |
USRE36181E (en) * | 1993-06-30 | 1999-04-06 | United Technologies Automotive, Inc. | Pseudorandom number generation and crytographic authentication |
US5917909A (en) * | 1992-12-23 | 1999-06-29 | Gao Gesellschaft Fur Automation Und Organisation Mbh | System for testing the authenticity of a data carrier |
US6026402A (en) * | 1998-01-07 | 2000-02-15 | Hewlett-Packard Company | Process restriction within file system hierarchies |
US6028933A (en) * | 1997-04-17 | 2000-02-22 | Lucent Technologies Inc. | Encrypting method and apparatus enabling multiple access for multiple services and multiple transmission modes over a broadband communication network |
US6073234A (en) * | 1997-05-07 | 2000-06-06 | Fuji Xerox Co., Ltd. | Device for authenticating user's access rights to resources and method |
US6181252B1 (en) * | 1996-08-23 | 2001-01-30 | Denso Corporation | Remote control system and method having a system-specific code |
US6230223B1 (en) * | 1998-06-01 | 2001-05-08 | Compaq Computer Corporation | Dual purpose apparatus method and system for accelerated graphics or second memory interface |
US6230233B1 (en) * | 1991-09-13 | 2001-05-08 | Sandisk Corporation | Wear leveling techniques for flash EEPROM systems |
US6243816B1 (en) * | 1998-04-30 | 2001-06-05 | International Business Machines Corporation | Single sign-on (SSO) mechanism personal key manager |
US6253328B1 (en) * | 1998-02-12 | 2001-06-26 | A. James Smith, Jr. | Method and apparatus for securing passwords and personal identification numbers |
US6353888B1 (en) * | 1997-07-07 | 2002-03-05 | Fuji Xerox Co., Ltd. | Access rights authentication apparatus |
US20020029343A1 (en) * | 2000-09-05 | 2002-03-07 | Fujitsu Limited | Smart card access management system, sharing method, and storage medium |
US6356941B1 (en) * | 1999-02-22 | 2002-03-12 | Cyber-Ark Software Ltd. | Network vaults |
US20020034303A1 (en) * | 2000-01-21 | 2002-03-21 | The Chamberlain Group, Inc. | Rolling code security system |
US6370251B1 (en) * | 1998-06-08 | 2002-04-09 | General Dynamics Decision Systems, Inc. | Traffic key access method and terminal for secure communication without key escrow facility |
US6371377B2 (en) * | 1997-12-10 | 2002-04-16 | Fujitsu Limited | Card type recording medium and access control method for card type recording medium and computer-readable recording medium having access control program for card type recording medium recorded |
US6385729B1 (en) * | 1998-05-26 | 2002-05-07 | Sun Microsystems, Inc. | Secure token device access to services provided by an internet service provider (ISP) |
US6389542B1 (en) * | 1999-10-27 | 2002-05-14 | Terence T. Flyntz | Multi-level secure computer with token-based access control |
US6393565B1 (en) * | 1998-08-03 | 2002-05-21 | Entrust Technologies Limited | Data management system and method for a limited capacity cryptographic storage unit |
US20020065730A1 (en) * | 2000-11-30 | 2002-05-30 | Naoaki Nii | Method of and a system for distributing electronic content |
US20020099666A1 (en) * | 2000-11-22 | 2002-07-25 | Dryer Joseph E. | System for maintaining the security of client files |
US20030018889A1 (en) * | 2001-07-20 | 2003-01-23 | Burnett Keith L. | Automated establishment of addressability of a network device for a target network enviroment |
US20030028514A1 (en) * | 2001-06-05 | 2003-02-06 | Lord Stephen Philip | Extended attribute caching in clustered filesystem |
US20030028797A1 (en) * | 1999-01-15 | 2003-02-06 | Rainbow Technologies, Inc. | Integrated USB connector for personal token |
US6522655B1 (en) * | 1998-05-12 | 2003-02-18 | Telefonaktiebolaget Lm Ericsson (Publ) | Method and apparatus in a telecommunications system |
US20030061504A1 (en) * | 2001-08-13 | 2003-03-27 | Sprigg Stephen A. | Application level access privilege to a storage area on a computer device |
US20030070083A1 (en) * | 2001-09-28 | 2003-04-10 | Kai-Wilhelm Nessler | Method and device for encryption/decryption of data on mass storage device |
US6571335B1 (en) * | 1999-04-01 | 2003-05-27 | Intel Corporation | System and method for authentication of off-chip processor firmware code |
US20030101327A1 (en) * | 2001-11-16 | 2003-05-29 | Samsung Electronics Co., Ltd. | Flash memory management method |
US6577734B1 (en) * | 1995-10-31 | 2003-06-10 | Lucent Technologies Inc. | Data encryption key management system |
US20030110169A1 (en) * | 2001-12-12 | 2003-06-12 | Secretseal Inc. | System and method for providing manageability to security information for secured items |
US20030120938A1 (en) * | 2001-11-27 | 2003-06-26 | Miki Mullor | Method of securing software against reverse engineering |
US6678828B1 (en) * | 2002-07-22 | 2004-01-13 | Vormetric, Inc. | Secure network file access control system |
US20040024917A1 (en) * | 2002-07-31 | 2004-02-05 | Barry Kennedy | Secure method to perform computer system firmware updates |
US20040025010A1 (en) * | 2002-07-30 | 2004-02-05 | Texas Instruments Incorporated | Computing platform certificate |
US20040025027A1 (en) * | 2002-07-30 | 2004-02-05 | Eric Balard | Secure protection method for access to protected resources in a processor |
US20040020511A1 (en) * | 2001-11-30 | 2004-02-05 | Sandhu Gurtej S. | Method of providing high flux of point of use activated reactive species for semiconductor processing |
US20040044625A1 (en) * | 2002-06-10 | 2004-03-04 | Ken Sakamura | Digital contents issuing system and digital contents issuing method |
US20040059916A1 (en) * | 2002-09-11 | 2004-03-25 | Nagamasa Mizushima | Memory card |
US20040063495A1 (en) * | 2002-09-30 | 2004-04-01 | Lemay Steven G. | EPROM file system in a gaming apparatus |
US20040066936A1 (en) * | 1995-05-17 | 2004-04-08 | The Chamberlain Group, Ltd. | Rolling code security system |
US20040083335A1 (en) * | 2002-10-28 | 2004-04-29 | Gonzalez Carlos J. | Automated wear leveling in non-volatile storage systems |
US20040083370A1 (en) * | 2002-09-13 | 2004-04-29 | Sun Microsystems, Inc., A Delaware Corporation | Rights maintenance in a rights locker system for digital content access control |
US20040093592A1 (en) * | 2002-11-13 | 2004-05-13 | Rao Bindu Rama | Firmware update in electronic devices employing SIM card for saving metadata information |
US20040098585A1 (en) * | 2002-11-05 | 2004-05-20 | Rainbow Technologies, Inc. | Secure authentication using hardware token and computer fingerprint |
US6742117B1 (en) * | 1997-01-30 | 2004-05-25 | Rohm Co., Ltd. | IC card and method of using IC card |
US20040103288A1 (en) * | 2002-11-27 | 2004-05-27 | M-Systems Flash Disk Pioneers Ltd. | Apparatus and method for securing data on a portable storage device |
US20040117653A1 (en) * | 2001-07-10 | 2004-06-17 | Packet Technologies Ltd. | Virtual private network mechanism incorporating security association processor |
US6754765B1 (en) * | 2001-05-14 | 2004-06-22 | Integrated Memory Logic, Inc. | Flash memory controller with updateable microcode |
US20040123127A1 (en) * | 2002-12-18 | 2004-06-24 | M-Systems Flash Disk Pioneers, Ltd. | System and method for securing portable data |
US20050010783A1 (en) * | 1995-10-24 | 2005-01-13 | Phil Libin | Access control |
US20050010758A1 (en) * | 2001-08-10 | 2005-01-13 | Peter Landrock | Data certification method and apparatus |
US20050015588A1 (en) * | 2003-07-17 | 2005-01-20 | Paul Lin | Token device that generates and displays one-time passwords and that couples to a computer for inputting or receiving data for generating and outputting one-time passwords and other functions |
US6845908B2 (en) * | 2002-03-18 | 2005-01-25 | Hitachi Semiconductor (America) Inc. | Storage card with integral file system, access control and cryptographic support |
US20050033968A1 (en) * | 2003-08-08 | 2005-02-10 | Metapass, Inc. | Secure digital key for automatic login |
US20050049931A1 (en) * | 2003-08-29 | 2005-03-03 | Wisnudel Marc Brian | Digital content kiosk and associated methods for delivering selected digital content to a user |
US20050050330A1 (en) * | 2003-08-27 | 2005-03-03 | Leedor Agam | Security token |
US6865555B2 (en) * | 2001-11-21 | 2005-03-08 | Digeo, Inc. | System and method for providing conditional access to digital content |
US20050055530A1 (en) * | 2003-09-08 | 2005-03-10 | Yuan-Ting Wu | Method and apparatus for protecting a specific memory section |
US6880079B2 (en) * | 2002-04-25 | 2005-04-12 | Vasco Data Security, Inc. | Methods and systems for secure transmission of information using a mobile device |
US20050091496A1 (en) * | 2003-10-23 | 2005-04-28 | Hyser Chris D. | Method and system for distributed key management in a secure boot environment |
US6892304B1 (en) * | 1997-10-09 | 2005-05-10 | Phoenix Technologies Ltd. | System and method for securely utilizing basic input and output system (BIOS) services |
US20050114620A1 (en) * | 2003-11-21 | 2005-05-26 | Justen Jordan L. | Using paging to initialize system memory |
US6901499B2 (en) * | 2002-02-27 | 2005-05-31 | Microsoft Corp. | System and method for tracking data stored in a flash memory device |
US6901449B1 (en) * | 2000-12-22 | 2005-05-31 | Microsoft Corporation | System and method for encapsulating data with a formatted data protocol |
US20050120205A1 (en) * | 2003-12-02 | 2005-06-02 | Hitachi, Ltd. | Certificate management system and method |
US20050137997A1 (en) * | 2003-12-11 | 2005-06-23 | Siemens Aktiengesellschaft | Method for updating an automation system |
US7036020B2 (en) * | 2001-07-25 | 2006-04-25 | Antique Books, Inc | Methods and systems for promoting security in a computer system employing attached storage devices |
US7058618B2 (en) * | 2001-04-04 | 2006-06-06 | Bayer Aktiengesellschaft | Method for establishing stress/strain curves by means of spline interpolation on the basis of characteristic points and with the use of neural networks |
US7062616B2 (en) * | 2001-06-12 | 2006-06-13 | Intel Corporation | Implementing a dual partition flash with suspend/resume capabilities |
US20070011724A1 (en) * | 2005-07-08 | 2007-01-11 | Gonzalez Carlos J | Mass storage device with automated credentials loading |
US20070061897A1 (en) * | 2005-09-14 | 2007-03-15 | Michael Holtzman | Hardware driver integrity check of memory card controller firmware |
US20070061597A1 (en) * | 2005-09-14 | 2007-03-15 | Micky Holtzman | Secure yet flexible system architecture for secure devices with flash mass storage memory |
US7215771B1 (en) * | 2000-06-30 | 2007-05-08 | Western Digital Ventures, Inc. | Secure disk drive comprising a secure drive key and a drive ID for implementing secure communication over a public network |
US7380275B2 (en) * | 2003-02-07 | 2008-05-27 | Broadon Communications Corp. | Secure and backward-compatible processor and secure software execution thereon |
US7493656B2 (en) * | 2005-06-02 | 2009-02-17 | Seagate Technology Llc | Drive security session manager |
US7657886B1 (en) * | 2004-06-03 | 2010-02-02 | Hewlett-Packard Development Company, L.P. | Mobile device with a MMU for faster firmware updates in a wireless network |
Family Cites Families (104)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CA1198826A (en) | 1982-02-19 | 1985-12-31 | Roger E. Billings | Distributed data processing system |
US4549896A (en) | 1984-08-27 | 1985-10-29 | Owens-Corning Fiberglas Corporation | Apparatus and method for removing gaseous inclusions from molten material |
US4780905A (en) | 1984-11-26 | 1988-10-25 | Nightwatch, Inc. | Computer data encryption system |
US4713753A (en) | 1985-02-21 | 1987-12-15 | Honeywell Inc. | Secure data processing system architecture with format control |
FR2663141B1 (en) | 1990-06-11 | 1992-08-21 | France Etat | METHOD FOR TRANSFERRING SECRECY, BY EXCHANGING TWO CERTIFICATES BETWEEN TWO RECIPROCALLY AUTHENTICATING MICROCULCATORS. |
US5268870A (en) | 1988-06-08 | 1993-12-07 | Eliyahou Harari | Flash EEPROM system and intelligent programming and erasing methods therefor |
US5065429A (en) | 1989-04-03 | 1991-11-12 | Lang Gerald S | Method and apparatus for protecting material on storage media |
DK279089D0 (en) * | 1989-06-07 | 1989-06-07 | Kommunedata I S | PROCEDURE FOR TRANSFER OF DATA, AN ELECTRONIC DOCUMENT OR SIMILAR, SYSTEM FOR EXERCISING THE PROCEDURE AND A CARD FOR USE IN EXERCISING THE PROCEDURE |
JP3143108B2 (en) * | 1990-03-13 | 2001-03-07 | 株式会社日立製作所 | File encryption method and file encryption system |
FR2667715A1 (en) | 1990-10-09 | 1992-04-10 | Gemplus Card Int | METHOD AND DEVICE FOR INCREASING THE PROTECTION OF A MEMORY CARD. |
US5438575A (en) * | 1992-11-16 | 1995-08-01 | Ampex Corporation | Data storage system with stale data detector and method of operation |
FR2698195B1 (en) | 1992-11-19 | 1994-12-16 | Gemplus Card Int | Encryption and authentication method and circuit for synchronous memory card. |
US5455862A (en) | 1993-12-02 | 1995-10-03 | Crest Industries, Inc. | Apparatus and method for encrypting communications without exchanging an encryption key |
US5442704A (en) * | 1994-01-14 | 1995-08-15 | Bull Nh Information Systems Inc. | Secure memory card with programmed controlled security access control |
AU710682B2 (en) | 1995-05-17 | 1999-09-30 | Chamberlain Group, Inc., The | Rolling code security system |
JPH08328962A (en) * | 1995-05-31 | 1996-12-13 | Mitsubishi Electric Corp | System composed of terminal equipment and memory card connected to the same |
US5943423A (en) | 1995-12-15 | 1999-08-24 | Entegrity Solutions Corporation | Smart token system for secure electronic transactions and identification |
JP3747520B2 (en) * | 1996-01-30 | 2006-02-22 | 富士ゼロックス株式会社 | Information processing apparatus and information processing method |
US5987134A (en) | 1996-02-23 | 1999-11-16 | Fuji Xerox Co., Ltd. | Device and method for authenticating user's access rights to resources |
US6006333A (en) | 1996-03-13 | 1999-12-21 | Sun Microsystems, Inc. | Password helper using a client-side master password which automatically presents the appropriate server-side password to a particular remote server |
US5995965A (en) | 1996-11-18 | 1999-11-30 | Humetrix, Inc. | System and method for remotely accessing user data records |
US6708274B2 (en) | 1998-04-30 | 2004-03-16 | Intel Corporation | Cryptographically protected paging subsystem |
GB9626241D0 (en) * | 1996-12-18 | 1997-02-05 | Ncr Int Inc | Secure data processing method and system |
US5956405A (en) | 1997-01-17 | 1999-09-21 | Microsoft Corporation | Implementation efficient encryption and message authentication |
EP1004992A3 (en) | 1997-03-24 | 2001-12-05 | Visa International Service Association | A system and method for a multi-application smart card which can facilitate a post-issuance download of an application onto the smart card |
JPH113284A (en) | 1997-06-10 | 1999-01-06 | Mitsubishi Electric Corp | Information storage medium and its security method |
JP3671611B2 (en) | 1997-08-05 | 2005-07-13 | 富士ゼロックス株式会社 | Access credential authentication apparatus and method |
US6101588A (en) * | 1997-09-25 | 2000-08-08 | Emc Corporation | Device level busy arrangement for mass storage subsystem including a plurality of devices |
JPH11161552A (en) | 1997-11-28 | 1999-06-18 | Fujitsu Ltd | Data protection method for exchangeable storage medium and storage device to which the method is applied |
KR100397316B1 (en) | 1998-01-21 | 2003-09-06 | 비.유.지., 인크. | Storage device, encrypting/decrypting device, and method for accessing nonvolatile memory |
US6445794B1 (en) | 1998-06-24 | 2002-09-03 | Benyamin Ron | System and method for synchronizing one time pad encryption keys for secure communication and access control |
US6615347B1 (en) | 1998-06-30 | 2003-09-02 | Verisign, Inc. | Digital certificate cross-referencing |
US6928547B2 (en) | 1998-07-06 | 2005-08-09 | Saflink Corporation | System and method for authenticating users in a computer network |
JP2000069541A (en) * | 1998-08-26 | 2000-03-03 | Mitsubishi Electric Corp | Mobile communication system |
EP0992809A1 (en) | 1998-09-28 | 2000-04-12 | Siemens Aktiengesellschaft | Circuit with deactivatable scan path |
CN1262485A (en) * | 1998-11-10 | 2000-08-09 | 阿拉丁知识系统有限公司 | User-computer interactive method for group capable of flexible connecting of computer system |
US6434700B1 (en) | 1998-12-22 | 2002-08-13 | Cisco Technology, Inc. | Authentication and authorization mechanisms for Fortezza passwords |
US6671808B1 (en) | 1999-01-15 | 2003-12-30 | Rainbow Technologies, Inc. | USB-compliant personal key |
US20030135739A1 (en) * | 1999-01-25 | 2003-07-17 | Talton David N. | System and method for authentication |
US6422460B1 (en) | 1999-01-29 | 2002-07-23 | Verisign, Inc. | Authorization system using an authorizing device |
US6148354A (en) | 1999-04-05 | 2000-11-14 | M-Systems Flash Disk Pioneers Ltd. | Architecture for a universal serial bus-based PC flash disk |
US7318117B2 (en) * | 2004-02-26 | 2008-01-08 | Super Talent Electronics, Inc. | Managing flash memory including recycling obsolete sectors |
JP4423711B2 (en) | 1999-08-05 | 2010-03-03 | ソニー株式会社 | Semiconductor memory device and semiconductor memory device operation setting method |
CN1248143C (en) | 1999-08-10 | 2006-03-29 | 富士通株式会社 | Memory card |
US6804786B1 (en) | 1999-09-10 | 2004-10-12 | Canon Kabushiki Kaisha | User customizable secure access token and multiple level portable interface |
US6611907B1 (en) | 1999-10-21 | 2003-08-26 | Matsushita Electric Industrial Co., Ltd. | Semiconductor memory card access apparatus, a computer-readable recording medium, an initialization method, and a semiconductor memory card |
US20020178370A1 (en) | 1999-12-30 | 2002-11-28 | Gurevich Michael N. | Method and apparatus for secure authentication and sensitive data management |
US6629192B1 (en) | 1999-12-30 | 2003-09-30 | Intel Corporation | Method and apparatus for use of a non-volatile storage management system for PC/AT compatible system firmware |
US20010037435A1 (en) * | 2000-05-31 | 2001-11-01 | Van Doren Stephen R. | Distributed address mapping and routing table mechanism that supports flexible configuration and partitioning in a modular switch-based, shared-memory multiprocessor computer system |
US7362868B2 (en) | 2000-10-20 | 2008-04-22 | Eruces, Inc. | Hidden link dynamic key manager for use in computer systems with database structure for storage of encrypted data and method for storage and retrieval of encrypted data |
US20020145632A1 (en) | 2000-10-27 | 2002-10-10 | Shimon Shmueli | Portable interface for computing |
EP2357651A3 (en) | 2000-12-07 | 2013-06-26 | SanDisk Technologies Inc. | System, method, and device for playing back recorded audio, video or other content from non-volatile memory cards, compact disks or other media |
US20040059952A1 (en) | 2000-12-14 | 2004-03-25 | Peter Newport | Authentication system |
JP3895940B2 (en) | 2001-03-27 | 2007-03-22 | 三洋電機株式会社 | Information terminal equipment |
US7526795B2 (en) | 2001-03-27 | 2009-04-28 | Micron Technology, Inc. | Data security for digital data storage |
JP2002329180A (en) | 2001-04-27 | 2002-11-15 | Toshiba Corp | Memory card having radio communication function and its data communication method |
US6591352B2 (en) | 2001-05-31 | 2003-07-08 | Intel Corporation | Method and apparatus for executing firmware from a valid startup block |
FI114416B (en) | 2001-06-15 | 2004-10-15 | Nokia Corp | Procedure for securing electronic device, fuse system and electronic device |
EP1273996B1 (en) | 2001-07-06 | 2008-08-06 | Texas Instruments Incorporated | Secure bootloader for securing digital devices |
DE10231598A1 (en) * | 2001-08-07 | 2003-02-20 | Heidelberger Druckmasch Ag | Product web remoistening apparatus e.g. for paper web, has applicator roller and heating element |
JP2003067208A (en) | 2001-08-23 | 2003-03-07 | Sony Corp | Information processing device and the method, recording medium and program |
GB0123422D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Improved memory controller |
GB0123416D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Non-volatile memory control |
TWI223204B (en) | 2001-11-08 | 2004-11-01 | Toshiba Corp | Memory card, content transmission system, and content transmission method |
DE10162306A1 (en) * | 2001-12-19 | 2003-07-03 | Philips Intellectual Property | Method and arrangement for verifying NV fuses as well as a corresponding computer program product and a corresponding computer-readable storage medium |
JP4139114B2 (en) * | 2002-02-04 | 2008-08-27 | 松下電器産業株式会社 | Digital content management apparatus and digital content management program |
US20030163633A1 (en) | 2002-02-27 | 2003-08-28 | Aasheim Jered Donald | System and method for achieving uniform wear levels in a flash memory device |
US6912633B2 (en) | 2002-03-18 | 2005-06-28 | Sun Microsystems, Inc. | Enhanced memory management for portable devices |
GB0210692D0 (en) | 2002-05-10 | 2002-06-19 | Assendon Ltd | Smart card token for remote authentication |
WO2003096287A1 (en) | 2002-05-10 | 2003-11-20 | Quizid Technologies Ltd. | An authentication token |
US8335915B2 (en) | 2002-05-14 | 2012-12-18 | Netapp, Inc. | Encryption based security system for network storage |
GB2391082B (en) | 2002-07-19 | 2005-08-03 | Ritech Internat Ltd | Portable data storage device with layered memory architecture |
CN101950343A (en) * | 2002-08-08 | 2011-01-19 | 晟碟以色列有限公司 | Digital rights management method and integrated circuit |
JP4129381B2 (en) * | 2002-09-25 | 2008-08-06 | 株式会社ルネサステクノロジ | Nonvolatile semiconductor memory device |
US20040139021A1 (en) * | 2002-10-07 | 2004-07-15 | Visa International Service Association | Method and system for facilitating data access and management on a secure token |
EP1554855A1 (en) | 2002-10-24 | 2005-07-20 | Matsushita Electric Industrial Co., Ltd. | System and method for pushing information from a service provider to a communication terminal comprising a memory card |
US6985992B1 (en) | 2002-10-28 | 2006-01-10 | Sandisk Corporation | Wear-leveling in non-volatile storage systems |
JP2004213216A (en) | 2002-12-27 | 2004-07-29 | Renesas Technology Corp | Information security microcomputer and its program developing device and program development system |
US7284136B2 (en) | 2003-01-23 | 2007-10-16 | Intel Corporation | Methods and apparatus for implementing a secure resume |
US20040168081A1 (en) | 2003-02-20 | 2004-08-26 | Microsoft Corporation | Apparatus and method simplifying an encrypted network |
JP4501349B2 (en) | 2003-03-13 | 2010-07-14 | ソニー株式会社 | System module execution device |
US6843423B2 (en) | 2003-03-13 | 2005-01-18 | Stmicroelectronics, Inc. | Smart card that can be configured for debugging and software development using secondary communication port |
JP4467246B2 (en) | 2003-03-13 | 2010-05-26 | パナソニック株式会社 | Memory card |
US8041878B2 (en) | 2003-03-19 | 2011-10-18 | Samsung Electronics Co., Ltd. | Flash file system |
US20040193925A1 (en) | 2003-03-26 | 2004-09-30 | Matnn Safriel | Portable password manager |
AU2003901454A0 (en) | 2003-03-28 | 2003-04-10 | Secure Systems Limited | Security system and method for computer operating systems |
US8041957B2 (en) | 2003-04-08 | 2011-10-18 | Qualcomm Incorporated | Associating software with hardware using cryptography |
JP4682498B2 (en) | 2003-04-09 | 2011-05-11 | ソニー株式会社 | Communication device and memory management method for communication device |
US6783078B1 (en) | 2003-05-09 | 2004-08-31 | Stmicroelectronics, Inc. | Universal serial bus (USB) smart card having read back testing features and related system, integrated circuit, and methods |
US20040230963A1 (en) * | 2003-05-12 | 2004-11-18 | Rothman Michael A. | Method for updating firmware in an operating system agnostic manner |
WO2004112036A1 (en) | 2003-06-11 | 2004-12-23 | Matsushita Electric Industrial Co., Ltd. | Reproduction apparatus, program, integrated circuit |
KR100548354B1 (en) | 2003-06-14 | 2006-02-02 | 엘지전자 주식회사 | User Authentication Method in Synchronization Protocol |
US6906961B2 (en) * | 2003-06-24 | 2005-06-14 | Micron Technology, Inc. | Erase block data splitting |
DE60324203D1 (en) * | 2003-06-27 | 2008-11-27 | Fujitsu Ltd | METHOD AND SYSTEM FOR DATA TRANSMISSION |
US7491122B2 (en) | 2003-07-09 | 2009-02-17 | Wms Gaming Inc. | Gaming machine having targeted run-time software authentication |
JP4890248B2 (en) | 2003-07-18 | 2012-03-07 | コアストリート、 リミテッド | Control access to a given area |
GB2404748B (en) | 2003-08-01 | 2006-10-04 | Symbian Ltd | Computing device and method |
US7594135B2 (en) | 2003-12-31 | 2009-09-22 | Sandisk Corporation | Flash memory system startup operation |
JP2005236442A (en) * | 2004-02-17 | 2005-09-02 | Sanyo Electric Co Ltd | Watermark padding device and method, and watermark extracting device and method |
US20060242151A1 (en) | 2004-12-21 | 2006-10-26 | Fabrice Jogand-Coulomb | Control structure for versatile content control |
US8108691B2 (en) | 2005-02-07 | 2012-01-31 | Sandisk Technologies Inc. | Methods used in a secure memory card with life cycle phases |
US8423788B2 (en) | 2005-02-07 | 2013-04-16 | Sandisk Technologies Inc. | Secure memory card with life cycle phases |
CN100456747C (en) * | 2006-08-02 | 2009-01-28 | 华为技术有限公司 | Method and network equipment for implementing inspection of reversal path of unicast |
DE102007052180A1 (en) | 2007-10-31 | 2009-05-07 | Fujitsu Siemens Computers Gmbh | Method, computer system and computer program product |
-
2005
- 2005-12-22 US US11/317,341 patent/US7934049B2/en not_active Expired - Fee Related
- 2005-12-22 US US11/317,339 patent/US20070061597A1/en not_active Abandoned
-
2006
- 2006-09-13 CN CN2006800338967A patent/CN101273363B/en not_active Expired - Fee Related
- 2006-09-14 TW TW095134078A patent/TW200731108A/en unknown
-
2008
- 2008-05-16 US US12/122,412 patent/US20080215847A1/en not_active Abandoned
Patent Citations (99)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4590552A (en) * | 1982-06-30 | 1986-05-20 | Texas Instruments Incorporated | Security bit for designating the security status of information stored in a nonvolatile memory |
US4797853A (en) * | 1985-11-15 | 1989-01-10 | Unisys Corporation | Direct memory access controller for improved system security, memory to memory transfers, and interrupt processing |
US4907268A (en) * | 1986-11-03 | 1990-03-06 | Enigma Logic, Inc. | Methods and apparatus for controlling access to information processed a multi-user-accessible digital computer |
US5129074A (en) * | 1988-09-22 | 1992-07-07 | Hitachi Vlsi Engineering Corporation | Data string storage device and method of storing and retrieving data strings |
US5006823A (en) * | 1988-10-28 | 1991-04-09 | Thomson-Csf | Microwave phase shifter with 0 or π phase shift |
US5319765A (en) * | 1990-11-29 | 1994-06-07 | Mitsubishi Denki Kabushiki Kaisha | Semiconductor memory unit utilizing a security code generator for selectively inhibiting memory access |
US5422460A (en) * | 1991-07-19 | 1995-06-06 | Whirlpool Europe B.V. | Glass ceramic cooking hob with a reflecting surface arranged in a position corresponding with a light and/or heat generator, in particular a halogen lamp cooled by air circulation |
US6230233B1 (en) * | 1991-09-13 | 2001-05-08 | Sandisk Corporation | Wear leveling techniques for flash EEPROM systems |
US5596738A (en) * | 1992-01-31 | 1997-01-21 | Teac Corporation | Peripheral device control system using changeable firmware in a single flash memory |
US5293424A (en) * | 1992-10-14 | 1994-03-08 | Bull Hn Information Systems Inc. | Secure memory card |
US5327563A (en) * | 1992-11-13 | 1994-07-05 | Hewlett-Packard | Method for locking software files to a specific storage device |
US5530862A (en) * | 1992-11-18 | 1996-06-25 | Canon Kabushiki Kaisha | In an interactive network board, method and apparatus for loading independently executable modules in prom |
US5917909A (en) * | 1992-12-23 | 1999-06-29 | Gao Gesellschaft Fur Automation Und Organisation Mbh | System for testing the authenticity of a data carrier |
US5404485A (en) * | 1993-03-08 | 1995-04-04 | M-Systems Flash Disk Pioneers Ltd. | Flash file system |
USRE36181E (en) * | 1993-06-30 | 1999-04-06 | United Technologies Automotive, Inc. | Pseudorandom number generation and crytographic authentication |
US5629513A (en) * | 1994-03-04 | 1997-05-13 | Gemplus Card International | Method for the functioning of a chip card, and chip card in accordance therewith |
US5606660A (en) * | 1994-10-21 | 1997-02-25 | Lexar Microsystems, Inc. | Method and apparatus for combining controller firmware storage and controller logic in a mass storage system |
US20040066936A1 (en) * | 1995-05-17 | 2004-04-08 | The Chamberlain Group, Ltd. | Rolling code security system |
US20050010783A1 (en) * | 1995-10-24 | 2005-01-13 | Phil Libin | Access control |
US6577734B1 (en) * | 1995-10-31 | 2003-06-10 | Lucent Technologies Inc. | Data encryption key management system |
US5857020A (en) * | 1995-12-04 | 1999-01-05 | Northern Telecom Ltd. | Timed availability of secured content provisioned on a storage medium |
US5710639A (en) * | 1996-01-25 | 1998-01-20 | Kuznicki; William Joseph | Scan line compressed facsimile communication system |
US5860082A (en) * | 1996-03-28 | 1999-01-12 | Datalight, Inc. | Method and apparatus for allocating storage in a flash memory |
US6181252B1 (en) * | 1996-08-23 | 2001-01-30 | Denso Corporation | Remote control system and method having a system-specific code |
US6742117B1 (en) * | 1997-01-30 | 2004-05-25 | Rohm Co., Ltd. | IC card and method of using IC card |
US6028933A (en) * | 1997-04-17 | 2000-02-22 | Lucent Technologies Inc. | Encrypting method and apparatus enabling multiple access for multiple services and multiple transmission modes over a broadband communication network |
US6073234A (en) * | 1997-05-07 | 2000-06-06 | Fuji Xerox Co., Ltd. | Device for authenticating user's access rights to resources and method |
US6353888B1 (en) * | 1997-07-07 | 2002-03-05 | Fuji Xerox Co., Ltd. | Access rights authentication apparatus |
US6892304B1 (en) * | 1997-10-09 | 2005-05-10 | Phoenix Technologies Ltd. | System and method for securely utilizing basic input and output system (BIOS) services |
US6371377B2 (en) * | 1997-12-10 | 2002-04-16 | Fujitsu Limited | Card type recording medium and access control method for card type recording medium and computer-readable recording medium having access control program for card type recording medium recorded |
US6026402A (en) * | 1998-01-07 | 2000-02-15 | Hewlett-Packard Company | Process restriction within file system hierarchies |
US6253328B1 (en) * | 1998-02-12 | 2001-06-26 | A. James Smith, Jr. | Method and apparatus for securing passwords and personal identification numbers |
US6243816B1 (en) * | 1998-04-30 | 2001-06-05 | International Business Machines Corporation | Single sign-on (SSO) mechanism personal key manager |
US6522655B1 (en) * | 1998-05-12 | 2003-02-18 | Telefonaktiebolaget Lm Ericsson (Publ) | Method and apparatus in a telecommunications system |
US6385729B1 (en) * | 1998-05-26 | 2002-05-07 | Sun Microsystems, Inc. | Secure token device access to services provided by an internet service provider (ISP) |
US6230223B1 (en) * | 1998-06-01 | 2001-05-08 | Compaq Computer Corporation | Dual purpose apparatus method and system for accelerated graphics or second memory interface |
US6370251B1 (en) * | 1998-06-08 | 2002-04-09 | General Dynamics Decision Systems, Inc. | Traffic key access method and terminal for secure communication without key escrow facility |
US6393565B1 (en) * | 1998-08-03 | 2002-05-21 | Entrust Technologies Limited | Data management system and method for a limited capacity cryptographic storage unit |
US6848045B2 (en) * | 1999-01-15 | 2005-01-25 | Rainbow Technologies, Inc. | Integrated USB connector for personal token |
US20030028797A1 (en) * | 1999-01-15 | 2003-02-06 | Rainbow Technologies, Inc. | Integrated USB connector for personal token |
US6356941B1 (en) * | 1999-02-22 | 2002-03-12 | Cyber-Ark Software Ltd. | Network vaults |
US6571335B1 (en) * | 1999-04-01 | 2003-05-27 | Intel Corporation | System and method for authentication of off-chip processor firmware code |
US6389542B1 (en) * | 1999-10-27 | 2002-05-14 | Terence T. Flyntz | Multi-level secure computer with token-based access control |
US20020034303A1 (en) * | 2000-01-21 | 2002-03-21 | The Chamberlain Group, Inc. | Rolling code security system |
US7215771B1 (en) * | 2000-06-30 | 2007-05-08 | Western Digital Ventures, Inc. | Secure disk drive comprising a secure drive key and a drive ID for implementing secure communication over a public network |
US20020029343A1 (en) * | 2000-09-05 | 2002-03-07 | Fujitsu Limited | Smart card access management system, sharing method, and storage medium |
US20020099666A1 (en) * | 2000-11-22 | 2002-07-25 | Dryer Joseph E. | System for maintaining the security of client files |
US20020065730A1 (en) * | 2000-11-30 | 2002-05-30 | Naoaki Nii | Method of and a system for distributing electronic content |
US6901449B1 (en) * | 2000-12-22 | 2005-05-31 | Microsoft Corporation | System and method for encapsulating data with a formatted data protocol |
US7058618B2 (en) * | 2001-04-04 | 2006-06-06 | Bayer Aktiengesellschaft | Method for establishing stress/strain curves by means of spline interpolation on the basis of characteristic points and with the use of neural networks |
US6754765B1 (en) * | 2001-05-14 | 2004-06-22 | Integrated Memory Logic, Inc. | Flash memory controller with updateable microcode |
US20030028514A1 (en) * | 2001-06-05 | 2003-02-06 | Lord Stephen Philip | Extended attribute caching in clustered filesystem |
US7062616B2 (en) * | 2001-06-12 | 2006-06-13 | Intel Corporation | Implementing a dual partition flash with suspend/resume capabilities |
US20040117653A1 (en) * | 2001-07-10 | 2004-06-17 | Packet Technologies Ltd. | Virtual private network mechanism incorporating security association processor |
US20030018889A1 (en) * | 2001-07-20 | 2003-01-23 | Burnett Keith L. | Automated establishment of addressability of a network device for a target network enviroment |
US7036020B2 (en) * | 2001-07-25 | 2006-04-25 | Antique Books, Inc | Methods and systems for promoting security in a computer system employing attached storage devices |
US20050010758A1 (en) * | 2001-08-10 | 2005-01-13 | Peter Landrock | Data certification method and apparatus |
US20030061504A1 (en) * | 2001-08-13 | 2003-03-27 | Sprigg Stephen A. | Application level access privilege to a storage area on a computer device |
US20030070083A1 (en) * | 2001-09-28 | 2003-04-10 | Kai-Wilhelm Nessler | Method and device for encryption/decryption of data on mass storage device |
US20030101327A1 (en) * | 2001-11-16 | 2003-05-29 | Samsung Electronics Co., Ltd. | Flash memory management method |
US6865555B2 (en) * | 2001-11-21 | 2005-03-08 | Digeo, Inc. | System and method for providing conditional access to digital content |
US20030120938A1 (en) * | 2001-11-27 | 2003-06-26 | Miki Mullor | Method of securing software against reverse engineering |
US20040020511A1 (en) * | 2001-11-30 | 2004-02-05 | Sandhu Gurtej S. | Method of providing high flux of point of use activated reactive species for semiconductor processing |
US20030110169A1 (en) * | 2001-12-12 | 2003-06-12 | Secretseal Inc. | System and method for providing manageability to security information for secured items |
US6901499B2 (en) * | 2002-02-27 | 2005-05-31 | Microsoft Corp. | System and method for tracking data stored in a flash memory device |
US6845908B2 (en) * | 2002-03-18 | 2005-01-25 | Hitachi Semiconductor (America) Inc. | Storage card with integral file system, access control and cryptographic support |
US6880079B2 (en) * | 2002-04-25 | 2005-04-12 | Vasco Data Security, Inc. | Methods and systems for secure transmission of information using a mobile device |
US20040044625A1 (en) * | 2002-06-10 | 2004-03-04 | Ken Sakamura | Digital contents issuing system and digital contents issuing method |
US6678828B1 (en) * | 2002-07-22 | 2004-01-13 | Vormetric, Inc. | Secure network file access control system |
US20040025010A1 (en) * | 2002-07-30 | 2004-02-05 | Texas Instruments Incorporated | Computing platform certificate |
US20040025036A1 (en) * | 2002-07-30 | 2004-02-05 | Eric Balard | Run-time firmware authentication |
US20040025027A1 (en) * | 2002-07-30 | 2004-02-05 | Eric Balard | Secure protection method for access to protected resources in a processor |
US20040054907A1 (en) * | 2002-07-30 | 2004-03-18 | Alain Chateau | Indirect data protection using random key encryption |
US20040024917A1 (en) * | 2002-07-31 | 2004-02-05 | Barry Kennedy | Secure method to perform computer system firmware updates |
US20040059916A1 (en) * | 2002-09-11 | 2004-03-25 | Nagamasa Mizushima | Memory card |
US20040083370A1 (en) * | 2002-09-13 | 2004-04-29 | Sun Microsystems, Inc., A Delaware Corporation | Rights maintenance in a rights locker system for digital content access control |
US20040063495A1 (en) * | 2002-09-30 | 2004-04-01 | Lemay Steven G. | EPROM file system in a gaming apparatus |
US20040083335A1 (en) * | 2002-10-28 | 2004-04-29 | Gonzalez Carlos J. | Automated wear leveling in non-volatile storage systems |
US20040098585A1 (en) * | 2002-11-05 | 2004-05-20 | Rainbow Technologies, Inc. | Secure authentication using hardware token and computer fingerprint |
US20040093592A1 (en) * | 2002-11-13 | 2004-05-13 | Rao Bindu Rama | Firmware update in electronic devices employing SIM card for saving metadata information |
US20040103288A1 (en) * | 2002-11-27 | 2004-05-27 | M-Systems Flash Disk Pioneers Ltd. | Apparatus and method for securing data on a portable storage device |
US20040123127A1 (en) * | 2002-12-18 | 2004-06-24 | M-Systems Flash Disk Pioneers, Ltd. | System and method for securing portable data |
US7380275B2 (en) * | 2003-02-07 | 2008-05-27 | Broadon Communications Corp. | Secure and backward-compatible processor and secure software execution thereon |
US20050015588A1 (en) * | 2003-07-17 | 2005-01-20 | Paul Lin | Token device that generates and displays one-time passwords and that couples to a computer for inputting or receiving data for generating and outputting one-time passwords and other functions |
US20050033968A1 (en) * | 2003-08-08 | 2005-02-10 | Metapass, Inc. | Secure digital key for automatic login |
US20050050330A1 (en) * | 2003-08-27 | 2005-03-03 | Leedor Agam | Security token |
US20050049931A1 (en) * | 2003-08-29 | 2005-03-03 | Wisnudel Marc Brian | Digital content kiosk and associated methods for delivering selected digital content to a user |
US20050055530A1 (en) * | 2003-09-08 | 2005-03-10 | Yuan-Ting Wu | Method and apparatus for protecting a specific memory section |
US20050091496A1 (en) * | 2003-10-23 | 2005-04-28 | Hyser Chris D. | Method and system for distributed key management in a secure boot environment |
US20050114620A1 (en) * | 2003-11-21 | 2005-05-26 | Justen Jordan L. | Using paging to initialize system memory |
US20050120205A1 (en) * | 2003-12-02 | 2005-06-02 | Hitachi, Ltd. | Certificate management system and method |
US20050137997A1 (en) * | 2003-12-11 | 2005-06-23 | Siemens Aktiengesellschaft | Method for updating an automation system |
US7657886B1 (en) * | 2004-06-03 | 2010-02-02 | Hewlett-Packard Development Company, L.P. | Mobile device with a MMU for faster firmware updates in a wireless network |
US7493656B2 (en) * | 2005-06-02 | 2009-02-17 | Seagate Technology Llc | Drive security session manager |
US20070011724A1 (en) * | 2005-07-08 | 2007-01-11 | Gonzalez Carlos J | Mass storage device with automated credentials loading |
US20070061897A1 (en) * | 2005-09-14 | 2007-03-15 | Michael Holtzman | Hardware driver integrity check of memory card controller firmware |
US20070061570A1 (en) * | 2005-09-14 | 2007-03-15 | Michael Holtzman | Method of hardware driver integrity check of memory card controller firmware |
US20070061597A1 (en) * | 2005-09-14 | 2007-03-15 | Micky Holtzman | Secure yet flexible system architecture for secure devices with flash mass storage memory |
US20070061581A1 (en) * | 2005-09-14 | 2007-03-15 | Micky Holtzman | Methods used in a secure yet flexible system architecture for secure devices with flash mass storage memory |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7743409B2 (en) | 2005-07-08 | 2010-06-22 | Sandisk Corporation | Methods used in a mass storage device with automated credentials loading |
US7748031B2 (en) | 2005-07-08 | 2010-06-29 | Sandisk Corporation | Mass storage device with automated credentials loading |
US8220039B2 (en) | 2005-07-08 | 2012-07-10 | Sandisk Technologies Inc. | Mass storage device with automated credentials loading |
US7536540B2 (en) | 2005-09-14 | 2009-05-19 | Sandisk Corporation | Method of hardware driver integrity check of memory card controller firmware |
US20100174851A1 (en) * | 2009-01-08 | 2010-07-08 | Micron Technology, Inc. | Memory system controller |
US8412880B2 (en) * | 2009-01-08 | 2013-04-02 | Micron Technology, Inc. | Memory system controller to manage wear leveling across a plurality of storage nodes |
US9104555B2 (en) | 2009-01-08 | 2015-08-11 | Micron Technology, Inc. | Memory system controller |
WO2014177904A1 (en) * | 2013-04-29 | 2014-11-06 | Freescale Semiconductor, Inc. | Memory controller |
US10489612B2 (en) | 2013-04-29 | 2019-11-26 | Nxp Usa, Inc. | Memory controller to verify authenticity of data |
US20160261412A1 (en) * | 2015-03-04 | 2016-09-08 | Avaya Inc. | Two-Step Authentication And Activation of Quad Small Form Factor Pluggable (QFSP+) Transceivers |
Also Published As
Publication number | Publication date |
---|---|
CN101273363B (en) | 2013-07-17 |
US20070061597A1 (en) | 2007-03-15 |
CN101273363A (en) | 2008-09-24 |
US7934049B2 (en) | 2011-04-26 |
TW200731108A (en) | 2007-08-16 |
US20070061581A1 (en) | 2007-03-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7934049B2 (en) | Methods used in a secure yet flexible system architecture for secure devices with flash mass storage memory | |
EP1934879B1 (en) | Secure yet flexible system architecture for secure devices with flash mass storage memory | |
JP5175856B2 (en) | Protection and method of flash memory block in secure device system | |
CN101894224B (en) | Protecting content on client platforms | |
TWI676116B (en) | Secured storage system and method for secure storage | |
JP4956292B2 (en) | Information security apparatus and counter control method | |
TWI441024B (en) | Method and system for security protection for memory content of processor main memory | |
CN109800050B (en) | Memory management method, device, related equipment and system of virtual machine | |
US6327652B1 (en) | Loading and identifying a digital rights management operating system | |
US7302709B2 (en) | Key-based secure storage | |
US6996710B1 (en) | Platform and method for issuing and certifying a hardware-protected attestation key | |
US8060744B2 (en) | Computer architecture for an electronic device providing single-level secure access to multi-level secure file system | |
WO2009107330A1 (en) | Information processor and method for controlling the same | |
TW200830830A (en) | Hard disc streaming cryptographic operations with embedded authentication | |
JP2005527019A (en) | Multi-token seal and seal release | |
US20080126705A1 (en) | Methods Used In A Portable Mass Storage Device With Virtual Machine Activation | |
CN109445705B (en) | Firmware authentication method and solid state disk | |
US20240370566A1 (en) | Secure Identity Chaining between Components of Trusted Computing Base | |
US20060015860A1 (en) | System and method for storing attributes in a file for processing an operating system | |
KR20090048581A (en) | Portable Mass Storage with Virtual Machine Activation | |
US7568102B2 (en) | System and method for authorizing the use of stored information in an operating system | |
Brož | Authenticated and resilient disk encryption | |
US12260007B2 (en) | Secure flash controller |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: SANDISK TECHNOLOGIES INC., TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SANDISK CORPORATION;REEL/FRAME:026370/0733 Effective date: 20110404 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |
|
AS | Assignment |
Owner name: SANDISK TECHNOLOGIES LLC, TEXAS Free format text: CHANGE OF NAME;ASSIGNOR:SANDISK TECHNOLOGIES INC;REEL/FRAME:039336/0717 Effective date: 20160516 |