US20220115074A1 - Systems and methods of implementing a calibration wordline to compensate for voltage threshold shift in nand flash memory - Google Patents

Systems and methods of implementing a calibration wordline to compensate for voltage threshold shift in nand flash memory Download PDF

Info

Publication number
US20220115074A1
US20220115074A1 US17/070,590 US202017070590A US2022115074A1 US 20220115074 A1 US20220115074 A1 US 20220115074A1 US 202017070590 A US202017070590 A US 202017070590A US 2022115074 A1 US2022115074 A1 US 2022115074A1
Authority
US
United States
Prior art keywords
memory
read
voltage
memory cells
data pattern
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
US17/070,590
Other versions
US11309036B1 (en
Inventor
Chai Im Teoh
Lip Vui Kan
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.)
Dell Products LP
Original Assignee
Dell Products LP
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 Dell Products LP filed Critical Dell Products LP
Priority to US17/070,590 priority Critical patent/US11309036B1/en
Assigned to DELL PRODUCTS L.P. reassignment DELL PRODUCTS L.P. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: KAN, LIP VUI, TEOH, CHAI IM
Assigned to CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH reassignment CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH SECURITY AGREEMENT Assignors: DELL PRODUCTS L.P., EMC IP Holding Company LLC
Assigned to THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT reassignment THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DELL PRODUCTS L.P., EMC IP Holding Company LLC
Assigned to THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT reassignment THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DELL PRODUCTS L.P., EMC IP Holding Company LLC
Assigned to THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS COLLATERAL AGENT reassignment THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS COLLATERAL AGENT SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DELL PRODUCTS L.P., EMC IP Holding Company LLC
Assigned to DELL PRODUCTS L.P., EMC IP Holding Company LLC reassignment DELL PRODUCTS L.P. RELEASE OF SECURITY INTEREST AT REEL 054591 FRAME 0471 Assignors: CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH
Publication of US20220115074A1 publication Critical patent/US20220115074A1/en
Publication of US11309036B1 publication Critical patent/US11309036B1/en
Application granted granted Critical
Assigned to DELL PRODUCTS L.P., EMC IP Holding Company LLC reassignment DELL PRODUCTS L.P. RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0523) Assignors: THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT
Assigned to EMC IP Holding Company LLC, DELL PRODUCTS L.P. reassignment EMC IP Holding Company LLC RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0434) Assignors: THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT
Assigned to EMC IP Holding Company LLC, DELL PRODUCTS L.P. reassignment EMC IP Holding Company LLC RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0609) Assignors: THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/04Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS
    • G11C16/0483Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS comprising cells having several storage transistors connected in series
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1008Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
    • G06F11/1012Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices using codes or arrangements adapted for a specific type of error
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1008Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
    • G06F11/1068Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices in sector programmable memories, e.g. flash disk
    • 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/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • G06F3/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • 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/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0655Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
    • G06F3/0659Command handling arrangements, e.g. command buffers, queues, command scheduling
    • 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/56Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
    • G11C11/5621Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency using charge storage in a floating gate
    • G11C11/5642Sensing or reading circuits; Data output circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/56Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
    • G11C11/5671Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency using charge trapping in an insulator
    • 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/26Sensing or reading circuits; Data output circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C29/00Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
    • G11C29/02Detection or location of defective auxiliary circuits, e.g. defective refresh counters
    • G11C29/021Detection or location of defective auxiliary circuits, e.g. defective refresh counters in voltage or current generators
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C29/00Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
    • G11C29/02Detection or location of defective auxiliary circuits, e.g. defective refresh counters
    • G11C29/028Detection or location of defective auxiliary circuits, e.g. defective refresh counters with adaption or trimming of parameters

Definitions

  • This invention relates generally to non-volatile memory and, more particularly, to NAND flash memory.
  • An information handling system generally processes, compiles, stores, and/or communicates information or data for business, personal, or other purposes thereby allowing users to take advantage of the value of the information.
  • information handling systems may also vary regarding what information is handled, how the information is handled, how much information is processed, stored, or communicated, and how quickly and efficiently the information may be processed, stored, or communicated.
  • the variations in information handling systems allow for information handling systems to be general or configured for a specific user or specific use such as financial transaction processing, airline reservations, enterprise data storage, or global communications.
  • information handling systems may include a variety of hardware and software components that may be configured to process, store, and communicate information and may include one or more computer systems, data storage systems, and networking systems.
  • Solid-state storage devices e.g., solid-state drives
  • a solid-state drive is a data storage device that uses non-volatile solid-state memory to store persistent data that is retained while the system is powered off.
  • a SSD may emulate a hard disk drive interface to easily replace a hard disk drive, and SSDs often use NAND flash memory as an underlying storage medium.
  • a page is the smallest NAND unit which may be written, and a traditional single-level cell (SLC) NAND media stores one bit per cell.
  • SLC single-level cell
  • NAND memory has been scaled up in density by putting more bits in a single cell.
  • Examples of denser types of NAND media include what is commonly referred to as multi-level cell (MLC) memory having two bits per cell, triple-level cell (TLC) memory having three bits per cell, and quad-level cell (QLC) memory having four bits per cell.
  • MLC multi-level cell
  • TLC triple-level cell
  • QLC quad-level cell
  • SSD NAND memory includes flash memory cells.
  • Each flash memory cell is typically a floating gate Metal Oxide Semiconductor Field Effect transistor (MOSFET) that stores an electron charge. The charge is stored in a floating gate that is electrically connected to a bitline (BL).
  • a control gate is electrically connected to a wordline (WL) and overlies the floating gate. The control gate is separated from the floating gate by an oxide insulator, and the floating gate is separate from the source and drain of the memory cell substrate by an oxide insulator. Current flow between the source and drain of the memory cell may be controlled by combination of the floating gate transistor voltage and a voltage applied to the control gate. Thus, different voltage combinations that are applied to the WL and BL of a flash memory cell determine a read, erase or program (write) operation on the cell.
  • MOSFET Metal Oxide Semiconductor Field Effect transistor
  • a designated read compare voltage (Vr) is applied by a SSD controller to the control gate of the memory cell to read the charge on the floating gate, and the designated value of Vr depends on the voltage threshold (Vth) of the memory cell.
  • Vth voltage threshold
  • the floating gate of the memory cell reads as “0” when the floating gate contains an electron charge
  • the floating gate of memory cell reads as “1” when the floating gate contains no electron charge.
  • the floating gate is charged (0)
  • application of the correct Vr causes does not cause current to flow from source to drain of the memory cell.
  • the floating gate is not charged (1)
  • application of the correct Vr causes current to flow from source to drain of the memory cell. Therefore, data from the memory cell is read by determining whether or not current flows from source to drain when the correct Vr is applied to the control gate.
  • a NAND flash block consists of pages which are written and read as a unit.
  • a flash memory cell is located at every crossing point of wordlines (WL) and bitlines (BL).
  • Control gates are linked to the WL, where the decoded address is applied.
  • a page is defined as cells that are linked with the same WL.
  • a voltage is applied concurrently to the WL and BL by the SSD controller to determine the operation as reading, erasing or programming.
  • a WL in TLC has 3 pages, and in QLC has 4 pages.
  • SSD devices used for personal computers and tablets are required to meet a minimum power off data retention requirement, and should retain data in an unaltered form for a specified period of time.
  • power off data retention error is a reliability issue for NAND-based SSD products.
  • charge loss occurs from the nitride storage layer or floating gate in the NAND flash. This charge loss causes the Vth (and therefore Vr) distribution for the NAND flash cells to be shifted towards lower values, and the rate of electron escape increases with increasing temperatures.
  • Vr Raw Bit Error Rate
  • Vr read compare voltage level
  • the SSD controller uses SSD firmware to vary the Vr in an attempt to compensate for the Vth shift.
  • This SSD firmware is pre-programmed with a pre-defined table of fixed read-retry levels, and the SSD controller makes multiple read attempts by adjusting Vr levels according to the table entries until the read errors are corrected or determined to be uncorrectable.
  • the SSD controller will invoke a next stage of error correction, such as low-density parity-check (LDPC) and Redundant Array of Independent Disks (RAID). If the RBER are beyond correction capability, then the SSD returns uncorrectable errors to the host. At any stage of correction, SSD command response time will be longer, especially when deeper stages of the error correction mechanism are being invoked.
  • LDPC low-density parity-check
  • RAID Redundant Array of Independent Disks
  • SSD firmware integrates fixed read compare voltage levels that been defined during product design. SSD manufacturers run characterization on a given component at high and low temperature, and on a SSD component at high temperature acceleration for validation.
  • the pre-defined table of read-retry levels of the SSD firmware is determined based on NAND characterization performed by SSD manufacturers, and are based on temperature acceleration or a data extrapolation from a limited number of samples during development, i.e., the data is collected from a limited number of NAND samples and limited lots of same.
  • SSDs are built to ship with NAND wafers having much wider variance and skews.
  • conventional SSD users encounter data retention errors and uncorrectable errors in the field due to NAND charge loss and when the resulting RBER are not within the projected curve that has been plotted during NAND development.
  • CTF charge trap flash
  • MOSFET MOSFET having a charge trap layer that stores an electron charge in a manner similar to the above-described floating gate layer technology.
  • charge trap flash (CTF) memory technology instead uses a charge trap layer made of a silicon nitride insulator material in place of the conductive doped polycrystalline silicon floating gate layer. Read, erase and program (write) operations are similarly performed on a NAND charge trap layer as described above for a NAND floating gate layer.
  • each NAND block of a flash memory device may be programmed with at least one calibration wordline (WL).
  • the calibration WL may be the first or last WL of each NAND block, although any other WL (or combination of multiple WLs) of a given NAND block may be so programmed as a calibration WL, including WLs located between the first and last WLs of the given NAND block.
  • a single level of single-level cell (SLC) NAND memory may include at least one calibration WL having a pre-defined data pattern.
  • a pre-defined data pattern may cover all levels in NAND media devices that are denser than SLC, e.g., such as multi-level cell (MLC) memory having two bits per cell, triple-level cell (TLC) memory having three bits per cell, and quad-level cell (QLC) memory having four bits per cell.
  • MLC multi-level cell
  • TLC triple-level cell
  • QLC quad-level cell
  • the disclosed systems and methods may be implemented, for example, with memory structures using floating gate flash memory technology or using charge trap flash (CTF) flash memory technology).
  • the disclosed systems and methods may be automatically implemented by a SSD controller when needed to compensate for flash memory voltage threshold (Vth) shift that occurs, e.g., due to NAND memory cell charge loss due to power-off data retention over an extended period of time.
  • Vth flash memory voltage threshold
  • Such a shift in flash memory voltage threshold (Vth) may be detected by the SSD controller when at least a portion of the pages in a SSD NAND block return a high number of read errors (e.g., a high Raw Bit Error Rate (RBER)) when read by the SSD controller using the default read compare voltage (Vr).
  • RBER Raw Bit Error Rate
  • a high number of read errors may be predefined as a maximum threshold number of read errors (e.g., a high RBER value may be predefined as a maximum RBER threshold value) as desired to fit the needs or requirements of a given application.
  • a maximum threshold number of read errors e.g., a high RBER value may be predefined as a maximum RBER threshold value
  • any other technique may be employed that is suitable for determining a number of read errors or a read error rate.
  • the SSD controller may then read the predefined data pattern from the designated calibration WL of the same given SSD NAND block using a default Vr that is predefined for the SSD NAND flash memory device. The SSD controller may then compare this read data against a reference copy of the same predefined data pattern that has been previously saved in SSD firmware.
  • the SSD may then analyze any differences between the data of the data pattern read from the given NAND block designated calibration WL and the reference copy of the same predefined data pattern to estimate or determine a magnitude of voltage shift (Vsh) that has occurred in the Vth distribution due to the NAND memory cell charge loss, e.g., that has occurred due to SSD power-off data retention over an extended period of time.
  • the SSD controller may then calculate a new and corrected read compare voltage magnitude (Vr_1) by subtracting the same voltage shift magnitude (Vsh) from the default Vr level, and then may use the corrected Vr_1 to read data with a reduced RBER value from the entire given SSD NAND block.
  • the disclosed systems and methods may be implemented in one embodiment to provide a dynamic read-retry mechanism for NAND flash memory that does not require or use a conventional predefined fixed read-retry table.
  • the disclosed systems and methods may also be implemented in one embodiment to compensate and correct for high RBER data reads by reading corrected data from the given NAND flash memory block in a reduced amount of time and with greater rate of success as compared to conventional techniques.
  • the disclosed systems and methods may be implemented to successfully read corrected data from the given NAND flash memory block in a single read-retry step using a corrected read compare voltage magnitude (Vr_1), as opposed to a multiple number of read-retry steps that are typically required using a conventional read-retry table.
  • Vr_1 corrected read compare voltage magnitude
  • the disclosed pre-programmed calibration wordline/s thus allow corrected data to be read from a NAND flash memory block in less time than is typically required when using the conventional read-retry technique to exhaust multiple (and potentially all) entries in a conventional read-retry table, and especially when the conventional fixed read-retry table technique does not successfully correct the Vth shift read errors and therefore may further require low-density parity-check (LDPC) and Redundant Array of Independent Disks (RAID) correction mechanisms.
  • LDPC low-density parity-check
  • RAID Redundant Array of Independent Disks
  • the disclosed systems and methods may be advantageously implemented in a manner that caters to the unequal quality of different NAND die in a NAND SSD device.
  • floating gate (or charge trap) charge loss rate typically increases with the number of program/erase cycles
  • the Vth shift across pages in the same NAND block typically suffers the same extent due to the same program/erase cycles.
  • the amount of Vth shift may vary across different NAND die, even for those die from the same wafers or lots.
  • the disclosed systems and methods may be implemented to improve SSD data throughput performance without impacting reliability and endurance, and also to reduce the incidence of SSD firmware misjudging the health of NAND blocks. This in turn reduces field failure incidence rate.
  • the pre-defined data pattern that is written in a calibration WL of each NAND block does not consume much user NAND area compared to overall NAND block size. For example, each WL in typical TLC memory is 48 KB and 64 KB in QLC memory, while a typical 3D TLC NAND block size is 18 MB.
  • the predefined data pattern calibration data will consume only about 0.35% space of a typical 3D TLC NAND block. With increasing NAND block density for 3D TLC and QLC memory, the percentage of space taken by calibration data is even less.
  • SSD designers may consider the risk and impact of data retention, estimate spare blocks in each NAND die, and further calculate the number of spare blocks needed for calibration in SSD, to achieve a balanced design for SSD reliability.
  • a method including: reading data from at least one memory block using multiple separate wordlines, the at least one memory block including multiple memory pages that each include a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value, and each of the separate wordlines being coupled to a different group of the memory cells that corresponds to one of the memory pages of the at least one memory block; where a designated one of the multiple memory pages includes a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern.
  • the method may further include: reading a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr); then comparing the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern; and then determining an adjusted read compare voltage (Vr ⁇ 1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
  • Vr read compare voltage
  • a system including: at least one memory block including multiple memory pages that each include a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value; and at least one programmable integrated circuit coupled to multiple separate wordlines, each of the separate wordlines being coupled to a different group of memory cells that corresponds to one of the memory pages of the at least one memory block.
  • a designated one of the multiple memory pages may include a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern; and the at least one programmable integrated circuit may be programmed to: read a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr); then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern; and then determine an adjusted read compare voltage (Vr ⁇ 1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
  • Vr read compare voltage
  • an information handling system including: a host programmable integrated circuit; and a solid state drive (SSD) coupled to the host programmable integrated circuit.
  • the SSD may include: at least one memory block including multiple memory pages that each include a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value, and at least one programmable integrated circuit coupled to multiple separate wordlines, each of the separate wordlines being coupled to a different group of memory cells that corresponds to one of the memory pages of the at least one memory block.
  • a designated one of the multiple memory pages may include a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern; and the at least one programmable integrated circuit of the SSD may be programmed to: read a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr), then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern, then determine an adjusted read compare voltage (Vr ⁇ 1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page, then re-read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr ⁇ 1), and then provide the re-read data to the host programmable integrated circuit.
  • Vr read compare voltage
  • FIG. 1 illustrates a block diagram of an information handling system according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 2 illustrates a bock diagram of a solid state drive (SSD) according to one exemplary embodiment of the disclosed systems and methods.
  • SSD solid state drive
  • FIG. 3A illustrates a side perspective view a NAND block according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 3B illustrates a top view of a NAND block layer according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 4 illustrates voltage threshold (Vth) shift and correction thereof according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 5 illustrates voltage threshold (Vth) shift and correction thereof according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 6 illustrates methodology according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 1 is a block diagram of one embodiment of an information handling system 150 with which the disclosed systems and methods may be implemented to compensate for NAND flash memory voltage threshold (Vth) shift.
  • Information handling system 150 of FIG. 1 may be a computer server system, notebook computer system, convertible computer system, desktop computer system, computer workstation, etc. It will be understood that the system configuration of FIG. 1 is exemplary only, and that the disclosed systems and methods may be implemented to compensate for flash memory voltage threshold (Vth) shift for other NAND devices of other configurations and/or types of information handing system configuration including, but not limited to, cell phones or smart phones, tablet computers, set-top boxes, etc.
  • information handling system 150 of this exemplary embodiment includes at least one host programmable integrated circuit 155 , which may each be a central processing unit CPU (e.g., such as an Intel Pentium series processor, an Advanced Micro Devices (AMD) processor, etc.) or one of many other processors or other types of suitable processing devices configured to interpret and/or execute program instructions and/or process data.
  • programmable integrated circuit 155 may interpret and/or execute program instructions and/or process data stored in system volatile memory 165 , solid state drive (SSD) 187 , optional additional storage media 185 and/or another component of information handling system 150 .
  • SSD solid state drive
  • System-powered volatile memory 165 may be coupled as shown to host programmable integrated circuit 155 via platform controller hub (PCH) 160 which facilitates input/output functions for the information handling system.
  • System read only memory (ROM) 161 e.g., such as erasable programmable read only memory “EPROM”, electrically erasable programmable read only memory “EEPROM”, etc.
  • ROM read only memory
  • EPROM erasable programmable read only memory
  • EEPROM electrically erasable programmable read only memory
  • NIC network interface card
  • network 176 e.g., such as the Internet or local corporate intranet
  • SSD 187 may be an internal or external drive coupled to PCH 160 , and includes NAND Flash memory 208 and a microcontroller 206 acting as a SSD memory controller to provide storage for the information handling system.
  • optional additional storage 185 e.g., hard drive, optical drive, etc.
  • PCH 160 may also be coupled to PCH 160 to provide additional storage for information handling system 150 .
  • One or more input devices e.g., keyboard 195 , mouse/touchpad 197 , etc.
  • a display device 175 e.g., LED display, touchscreen display, etc.
  • iGPU integrated graphics processing unit
  • the exemplary information handling system 150 of this embodiment may also include an optional service processor 182 suitable for the given configuration of information handling system 150 (e.g., such as embedded controller, baseboard management controller “BMC”, etc.) and that is coupled to PCH 160 and its integrated controller chip as shown.
  • an optional service processor 182 suitable for the given configuration of information handling system 150 (e.g., such as embedded controller, baseboard management controller “BMC”, etc.) and that is coupled to PCH 160 and its integrated controller chip as shown.
  • BMC baseboard management controller
  • PCH 160 may be coupled to other components with optional interfaces such as a PCIe interface and device interfaces such as a USB (Universal Serial Bus) interface, for example.
  • a PCIe interface and device interfaces such as a USB (Universal Serial Bus) interface, for example.
  • SSD 187 may be configured as an integral component within a chassis of information handling system 150 (e.g., internal SSD), or may be alternatively configured as an attached external storage device.
  • FIG. 2 illustrates a block diagram of one exemplary embodiment of SSD 187 that stores information for information handling system 150 .
  • SSD 187 includes NAND flash non-volatile memory device 208 that includes multiple NAND blocks 210 1 to 210 N to which data is written to and read back by host programmable integrated circuit 155 across data bus 202 (e.g., high speed PCIe 3.0 bus or other suitable data bus such as serial advanced technology attachment “SATA”, serial attached SCSI “SAS”, etc.) via bus interface 204 .
  • data bus 202 e.g., high speed PCIe 3.0 bus or other suitable data bus such as serial advanced technology attachment “SATA”, serial attached SCSI “SAS”, etc.
  • a SSD flash memory controller 206 e.g., any suitable programmable integrated circuit such as microprocessor, microcontroller, ASIC, FPGA, etc.
  • controller memory 230 e.g., non-volatile flash memory
  • firmware includes read/write control logic 220 that may be used by controller 206 to control reads to and writes from the NAND blocks 210 of NAND flash memory device 208 , as well as Vth shift compensation logic 222 that may be used by controller 206 to compensate for NAND flash memory voltage threshold (Vth) shift based on contents of at least one calibration wordline (WL) provided in each NAND block of a flash memory device in a manners as descried further herein.
  • controller 206 may reference a mapping table of read/write control logic 220 in performing reads and writes in order to translate virtual logical block addresses (LBAs) of SSD 187 (as “seen” by host programmable integrated circuit 155 ) to physical block addresses of NAND blocks 210 of NAND flash memory device 208 .
  • Controller 206 may also reference a reference copy of a predefined data pattern that is written to a designated calibration WL of each SSD NAND block 210 .
  • the memory cells of the designated calibration WL may be reserved for storing the predefined data pattern, i.e., such that the predefined data pattern is maintained within the memory cells of the designated calibration WL and is not erased or overwritten by other data during operation of SSD 187 .
  • FIG. 3A illustrates a side perspective view of one of the NAND blocks 210 of NAND flash device 208 of FIG. 2 as it may be configured according to one exemplary embodiment of the disclosed systems and methods. It will be understood that each NAND block 210 of NAND flash device 208 may be similarly configured.
  • NAND block 210 is a quad-level cell (QLC) memory having four parallel layers 211 1 to 211 4 that are stacked together to provide four bits per memory cell 360 , with each group of four vertically aligned memory cells 360 of the stacked layers being vertically linked together as shown.
  • QLC quad-level cell
  • NAND blocks having a differing number of stacked parallel layers e.g., multi-level cell (MLC) memory having two stacked parallel layers providing two bits per cell, triple-level cell (TLC) memory having three stacked parallel layers providing three bits per cell, etc.
  • MLC multi-level cell
  • TLC triple-level cell
  • FIG. 3B illustrates a top view of layer 211 4 of NAND block 210 of FIG. 3A .
  • layer 211 4 includes an array (or matrix) of NAND memory cells 360 arranged in a pattern of parallel columns and parallel rows. More particularly, layer 211 4 has multiple parallel rows of NAND memory cells 360 , with the NAND memory cells 360 of each row being linked together by a different wordline (WL) that is electrically connected to the control gate of each NAND cell 360 to form a NAND flash page corresponding to each wordline of FIG. 3B .
  • WL wordline
  • layer 211 4 also has multiple parallel columns of NAND memory cells 360 , with the NAND cells 360 of each column being linked together by a different bitline (BL) that is electrically connected to the floating gate (or charge trap) of each NAND memory cell 360 to form a NAND flash string.
  • a floating gate of a memory cell 360 may be composed of a conductive doped polycrystalline silicon, and in another embodiment a charge trap layer of a memory cell 360 made be composed of a silicon nitride insulator material.
  • the memory cells 360 of each page of NAND flash block 210 may be written and read by SSD controller 206 as a unit.
  • a flash memory cell 360 is located at every crossing point of wordlines (WL) and bitlines (BL). Control gates are linked to the wordline, where the decoded address is applied.
  • Each page of memory block 210 is defined as memory cells 360 that are linked with the same wordline.
  • a voltage may be applied concurrently to the wordline and bitline by the SSD controller 206 to determine the operation as reading, erasing or programming.
  • each flash memory cell 360 of FIG. 3B may be a floating gate or charge trap MOSFET that stores an electron charge.
  • the charge of each memory cell may be stored in a floating gate or a charge trap that is electrically connected to a bitline.
  • a control gate of each memory cell 360 is electrically connected to a wordline and overlies the floating gate. The control gate is separated from the floating gate or charge trap by an oxide insulator, and the floating gate or charge trap is separate from the source and drain of a substrate of the memory cell 360 by an oxide insulator.
  • Current flow between the source and drain of the memory cell 360 may be controlled by combination of the floating gate or charge trap transistor voltage and a voltage applied to the control gate. Thus, different voltage combinations may be applied to the wordline and bitline of a given flash memory cell 360 to determine (or select) a read, erase or program (write) operation on the given memory cell 360 .
  • a designated read compare voltage may be applied by the SSD controller 206 to the control gate of the given memory cell 360 to read the charge on the floating gate or charge trap, and the designated value of Vr depends on the voltage threshold (Vth) of the memory cell, i.e., the floating gate or charge trap of the memory cell 360 reads as “0” when the floating gate or charge trap contains an electron charge, and the floating gate or charge trap of the memory cell 350 reads as “1” when the floating gate or charge trap contains no electron charge.
  • Vth voltage threshold
  • the memory cells 360 of at least one designated calibration wordline (WL C ) 350 of NAND block 210 may be programmed with a pre-defined data pattern, as shown by the dashed box labelled 350 .
  • the calibration WL C 350 is the first WL of NAND block 210 , although any other one or more wordlines of a given NAND block may be programmed with a pre-defined data pattern, including the last WL of a NAND block or any one or more wordlines located in-between the first WL and the last WL of NAND block 210 .
  • a calibration WL may be programmed with a pre-defined data pattern that covers all existing level/s of the given NAND block.
  • SSD controller 206 may write data to, read data from, and/or erase data from, the remaining memory cells 360 of the other (non-calibration) wordlines (WL D )'s of NAND block 210 that are different from the designated calibration wordline (WL C ) 350 ) in response to write, read and/or erase commands received by SSD controller 206 from host programmable integrated circuit 155 .
  • FIG. 4 illustrates an example of the effect of voltage threshold (Vth) shift caused by floating gate (or charge trap) charge loss during an extended data retention time for a triple-level cell (TLC) NAND memory block, and a correction according to one exemplary embodiment that may be made to Vr to compensate for this shift.
  • Vth initial threshold voltage
  • the initial threshold voltage (Vth) probability distribution of each of the two highest possible threshold voltage states “P6” and “P7” of TLC NAND memory is represented by a respective solid-line curve of probability density across all flash memory cells of a NAND flash memory device 208 that spans across a voltage window defined for that respective state.
  • the ER state corresponds to a “1” bit
  • the P1 state corresponds to a programmed “0” bit.
  • Vr a solid line default read compare voltage level (Vr) lies in-between and completely separates the P6 and P7 voltage windows from each other.
  • Vr may be used to correctly determine the difference between the P6 and P7 states, i.e., a read cell voltage less than Vr corresponds to the P6 state and a read cell voltage greater than Vr corresponds to the P7 state.
  • dashed-line probability density curves corresponding to each of shifted threshold voltage states P6 and P7 that exist after an elapsed data retention time.
  • floating gate (or charge trap) charge loss causes a portion of the shifted voltage threshold probability density curve of the P7 state to drop below the original default read compare voltage level (Vr), i.e., as shown in FIG. 4 by the hashed area of the P7 probability density curve which lies to the left of the original solid default Vr level line. Therefore, those read P7 voltage values that lie below the original default level (Vr) will yield an incorrect determination of a “P6” state when read after the elapsed data retention time.
  • Vr original default read compare voltage level
  • the amount of voltage threshold shift between the original and shifted probability density curves may be expressed by determining the voltage difference ( ⁇ Vm) between the original voltage threshold median (Vm) of a given probability density curve to the shifted voltage threshold median (Vm ⁇ 1) of the same given probability density curve.
  • an adjusted read compare level (Vr ⁇ 1) is determined as shown by the dashed line in FIG. 4 .
  • the value of the adjusted Vr ⁇ 1 may be determined by shifting the value of the original default read compare voltage level Vr downward by a voltage difference ( ⁇ Vr) that is equal to the measured difference in voltage ( ⁇ Vm) of the voltage shift between Vm and Vm ⁇ 1.
  • ⁇ Vr voltage difference
  • the resulting dashed-line adjusted read compare voltage (Vr ⁇ 1) completely separates the shifted P6 and P7 voltage windows from each other after floating gate (or charge trap) charge loss during data retention.
  • Vr ⁇ 1 may be used to correctly determine the difference between the P6 and P7 states, i.e., a read cell voltage less than Vr ⁇ 1 corresponds to the P6 state and a read cell voltage greater than Vr ⁇ 1 corresponds to the P7 state.
  • FIG. 5 illustrates another example of the effect of voltage threshold (Vth) shift caused by floating gate (or charge trap) charge loss during an extended data retention time for a tri-level cell (QLC) NAND memory block.
  • Vth voltage threshold
  • the initial threshold voltage (Vth) probability distribution of each of eight possible voltage states “ER” and “P1” to “P7” is represented by a respective curve of probability density across all flash memory cells of a NAND flash memory device 208 for the voltage window corresponding to that respective voltage state.
  • bit values most significant bit, center significant bit, and least significant bit
  • Va voltage level
  • Vh voltage level
  • the default read compare level Vr may be used to correctly determine the existing voltage state of that memory cell, i.e., a read cell voltage greater than Ve and less than Vf corresponds to the P5 voltage state (000).
  • a designated calibration WL of a given SSD NAND block may be programmed with a predefined TLC data pattern P7 of 110, which initially corresponds to a Vr between Vg and Vh.
  • the predefined TLC data pattern is also stored in firmware to use for comparison to actual read data patterns. Assume now that during SSD operation the Vr read out for the memory cells of the calibration WL is instead between Ve and Vf, which corresponds to TLC data pattern P5 of 000.
  • This actual read data pattern P5 may then be compared to the predefined TLC data pattern stored in firmware (e.g., by analyzing data shift pattern and statistics using Vth shift compensation logic 222 ) to determine how much voltage shift in the Vth distribution has occurred, and then to apply the same amount of voltage shift to Vr to calculate a new Vr ⁇ 1 value. For example, in the present case, it may be determined that a Vth shift downward has occurred that corresponds to a ⁇ Vm of X mV ⁇ tolerance, e.g., due to floating gate (or charge trap) charge loss that has occurred during a data retention time period. This same downward Vth shift may then be applied to shift the default Vr value downward to determine the new Vr ⁇ 1 value.
  • the value of “X” millivolts corresponds to the Vth difference between Vm8 and Vm6 that is determined by the comparison to the stored predefined TLC data pattern.
  • the read compare level Vr is also shifted downward by the same X mV ⁇ tolerance to compensate for the measured downward Vth shift before executing a read retry of the memory cells of the given SSD NAND block.
  • the memory cells of designated calibration WL will correctly read between Vg and Vh.
  • the memory cells of the remaining WLs of the SSD NAND block may also be correctly read using the new reduced read compare level Vr.
  • FIG. 6 illustrates methodology 600 that may be performed (e.g., by SSD controller 206 ) to compensate for NAND flash memory voltage threshold (Vth) shift such as described above in relation to FIG. 5 , it being understood that methodology 600 may be performed by SSD controller 206 in one embodiment to separately compensate for NAND flash memory voltage threshold (Vth) shift in each of the different NAND blocks 210 of NAND flash device 208 of FIG. 2 .
  • methodology 600 begins in step 602 where a normal read of one or more NAND blocks 210 is made using the default original read compare level Vr, e.g., in response to a read request received by SSD controller 206 from host programmable integrated circuit 155 .
  • a checksum of the read data may be computed and compared to parity in step 604 to determine if the number of read errors (e.g., expressed as number of read errors or a read error rate such as RBER) falls within a maximum acceptable number of read errors, e.g., defined by a maximum checksum error threshold. If the number of read errors fall within the maximum acceptable error threshold in step 604 , then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155 .
  • any other alternative technique may be employed in step 604 that is suitable for determining a number of read errors and/or a read error rate.
  • methodology 600 proceeds to step 608 where an optional read-retry of the NAND block/s 210 is again made using the default read compare level Vr.
  • a checksum of the read-retry data is computed and compared to parity in step 610 to determine if the number of read errors again falls within a maximum acceptable number of errors defined by the maximum checksum error threshold. If the number of read errors again falls within the maximum acceptable error threshold in step 610 , then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155 .
  • step 610 methodology 600 proceeds to step 612 where a dynamic read-retry of the calibration WL 350 of the NAND block/s 210 is made using the original default read compare level Vr to read a value of the data pattern of the memory cells in the calibration WL 350 . Then in step 614 the read data pattern value of step 612 is compared to a stored value of the pre-defined data pattern that is maintained in non-volatile memory of the firmware 230 of the SSD controller 187 . This comparison may be made to determine a compensated read compare level Vr ⁇ 1, for example, according to the methodology described in relation to FIG. 5 .
  • a read of the one or more NAND blocks 210 is made in step 616 using the new compensated read compare level Vr ⁇ 1.
  • a checksum of the data read in step 616 is then computed and compared to parity in step 618 to determine if the number of read errors falls within a maximum acceptable number of read errors defined by the maximum checksum read error threshold. If the number of errors fall within the maximum acceptable error threshold in step 618 , then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155 .
  • methodology 600 proceeds to optional step 620 where a soft low density parity code (LDPC) decode operation may be performed, and then checksum of the resulting data computed and compared to parity in step 622 . If the number of read errors falls within the maximum acceptable error threshold in step 622 , then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155 .
  • LDPC soft low density parity code
  • methodology 600 proceeds to optional step 624 where a hard LDPC decode operation may be performed, and then checksum of the resulting data computed and compared to parity in step 626 . If the number of read errors falls within the maximum acceptable error threshold in step 626 , then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155 .
  • methodology 600 proceeds to optional step 628 where data correction and/or reconstruction is performed from a redundant array of independent disks (RAID), and the resulting data is reported as read in step 606 to the host programmable integrated circuit 155 .
  • RAID redundant array of independent disks
  • an information handling system or component thereof may be implemented by circuitry and/or by a computer program of instructions (e.g., computer readable code such as firmware code or software code) embodied in a non-transitory tangible computer readable medium (e.g., optical disk, magnetic disk, non-volatile memory device, etc.), in which the computer program comprising instructions are configured when executed on a programmable integrated circuit (e.g., processor such as CPU, controller, microcontroller, microprocessor, ASIC, etc.
  • a programmable integrated circuit e.g., processor such as CPU, controller, microcontroller, microprocessor, ASIC, etc.
  • programmable logic device such as FPGA, complex programmable logic device “CPLD”, etc.
  • PLD programmable logic device
  • a group of such programmable integrated circuits may be selected from the group consisting of CPU, controller, microcontroller, microprocessor, FPGA, CPLD and ASIC.
  • the computer program of instructions may include an ordered listing of executable instructions for implementing logical functions in an information handling system or component thereof.
  • the executable instructions may include a plurality of code segments operable to instruct components of an information handling system to perform the methodologies disclosed herein. It will also be understood that one or more steps of the present methodologies may be employed in one or more code segments of the computer program.
  • a code segment executed by the information handling system may include one or more steps of the disclosed methodologies.
  • a programmable integrated circuit may be configured to execute or otherwise be programmed with software, firmware, logic, and/or other program instructions stored in one or more non-transitory tangible computer-readable mediums (e.g., example, data storage devices, flash memories, random update memories, read only memories, programmable memory devices, reprogrammable storage devices, hard drives, floppy disks, DVDs, CD-ROMs, and/or any other tangible data storage mediums) to perform the operations, tasks, functions, or actions described herein for the disclosed embodiments.
  • non-transitory tangible computer-readable mediums e.g., example, data storage devices, flash memories, random update memories, read only memories, programmable memory devices, reprogrammable storage devices, hard drives, floppy disks, DVDs, CD-ROMs, and/or any other tangible data storage mediums
  • an information handling system may include any instrumentality or aggregate of instrumentalities operable to compute, calculate, determine, classify, process, transmit, receive, retrieve, originate, switch, store, display, communicate, manifest, detect, record, reproduce, handle, or utilize any form of information, intelligence, or data for business, scientific, control, or other purposes.
  • an information handling system may be a personal computer (e.g., desktop or laptop), tablet computer, mobile device (e.g., personal digital assistant (PDA) or smart phone), server (e.g., blade server or rack server), a network storage device, or any other suitable device and may vary in size, shape, performance, functionality, and price.
  • the information handling system may include random update memory (RAM), one or more processing resources such as a central processing unit (CPU) or hardware or software control logic, ROM, and/or other types of nonvolatile memory. Additional components of the information handling system may include one or more disk drives, one or more network ports for communicating with external devices as well as various input and output (I/O) devices, such as a keyboard, a mouse, touch screen and/or a video display. The information handling system may also include one or more buses operable to transmit communications between the various hardware components.
  • RAM random update memory
  • processing resources such as a central processing unit (CPU) or hardware or software control logic
  • ROM read-only memory
  • Additional components of the information handling system may include one or more disk drives, one or more network ports for communicating with external devices as well as various input and output (I/O) devices, such as a keyboard, a mouse, touch screen and/or a video display.
  • I/O input and output
  • the information handling system may also include one or more buses operable to transmit communications between

Abstract

Systems and methods that may be implemented for that may be implemented to compensate for NAND flash memory voltage threshold (Vth) shift by using one or more designated calibration wordlines that are programmed into the NAND flash memory with a pre-defined data pattern. In one example configuration, the disclosed systems and methods may be automatically implemented by a SSD controller when needed to compensate for flash memory voltage threshold (Vth) shift that occurs, e.g., due to NAND memory cell charge loss due to power-off data retention over an extended period of time.

Description

    FIELD
  • This invention relates generally to non-volatile memory and, more particularly, to NAND flash memory.
  • BACKGROUND
  • As the value and use of information continues to increase, individuals and businesses seek additional ways to process and store information. One option available to users is information handling systems. An information handling system generally processes, compiles, stores, and/or communicates information or data for business, personal, or other purposes thereby allowing users to take advantage of the value of the information. Because technology and information handling needs and requirements vary between different users or applications, information handling systems may also vary regarding what information is handled, how the information is handled, how much information is processed, stored, or communicated, and how quickly and efficiently the information may be processed, stored, or communicated. The variations in information handling systems allow for information handling systems to be general or configured for a specific user or specific use such as financial transaction processing, airline reservations, enterprise data storage, or global communications. In addition, information handling systems may include a variety of hardware and software components that may be configured to process, store, and communicate information and may include one or more computer systems, data storage systems, and networking systems.
  • Information handling systems employ solid-state storage devices, (e.g., solid-state drives) to store data and programs of instructions for later retrieval. A solid-state drive (SSD) is a data storage device that uses non-volatile solid-state memory to store persistent data that is retained while the system is powered off. A SSD may emulate a hard disk drive interface to easily replace a hard disk drive, and SSDs often use NAND flash memory as an underlying storage medium. A page is the smallest NAND unit which may be written, and a traditional single-level cell (SLC) NAND media stores one bit per cell. However, NAND memory has been scaled up in density by putting more bits in a single cell. Examples of denser types of NAND media include what is commonly referred to as multi-level cell (MLC) memory having two bits per cell, triple-level cell (TLC) memory having three bits per cell, and quad-level cell (QLC) memory having four bits per cell.
  • SSD NAND memory includes flash memory cells. Each flash memory cell is typically a floating gate Metal Oxide Semiconductor Field Effect transistor (MOSFET) that stores an electron charge. The charge is stored in a floating gate that is electrically connected to a bitline (BL). A control gate is electrically connected to a wordline (WL) and overlies the floating gate. The control gate is separated from the floating gate by an oxide insulator, and the floating gate is separate from the source and drain of the memory cell substrate by an oxide insulator. Current flow between the source and drain of the memory cell may be controlled by combination of the floating gate transistor voltage and a voltage applied to the control gate. Thus, different voltage combinations that are applied to the WL and BL of a flash memory cell determine a read, erase or program (write) operation on the cell.
  • To read a NAND flash memory cell, a designated read compare voltage (Vr) is applied by a SSD controller to the control gate of the memory cell to read the charge on the floating gate, and the designated value of Vr depends on the voltage threshold (Vth) of the memory cell. In this regard, the floating gate of the memory cell reads as “0” when the floating gate contains an electron charge, and the floating gate of memory cell reads as “1” when the floating gate contains no electron charge. When the floating gate is charged (0), application of the correct Vr causes does not cause current to flow from source to drain of the memory cell. However, when the floating gate is not charged (1), application of the correct Vr causes current to flow from source to drain of the memory cell. Therefore, data from the memory cell is read by determining whether or not current flows from source to drain when the correct Vr is applied to the control gate.
  • A NAND flash block consists of pages which are written and read as a unit. A flash memory cell is located at every crossing point of wordlines (WL) and bitlines (BL). Control gates are linked to the WL, where the decoded address is applied. A page is defined as cells that are linked with the same WL. A voltage is applied concurrently to the WL and BL by the SSD controller to determine the operation as reading, erasing or programming. A WL in TLC has 3 pages, and in QLC has 4 pages.
  • SSD devices used for personal computers and tablets are required to meet a minimum power off data retention requirement, and should retain data in an unaltered form for a specified period of time. However, power off data retention error is a reliability issue for NAND-based SSD products. In particular, when a NAND-based SSD is powered off, charge loss occurs from the nitride storage layer or floating gate in the NAND flash. This charge loss causes the Vth (and therefore Vr) distribution for the NAND flash cells to be shifted towards lower values, and the rate of electron escape increases with increasing temperatures. When the NAND-based SSD is powered back on, the shifted Vth will cause a high Raw Bit Error Rate (RBER) during data read out.
  • During data read out, data read from NAND flash cells of a conventional SSD is compared by the SSD controller against a default read compare voltage level (Vr). If the read data exhibits a high RBER due to a shifted Vth such as described above, then the SSD controller will initiate a read-retry operation. During the read-retry operation, the SSD controller uses SSD firmware to vary the Vr in an attempt to compensate for the Vth shift. This SSD firmware is pre-programmed with a pre-defined table of fixed read-retry levels, and the SSD controller makes multiple read attempts by adjusting Vr levels according to the table entries until the read errors are corrected or determined to be uncorrectable. If all read-retry entries in the table are attempted and the read errors are still uncorrectable, the SSD controller will invoke a next stage of error correction, such as low-density parity-check (LDPC) and Redundant Array of Independent Disks (RAID). If the RBER are beyond correction capability, then the SSD returns uncorrectable errors to the host. At any stage of correction, SSD command response time will be longer, especially when deeper stages of the error correction mechanism are being invoked.
  • Conventional SSD firmware integrates fixed read compare voltage levels that been defined during product design. SSD manufacturers run characterization on a given component at high and low temperature, and on a SSD component at high temperature acceleration for validation. The pre-defined table of read-retry levels of the SSD firmware is determined based on NAND characterization performed by SSD manufacturers, and are based on temperature acceleration or a data extrapolation from a limited number of samples during development, i.e., the data is collected from a limited number of NAND samples and limited lots of same. However, when a qualified SSD enter mass production, SSDs are built to ship with NAND wafers having much wider variance and skews. As a result, conventional SSD users encounter data retention errors and uncorrectable errors in the field due to NAND charge loss and when the resulting RBER are not within the projected curve that has been plotted during NAND development.
  • Conventional SSD NAND flash memory cells are also implemented using charge trap flash (CTF) memory technology that employs a MOSFET having a charge trap layer that stores an electron charge in a manner similar to the above-described floating gate layer technology. However, whereas conventional floating gate technology utilizes a conductive doped polycrystalline silicon floating gate layer, charge trap flash (CTF) memory technology instead uses a charge trap layer made of a silicon nitride insulator material in place of the conductive doped polycrystalline silicon floating gate layer. Read, erase and program (write) operations are similarly performed on a NAND charge trap layer as described above for a NAND floating gate layer.
  • SUMMARY
  • Disclosed herein are systems and methods that may be implemented in one embodiment to compensate for NAND flash memory voltage threshold (Vth) shift by using one or more designated calibration wordlines that are programmed into the NAND flash memory with a pre-defined data pattern. In one exemplary embodiment, each NAND block of a flash memory device (e.g., such as a SSD NAND flash memory device) may be programmed with at least one calibration wordline (WL). The calibration WL may be the first or last WL of each NAND block, although any other WL (or combination of multiple WLs) of a given NAND block may be so programmed as a calibration WL, including WLs located between the first and last WLs of the given NAND block. In one embodiment, a single level of single-level cell (SLC) NAND memory may include at least one calibration WL having a pre-defined data pattern. In other embodiments, a pre-defined data pattern may cover all levels in NAND media devices that are denser than SLC, e.g., such as multi-level cell (MLC) memory having two bits per cell, triple-level cell (TLC) memory having three bits per cell, and quad-level cell (QLC) memory having four bits per cell. The disclosed systems and methods may be implemented, for example, with memory structures using floating gate flash memory technology or using charge trap flash (CTF) flash memory technology).
  • In one example embodiment, the disclosed systems and methods may be automatically implemented by a SSD controller when needed to compensate for flash memory voltage threshold (Vth) shift that occurs, e.g., due to NAND memory cell charge loss due to power-off data retention over an extended period of time. Such a shift in flash memory voltage threshold (Vth) may be detected by the SSD controller when at least a portion of the pages in a SSD NAND block return a high number of read errors (e.g., a high Raw Bit Error Rate (RBER)) when read by the SSD controller using the default read compare voltage (Vr). In one embodiment, a high number of read errors may be predefined as a maximum threshold number of read errors (e.g., a high RBER value may be predefined as a maximum RBER threshold value) as desired to fit the needs or requirements of a given application. However, any other technique may be employed that is suitable for determining a number of read errors or a read error rate.
  • Upon detection of a high RBER value when reading data from a given block of a SSD NAND flash memory device, the SSD controller may then read the predefined data pattern from the designated calibration WL of the same given SSD NAND block using a default Vr that is predefined for the SSD NAND flash memory device. The SSD controller may then compare this read data against a reference copy of the same predefined data pattern that has been previously saved in SSD firmware. The SSD may then analyze any differences between the data of the data pattern read from the given NAND block designated calibration WL and the reference copy of the same predefined data pattern to estimate or determine a magnitude of voltage shift (Vsh) that has occurred in the Vth distribution due to the NAND memory cell charge loss, e.g., that has occurred due to SSD power-off data retention over an extended period of time. The SSD controller may then calculate a new and corrected read compare voltage magnitude (Vr_1) by subtracting the same voltage shift magnitude (Vsh) from the default Vr level, and then may use the corrected Vr_1 to read data with a reduced RBER value from the entire given SSD NAND block.
  • The disclosed systems and methods may be implemented in one embodiment to provide a dynamic read-retry mechanism for NAND flash memory that does not require or use a conventional predefined fixed read-retry table. The disclosed systems and methods may also be implemented in one embodiment to compensate and correct for high RBER data reads by reading corrected data from the given NAND flash memory block in a reduced amount of time and with greater rate of success as compared to conventional techniques. In this regard, the disclosed systems and methods may be implemented to successfully read corrected data from the given NAND flash memory block in a single read-retry step using a corrected read compare voltage magnitude (Vr_1), as opposed to a multiple number of read-retry steps that are typically required using a conventional read-retry table. The disclosed pre-programmed calibration wordline/s thus allow corrected data to be read from a NAND flash memory block in less time than is typically required when using the conventional read-retry technique to exhaust multiple (and potentially all) entries in a conventional read-retry table, and especially when the conventional fixed read-retry table technique does not successfully correct the Vth shift read errors and therefore may further require low-density parity-check (LDPC) and Redundant Array of Independent Disks (RAID) correction mechanisms.
  • The disclosed systems and methods may be advantageously implemented in a manner that caters to the unequal quality of different NAND die in a NAND SSD device. Given that floating gate (or charge trap) charge loss rate typically increases with the number of program/erase cycles, the Vth shift across pages in the same NAND block typically suffers the same extent due to the same program/erase cycles. However, the amount of Vth shift may vary across different NAND die, even for those die from the same wafers or lots. Moreover, there are outlier NAND die/s that exhibit Vth shift characteristics that do not follow the manufacturer's estimation during product development. These types of Vth shift variations are correctable with use of the calibration wordline of the disclosed systems and methods, but are not covered or taken into account by the conventional technique using a fixed table of read-retry levels.
  • Thus, the disclosed systems and methods may be implemented to improve SSD data throughput performance without impacting reliability and endurance, and also to reduce the incidence of SSD firmware misjudging the health of NAND blocks. This in turn reduces field failure incidence rate. Moreover, the pre-defined data pattern that is written in a calibration WL of each NAND block does not consume much user NAND area compared to overall NAND block size. For example, each WL in typical TLC memory is 48 KB and 64 KB in QLC memory, while a typical 3D TLC NAND block size is 18 MB. Thus, the predefined data pattern calibration data will consume only about 0.35% space of a typical 3D TLC NAND block. With increasing NAND block density for 3D TLC and QLC memory, the percentage of space taken by calibration data is even less. Further, SSD designers may consider the risk and impact of data retention, estimate spare blocks in each NAND die, and further calculate the number of spare blocks needed for calibration in SSD, to achieve a balanced design for SSD reliability.
  • In one respect, disclosed herein is a method, including: reading data from at least one memory block using multiple separate wordlines, the at least one memory block including multiple memory pages that each include a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value, and each of the separate wordlines being coupled to a different group of the memory cells that corresponds to one of the memory pages of the at least one memory block; where a designated one of the multiple memory pages includes a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern. The method may further include: reading a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr); then comparing the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern; and then determining an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
  • In another respect, disclosed herein is a system, including: at least one memory block including multiple memory pages that each include a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value; and at least one programmable integrated circuit coupled to multiple separate wordlines, each of the separate wordlines being coupled to a different group of memory cells that corresponds to one of the memory pages of the at least one memory block. A designated one of the multiple memory pages may include a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern; and the at least one programmable integrated circuit may be programmed to: read a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr); then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern; and then determine an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
  • In another respect, disclosed herein is an information handling system, including: a host programmable integrated circuit; and a solid state drive (SSD) coupled to the host programmable integrated circuit. The SSD may include: at least one memory block including multiple memory pages that each include a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value, and at least one programmable integrated circuit coupled to multiple separate wordlines, each of the separate wordlines being coupled to a different group of memory cells that corresponds to one of the memory pages of the at least one memory block. A designated one of the multiple memory pages may include a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern; and the at least one programmable integrated circuit of the SSD may be programmed to: read a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr), then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern, then determine an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page, then re-read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr−1), and then provide the re-read data to the host programmable integrated circuit.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 illustrates a block diagram of an information handling system according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 2 illustrates a bock diagram of a solid state drive (SSD) according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 3A illustrates a side perspective view a NAND block according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 3B illustrates a top view of a NAND block layer according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 4 illustrates voltage threshold (Vth) shift and correction thereof according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 5 illustrates voltage threshold (Vth) shift and correction thereof according to one exemplary embodiment of the disclosed systems and methods.
  • FIG. 6 illustrates methodology according to one exemplary embodiment of the disclosed systems and methods.
  • DESCRIPTION OF ILLUSTRATIVE EMBODIMENTS
  • FIG. 1 is a block diagram of one embodiment of an information handling system 150 with which the disclosed systems and methods may be implemented to compensate for NAND flash memory voltage threshold (Vth) shift. Information handling system 150 of FIG. 1 may be a computer server system, notebook computer system, convertible computer system, desktop computer system, computer workstation, etc. It will be understood that the system configuration of FIG. 1 is exemplary only, and that the disclosed systems and methods may be implemented to compensate for flash memory voltage threshold (Vth) shift for other NAND devices of other configurations and/or types of information handing system configuration including, but not limited to, cell phones or smart phones, tablet computers, set-top boxes, etc.
  • As shown in FIG. 1, information handling system 150 of this exemplary embodiment includes at least one host programmable integrated circuit 155, which may each be a central processing unit CPU (e.g., such as an Intel Pentium series processor, an Advanced Micro Devices (AMD) processor, etc.) or one of many other processors or other types of suitable processing devices configured to interpret and/or execute program instructions and/or process data. In some embodiments, programmable integrated circuit 155 may interpret and/or execute program instructions and/or process data stored in system volatile memory 165, solid state drive (SSD) 187, optional additional storage media 185 and/or another component of information handling system 150. System-powered volatile memory 165 (e.g., dynamic random access memory DRAM) may be coupled as shown to host programmable integrated circuit 155 via platform controller hub (PCH) 160 which facilitates input/output functions for the information handling system. System read only memory (ROM) 161 (e.g., such as erasable programmable read only memory “EPROM”, electrically erasable programmable read only memory “EEPROM”, etc.) is also provided as shown for storing start up firmware, such as system BIOS. Also shown coupled to host programmable integrated circuit 155 is network interface card (NIC) 157 that is provided to enable communication across network 176 (e.g., such as the Internet or local corporate intranet) with various multiple information handling systems configured as network devices 178 1-178 N.
  • Still referring to FIG. 1, SSD 187 may be an internal or external drive coupled to PCH 160, and includes NAND Flash memory 208 and a microcontroller 206 acting as a SSD memory controller to provide storage for the information handling system. As shown, optional additional storage 185 (e.g., hard drive, optical drive, etc.) may also be coupled to PCH 160 to provide additional storage for information handling system 150. One or more input devices (e.g., keyboard 195, mouse/touchpad 197, etc.) may be optionally coupled to PCH 160 and its controller chip to enable the user to interact with the information handling system 150 and programs or other software/firmware executing thereon. A display device 175 (e.g., LED display, touchscreen display, etc.) may be coupled as shown to an integrated graphics processing unit (iGPU) of host programmable integrated circuit 155 for display of information to a user.
  • As further shown in this embodiment, the exemplary information handling system 150 of this embodiment may also include an optional service processor 182 suitable for the given configuration of information handling system 150 (e.g., such as embedded controller, baseboard management controller “BMC”, etc.) and that is coupled to PCH 160 and its integrated controller chip as shown. It will be understood that the particular combination of information handling system components of FIG. 1 is exemplary only, and that the disclosed systems and methods may be implemented with an information handling system that includes any other suitable combination of additional, fewer or alternative information handling system components (e.g., including one or more programmable integrated circuits).
  • In the embodiment of FIG. 1, PCH 160 may be coupled to other components with optional interfaces such as a PCIe interface and device interfaces such as a USB (Universal Serial Bus) interface, for example. It will be understood that SSD 187 may be configured as an integral component within a chassis of information handling system 150 (e.g., internal SSD), or may be alternatively configured as an attached external storage device.
  • FIG. 2 illustrates a block diagram of one exemplary embodiment of SSD 187 that stores information for information handling system 150. In the embodiment of FIG. 2, SSD 187 includes NAND flash non-volatile memory device 208 that includes multiple NAND blocks 210 1 to 210 N to which data is written to and read back by host programmable integrated circuit 155 across data bus 202 (e.g., high speed PCIe 3.0 bus or other suitable data bus such as serial advanced technology attachment “SATA”, serial attached SCSI “SAS”, etc.) via bus interface 204. As shown, a SSD flash memory controller 206 (e.g., any suitable programmable integrated circuit such as microprocessor, microcontroller, ASIC, FPGA, etc.) is coupled to controller memory 230 (e.g., non-volatile flash memory) that stores firmware that includes read/write control logic 220 that may be used by controller 206 to control reads to and writes from the NAND blocks 210 of NAND flash memory device 208, as well as Vth shift compensation logic 222 that may be used by controller 206 to compensate for NAND flash memory voltage threshold (Vth) shift based on contents of at least one calibration wordline (WL) provided in each NAND block of a flash memory device in a manners as descried further herein.
  • In one embodiment, controller 206 may reference a mapping table of read/write control logic 220 in performing reads and writes in order to translate virtual logical block addresses (LBAs) of SSD 187 (as “seen” by host programmable integrated circuit 155) to physical block addresses of NAND blocks 210 of NAND flash memory device 208. Controller 206 may also reference a reference copy of a predefined data pattern that is written to a designated calibration WL of each SSD NAND block 210. In one exemplary embodiment, the memory cells of the designated calibration WL may be reserved for storing the predefined data pattern, i.e., such that the predefined data pattern is maintained within the memory cells of the designated calibration WL and is not erased or overwritten by other data during operation of SSD 187.
  • Further information on possible components and operation of an information handing system 150 and/or NAND flash memory device 187 may be found in U.S. Pat. Nos. 8,239,618; 8,671,241; 8,266,354; and 10,275,162, each of which is incorporated herein by reference in its entirety for all purposes.
  • FIG. 3A illustrates a side perspective view of one of the NAND blocks 210 of NAND flash device 208 of FIG. 2 as it may be configured according to one exemplary embodiment of the disclosed systems and methods. It will be understood that each NAND block 210 of NAND flash device 208 may be similarly configured. In the embodiment of FIG. 3A, NAND block 210 is a quad-level cell (QLC) memory having four parallel layers 211 1 to 211 4 that are stacked together to provide four bits per memory cell 360, with each group of four vertically aligned memory cells 360 of the stacked layers being vertically linked together as shown. Although an exemplary quad-level cell (QLC) embodiment is shown in FIG. 3A, it will be understood that the disclosed systems and methods may be similarly implemented for NAND blocks having a differing number of stacked parallel layers, e.g., multi-level cell (MLC) memory having two stacked parallel layers providing two bits per cell, triple-level cell (TLC) memory having three stacked parallel layers providing three bits per cell, etc.
  • FIG. 3B illustrates a top view of layer 211 4 of NAND block 210 of FIG. 3A. As shown in FIG. 3B, layer 211 4 includes an array (or matrix) of NAND memory cells 360 arranged in a pattern of parallel columns and parallel rows. More particularly, layer 211 4 has multiple parallel rows of NAND memory cells 360, with the NAND memory cells 360 of each row being linked together by a different wordline (WL) that is electrically connected to the control gate of each NAND cell 360 to form a NAND flash page corresponding to each wordline of FIG. 3B. As also shown in FIG. 3B, layer 211 4 also has multiple parallel columns of NAND memory cells 360, with the NAND cells 360 of each column being linked together by a different bitline (BL) that is electrically connected to the floating gate (or charge trap) of each NAND memory cell 360 to form a NAND flash string. In one embodiment a floating gate of a memory cell 360 may be composed of a conductive doped polycrystalline silicon, and in another embodiment a charge trap layer of a memory cell 360 made be composed of a silicon nitride insulator material.
  • The memory cells 360 of each page of NAND flash block 210 may be written and read by SSD controller 206 as a unit. A flash memory cell 360 is located at every crossing point of wordlines (WL) and bitlines (BL). Control gates are linked to the wordline, where the decoded address is applied. Each page of memory block 210 is defined as memory cells 360 that are linked with the same wordline. A voltage may be applied concurrently to the wordline and bitline by the SSD controller 206 to determine the operation as reading, erasing or programming.
  • In one embodiment, each flash memory cell 360 of FIG. 3B may be a floating gate or charge trap MOSFET that stores an electron charge. In such an embodiment, the charge of each memory cell may be stored in a floating gate or a charge trap that is electrically connected to a bitline. A control gate of each memory cell 360 is electrically connected to a wordline and overlies the floating gate. The control gate is separated from the floating gate or charge trap by an oxide insulator, and the floating gate or charge trap is separate from the source and drain of a substrate of the memory cell 360 by an oxide insulator. Current flow between the source and drain of the memory cell 360 may be controlled by combination of the floating gate or charge trap transistor voltage and a voltage applied to the control gate. Thus, different voltage combinations may be applied to the wordline and bitline of a given flash memory cell 360 to determine (or select) a read, erase or program (write) operation on the given memory cell 360.
  • To read a given memory cell 360 of FIG. 3B, a designated read compare voltage (Vr) may be applied by the SSD controller 206 to the control gate of the given memory cell 360 to read the charge on the floating gate or charge trap, and the designated value of Vr depends on the voltage threshold (Vth) of the memory cell, i.e., the floating gate or charge trap of the memory cell 360 reads as “0” when the floating gate or charge trap contains an electron charge, and the floating gate or charge trap of the memory cell 350 reads as “1” when the floating gate or charge trap contains no electron charge. When the floating gate or charge trap is charged (0), application of the correct Vr causes does not cause current to flow from source to drain of the memory cell. However, when the floating gate or charge trap is not charged (1), application of the correct Vr causes current to flow from source to drain of the memory cell 360. Therefore, data from the memory cell 360 may be read by determining whether or not current flows from source to drain when the correct Vr is applied to the control gate.
  • Still referring to FIG. 3B, the memory cells 360 of at least one designated calibration wordline (WLC) 350 of NAND block 210 may be programmed with a pre-defined data pattern, as shown by the dashed box labelled 350. In the illustrated embodiment, the calibration WL C 350 is the first WL of NAND block 210, although any other one or more wordlines of a given NAND block may be programmed with a pre-defined data pattern, including the last WL of a NAND block or any one or more wordlines located in-between the first WL and the last WL of NAND block 210. In the QLC memory embodiment of FIGS. 3A and 3B, the same pre-defined data pattern covers (or is applied to) all four levels 211 1, 211 2, 211 3 and 211 4 of NAND block 210. In other embodiments that employ NAND memory having more or less than four levels, a calibration WL may be programmed with a pre-defined data pattern that covers all existing level/s of the given NAND block. SSD controller 206 may write data to, read data from, and/or erase data from, the remaining memory cells 360 of the other (non-calibration) wordlines (WLD)'s of NAND block 210 that are different from the designated calibration wordline (WLC) 350) in response to write, read and/or erase commands received by SSD controller 206 from host programmable integrated circuit 155.
  • FIG. 4 illustrates an example of the effect of voltage threshold (Vth) shift caused by floating gate (or charge trap) charge loss during an extended data retention time for a triple-level cell (TLC) NAND memory block, and a correction according to one exemplary embodiment that may be made to Vr to compensate for this shift. In FIG. 4, the initial threshold voltage (Vth) probability distribution of each of the two highest possible threshold voltage states “P6” and “P7” of TLC NAND memory is represented by a respective solid-line curve of probability density across all flash memory cells of a NAND flash memory device 208 that spans across a voltage window defined for that respective state. As shown, the ER state corresponds to a “1” bit and the P1 state corresponds to a programmed “0” bit. In FIG. 4, a solid line default read compare voltage level (Vr) lies in-between and completely separates the P6 and P7 voltage windows from each other. Thus, prior to floating gate (or charge trap) charge loss during data retention, Vr may be used to correctly determine the difference between the P6 and P7 states, i.e., a read cell voltage less than Vr corresponds to the P6 state and a read cell voltage greater than Vr corresponds to the P7 state.
  • Also shown in FIG. 4 are dashed-line probability density curves corresponding to each of shifted threshold voltage states P6 and P7 that exist after an elapsed data retention time. During the elapsed data retention time, floating gate (or charge trap) charge loss causes a portion of the shifted voltage threshold probability density curve of the P7 state to drop below the original default read compare voltage level (Vr), i.e., as shown in FIG. 4 by the hashed area of the P7 probability density curve which lies to the left of the original solid default Vr level line. Therefore, those read P7 voltage values that lie below the original default level (Vr) will yield an incorrect determination of a “P6” state when read after the elapsed data retention time. The amount of voltage threshold shift between the original and shifted probability density curves may be expressed by determining the voltage difference (ΔVm) between the original voltage threshold median (Vm) of a given probability density curve to the shifted voltage threshold median (Vm−1) of the same given probability density curve.
  • To correct for the voltage threshold shift shown in FIG. 4, an adjusted read compare level (Vr−1) is determined as shown by the dashed line in FIG. 4. In one embodiment, the value of the adjusted Vr−1 may be determined by shifting the value of the original default read compare voltage level Vr downward by a voltage difference (ΔVr) that is equal to the measured difference in voltage (ΔVm) of the voltage shift between Vm and Vm−1. As shown, the resulting dashed-line adjusted read compare voltage (Vr−1) completely separates the shifted P6 and P7 voltage windows from each other after floating gate (or charge trap) charge loss during data retention. Thus, after floating gate (or charge trap) charge loss, Vr−1 may be used to correctly determine the difference between the P6 and P7 states, i.e., a read cell voltage less than Vr−1 corresponds to the P6 state and a read cell voltage greater than Vr−1 corresponds to the P7 state.
  • FIG. 5 illustrates another example of the effect of voltage threshold (Vth) shift caused by floating gate (or charge trap) charge loss during an extended data retention time for a tri-level cell (QLC) NAND memory block. In FIG. 5, the initial threshold voltage (Vth) probability distribution of each of eight possible voltage states “ER” and “P1” to “P7” is represented by a respective curve of probability density across all flash memory cells of a NAND flash memory device 208 for the voltage window corresponding to that respective voltage state. Also shown in parenthesis are bit values (most significant bit, center significant bit, and least significant bit) corresponding to each of these eight possible threshold voltage states. A different respective voltage level (Va) to (Vh) lies in-between and completely separates each of the adjacent voltage windows from each other as shown. Thus, prior to floating gate (or charge trap) charge loss during data retention, the default read compare level Vr may be used to correctly determine the existing voltage state of that memory cell, i.e., a read cell voltage greater than Ve and less than Vf corresponds to the P5 voltage state (000).
  • Still referring to FIG. 5, a designated calibration WL of a given SSD NAND block may be programmed with a predefined TLC data pattern P7 of 110, which initially corresponds to a Vr between Vg and Vh. The predefined TLC data pattern is also stored in firmware to use for comparison to actual read data patterns. Assume now that during SSD operation the Vr read out for the memory cells of the calibration WL is instead between Ve and Vf, which corresponds to TLC data pattern P5 of 000. This actual read data pattern P5 may then be compared to the predefined TLC data pattern stored in firmware (e.g., by analyzing data shift pattern and statistics using Vth shift compensation logic 222) to determine how much voltage shift in the Vth distribution has occurred, and then to apply the same amount of voltage shift to Vr to calculate a new Vr−1 value. For example, in the present case, it may be determined that a Vth shift downward has occurred that corresponds to a ΔVm of X mV±tolerance, e.g., due to floating gate (or charge trap) charge loss that has occurred during a data retention time period. This same downward Vth shift may then be applied to shift the default Vr value downward to determine the new Vr−1 value.
  • In this example of FIG. 5, the value of “X” millivolts corresponds to the Vth difference between Vm8 and Vm6 that is determined by the comparison to the stored predefined TLC data pattern. To compensate for this determined Vth shift, the read compare level Vr is also shifted downward by the same X mV±tolerance to compensate for the measured downward Vth shift before executing a read retry of the memory cells of the given SSD NAND block. During the read retry using the new and reduced read compare level Vr, the memory cells of designated calibration WL will correctly read between Vg and Vh. The memory cells of the remaining WLs of the SSD NAND block may also be correctly read using the new reduced read compare level Vr.
  • FIG. 6 illustrates methodology 600 that may be performed (e.g., by SSD controller 206) to compensate for NAND flash memory voltage threshold (Vth) shift such as described above in relation to FIG. 5, it being understood that methodology 600 may be performed by SSD controller 206 in one embodiment to separately compensate for NAND flash memory voltage threshold (Vth) shift in each of the different NAND blocks 210 of NAND flash device 208 of FIG. 2. As shown, methodology 600 begins in step 602 where a normal read of one or more NAND blocks 210 is made using the default original read compare level Vr, e.g., in response to a read request received by SSD controller 206 from host programmable integrated circuit 155. In one embodiment, a checksum of the read data may be computed and compared to parity in step 604 to determine if the number of read errors (e.g., expressed as number of read errors or a read error rate such as RBER) falls within a maximum acceptable number of read errors, e.g., defined by a maximum checksum error threshold. If the number of read errors fall within the maximum acceptable error threshold in step 604, then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155. However, it will be understood that any other alternative technique may be employed in step 604 that is suitable for determining a number of read errors and/or a read error rate.
  • If the number of read errors does not fall within the maximum acceptable read error threshold in step 604, then methodology 600 proceeds to step 608 where an optional read-retry of the NAND block/s 210 is again made using the default read compare level Vr. A checksum of the read-retry data is computed and compared to parity in step 610 to determine if the number of read errors again falls within a maximum acceptable number of errors defined by the maximum checksum error threshold. If the number of read errors again falls within the maximum acceptable error threshold in step 610, then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155.
  • However, if the number of read errors does not fall within the maximum acceptable read error threshold in step 610, then methodology 600 proceeds to step 612 where a dynamic read-retry of the calibration WL 350 of the NAND block/s 210 is made using the original default read compare level Vr to read a value of the data pattern of the memory cells in the calibration WL 350. Then in step 614 the read data pattern value of step 612 is compared to a stored value of the pre-defined data pattern that is maintained in non-volatile memory of the firmware 230 of the SSD controller 187. This comparison may be made to determine a compensated read compare level Vr−1, for example, according to the methodology described in relation to FIG. 5. Then, a read of the one or more NAND blocks 210 is made in step 616 using the new compensated read compare level Vr−1. A checksum of the data read in step 616 is then computed and compared to parity in step 618 to determine if the number of read errors falls within a maximum acceptable number of read errors defined by the maximum checksum read error threshold. If the number of errors fall within the maximum acceptable error threshold in step 618, then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155.
  • However, if the number of read errors does not fall within the maximum acceptable error threshold in step 618, then methodology 600 proceeds to optional step 620 where a soft low density parity code (LDPC) decode operation may be performed, and then checksum of the resulting data computed and compared to parity in step 622. If the number of read errors falls within the maximum acceptable error threshold in step 622, then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155.
  • However, if the number of read errors does not fall within the maximum acceptable error threshold in step 622, then methodology 600 proceeds to optional step 624 where a hard LDPC decode operation may be performed, and then checksum of the resulting data computed and compared to parity in step 626. If the number of read errors falls within the maximum acceptable error threshold in step 626, then methodology proceeds to step 606 where the read data from the NAND block/s 210 is reported as read to the host programmable integrated circuit 155. However, if the number of read errors does not fall within the maximum acceptable read error threshold in step 626, then methodology 600 proceeds to optional step 628 where data correction and/or reconstruction is performed from a redundant array of independent disks (RAID), and the resulting data is reported as read in step 606 to the host programmable integrated circuit 155.
  • It will be understood that the steps of methodology 600 described herein are exemplary only, and that any other sequence or combination of additional, fewer and/or alternative steps may be employed that is suitable for compensating for NAND flash memory voltage threshold (Vth) shift by using one or more designated calibration wordlines in a manner as described herein.
  • It will also be understood that one or more of the tasks, functions, or methodologies described herein for an information handling system or component thereof (e.g., including those described herein for components 155, 182, 206, 220, 222, 230, etc.) may be implemented by circuitry and/or by a computer program of instructions (e.g., computer readable code such as firmware code or software code) embodied in a non-transitory tangible computer readable medium (e.g., optical disk, magnetic disk, non-volatile memory device, etc.), in which the computer program comprising instructions are configured when executed on a programmable integrated circuit (e.g., processor such as CPU, controller, microcontroller, microprocessor, ASIC, etc. or programmable logic device “PLD” such as FPGA, complex programmable logic device “CPLD”, etc.) to perform one or more steps of the methodologies disclosed herein. In one embodiment, a group of such programmable integrated circuits may be selected from the group consisting of CPU, controller, microcontroller, microprocessor, FPGA, CPLD and ASIC. The computer program of instructions may include an ordered listing of executable instructions for implementing logical functions in an information handling system or component thereof. The executable instructions may include a plurality of code segments operable to instruct components of an information handling system to perform the methodologies disclosed herein. It will also be understood that one or more steps of the present methodologies may be employed in one or more code segments of the computer program. For example, a code segment executed by the information handling system may include one or more steps of the disclosed methodologies. It will be understood that a programmable integrated circuit may be configured to execute or otherwise be programmed with software, firmware, logic, and/or other program instructions stored in one or more non-transitory tangible computer-readable mediums (e.g., example, data storage devices, flash memories, random update memories, read only memories, programmable memory devices, reprogrammable storage devices, hard drives, floppy disks, DVDs, CD-ROMs, and/or any other tangible data storage mediums) to perform the operations, tasks, functions, or actions described herein for the disclosed embodiments.
  • For purposes of this disclosure, an information handling system may include any instrumentality or aggregate of instrumentalities operable to compute, calculate, determine, classify, process, transmit, receive, retrieve, originate, switch, store, display, communicate, manifest, detect, record, reproduce, handle, or utilize any form of information, intelligence, or data for business, scientific, control, or other purposes. For example, an information handling system may be a personal computer (e.g., desktop or laptop), tablet computer, mobile device (e.g., personal digital assistant (PDA) or smart phone), server (e.g., blade server or rack server), a network storage device, or any other suitable device and may vary in size, shape, performance, functionality, and price. The information handling system may include random update memory (RAM), one or more processing resources such as a central processing unit (CPU) or hardware or software control logic, ROM, and/or other types of nonvolatile memory. Additional components of the information handling system may include one or more disk drives, one or more network ports for communicating with external devices as well as various input and output (I/O) devices, such as a keyboard, a mouse, touch screen and/or a video display. The information handling system may also include one or more buses operable to transmit communications between the various hardware components.
  • While the invention may be adaptable to various modifications and alternative forms, specific embodiments have been shown by way of example and described herein. However, it should be understood that the invention is not intended to be limited to the particular forms disclosed. Rather, the invention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the invention as defined by the appended claims. Moreover, the different aspects of the disclosed systems and methods may be utilized in various combinations and/or independently. Thus the invention is not limited to only those combinations shown herein, but rather may include other combinations.

Claims (20)

What is claimed is:
1. A method, comprising:
reading data from at least one memory block using multiple separate wordlines, the at least one memory block comprising multiple memory pages that each comprise a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value, and each of the separate wordlines being coupled to a different group of the memory cells that corresponds to one of the memory pages of the at least one memory block;
where a designated one of the multiple memory pages comprises a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern; and
where the method further comprises:
reading a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr);
then comparing the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern; and
then determining an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
2. The method of claim 1, where the at least one memory block comprises an array of memory cells that are grouped in rows to define the multiple separate memory pages, each of the multiple separate memory pages comprising a separate row of the memory cells that are coupled together by a different one of the multiple separate wordlines; and where the method further comprises:
reading the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the read compare voltage (Vr);
then determining the adjusted read compare voltage (Vr−1) based on the determined magnitude of shift in voltage of the stored charge in the memory cells of the designated memory page; and
then re-reading the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr−1).
3. The method of claim 1, where the magnitude of a shift in the voltage of the stored charge in each of the memory cells of the designated memory page corresponds to a determined difference between the current data pattern and the pre-defined data pattern; and where the method further comprises determining the adjusted read compare voltage (Vr−1) by shifting the value of the default read compare voltage (Vr) downward by a voltage difference that is equal to the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
4. The method of claim 1, further comprising:
reading the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the read compare voltage (Vr);
then determining a number of read errors or a read error rate for the read stored data;
then comparing the number of read errors or the read error rate to a pre-defined maximum threshold number of read errors or to a threshold maximum read error rate; and then either one of:
providing the read data to a different programmable integrated circuit only if the number of read errors or the read error rate is less than or equal to the pre-defined maximum threshold number of read errors or the threshold maximum read error rate, or
re-reading the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr−1) and provide the re-read data to the different programmable integrated circuit only if the number of read errors or the read error rate is greater than the pre-defined maximum threshold number of read errors or the threshold maximum read error rate.
5. The method of claim 4, where the different programmable integrated circuit is a host programmable integrated circuit of an information handling system; and where the multiple memory blocks and the at least one programmable integrated circuit are components of a solid state drive (SSD) coupled to the host programmable integrated circuit.
6. The method of claim 1, where the at least one memory block comprises multiple memory blocks; where each of the separate wordlines is coupled to a different group of memory cells that corresponds to one of the memory pages of the multiple memory blocks; where a designated one of the multiple memory pages of each of the multiple memory blocks comprises a group of memory cells that are programmed with stored data values corresponding to the pre-defined data pattern; and where the method further comprises:
reading a current data pattern stored in the memory cells of the designated memory page of each of the multiple memory blocks using a default read compare voltage (Vr);
then comparing the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page of each of the multiple memory blocks between the current data pattern and the pre-defined data pattern; and
then determining an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page of each of the multiple memory blocks.
7. The method of claim 1, where the at least one memory block comprises an array of memory cells arranged in columns and rows, each row of memory cells coupled together to form a wordline of the memory block, and each column of memory cells coupled together to form a bitline (BL) of the memory block.
8. The method of claim 1, where the at least one memory block comprises one of a single-level cell (SLC) NAND memory, a multi-level cell (MLC) NAND memory, a triple-level cell (TLC) NAND memory, or a quad-level cell (QLC) NAND memory.
9. A system, comprising:
at least one memory block comprising multiple memory pages that each comprise a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value; and
at least one programmable integrated circuit coupled to multiple separate wordlines, each of the separate wordlines being coupled to a different group of memory cells that corresponds to one of the memory pages of the at least one memory block;
where a designated one of the multiple memory pages comprises a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern; and
where the at least one programmable integrated circuit is programmed to:
read a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr);
then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern; and
then determine an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
10. The system of claim 9, where the at least one memory block comprises an array of memory cells that are grouped in rows to define the multiple separate memory pages, each of the multiple separate memory pages comprising a separate row of the memory cells that are coupled together by a different one of the multiple separate wordlines; and where the at least one programmable integrated circuit is programmed to:
read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the read compare voltage (Vr);
then determine the adjusted read compare voltage (Vr−1) based on the determined magnitude of shift in voltage of the stored charge in the memory cells of the designated memory page; and
then re-read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr−1).
11. The system of claim 9, where the magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page corresponds to a determined difference between the current data pattern and the pre-defined data pattern; and where the programmable integrated circuit is further programmed to determine the adjusted read compare voltage (Vr−1) by shifting the value of the default read compare voltage (Vr) downward by a voltage difference that is equal to the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
12. The system of claim 9, where the programmable integrated circuit is programmed to:
read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the read compare voltage (Vr);
then determine a number of read errors or a read error rate for the read stored data;
then compare the number of read errors or the read error rate to a pre-defined maximum threshold number of read errors or to a threshold maximum read error rate; and then either one of:
provide the read data to a different programmable integrated circuit only if the number of read errors or the read error rate is less than or equal to the pre-defined maximum threshold number of read errors or the threshold maximum read error rate, or
re-read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr−1) and provide the re-read data to the different programmable integrated circuit only if the number of read errors or the read error rate is greater than the pre-defined maximum threshold number of read errors or the threshold maximum read error rate.
13. The system of claim 9, where the at least one memory block comprises multiple memory blocks; where each of the separate wordlines is coupled to a different group of memory cells that corresponds to one of the memory pages of the multiple memory blocks; where a designated one of the multiple memory pages of each of the multiple memory blocks comprises a group of memory cells that are programmed with stored data values corresponding to the pre-defined data pattern; and where the at least one programmable integrated circuit is programmed to:
read a current data pattern stored in the memory cells of the designated memory page of each of the multiple memory blocks using a default read compare voltage (Vr);
then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page of each of the multiple memory blocks between the current data pattern and the pre-defined data pattern; and
then determine an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page of each of the multiple memory blocks.
14. The system of claim 13, further comprising a solid state drive (SSD) that includes the multiple memory blocks and the at least one programmable integrated circuit.
15. The system of claim 9, where the at least one memory block comprises an array of memory cells arranged in columns and rows, each row of memory cells coupled together to form a wordline of the memory block, and each column of memory cells coupled together to form a bitline (BL) of the memory block.
16. The system of claim 9, where the at least one memory block comprises one of a single-level cell (SLC) NAND memory, a multi-level cell (MLC) NAND memory, a triple-level cell (TLC) NAND memory, or a quad-level cell (QLC) NAND memory.
17. An information handling system, comprising:
a host programmable integrated circuit;
a solid state drive (SSD) coupled to the host programmable integrated circuit, the SSD comprising:
at least one memory block comprising multiple memory pages that each comprise a different group of memory cells, each of the memory cells storing an electron charge having a voltage corresponding to a stored data value, and
at least one programmable integrated circuit coupled to multiple separate wordlines, each of the separate wordlines being coupled to a different group of memory cells that corresponds to one of the memory pages of the at least one memory block,
where a designated one of the multiple memory pages comprises a group of memory cells that are programmed with stored data values corresponding to a pre-defined data pattern; and
where the at least one programmable integrated circuit of the SSD is programmed to:
read a current data pattern stored in the memory cells of the designated memory page using a default read compare voltage (Vr),
then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page between the current data pattern and the pre-defined data pattern,
then determine an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page,
then re-read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr−1), and
then provide the re-read data to the host programmable integrated circuit.
18. The information handling system of claim 17, where the magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page corresponds to a determined difference between the current data pattern and the pre-defined data pattern; and where the programmable integrated circuit of the SSD is further programmed to determine the adjusted read compare voltage (Vr−1) by shifting the value of the default read compare voltage (Vr) downward by a voltage difference that is equal to the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page.
19. The information handling system of claim 17, where the programmable integrated circuit of the SSD is programmed to:
read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the read compare voltage (Vr);
then determine a number of read errors or a read error rate for the read stored data;
then compare the number of read errors or the read error rate to a pre-defined maximum threshold number of read errors or to a threshold maximum read error rate; and then either one of:
report the read data to the host programmable integrated circuit only if the number of read errors or the read error rate is less than or equal to the pre-defined maximum threshold number of read errors or the threshold maximum read error rate, or
re-read the stored data value of each given memory cell of the array of memory cells by determining the voltage of the stored charge in the given memory cell relative to the adjusted read compare voltage (Vr−1) and report the re-read data to the host programmable integrated circuit only if the number of read errors or the read error rate is greater than the pre-defined maximum threshold number of read errors or the threshold maximum read error rate.
20. The information handling system of claim 17, where the at least one memory block comprises multiple memory blocks; where each of the separate wordlines is coupled to a different group of memory cells that corresponds to one of the memory pages of the multiple memory blocks; where a designated one of the multiple memory pages of each of the multiple memory blocks comprises a group of memory cells that are programmed with stored data values corresponding to the pre-defined data pattern; and where the at least one programmable integrated circuit is programmed to:
read a current data pattern stored in the memory cells of the designated memory page of each of the multiple memory blocks using a default read compare voltage (Vr);
then compare the read current data pattern to the pre-defined data pattern to determine a magnitude of a shift in voltage of the stored charge in each of the memory cells of the designated memory page of each of the multiple memory blocks between the current data pattern and the pre-defined data pattern; and
then determine an adjusted read compare voltage (Vr−1) based on the determined magnitude of the shift in voltage of the stored charge in the memory cells of the designated memory page of each of the multiple memory blocks.
US17/070,590 2020-10-14 2020-10-14 Systems and methods of implementing a calibration wordline to compensate for voltage threshold shift in NAND flash memory Active 2040-11-13 US11309036B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US17/070,590 US11309036B1 (en) 2020-10-14 2020-10-14 Systems and methods of implementing a calibration wordline to compensate for voltage threshold shift in NAND flash memory

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US17/070,590 US11309036B1 (en) 2020-10-14 2020-10-14 Systems and methods of implementing a calibration wordline to compensate for voltage threshold shift in NAND flash memory

Publications (2)

Publication Number Publication Date
US20220115074A1 true US20220115074A1 (en) 2022-04-14
US11309036B1 US11309036B1 (en) 2022-04-19

Family

ID=81077897

Family Applications (1)

Application Number Title Priority Date Filing Date
US17/070,590 Active 2040-11-13 US11309036B1 (en) 2020-10-14 2020-10-14 Systems and methods of implementing a calibration wordline to compensate for voltage threshold shift in NAND flash memory

Country Status (1)

Country Link
US (1) US11309036B1 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20220406364A1 (en) * 2021-06-16 2022-12-22 Sandisk Technologies Llc Hetero-Plane Data Storage Structures For Non-Volatile Memory
US20230056133A1 (en) * 2021-08-18 2023-02-23 Nxp B.V. Temperature exposure detection based on memory cell retention error rate
US20240006007A1 (en) * 2022-07-01 2024-01-04 Micron Technology, Inc. Predetermined pattern program operations

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6898104B2 (en) * 2002-11-12 2005-05-24 Kabushiki Kaisha Toshiba Semiconductor device having semiconductor memory with sense amplifier
US7619918B2 (en) * 2006-12-29 2009-11-17 Intel Corporation Apparatus, method, and system for flash memory
US7774525B2 (en) 2007-03-13 2010-08-10 Dell Products L.P. Zoned initialization of a solid state drive
US7782697B2 (en) * 2007-04-24 2010-08-24 Novelics, Llc. DRAM with hybrid sense amplifier
US8239618B2 (en) 2010-05-27 2012-08-07 Dell Products L.P. System and method for emulating preconditioning of solid-state device
US8671241B2 (en) 2011-09-13 2014-03-11 Dell Products Lp Systems and methods for using reserved solid state nonvolatile memory storage capacity for system reduced power state
US10049727B2 (en) * 2016-06-22 2018-08-14 Darryl G. Walker Semiconductor devices, circuits and methods for read and/or write assist of an SRAM circuit portion based on voltage detection and/or temperature detection circuits
US10275162B2 (en) 2017-06-23 2019-04-30 Dell Products L.P. Methods and systems for managing data migration in solid state non-volatile memory
KR102386242B1 (en) * 2017-11-14 2022-04-12 삼성전자주식회사 Memory device including a circuit for detecting word line defect which is independent from power supply voltage variation, and operating method of the memory device
KR102070307B1 (en) * 2018-05-28 2020-01-23 에센코어 리미티드 Method of operating storage unit
US10741260B1 (en) * 2019-05-28 2020-08-11 Micron Technology, Inc. Systems and methods providing improved calibration of memory control voltage
US11061752B2 (en) * 2019-07-17 2021-07-13 Micron Technology, Inc. Dynamic programming of page margins

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20220406364A1 (en) * 2021-06-16 2022-12-22 Sandisk Technologies Llc Hetero-Plane Data Storage Structures For Non-Volatile Memory
US11610625B2 (en) * 2021-06-16 2023-03-21 Sandisk Technologies Llc Hetero-plane data storage structures for non-volatile memory
US20230056133A1 (en) * 2021-08-18 2023-02-23 Nxp B.V. Temperature exposure detection based on memory cell retention error rate
US11670394B2 (en) * 2021-08-18 2023-06-06 Nxp B.V. Temperature exposure detection based on memory cell retention error rate
US20240006007A1 (en) * 2022-07-01 2024-01-04 Micron Technology, Inc. Predetermined pattern program operations

Also Published As

Publication number Publication date
US11309036B1 (en) 2022-04-19

Similar Documents

Publication Publication Date Title
US9298545B2 (en) Data protection across multiple memory blocks
US10467094B2 (en) Method and apparatus for performing data recovery in a raid storage
KR101655306B1 (en) Memory system and access method thereof
US11309036B1 (en) Systems and methods of implementing a calibration wordline to compensate for voltage threshold shift in NAND flash memory
US11194655B2 (en) Storage controller and storage device including the same
US10847231B2 (en) Memory system with adaptive read-threshold scheme and method of operating such memory system
KR101716716B1 (en) Flash memory device having flag cells and program operating method thereof
US8593884B2 (en) Data storage system and a data retention method thereof
US9478298B2 (en) Memory system and method of reading data thereof
KR20110097446A (en) Memory system and data processing method thereof
US20210149800A1 (en) Ssd system using power-cycle based read scrub
US20220130438A1 (en) Memory system and operating method thereof
KR20100028022A (en) Flash memory refresh techniques triggered by controlled scrub data reads
US11868647B2 (en) Nonvolatile memory device, with valley search for threshold voltage, memory controller, and reading method of storage device including the same
US11467903B2 (en) Memory system and operating method thereof
US11630726B2 (en) Memory system and operating method thereof
US20220083255A1 (en) Memory system and operating method thereof
US11061615B2 (en) Memory system, memory controller and operating method thereof
KR20140104829A (en) Multi level cell nonvolatile memory system
US11354188B2 (en) Data processing system including host with reliability management of memory systems and method for the same
US11636007B2 (en) Memory system and operating method thereof for flushing data in data cache with parity
US11640263B2 (en) Memory system and operating method thereof
US20240079073A1 (en) Storage controller generating read voltages for soft decision decoding based on read information and decoding information, storage device including the same, and operating method thereof
US20240036741A1 (en) Memory system, memory controller and method for operating memory system, capable of determining target meta memory block on the basis of detected target state
US20230289260A1 (en) Controller and operating method of the controller for determining reliability data based on syndrome weight

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

AS Assignment

Owner name: DELL PRODUCTS L.P., TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TEOH, CHAI IM;KAN, LIP VUI;REEL/FRAME:054059/0229

Effective date: 20201013

AS Assignment

Owner name: CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH, NORTH CAROLINA

Free format text: SECURITY AGREEMENT;ASSIGNORS:EMC IP HOLDING COMPANY LLC;DELL PRODUCTS L.P.;REEL/FRAME:054591/0471

Effective date: 20201112

AS Assignment

Owner name: THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT, TEXAS

Free format text: SECURITY INTEREST;ASSIGNORS:EMC IP HOLDING COMPANY LLC;DELL PRODUCTS L.P.;REEL/FRAME:054475/0523

Effective date: 20201113

Owner name: THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS COLLATERAL AGENT, TEXAS

Free format text: SECURITY INTEREST;ASSIGNORS:EMC IP HOLDING COMPANY LLC;DELL PRODUCTS L.P.;REEL/FRAME:054475/0609

Effective date: 20201113

Owner name: THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT, TEXAS

Free format text: SECURITY INTEREST;ASSIGNORS:EMC IP HOLDING COMPANY LLC;DELL PRODUCTS L.P.;REEL/FRAME:054475/0434

Effective date: 20201113

AS Assignment

Owner name: EMC IP HOLDING COMPANY LLC, TEXAS

Free format text: RELEASE OF SECURITY INTEREST AT REEL 054591 FRAME 0471;ASSIGNOR:CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH;REEL/FRAME:058001/0463

Effective date: 20211101

Owner name: DELL PRODUCTS L.P., TEXAS

Free format text: RELEASE OF SECURITY INTEREST AT REEL 054591 FRAME 0471;ASSIGNOR:CREDIT SUISSE AG, CAYMAN ISLANDS BRANCH;REEL/FRAME:058001/0463

Effective date: 20211101

STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: DELL PRODUCTS L.P., TEXAS

Free format text: RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0609);ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT;REEL/FRAME:062021/0570

Effective date: 20220329

Owner name: EMC IP HOLDING COMPANY LLC, TEXAS

Free format text: RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0609);ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT;REEL/FRAME:062021/0570

Effective date: 20220329

Owner name: DELL PRODUCTS L.P., TEXAS

Free format text: RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0434);ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT;REEL/FRAME:060332/0740

Effective date: 20220329

Owner name: EMC IP HOLDING COMPANY LLC, TEXAS

Free format text: RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0434);ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT;REEL/FRAME:060332/0740

Effective date: 20220329

Owner name: DELL PRODUCTS L.P., TEXAS

Free format text: RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0523);ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT;REEL/FRAME:060332/0664

Effective date: 20220329

Owner name: EMC IP HOLDING COMPANY LLC, TEXAS

Free format text: RELEASE OF SECURITY INTEREST IN PATENTS PREVIOUSLY RECORDED AT REEL/FRAME (054475/0523);ASSIGNOR:THE BANK OF NEW YORK MELLON TRUST COMPANY, N.A., AS NOTES COLLATERAL AGENT;REEL/FRAME:060332/0664

Effective date: 20220329