Nothing Special   »   [go: up one dir, main page]

US20060256610A1 - Nonvolatile memory system using magneto-resistive random access memory (MRAM) - Google Patents

Nonvolatile memory system using magneto-resistive random access memory (MRAM) Download PDF

Info

Publication number
US20060256610A1
US20060256610A1 US11/130,351 US13035105A US2006256610A1 US 20060256610 A1 US20060256610 A1 US 20060256610A1 US 13035105 A US13035105 A US 13035105A US 2006256610 A1 US2006256610 A1 US 2006256610A1
Authority
US
United States
Prior art keywords
nonvolatile memory
mram
cycle
flash
access cycle
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.)
Granted
Application number
US11/130,351
Other versions
US7245527B2 (en
Inventor
Qadeer Qureshi
Thomas Jew
Curtis Wyman
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Everspin Technologies Inc
Morgan Stanley Senior Funding Inc
Original Assignee
Freescale Semiconductor Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Freescale Semiconductor Inc filed Critical Freescale Semiconductor Inc
Priority to US11/130,351 priority Critical patent/US7245527B2/en
Assigned to FREESCALE SEMICONDUCTOR, INC. reassignment FREESCALE SEMICONDUCTOR, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: JEW, THOMAS, QURESHI, QADEER A., WYMAN, CURTIS F.
Priority to PCT/US2006/013738 priority patent/WO2006124158A2/en
Priority to JP2008512281A priority patent/JP2008546053A/en
Publication of US20060256610A1 publication Critical patent/US20060256610A1/en
Assigned to CITIBANK, N.A. AS COLLATERAL AGENT reassignment CITIBANK, N.A. AS COLLATERAL AGENT SECURITY AGREEMENT Assignors: FREESCALE ACQUISITION CORPORATION, FREESCALE ACQUISITION HOLDINGS CORP., FREESCALE HOLDINGS (BERMUDA) III, LTD., FREESCALE SEMICONDUCTOR, INC.
Application granted granted Critical
Publication of US7245527B2 publication Critical patent/US7245527B2/en
Priority to KR1020077026755A priority patent/KR101391270B1/en
Assigned to CITIBANK, N.A. reassignment CITIBANK, N.A. SECURITY AGREEMENT Assignors: FREESCALE SEMICONDUCTOR, INC.
Assigned to EVERSPIN TECHNOLOGIES, INC. reassignment EVERSPIN TECHNOLOGIES, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: FREESCALE SEMICONDUCTOR, INC.
Assigned to EVERSPIN TECHNOLOGIES, INC. reassignment EVERSPIN TECHNOLOGIES, INC. RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: CITIBANK, N.A.
Assigned to EVERSPIN TECHNOLOGIES, INC. reassignment EVERSPIN TECHNOLOGIES, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: FREESCALE SEMICONDUCTOR, INC.
Assigned to FREESCALE SEMICONDUCTOR, INC. reassignment FREESCALE SEMICONDUCTOR, INC. PATENT RELEASE Assignors: CITIBANK, N.A., AS COLLATERAL AGENT
Assigned to FREESCALE SEMICONDUCTOR, INC. reassignment FREESCALE SEMICONDUCTOR, INC. PATENT RELEASE Assignors: CITIBANK, N.A., AS COLLATERAL AGENT
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. SECURITY AGREEMENT SUPPLEMENT Assignors: NXP B.V.
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12092129 PREVIOUSLY RECORDED ON REEL 038017 FRAME 0058. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT. Assignors: NXP B.V.
Assigned to NXP B.V. reassignment NXP B.V. PATENT RELEASE Assignors: MORGAN STANLEY SENIOR FUNDING, INC.
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12681366 PREVIOUSLY RECORDED ON REEL 039361 FRAME 0212. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT. Assignors: NXP B.V.
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12681366 PREVIOUSLY RECORDED ON REEL 038017 FRAME 0058. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT. Assignors: NXP B.V.
Assigned to NXP B.V. reassignment NXP B.V. RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: MORGAN STANLEY SENIOR FUNDING, INC.
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 042762 FRAME 0145. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT. Assignors: NXP B.V.
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 039361 FRAME 0212. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT. Assignors: NXP B.V.
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 042985 FRAME 0001. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT. Assignors: NXP B.V.
Assigned to MORGAN STANLEY SENIOR FUNDING, INC. reassignment MORGAN STANLEY SENIOR FUNDING, INC. CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 038017 FRAME 0058. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT. Assignors: NXP B.V.
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0683Plurality of storage devices
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/08Address circuits; Decoders; Word-line control circuits
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1668Details of memory controller
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/005Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor comprising combined but independently operative RAM-ROM, RAM-PROM, RAM-EPROM cells

Definitions

  • the invention relates generally to memory devices, and more particularly to nonvolatile memory systems.
  • Computer systems are usually defined as having three main blocks: a central processing unit (CPU), memory, and input/output peripherals.
  • CPU central processing unit
  • memory volatile and non-volatile memory
  • input/output peripherals output peripherals
  • Integrated circuit technology has greatly reduced the cost of all components of the computer system. For example CPUs are now implemented with single-chip microprocessors. Modern microprocessors can achieve computing performance that was only available to supercomputers just a generation ago.
  • FIG. 1 illustrates a computer system 100 known in the prior art.
  • Computer system 100 includes a microprocessor 110 , a memory 120 , and an input/output system 130 all connected together by means of a system bus 140 .
  • memory 120 includes several different types of memory devices, including a read-only memory (ROM) 122 , a flash electrically-erasable programmable ROM (FLASH) 124 , a static random access memory (SRAM) 126 , and a dynamic random access memory (DRAM) 128 .
  • ROM read-only memory
  • FLASH flash electrically-erasable programmable ROM
  • SRAM static random access memory
  • DRAM dynamic random access memory
  • ROM 122 is nonvolatile, permanent storage that is inexpensive but cannot be re-written. ROM 122 is implemented using mask-programmable single-transistor memory cells and requires custom masks but is inexpensive to manufacture. ROM 122 stores a program executable by microprocessor 110 that is not expected to change over the lifetime of computer system 100 . A typical use of ROM 122 is to store the basic input/output system (BIOS) of a desktop computer.
  • BIOS basic input/output system
  • FLASH 124 is nonvolatile memory that may use floating-gate transistors to store electrical charges that indicate the state of the memory cells. Relatively large portions or sectors of FLASH 124 can be erased “in a flash”. However FLASH 124 is somewhat more expensive than ROM 122 and a program operation to write new data takes much longer than a read operation. Furthermore FLASH 124 has a reliability problem known as endurance, in that it loses its ability to be re-programmed over time after a large number of erase and program cycles have been performed. Because of these characteristics FLASH 124 is used to store parameters and user settings that stay relatively constant. For example, if computer system 100 were used in a cellular telephone, FLASH 124 could be used to store phone numbers in an electronic “phone book”.
  • SRAM 126 is randomly accessible at high speed for both reads and writes, but it volatile and relatively expensive.
  • SRAM 126 includes memory cells implemented as addressable static latches. Thus it is usually reserved for use as a high-speed scratchpad memory or cache for microprocessor 110 .
  • DRAM 128 is randomly accessible and inexpensive, but is slower than SRAM 126 and is volatile.
  • DRAM 128 is commonly implemented using storage cells that each include a capacitor and a single transistor, and thus can achieve high density and low price per bit. However because the charges stored in the memory cells are dynamic, the memory cells must be periodically refreshed. DRAMs are commonly used for storage of large programs that are loaded from input/output devices such as compact discs (CDs) and hard disk drives.
  • CDs compact discs
  • MRAM magneto-resistive random access memory
  • the present invention provides a non-volatile memory system including a magnetoresistive random access memory (MRAM) including a plurality of magnetoresistive memory cells, a flash nonvolatile memory, and a controller coupled to the MRAM and to the flash nonvolatile memory.
  • MRAM magnetoresistive random access memory
  • the controller is adapted to be coupled to a system bus and controls a selected one of the MRAM and the flash nonvolatile memory in response to an access initiated from the system bus.
  • the present invention provides a non-volatile memory system including a magnetoresistive random access memory (MRAM), a flash nonvolatile memory, and a controller coupled to the MRAM and to the flash nonvolatile memory.
  • MRAM magnetoresistive random access memory
  • the MRAM has a plurality of sectors of MRAM cells and a corresponding plurality of tags. Each of the plurality of tags indicates an address of a corresponding one of the plurality of sectors.
  • the flash nonvolatile memory has a second plurality of sectors of storage locations.
  • the controller is coupled to the MRAM and to the flash nonvolatile memory and is adapted to be coupled to a system bus.
  • the controller determines whether an address of the access cycle is stored in one of the plurality of tags and if so performs the access cycle to a corresponding one of the plurality of sectors of the MRAM instead of to the flash nonvolatile memory.
  • the present invention provides a method of controlling a non-volatile memory system that includes a magneto-resistive random access memory (MRAM) and a flash nonvolatile memory.
  • An access cycle is received from a system bus. Whether the access cycle is a write cycle is determined. If the access cycle is the write cycle, write data is stored in a temporary buffer, the write cycle is terminated on the system bus, and the write data is subsequently stored in the MRAM.
  • MRAM magneto-resistive random access memory
  • FIG. 1 illustrates in block diagram form a computer system known in the prior art
  • FIG. 2 illustrates in block diagram form a computer system according to the present invention
  • FIG. 3 illustrates a block diagram of the non-volatile memory system of FIG. 2 ;
  • FIG. 4 illustrates a flow chart of the operation of the controller of FIG. 3 according to one embodiment of the present invention
  • FIG. 5 illustrates a flow chart of the operation of the controller of FIG. 3 according to another embodiment of the present invention.
  • FIG. 6 illustrates in block diagram form additional details of the non-volatile memory system of FIG. 2 according to another aspect of the present invention.
  • FIG. 2 illustrates in block diagram form a computer system 200 according to the present invention.
  • Computer system 200 includes a microprocessor 210 and a non-volatile memory system 230 both connected to a system bus 220 .
  • System bus 220 conducts address, data, and control signals to allow microprocessor 210 to perform read and write accesses to memory system 230 and other memory and input/output devices not shown in FIG. 2 .
  • Non-volatile memory system 230 includes a magneto-resistive random access memory (MRAM) 232 , a flash electrically erasable programmable read only memory (FLASH) 234 , and a controller 236 bidirectionally connected to both MRAM 232 and FLASH 234 for controlling the operation thereof.
  • MRAM magneto-resistive random access memory
  • FLASH flash electrically erasable programmable read only memory
  • controller 236 bidirectionally connected to both MRAM 232 and FLASH 234 for controlling the operation thereof.
  • FIG. 3 illustrates a block diagram 300 of non-volatile memory system 230 of FIG. 2 including details of MRAM 232 and FLASH 234 important in understanding the present invention.
  • controller 236 includes bidirectional connections to both MRAM 232 and FLASH 234 .
  • MRAM 232 is shown in greater detail as including a group of n MRAM sectors 310 labeled “MS 1 ” through “MS n ”, and a corresponding group of n tags 320 labeled “TAG 1 ” through TAG n ” and respectively associated with MRAM sectors MS 1 through MS n .
  • FLASH 234 is also shown in greater detail as including a group of m FLASH sectors 330 labeled “FS 1 ” through “FS m ”.
  • Controller 236 is responsive to an access cycle initiated by a device such as microprocessor 210 on system bus 220 to perform the requested memory transfer or perform the operation indicated by the control signals on system bus 220 .
  • Controller 236 uses MRAM 232 to reduce the apparent latency of an access to the memory space of FLASH 234 by making MRAM 232 a buffer for write and erase accesses. This operation is better understood with reference to FIG. 4 , which illustrates a flow chart 400 of the operation of controller 236 of FIG. 3 according to one embodiment of the present invention. In this embodiment the size of the sectors in MRAM 232 and FLASH 234 is arbitrary.
  • the flow starts at step 402 and controller 236 checks for a new access cycle at decision box 404 .
  • controller 236 When a new access cycle is received, controller 236 next determines, at decision box 406 , whether the read or write data is in a sector that has been allocated to MRAM 232 . If the data has been allocated to MRAM 232 , then controller 236 next determines, at decision box 408 , whether the access cycle is a read cycle or a write cycle. If the access cycle is a write cycle, then controller 236 , at step 410 , writes the data to MRAM 232 and updates internal tables to indicate that a corresponding sector of MRAM 232 contains modified data. If the access cycle is a read cycle, then the data is read from MRAM 232 at step 412 , because MRAM 232 includes the most recent copy of the data.
  • controller 236 next determines, at decision box 414 , whether the access cycle is a read cycle or a write cycle. If the access cycle is a write cycle, then controller 236 , at step 416 , receives the data pending allocation of the data in MRAM 232 and completes the write access with no apparent latency. After either determining that the cycle is not a write cycle or after storing write data in a temporary buffer at step 416 , controller 236 allocates a sector of MRAM 232 to correspond to the accessed sector, performing a writeback of another MRAM sector to flash 234 if needed (if all sectors have been previously allocated). Then at step 420 data is copied from a sector of FLASH 234 into a selected sector of MRAM 232 , combining it with write data from the temporary buffer in the case of a write cycle.
  • FIG. 5 illustrates a flow chart 500 of the operation of the controller of FIG. 3 according to another embodiment of the present invention.
  • the sector sizes are the same.
  • the flow starts at step 502 and controller 236 checks for a new access cycle at step 504 .
  • the access cycle is in the form of a FLASH-type command, either read, write, or erase.
  • Controller 236 performs sub-flows 510 , 520 , or 530 depending on whether the access cycle is a read cycle, an erase cycle, or a write cycle, respectively.
  • controller 236 proceeds to sub-flow 510 . Controller 236 determines, at decision box 512 , whether the read data is in a sector that has been already allocated to MRAM 232 . If the read data is in a sector that has not been allocated to MRAM 232 , then controller 236 allocates the data to MRAM 232 at step 514 by storing the address of the access cycle in a TAG, copying the data from FLASH 234 to MRAM 232 , and setting a corresponding valid bit in the TAG. Note that if any of the sectors of MRAM 232 is empty, i.e., it does not have its valid bit set, then controller 236 selects one of the non-allocated sectors to allocate to the selected sector.
  • controller 236 If all sectors have been previously allocated, then controller 236 writes back the data of one of the previously-allocated sectors into FLASH 234 before copying the selected sector data. Note as is conventional a write (program) cycle to FLASH 234 is preceded by an erase cycle. Then regardless of whether data has been allocated controller 236 provides data from MRAM 232 to system bus 220 at step 518 to compete the read access.
  • controller 236 proceeds to sub-flow 520 . Controller 236 first stores information about the erase command in a temporary buffer, and terminates the erase cycle. Thus the erase cycle appears to system bus 220 to have no latency. Next at step 524 , controller 236 starts the erase cycle in FLASH 234 while continuing to manage sectors of MRAM 232 as appropriate.
  • controller 236 proceeds to sub-flow 530 . Controller 236 determines, at decision box 532 , whether the accessed data is present in MRAM 232 . If not, then controller 236 stores the write data in a temporary buffer at step 534 and terminates the cycle on system bus 220 . Then at step 536 controller 235 allocates a sector of MRAM 232 , writing a sector containing old data back if necessary. Then at step 538 controller 236 copies the sector to a selected sector of MRAM 232 by reading FLASH 234 and moving the data so read into MRAM 232 , combining it with the write data from the temporary buffer as necessary. Then controller 236 updates the TAGs in MRAM 232 with the address of the corresponding sector in FLASH 234 , and updates the bits that indicate the sector has been allocated.
  • FIG. 6 illustrates in block diagram form additional details of the non-volatile memory system of FIG. 2 according to another aspect of the present invention.
  • controller 236 includes a static random access memory (SRAM) interface 610 and a FLASH command interface 620 .
  • SRAM interface 610 is connected to system bus by a set of control signals normally associated with SRAMs: a chip enable output signal ( ⁇ overscore (CE) ⁇ ), a output enable signal ( ⁇ overscore (OE) ⁇ ), a write enable signal ( ⁇ overscore (WE) ⁇ ), an input clock signal CLK, and a control signal labeled “ ⁇ overscore (BUSY) ⁇ ”. Address and data signals are not shown in FIG. 6 .
  • SRAM interface 610 recognizes standard SRAM control signals CE, OE, and WE and in addition a synchronous clock signal CLK in order to perform the read and write accesses as further described above. SRAM interface 610 then provides information to FLASH command interface 620 to control MRAM 232 and FLASH 234 as described above. By including SRAM interface 610 , controller 236 allows non-volatile memory system 600 to appear to the system as fast low- or zero-latency SRAM, which is capable of retaining its contents when power is removed.
  • FLASH 234 could be implemented by any known FLASH technology including NOR FLASH, NAND FLASH, and have single or multiple bits per cell.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Computer Hardware Design (AREA)
  • Read Only Memory (AREA)
  • Memory System (AREA)
  • Static Random-Access Memory (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)
  • Mram Or Spin Memory Techniques (AREA)
  • Semiconductor Memories (AREA)
  • Non-Volatile Memory (AREA)

Abstract

A non-volatile memory system (230) includes a magnetoresistive random access memory (MRAM) (232) including a plurality of magnetoresistive memory cells, a floating-gate nonvolatile memory (234) including a plurality of floating-gate memory cells, and a controller (236) coupled to the MRAM (232) and to the floating-gate nonvolatile memory (234). The controller (236) is adapted to be coupled to a system bus (220) and controls a selected one of the MRAM (232) and the floating-gate nonvolatile memory (234) in response to an access initiated from the system bus (220).

Description

    FIELD OF THE DISCLOSURE
  • The invention relates generally to memory devices, and more particularly to nonvolatile memory systems.
  • BACKGROUND
  • Computer systems are usually defined as having three main blocks: a central processing unit (CPU), memory, and input/output peripherals. Over the past half-century or so developments in integrated circuit technology have made computers inexpensive and therefore common in everyday life, for all types of uses including desktop personal computers, cellular telephones, automobile engine controllers, and the like.
  • Integrated circuit technology has greatly reduced the cost of all components of the computer system. For example CPUs are now implemented with single-chip microprocessors. Modern microprocessors can achieve computing performance that was only available to supercomputers just a generation ago.
  • The integrated circuit revolution has also reduced the cost of computer memory. FIG. 1 illustrates a computer system 100 known in the prior art. Computer system 100 includes a microprocessor 110, a memory 120, and an input/output system 130 all connected together by means of a system bus 140. As shown in FIG. 1 memory 120 includes several different types of memory devices, including a read-only memory (ROM) 122, a flash electrically-erasable programmable ROM (FLASH) 124, a static random access memory (SRAM) 126, and a dynamic random access memory (DRAM) 128. Computer system 100 requires some or all of these different types of memory devices because integrated circuit technology has so far failed to produce a single type of memory device that meets all the needs of computer system 100.
  • ROM 122 is nonvolatile, permanent storage that is inexpensive but cannot be re-written. ROM 122 is implemented using mask-programmable single-transistor memory cells and requires custom masks but is inexpensive to manufacture. ROM 122 stores a program executable by microprocessor 110 that is not expected to change over the lifetime of computer system 100. A typical use of ROM 122 is to store the basic input/output system (BIOS) of a desktop computer.
  • FLASH 124 is nonvolatile memory that may use floating-gate transistors to store electrical charges that indicate the state of the memory cells. Relatively large portions or sectors of FLASH 124 can be erased “in a flash”. However FLASH 124 is somewhat more expensive than ROM 122 and a program operation to write new data takes much longer than a read operation. Furthermore FLASH 124 has a reliability problem known as endurance, in that it loses its ability to be re-programmed over time after a large number of erase and program cycles have been performed. Because of these characteristics FLASH 124 is used to store parameters and user settings that stay relatively constant. For example, if computer system 100 were used in a cellular telephone, FLASH 124 could be used to store phone numbers in an electronic “phone book”.
  • SRAM 126 is randomly accessible at high speed for both reads and writes, but it volatile and relatively expensive. SRAM 126 includes memory cells implemented as addressable static latches. Thus it is usually reserved for use as a high-speed scratchpad memory or cache for microprocessor 110.
  • DRAM 128 is randomly accessible and inexpensive, but is slower than SRAM 126 and is volatile. DRAM 128 is commonly implemented using storage cells that each include a capacitor and a single transistor, and thus can achieve high density and low price per bit. However because the charges stored in the memory cells are dynamic, the memory cells must be periodically refreshed. DRAMs are commonly used for storage of large programs that are loaded from input/output devices such as compact discs (CDs) and hard disk drives.
  • It should be apparent that any actual computer system may not use all types of memory devices shown in FIG. 1.
  • In recent years semiconductor manufacturers have developed a new type of memory known as magneto-resistive random access memory (MRAM) that may one day unify the available types of memory devices. MRAM is based on small storage cells that store states using magnetic fields. MRAM is non-volatile, randomly accessible, and capable of high-density integration. However as of yet manufacturing techniques have not been developed to produce MRAM at costs comparable to FLASH or DRAM at comparable densities.
  • Therefore what is needed is a new memory system capable of taking advantage of the properties of MRAM while it remains more expensive than these other types of memory.
  • BRIEF SUMMARY
  • Thus in one form the present invention provides a non-volatile memory system including a magnetoresistive random access memory (MRAM) including a plurality of magnetoresistive memory cells, a flash nonvolatile memory, and a controller coupled to the MRAM and to the flash nonvolatile memory. The controller is adapted to be coupled to a system bus and controls a selected one of the MRAM and the flash nonvolatile memory in response to an access initiated from the system bus.
  • In another form, the present invention provides a non-volatile memory system including a magnetoresistive random access memory (MRAM), a flash nonvolatile memory, and a controller coupled to the MRAM and to the flash nonvolatile memory. The MRAM has a plurality of sectors of MRAM cells and a corresponding plurality of tags. Each of the plurality of tags indicates an address of a corresponding one of the plurality of sectors. The flash nonvolatile memory has a second plurality of sectors of storage locations. The controller is coupled to the MRAM and to the flash nonvolatile memory and is adapted to be coupled to a system bus. In response to an access cycle received from the system bus, the controller determines whether an address of the access cycle is stored in one of the plurality of tags and if so performs the access cycle to a corresponding one of the plurality of sectors of the MRAM instead of to the flash nonvolatile memory.
  • In another form the present invention provides a method of controlling a non-volatile memory system that includes a magneto-resistive random access memory (MRAM) and a flash nonvolatile memory. An access cycle is received from a system bus. Whether the access cycle is a write cycle is determined. If the access cycle is the write cycle, write data is stored in a temporary buffer, the write cycle is terminated on the system bus, and the write data is subsequently stored in the MRAM.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The present disclosure may be better understood, and its numerous features and advantages made apparent to those skilled in the art by referencing the accompanying drawing, in which like reference numbers indicate similar or identical items.
  • FIG. 1 illustrates in block diagram form a computer system known in the prior art;
  • FIG. 2 illustrates in block diagram form a computer system according to the present invention;
  • FIG. 3 illustrates a block diagram of the non-volatile memory system of FIG. 2;
  • FIG. 4 illustrates a flow chart of the operation of the controller of FIG. 3 according to one embodiment of the present invention;
  • FIG. 5 illustrates a flow chart of the operation of the controller of FIG. 3 according to another embodiment of the present invention; and
  • FIG. 6 illustrates in block diagram form additional details of the non-volatile memory system of FIG. 2 according to another aspect of the present invention.
  • DETAILED DESCRIPTION
  • FIG. 2 illustrates in block diagram form a computer system 200 according to the present invention. Computer system 200 includes a microprocessor 210 and a non-volatile memory system 230 both connected to a system bus 220. System bus 220 conducts address, data, and control signals to allow microprocessor 210 to perform read and write accesses to memory system 230 and other memory and input/output devices not shown in FIG. 2.
  • Non-volatile memory system 230 includes a magneto-resistive random access memory (MRAM) 232, a flash electrically erasable programmable read only memory (FLASH) 234, and a controller 236 bidirectionally connected to both MRAM 232 and FLASH 234 for controlling the operation thereof. By including both MRAM 232 and FLASH 234 and controlling them as will be described more fully below, non-volatile memory system 230 leverages the features and abilities of MRAM 232 to overcome the problems normally associated with FLASH 234 including long write and erase latency and limited endurance.
  • FIG. 3 illustrates a block diagram 300 of non-volatile memory system 230 of FIG. 2 including details of MRAM 232 and FLASH 234 important in understanding the present invention. As in FIG. 2, controller 236 includes bidirectional connections to both MRAM 232 and FLASH 234. MRAM 232 is shown in greater detail as including a group of n MRAM sectors 310 labeled “MS1” through “MSn”, and a corresponding group of n tags 320 labeled “TAG1” through TAGn” and respectively associated with MRAM sectors MS1 through MSn. FLASH 234 is also shown in greater detail as including a group of m FLASH sectors 330 labeled “FS1” through “FSm”.
  • Controller 236 is responsive to an access cycle initiated by a device such as microprocessor 210 on system bus 220 to perform the requested memory transfer or perform the operation indicated by the control signals on system bus 220. Controller 236 uses MRAM 232 to reduce the apparent latency of an access to the memory space of FLASH 234 by making MRAM 232 a buffer for write and erase accesses. This operation is better understood with reference to FIG. 4, which illustrates a flow chart 400 of the operation of controller 236 of FIG. 3 according to one embodiment of the present invention. In this embodiment the size of the sectors in MRAM 232 and FLASH 234 is arbitrary. The flow starts at step 402 and controller 236 checks for a new access cycle at decision box 404. When a new access cycle is received, controller 236 next determines, at decision box 406, whether the read or write data is in a sector that has been allocated to MRAM 232. If the data has been allocated to MRAM 232, then controller 236 next determines, at decision box 408, whether the access cycle is a read cycle or a write cycle. If the access cycle is a write cycle, then controller 236, at step 410, writes the data to MRAM 232 and updates internal tables to indicate that a corresponding sector of MRAM 232 contains modified data. If the access cycle is a read cycle, then the data is read from MRAM 232 at step 412, because MRAM 232 includes the most recent copy of the data.
  • If the data is not present in MRAM 232, then controller 236 next determines, at decision box 414, whether the access cycle is a read cycle or a write cycle. If the access cycle is a write cycle, then controller 236, at step 416, receives the data pending allocation of the data in MRAM 232 and completes the write access with no apparent latency. After either determining that the cycle is not a write cycle or after storing write data in a temporary buffer at step 416, controller 236 allocates a sector of MRAM 232 to correspond to the accessed sector, performing a writeback of another MRAM sector to flash 234 if needed (if all sectors have been previously allocated). Then at step 420 data is copied from a sector of FLASH 234 into a selected sector of MRAM 232, combining it with write data from the temporary buffer in the case of a write cycle.
  • FIG. 5 illustrates a flow chart 500 of the operation of the controller of FIG. 3 according to another embodiment of the present invention. In this embodiment the sector sizes are the same. The flow starts at step 502 and controller 236 checks for a new access cycle at step 504. As illustrated in FIG. 5, the access cycle is in the form of a FLASH-type command, either read, write, or erase. Controller 236 performs sub-flows 510, 520, or 530 depending on whether the access cycle is a read cycle, an erase cycle, or a write cycle, respectively.
  • If the access cycle is a read cycle, then controller 236 proceeds to sub-flow 510. Controller 236 determines, at decision box 512, whether the read data is in a sector that has been already allocated to MRAM 232. If the read data is in a sector that has not been allocated to MRAM 232, then controller 236 allocates the data to MRAM 232 at step 514 by storing the address of the access cycle in a TAG, copying the data from FLASH 234 to MRAM 232, and setting a corresponding valid bit in the TAG. Note that if any of the sectors of MRAM 232 is empty, i.e., it does not have its valid bit set, then controller 236 selects one of the non-allocated sectors to allocate to the selected sector. If all sectors have been previously allocated, then controller 236 writes back the data of one of the previously-allocated sectors into FLASH 234 before copying the selected sector data. Note as is conventional a write (program) cycle to FLASH 234 is preceded by an erase cycle. Then regardless of whether data has been allocated controller 236 provides data from MRAM 232 to system bus 220 at step 518 to compete the read access.
  • If the access cycle is an erase cycle, then controller 236 proceeds to sub-flow 520. Controller 236 first stores information about the erase command in a temporary buffer, and terminates the erase cycle. Thus the erase cycle appears to system bus 220 to have no latency. Next at step 524, controller 236 starts the erase cycle in FLASH 234 while continuing to manage sectors of MRAM 232 as appropriate.
  • If the access cycle is a write cycle, controller 236 proceeds to sub-flow 530. Controller 236 determines, at decision box 532, whether the accessed data is present in MRAM 232. If not, then controller 236 stores the write data in a temporary buffer at step 534 and terminates the cycle on system bus 220. Then at step 536 controller 235 allocates a sector of MRAM 232, writing a sector containing old data back if necessary. Then at step 538 controller 236 copies the sector to a selected sector of MRAM 232 by reading FLASH 234 and moving the data so read into MRAM 232, combining it with the write data from the temporary buffer as necessary. Then controller 236 updates the TAGs in MRAM 232 with the address of the corresponding sector in FLASH 234, and updates the bits that indicate the sector has been allocated.
  • FIG. 6 illustrates in block diagram form additional details of the non-volatile memory system of FIG. 2 according to another aspect of the present invention. As shown in FIG. 6, controller 236 includes a static random access memory (SRAM) interface 610 and a FLASH command interface 620. SRAM interface 610 is connected to system bus by a set of control signals normally associated with SRAMs: a chip enable output signal ({overscore (CE)}), a output enable signal ({overscore (OE)}), a write enable signal ({overscore (WE)}), an input clock signal CLK, and a control signal labeled “{overscore (BUSY)}”. Address and data signals are not shown in FIG. 6. SRAM interface 610 recognizes standard SRAM control signals CE, OE, and WE and in addition a synchronous clock signal CLK in order to perform the read and write accesses as further described above. SRAM interface 610 then provides information to FLASH command interface 620 to control MRAM 232 and FLASH 234 as described above. By including SRAM interface 610, controller 236 allows non-volatile memory system 600 to appear to the system as fast low- or zero-latency SRAM, which is capable of retaining its contents when power is removed.
  • Note that FLASH 234 could be implemented by any known FLASH technology including NOR FLASH, NAND FLASH, and have single or multiple bits per cell.
  • While at least one exemplary embodiment has been presented in the foregoing detailed description, it should be appreciated that a vast number of variations exist. It should also be appreciated that the exemplary embodiment or exemplary embodiments are only examples, and are not intended to limit the scope, applicability, or configuration of the invention in any way. Rather, the foregoing detailed description will provide those skilled in the art with a convenient road map for implementing the exemplary embodiment or exemplary embodiments. It should be understood that various changes can be made in the function and arrangement of elements without departing from the scope of the invention as set forth in the appended claims and the legal equivalents thereof.

Claims (20)

1. A non-volatile memory system comprising:
a magnetoresistive random access memory (MRAM);
a flash nonvolatile memory; and
a controller coupled to said MRAM and to said flash nonvolatile memory and adapted to be coupled to a system bus for controlling a selected one of said MRAM and said flash nonvolatile memory in response to an access cycle initiated from said system bus.
2. The nonvolatile memory system of claim 1 wherein when said access cycle is a write cycle of a data element to an address within a memory space of said flash nonvolatile memory, said controller writes said data element to said MRAM instead of to said flash nonvolatile memory.
3. The nonvolatile memory system of claim 2 wherein said controller further terminates said write cycle after writing said data element to said MRAM without writing said data element to said flash nonvolatile memory, thereby reducing write latency.
4. The nonvolatile memory system of claim 1 wherein said controller controls said MRAM instead of said flash nonvolatile memory to perform said access cycle when an address of said access cycle has been allocated to said MRAM.
5. The nonvolatile memory system of claim 1 wherein said controller includes a static random access memory (SRAM) interface having inputs for receiving a chip enable signal, an output enable signal, and a write enable signal.
6. The nonvolatile memory system of claim 5 wherein said SRAM interface further has an input for receiving a clock signal and performs said access cycle synchronously with said clock signal.
7. The nonvolatile memory system of claim 5 wherein said SRAM interface has an output for providing a busy signal to indicate that said access cycle is in progress when said controller performs said access cycle to said flash nonvolatile memory.
8. A non-volatile memory system comprising:
a magneto-resistive random access memory (MRAM) having a plurality of sectors and a corresponding plurality of tags, wherein each of said plurality of tags indicates an address of a corresponding one of said plurality of sectors;
a flash nonvolatile memory; and
a controller coupled to said MRAM and to said flash nonvolatile memory and adapted to be coupled to a system bus, wherein in response to an access cycle received from said system bus, said controller determines whether an address of said access cycle is stored in one of said plurality of tags and if so performs said access cycle to a corresponding one of said plurality of sectors of said MRAM instead of to said flash nonvolatile memory.
9. The nonvolatile memory system of claim 8 wherein if said address of said access cycle is not stored in one of said plurality of tags, said controller allocates an address from said flash nonvolatile memory to a selected sector of said plurality of sectors of said MRAM and performs said access cycle to said selected sector instead of to said flash nonvolatile memory.
10. The nonvolatile memory system of claim 9 wherein said controller allocates said address from said flash nonvolatile memory to said selected sector of said MRAM by copying a corresponding sector from said flash nonvolatile memory to said selected sector and storing an address of said corresponding sector in a corresponding tag of said plurality of tags.
11. The nonvolatile memory system of claim 10 wherein said controller allocates said corresponding sector to said MRAM further by setting a valid bit corresponding to said selected sector in said MRAM.
12. The nonvolatile memory system of claim 9 wherein said controller writes back old data from said selected sector to said flash nonvolatile memory before allocating said address if all of said plurality of sectors of said MRAM have been previously allocated when the nonvolatile memory system receives said access cycle.
13. The nonvolatile memory system of claim 8 wherein in response to a write cycle in which said address of said access cycle is not stored in one of said plurality of tags, said controller stores write data in a temporary buffer and terminates said access cycle on said system bus before allocating said address to said MRAM.
14. The nonvolatile memory system of claim 8 wherein in response to an erase cycle the nonvolatile memory system terminates said erase cycle on said system bus and subsequently erases a corresponding sector in said flash nonvolatile memory.
15. The nonvolatile memory system of claim 8 further comprising a static random access memory (SRAM) interface having inputs for receiving a chip enable signal, an output enable signal, and a write enable signal.
16. A method of controlling a non-volatile memory system that includes a magneto-resistive random access memory (MRAM) and a flash nonvolatile memory comprising the steps of:
receiving an access cycle from a system bus;
determining whether said access cycle is a write cycle;
if said access cycle is said write cycle, storing write data in a temporary buffer, terminating said write cycle on said system bus, and subsequently storing said write data in the MRAM.
17. The method of claim 16 further comprising the steps of:
determining whether an address associated with said access cycle has been allocated to the MRAM;
if said address associated with said access cycle has been allocated to the MRAM, storing said write data in the MRAM; and
if said address associated with said access cycle has not been allocated to the MRAM, allocating said address to the MRAM from said flash nonvolatile memory and then storing said write data in the MRAM.
18. The method of claim 17 further comprising the steps of:
if said address associated with said access cycle has not been allocated to the MRAM and all sectors of the MRAM have been allocated, writing back a selected sector containing old data to the flash nonvolatile memory and subsequently storing said write data in said selected sector.
19. The method of claim 18 wherein the step of writing back said selected sector containing said old data to the flash nonvolatile memory comprises the step of:
selecting a sector of the MRAM which includes the most updates as said selected sector.
20. The method of claim 16 further comprising the step of:
determining whether said access cycle is an erase cycle; and
if said access cycle is said erase cycle, terminating said erase cycle on said system bus, and subsequently erasing a corresponding sector of the flash nonvolatile memory.
US11/130,351 2005-05-16 2005-05-16 Nonvolatile memory system using magneto-resistive random access memory (MRAM) Active 2025-09-15 US7245527B2 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
US11/130,351 US7245527B2 (en) 2005-05-16 2005-05-16 Nonvolatile memory system using magneto-resistive random access memory (MRAM)
PCT/US2006/013738 WO2006124158A2 (en) 2005-05-16 2006-04-07 Nonvolatile memory system using magneto-resistive random access memory (mram)
JP2008512281A JP2008546053A (en) 2005-05-16 2006-04-07 Nonvolatile memory system using magnetoresistive random access memory (MRAM)
KR1020077026755A KR101391270B1 (en) 2005-05-16 2007-11-16 Nonvolatile memory system using magneto-resistive random access memoryMRAM

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US11/130,351 US7245527B2 (en) 2005-05-16 2005-05-16 Nonvolatile memory system using magneto-resistive random access memory (MRAM)

Publications (2)

Publication Number Publication Date
US20060256610A1 true US20060256610A1 (en) 2006-11-16
US7245527B2 US7245527B2 (en) 2007-07-17

Family

ID=37418948

Family Applications (1)

Application Number Title Priority Date Filing Date
US11/130,351 Active 2025-09-15 US7245527B2 (en) 2005-05-16 2005-05-16 Nonvolatile memory system using magneto-resistive random access memory (MRAM)

Country Status (4)

Country Link
US (1) US7245527B2 (en)
JP (1) JP2008546053A (en)
KR (1) KR101391270B1 (en)
WO (1) WO2006124158A2 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100037001A1 (en) * 2008-08-08 2010-02-11 Imation Corp. Flash memory based storage devices utilizing magnetoresistive random access memory (MRAM)
US20100095057A1 (en) * 2008-10-15 2010-04-15 Seagate Technology Llc Non-volatile resistive sense memory on-chip cache
US20100228912A1 (en) * 2009-03-04 2010-09-09 Seagate Technology Llc Non-Volatile Memory With Hybrid Index Tag Array
US20100315874A1 (en) * 2009-06-15 2010-12-16 Ramin Ghodsi Use of emerging non-volatile memory elements with flash memory
US8719492B1 (en) * 2013-03-08 2014-05-06 Avalanche Technology, Inc. Non-volatile storage module having magnetic random access memory (MRAM) with a buffer window
CN103858169A (en) * 2011-10-12 2014-06-11 国际商业机器公司 Multi-bit spin-momentum-transfer magnetoresistence random access memory with single magnetic-tunnel-junction stack
CN114415937A (en) * 2021-12-06 2022-04-29 北京航空航天大学 Nonvolatile storage memory controller and control method

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20110048304A (en) * 2009-11-02 2011-05-11 삼성전자주식회사 Method for prevention of losing code data in solder reflow and devices using same
JP2011145838A (en) * 2010-01-13 2011-07-28 Toshiba Corp Storage device management device and method for managing storage device
KR20130114354A (en) * 2012-04-09 2013-10-18 삼성전자주식회사 Memory system and operating method of controller
US10241683B2 (en) 2015-10-26 2019-03-26 Nxp Usa, Inc. Non-volatile RAM system
KR20200044312A (en) 2018-10-19 2020-04-29 삼성전자주식회사 Semiconductor device
KR102709411B1 (en) 2018-12-19 2024-09-24 삼성전자주식회사 Operating method of memory controller and memory system, and memory system
KR102709412B1 (en) 2019-01-24 2024-09-24 삼성전자주식회사 A memory system comprising a plurality of controllers
US10763425B1 (en) 2019-05-30 2020-09-01 Honeywell International Inc. Magnetic tunnel junction based programmable memory cell

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5604881A (en) * 1988-12-22 1997-02-18 Framdrive Ferroelectric storage device emulating a rotating disk drive unit in a computer system and having a multiplexed optical data interface
US5701516A (en) * 1992-03-09 1997-12-23 Auspex Systems, Inc. High-performance non-volatile RAM protected write cache accelerator system employing DMA and data transferring scheme
US6567307B1 (en) * 2000-07-21 2003-05-20 Lexar Media, Inc. Block management for mass storage
US6691205B2 (en) * 2001-03-05 2004-02-10 M-Systems Flash Disk Pioneers Ltd. Method for using RAM buffers with simultaneous accesses in flash based storage systems
US6707748B2 (en) * 2002-05-07 2004-03-16 Ritek Corporation Back up power embodied non-volatile memory device
US6728845B2 (en) * 1999-08-31 2004-04-27 Intel Corporation SRAM controller for parallel processor architecture and method for controlling access to a RAM using read and read/write queues
US20050010712A1 (en) * 2003-07-08 2005-01-13 Young-Jun Kim Devices and methods for converting remote device formats to host device formats for access to host associated resources
US20050068802A1 (en) * 2003-09-29 2005-03-31 Yoshiyuki Tanaka Semiconductor storage device and method of controlling the same

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR0136594B1 (en) * 1988-09-30 1998-10-01 미다 가쓰시게 Single chip microcomputer
JP2003091993A (en) * 2001-09-19 2003-03-28 Sony Corp Data storage device, and nonvolatile semiconductor memory device to be used therefor
US6950919B2 (en) * 2003-03-26 2005-09-27 Hewlett-Packard Development Company, L.P. Computer system with operating system to dynamically adjust the main memory
JP2004341989A (en) * 2003-05-19 2004-12-02 Matsushita Electric Ind Co Ltd Memory card pack and memory card

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5604881A (en) * 1988-12-22 1997-02-18 Framdrive Ferroelectric storage device emulating a rotating disk drive unit in a computer system and having a multiplexed optical data interface
US5701516A (en) * 1992-03-09 1997-12-23 Auspex Systems, Inc. High-performance non-volatile RAM protected write cache accelerator system employing DMA and data transferring scheme
US6728845B2 (en) * 1999-08-31 2004-04-27 Intel Corporation SRAM controller for parallel processor architecture and method for controlling access to a RAM using read and read/write queues
US6567307B1 (en) * 2000-07-21 2003-05-20 Lexar Media, Inc. Block management for mass storage
US6691205B2 (en) * 2001-03-05 2004-02-10 M-Systems Flash Disk Pioneers Ltd. Method for using RAM buffers with simultaneous accesses in flash based storage systems
US6707748B2 (en) * 2002-05-07 2004-03-16 Ritek Corporation Back up power embodied non-volatile memory device
US20050010712A1 (en) * 2003-07-08 2005-01-13 Young-Jun Kim Devices and methods for converting remote device formats to host device formats for access to host associated resources
US20050068802A1 (en) * 2003-09-29 2005-03-31 Yoshiyuki Tanaka Semiconductor storage device and method of controlling the same

Cited By (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8140739B2 (en) * 2008-08-08 2012-03-20 Imation Corp. Flash memory based storage devices utilizing magnetoresistive random access memory (MRAM) to store files having logical block addresses stored in a write frequency file buffer table
US8745319B2 (en) 2008-08-08 2014-06-03 Imation Corp. Flash memory based storage devices utilizing magnetoresistive random access memory (MRAM) to store control information facilitating wear leveling
US20100037001A1 (en) * 2008-08-08 2010-02-11 Imation Corp. Flash memory based storage devices utilizing magnetoresistive random access memory (MRAM)
US20100095057A1 (en) * 2008-10-15 2010-04-15 Seagate Technology Llc Non-volatile resistive sense memory on-chip cache
US8650355B2 (en) * 2008-10-15 2014-02-11 Seagate Technology Llc Non-volatile resistive sense memory on-chip cache
US20100228912A1 (en) * 2009-03-04 2010-09-09 Seagate Technology Llc Non-Volatile Memory With Hybrid Index Tag Array
US8489801B2 (en) 2009-03-04 2013-07-16 Henry F. Huang Non-volatile memory with hybrid index tag array
US7898859B2 (en) 2009-06-15 2011-03-01 Micron Technology, Inc. Use of emerging non-volatile memory elements with flash memory
TWI476772B (en) * 2009-06-15 2015-03-11 Micron Technology Inc Use of emerging non-volatile memory elements with flash memory
KR101271912B1 (en) * 2009-06-15 2013-06-05 마이크론 테크놀로지, 인크 Use of emerging non-volatile memory elements with flash memory
US8462552B2 (en) 2009-06-15 2013-06-11 Micron Technology, Inc. Use of emerging non-volatile memory elements with flash memory
US20110141813A1 (en) * 2009-06-15 2011-06-16 Ramin Ghodsi Use of emerging non-volatile memory elements with flash memory
WO2010147770A3 (en) * 2009-06-15 2011-02-10 Micron Technology, Inc. Use of emerging non-volatile memory elements with flash memory
US8711628B2 (en) 2009-06-15 2014-04-29 Micron Technology, Inc. Use of emerging non-volatile memory elements with flash memory
TWI601140B (en) * 2009-06-15 2017-10-01 美光科技公司 Use of emerging non-volatile memory elements with flash memory
US20100315874A1 (en) * 2009-06-15 2010-12-16 Ramin Ghodsi Use of emerging non-volatile memory elements with flash memory
CN105261387A (en) * 2009-06-15 2016-01-20 美光科技公司 Use of emerging non-volatile memory elements with flash memory
US8345478B2 (en) 2009-06-15 2013-01-01 Micron Technology, Inc. Use of emerging non-volatile memory elements with flash memory
CN103858169A (en) * 2011-10-12 2014-06-11 国际商业机器公司 Multi-bit spin-momentum-transfer magnetoresistence random access memory with single magnetic-tunnel-junction stack
US8719492B1 (en) * 2013-03-08 2014-05-06 Avalanche Technology, Inc. Non-volatile storage module having magnetic random access memory (MRAM) with a buffer window
CN114415937A (en) * 2021-12-06 2022-04-29 北京航空航天大学 Nonvolatile storage memory controller and control method

Also Published As

Publication number Publication date
KR101391270B1 (en) 2014-05-02
WO2006124158A2 (en) 2006-11-23
US7245527B2 (en) 2007-07-17
WO2006124158A3 (en) 2007-04-05
KR20080007470A (en) 2008-01-21
JP2008546053A (en) 2008-12-18

Similar Documents

Publication Publication Date Title
KR101391270B1 (en) Nonvolatile memory system using magneto-resistive random access memoryMRAM
CN111383676B (en) Memory device, memory system and related methods
US8832360B2 (en) Solid state storage device controller with expansion mode
JP5728672B2 (en) Hybrid memory management
US9418017B2 (en) Hot memory block table in a solid state storage device
US7689761B2 (en) Data storage system with complex memory and method of operating the same
EP1960887B1 (en) Method for flash-memory management
JP4834676B2 (en) System and method using on-chip non-volatile memory write cache
US8966163B2 (en) Non-volatile memory device and method for programming the same
US20140149648A1 (en) Memory system with user configurable density/performance option
US7773420B2 (en) Memory card system including NAND flash memory and SRAM/NOR flash memory, and data storage method thereof
EP2345037A2 (en) Translation layer in a solid state storage device
US8127072B2 (en) Data storage device and method for accessing flash memory
CN106802870B (en) high-efficiency Nor-Flash controller of embedded system chip and control method
US8745312B2 (en) Storage device and method of mapping a nonvolatile memory based on a map history
KR100418522B1 (en) non-volatile semiconductor memory device having spare memory array address capable of moving and read operation therefore
CN113590505B (en) Address mapping method, solid state disk controller and solid state disk
KR100780963B1 (en) Memory card and driving method thereof
CN114968067A (en) Data sorting method using persistent memory and memory storage system

Legal Events

Date Code Title Description
AS Assignment

Owner name: FREESCALE SEMICONDUCTOR, INC., TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:QURESHI, QADEER A.;JEW, THOMAS;WYMAN, CURTIS F.;REEL/FRAME:016573/0227;SIGNING DATES FROM 20050513 TO 20050516

AS Assignment

Owner name: CITIBANK, N.A. AS COLLATERAL AGENT, NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNORS:FREESCALE SEMICONDUCTOR, INC.;FREESCALE ACQUISITION CORPORATION;FREESCALE ACQUISITION HOLDINGS CORP.;AND OTHERS;REEL/FRAME:018855/0129

Effective date: 20061201

Owner name: CITIBANK, N.A. AS COLLATERAL AGENT,NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNORS:FREESCALE SEMICONDUCTOR, INC.;FREESCALE ACQUISITION CORPORATION;FREESCALE ACQUISITION HOLDINGS CORP.;AND OTHERS;REEL/FRAME:018855/0129

Effective date: 20061201

STCF Information on status: patent grant

Free format text: PATENTED CASE

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

AS Assignment

Owner name: CITIBANK, N.A., NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNOR:FREESCALE SEMICONDUCTOR, INC.;REEL/FRAME:020518/0215

Effective date: 20071025

Owner name: CITIBANK, N.A.,NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNOR:FREESCALE SEMICONDUCTOR, INC.;REEL/FRAME:020518/0215

Effective date: 20071025

AS Assignment

Owner name: EVERSPIN TECHNOLOGIES, INC., ARIZONA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:FREESCALE SEMICONDUCTOR, INC.;REEL/FRAME:022597/0062

Effective date: 20090225

Owner name: EVERSPIN TECHNOLOGIES, INC.,ARIZONA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:FREESCALE SEMICONDUCTOR, INC.;REEL/FRAME:022597/0062

Effective date: 20090225

AS Assignment

Owner name: EVERSPIN TECHNOLOGIES, INC., ARIZONA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CITIBANK, N.A.;REEL/FRAME:024767/0398

Effective date: 20080605

FEPP Fee payment procedure

Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: EVERSPIN TECHNOLOGIES, INC., ARIZONA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:FREESCALE SEMICONDUCTOR, INC.;REEL/FRAME:036084/0057

Effective date: 20080606

AS Assignment

Owner name: FREESCALE SEMICONDUCTOR, INC., TEXAS

Free format text: PATENT RELEASE;ASSIGNOR:CITIBANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:037354/0704

Effective date: 20151207

Owner name: FREESCALE SEMICONDUCTOR, INC., TEXAS

Free format text: PATENT RELEASE;ASSIGNOR:CITIBANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:037354/0225

Effective date: 20151207

AS Assignment

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:038017/0058

Effective date: 20160218

AS Assignment

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12092129 PREVIOUSLY RECORDED ON REEL 038017 FRAME 0058. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:039361/0212

Effective date: 20160218

AS Assignment

Owner name: NXP B.V., NETHERLANDS

Free format text: PATENT RELEASE;ASSIGNOR:MORGAN STANLEY SENIOR FUNDING, INC.;REEL/FRAME:039707/0471

Effective date: 20160805

AS Assignment

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12681366 PREVIOUSLY RECORDED ON REEL 039361 FRAME 0212. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:042762/0145

Effective date: 20160218

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12681366 PREVIOUSLY RECORDED ON REEL 038017 FRAME 0058. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:042985/0001

Effective date: 20160218

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12

AS Assignment

Owner name: NXP B.V., NETHERLANDS

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:MORGAN STANLEY SENIOR FUNDING, INC.;REEL/FRAME:050745/0001

Effective date: 20190903

AS Assignment

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 042985 FRAME 0001. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:051029/0001

Effective date: 20160218

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 042762 FRAME 0145. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:051145/0184

Effective date: 20160218

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 039361 FRAME 0212. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:051029/0387

Effective date: 20160218

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION12298143 PREVIOUSLY RECORDED ON REEL 039361 FRAME 0212. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:051029/0387

Effective date: 20160218

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION 12298143 PREVIOUSLY RECORDED ON REEL 038017 FRAME 0058. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:051030/0001

Effective date: 20160218

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION12298143 PREVIOUSLY RECORDED ON REEL 042985 FRAME 0001. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:051029/0001

Effective date: 20160218

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., MARYLAND

Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REMOVE APPLICATION12298143 PREVIOUSLY RECORDED ON REEL 042762 FRAME 0145. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY AGREEMENT SUPPLEMENT;ASSIGNOR:NXP B.V.;REEL/FRAME:051145/0184

Effective date: 20160218