Patentable/Patents/US-20260004861-A1
US-20260004861-A1

Level-Based Programming with Multiple Analog Program Verify Operations Between Programming Pulses

PublishedJanuary 1, 2026
Assigneenot available in USPTO data we have
Technical Abstract

A method includes causing, in between applying programming pulses to selectively store data to multiple voltage levels of a plurality of memory cells, a second occurrence of a first analog verify operation to be performed on a first set of memory cells to identify one or more memory cells of a first subset of the first set of memory cells. The first subset of memory cells are those that failed the first analog verify operation and the one or more memory cells twice failed the first analog verify operation. A first occurrence of a second analog verify operation is performed at a second set of memory cells to identify a second subset of the second set of memory cells that failed the second analog verify operation.

Patent Claims

Legal claims defining the scope of protection, as filed with the USPTO.

1

an array comprising a plurality of memory cells; and causing a first set of memory cells to be programmed using a first programming pulse; causing a first occurrence of a first analog verify operation to be performed on the first set of memory cells to determine a first subset of the first set of memory cells that failed the first analog verify operation; causing the first subset of memory cells and a second set of memory cells to be programmed using a second programming pulse; causing a second occurrence of the first analog verify operation to be performed on the first set of memory cells to determine one or more memory cells of the first subset of memory cells that again failed the first analog verify operation; and causing a first occurrence of a second analog verify operation to be performed on the second set of memory cells to determine a second subset of the second set of memory cells that failed the second analog verify operation. control logic coupled with the array, wherein the control logic, during multi-level memory cell programming, is to perform operations comprising: . A memory device comprising:

2

claim 1 . The memory device of, wherein the second programming pulse has a higher voltage level than the first programming pulse.

3

claim 1 . The memory device of, further comprising a plurality of bitlines, each selectively coupled to a respective memory cell of the plurality of memory cells and operatively coupled to the control logic, wherein, while programming using the second programming pulse, the operations further comprise causing an analog enable voltage level to be applied to one or more bitlines, of the plurality of bitlines, associated with the first subset of memory cells.

4

claim 1 . The memory device of, wherein the operations further comprise causing the one or more memory cells of the first subset of memory cells, the second subset of memory cells, and a third set of memory cells to be programmed using a third programming pulse having a higher voltage than the second programming pulse.

5

claim 4 causing a finalize analog voltage level to be applied to bitlines, of the plurality of bitlines, coupled to the one or more memory cells of the first subset of memory cells; and causing an analog enable voltage level to be applied to bitlines, of the plurality of bitlines, coupled to the second subset of memory cells. . The memory device of, further comprising a plurality of bitlines, each selectively coupled to a respective memory cell of the plurality of memory cells and operatively coupled to the control logic, wherein, while programming using the third programming pulse, the operations further comprise:

6

claim 4 causing a second occurrence of the second analog verify operation to be performed on the second set of memory cells to determine one or more memory cells of the second subset of memory cells that again failed the second analog verify operation; and causing a third analog verify operation to be performed on the third set of memory cells to determine a third subset of the third set of memory cells that failed the third analog verify operation. . The memory device of, wherein the operations further comprise:

7

claim 4 causing a final set of memory cells to be programmed using a penultimate programming pulse having a higher voltage than a preceding programming pulse; causing a final analog verify operation to be performed on the final set of memory cells to determine a final subset of the final set of memory cells that failed the final analog verify operation; causing the final subset of memory cells to be programmed using a final programming pulse, wherein the first programming pulse through the final programming pulse are numbered one greater than a number of multi-level data states that were programmed in the plurality of memory cells; and causing, while programming using the final programming pulse, an analog enable voltage level to be applied to bitlines coupled to the final subset of memory cells. . The memory device of, wherein the operations further comprise:

8

causing, by control logic of a memory device, a first set of memory cells to be programmed using a first programming pulse, wherein the memory device comprises an array of a plurality of memory cells that includes the first set of memory cells; causing a first occurrence of a first analog verify operation to be performed on the first set of memory cells to determine a first subset of the first set of memory cells that failed the first analog verify operation; causing the first subset of memory cells and a second set of memory cells to be programmed using a second programming pulse; causing a second occurrence of the first analog verify operation to be performed on the first set of memory cells to determine one or more memory cells of the first subset of memory cells that again failed the first analog verify operation; and causing, by the control logic, a first occurrence of a second analog verify operation to be performed on the second set of memory cells to determine a second subset of the second set of memory cells that failed the second analog verify operation. . A method comprising:

9

claim 8 . The method of, wherein the second programming pulse has a higher voltage level than the first programming pulse.

10

claim 8 . The method of, further comprising, while programming using the second programming pulse, causing an analog enable voltage level to be applied to bitlines, of a plurality of bitlines, coupled to the first subset of memory cells.

11

claim 8 . The method of, further comprising causing the one or more memory cells of the first subset of memory cells, the second subset of memory cells, and a third set of memory cells to be programmed using a third programming pulse having a higher voltage than the second programming pulse.

12

claim 11 causing a finalize analog voltage level to be applied to bitlines, of a plurality of bitlines, coupled to the one or more memory cells of the first subset of memory cells; and causing an analog enable voltage level to be applied to bitlines, of the plurality of bitlines, coupled to the second subset of memory cells. . The method of, further comprising, while programming using the third programming pulse:

13

claim 11 causing a second occurrence of the second analog verify operation to be performed on the second set of memory cells to determine one or more memory cells of the second subset of memory cells that again failed the second analog verify operation; and Causing a third analog verify operation to be performed on the third set of memory cells to determine a third subset of the third set of memory cells that failed the third analog verify operation. . The method of, further comprising:

14

claim 11 causing a final set of memory cells to be programmed using a penultimate programming pulse having a higher voltage than a preceding programming pulse; causing a final analog verify operation to be performed at the final set of memory cells to determine a final subset of the final set of memory cells that failed the final analog verify operation; causing the final subset of memory cells to be programmed using a final programming pulse, wherein the first programming pulse through the final programming pulse are numbered one greater than a number of multi-level data states that were programmed at the plurality of memory cells; and causing, while programming using the final programming pulse, an analog enable voltage level to be applied to bitlines coupled to the final subset of memory cells. . The method of, further comprising:

15

a second occurrence of a first analog verify operation to be performed on a first set of memory cells to identify one or more memory cells of a first subset of the first set of memory cells, wherein the first subset of memory cells failed the first analog verify operation, and the one or more memory cells twice failed the first analog verify operation; and a first occurrence of a second analog verify operation to be performed on a second set of memory cells to identify a second subset of the second set of memory cells that failed the second analog verify operation. causing, by control logic of a memory device, and in between applying programming pulses to selectively store data to multiple voltage levels of a plurality of memory cells: . A method comprising:

16

claim 15 causing the first set of memory cells to be programmed using a first programming pulse, wherein the memory device comprises an array of a plurality of memory cells that includes the first set of memory cells; causing a first occurrence of the first analog verify operation to be performed on the first set of memory cells to determine the first subset of memory cells that failed the first analog verify operation; and causing the first subset of memory cells and a second set of memory cells to be programmed using a second programming pulse having a higher voltage level than the first programming pulse. . The method of, further comprising:

17

claim 16 . The method of, further comprising, while programming using the second programming pulse, causing an analog enable voltage level to be applied to bitlines, of a plurality of bitlines, associated with the first subset of memory cells.

18

claim 16 . The method of, further comprising causing the one or more memory cells of the first subset of memory cells, the second subset of memory cells, and a third set of memory cells to be programmed using a third programming pulse having a higher voltage than the second programming pulse.

19

claim 18 causing a finalize analog voltage level to be applied to bitlines, of a plurality of bitlines, coupled to the one or more memory cells of the first subset of memory cells; and causing an analog enable voltage level to be applied to bitlines, of the plurality of bitlines, coupled to the second subset of memory cells. . The method of, further comprising, while programming using the third programming pulse:

20

claim 18 causing a second occurrence the second analog verify operation to be performed on the second set of memory cells to determine one or more memory cells of the second subset of memory cells that again failed the second analog verify operation; and causing a third analog verify operation to be performed at the third set of memory cells to determine a third subset of the third set of memory cells that failed the third analog verify operation. . The method of, further comprising:

21

claim 18 causing a final set of memory cells to be programmed using a penultimate programming pulse having a higher voltage than a preceding programming pulse; causing a final analog verify operation to be performed at the final set of memory cells to determine a final subset of the final set of memory cells that failed the final analog verify operation; causing the final subset of memory cells to be programmed using a final programming pulse, wherein the first programming pulse through the final programming pulse are numbered one greater than a number of multi-level data states that were programmed at the plurality of memory cells; and causing, while programming using the final programming pulse, an analog enable voltage level to be applied to bitlines coupled to the final subset of memory cells. . The method of, further comprising:

Detailed Description

Complete technical specification and implementation details from the patent document.

The present application claims the benefit under 35 U.S.C. § 119(e) of U.S. Provisional Patent Application No. 63/665,454 filed Jun. 28, 2024, which is incorporated by reference herein.

Embodiments of the disclosure are generally related to memory sub-systems, and more specifically, relate to program level-based programming with multiple analog program verify operations between programming pulses.

A memory sub-system can include one or more memory devices that store data. The memory devices can be, for example, non-volatile memory devices and volatile memory devices. In general, a host system can utilize a memory sub-system to store data at the memory devices and to retrieve data from the memory devices.

1 FIG.A Embodiments of the present disclosure are directed to memory devices employing level-based programming with multiple analog program verify operations between programming pulses. A memory device can be a non-volatile memory device. One example of non-volatile memory devices is a negative-and (NAND) memory device, which is an example of a flash memory device. Other examples of non-volatile memory devices are described below in conjunction with. These memory devices include memory cells in which to store data. For example, changes in threshold voltage (Vt) of the memory cells, through programming (which is often referred to as writing) of charge storage structures (e.g., floating gates or charge traps) or other physical phenomena (e.g., phase change or polarization), determine the data state (or data value) of each memory cell.

In programming memory, memory cells can generally be programmed as single-level cells (SLC) or multiple-level cells (MLC). Single-level cells can use a single memory cell to represent one digit (e.g., bit) of data. For example, in SLC, a Vt of 2.5V can indicate a programmed memory cell (e.g., representing a logical 0) while a Vt of −0.5V can indicate an erased cell (e.g., representing a logical 1). As an example, the erased state in SLC can be represented by any threshold voltage less than or equal to 0V, while the programmed data state can be represented by any threshold voltage greater than 0V. Multiple-level cells use more than two Vt ranges, where each Vt range indicates a different data state. A margin (e.g., a certain number of volts) such as a dead space can separate adjacent Vt ranges to facilitate differentiating between data states. Multiple-level cells can take advantage of the analog nature of traditional non-volatile memory cells by assigning a bit pattern to a specific Vt range.

In multi-level memory cell programming (e.g., of MLC memory), data values are often programmed using more than one pass, e.g., programming one or more digits in each pass. For example, in four-level MLC (typically referred to simply as MLC), a first digit, e.g., a least significant bit (LSB), which is often referred to as lower page (LP) data, can be programmed to the memory cells in a first pass, thus resulting in two (e.g., first and second) threshold voltage ranges. Subsequently, a second digit, e.g., a most significant bit (MSB), which is often referred to as upper page (UP) data can be programmed to the memory cells in a second pass, typically moving some portion of those memory cells in the first threshold voltage range into a third threshold voltage range, and moving some portion of those memory cells in the second threshold voltage range into a fourth threshold voltage range. Similarly, eight-level MLC (typically referred to as TLC) can represent a bit pattern of three bits, including a first digit, e.g., a least significant bit (LSB) or lower page (LP) data; a second digit, e.g., upper page (UP) data; and a third digit, e.g., a most significant bit (MSB) or extra page (XP) data. In operating TLC, the LP data can be programmed to the memory cells in a first pass, resulting in two threshold voltage ranges, followed by the UP data and the XP data in a second pass, resulting in eight threshold voltage ranges. Similarly, sixteen-level MLC (typically referred to as QLC) can represent a bit pattern of four bits, and 32-level MLC (typically referred to as PLC) can represent a bit pattern of five bits.

Programming in memories is typically accomplished by applying one or more programming pulses, separated by verify pulses, to program each memory cell of a selected group of memory cells to a respective target data state (which might be an interim or final data state). With such a scheme, the programming pulses are applied to access lines, such as those typically referred to as wordlines, for selected memory cells. After each programming pulse, one or more verify voltage levels are typically used to verify the programming of the selected memory cells. Programming typically uses many programming pulses in an incremental step pulse programming (ISPP) scheme, where each programming pulse is a single-level pulse that moves the memory cell threshold voltage by some amount.

The programming pulses might be applied to a selected access line (e.g., wordline) and thus to the control gates of the row of memory cells connected to the selected access line (e.g., having their control gates connected to the selected access line). Typical programming pulses might start at or near a particular program (or gate) step voltage (e.g., 13V, 16V, or the like) and tend to increase in magnitude for each subsequent programming pulse application. While the program potential (e.g., voltage level of the programming pulse) is applied to the selected access line, an enable voltage, such as a reference potential (e.g., 0V), might be applied to the channels (also referred to as bitlines or data lines) of memory cells selected for programming, i.e., those memory cells for which the programming operation is intended to shift their data state to some higher level. This might result in a charge transfer from the channel to the charge storage structures of these selected memory cells. For example, floating gates are typically charged through direct injection or Fowler-Nordheim tunneling of electrons from the channel to the floating gate, resulting in an increased threshold voltage in a programmed state.

An inhibit voltage level (e.g., Vcc) is typically applied to data lines which are selectively connected to a NAND string containing a memory cell that is connected to the selected access line and is not selected for, or is no longer selected for, programming. In addition to data lines selectively connected to memory cells already at their target data state, these unselected data lines might further include data lines that are not addressed by the programming operation. For example, a logical page of data might correspond to memory cells connected to a particular access line and selectively connected to some particular subset of the data lines (e.g., every other data line), such that the remaining subset of data lines would be unselected for the programming operation and thus inhibited.

Between the application of one or more programming pulses, a verify phase of the programming operation is typically performed to check each selected memory cell to determine if the selected memory cell has reached its target data state. If the selected memory cell has reached its target data state, the selected memory cell might be inhibited from further programming if there remain other selected memory cells still requiring additional programming pulses to reach their target data states. Following a verify phase, an additional programming pulse might be applied if there are memory cells that have not completed programming. This process of applying a programming pulse followed by verification (e.g., a programming phase and a verify, or sensing, phase of a programming operation) typically continues until all the selected memory cells have reached their target data states. If a particular number of programming pulses (e.g., maximum number) have been applied, or a particular voltage level of a programming pulse (e.g., maximum voltage level) has been reached, and one or more selected memory cells still have not completed programming, those memory cells might be marked as defective, for example.

The use of different voltage levels on data lines to be enabled for programming might occur in programming schemes known as selective slow programming convergence (SSPC), where memory cells nearer to their respective target data states are programmed more slowly (e.g., partially enabled for programming) compared to memory cells farther from their respective target data states (e.g., fully enabled for programming) while receiving a same voltage level at their respective control gates. SSPC programming schemes can facilitate more narrow distributions of threshold voltages defining each data state over more traditional programming schemes that rely on memory cells being either fully enabled or inhibited from programming. By narrowing the threshold voltage distributions, and thus providing more dead space, or margin, between adjacent threshold voltage distributions, accuracy of determining data states of memory cells might be improved and/or memory density (e.g., number of digits of data per memory cell) might be increased.

Although SSPC programming schemes can provide for tighter threshold voltage distributions over more traditional programming schemes, that benefit typically comes with a cost. In particular, memory cells subject to the programming operation must generally be apportioned to different subsets of memory cells for each programming pulse, e.g., one subset of memory cells to be inhibited from programming, one subset of memory cells to be enabled (e.g., fully enabled) for programming, and one subset of memory cells for each level of partial enablement of programming. Each subset of memory cells might correspond to a respective, mutually exclusive, range of threshold voltages. The threshold voltage for each memory cell subject to the programming operation must generally be determined or estimated in order to apportion it to the proper subset of memory cells. This can add time and/or complexity to the verify phase of the programming operation.

string string Certain memory devices deploy a process that seeks to facilitate further narrowing of threshold voltage distributions over typical SSPC programming schemes, while mitigating a need to apportion memory cells for each level of partial enablement of programming. These memory devices provide a data line voltage level during a subsequent programming pulse that is inversely related to its corresponding NAND string current level (e.g., I) during a verify phase of the programming operation (e.g., an immediately prior verify phase of the programming operation). Consider the example of eight NAND strings each having a memory cell selected for programming during a programming operation, and exhibiting Ivalues of I0, I1, I2, I3, I4, I5, I6, and I7 during a verify phase of the programming operation, where I0<I1<I2<I3<I4<I5<I6<I7. During a subsequent programming pulse, their corresponding data lines might receive voltage levels of V0, V1, V2, V3, V4, V5, V6, and V7, respectively, where V0>V1>V2>V3>V4>V5>V6>V7.

string string These certain memory devices also capture a retained voltage level of a node of a page buffer circuit following or during a verify phase of the programming operation. During the verify phase of the programming operation, the node might be precharged, and then selectively discharged through a data line responsive to a level of activation of a selected memory cell of a programming operation. As such, a memory cell having a higher threshold voltage, e.g., a lower Iin response to a given control gate voltage level, might be expected to result in a higher retained voltage level at the node than a memory cell having a lower threshold voltage, e.g., a higher Iin response to the given control gate voltage level. The remaining voltage level of the node might subsequently be used as a control voltage of a source-follower to generate a data line (e.g., bitline) voltage level for a subsequent programming operation. In this manner, memory cells closer to their target threshold voltage might be expected to receive a higher data line voltage, e.g., lower level of partial enablement, and memory cells farther from their target threshold voltage might be expected to receive a lower data line voltage, e.g., higher level of partial enablement. Such a verify phase might be referred to as an analog verification (or analog verify operation), as the subsequent data line voltage level is not entirely determined in response to whether a sense transistor is activated or not, but is instead open to data line voltage levels that might be proportional (e.g., inversely proportional) to a level of current flow through its corresponding memory cell.

The process in these certain memory devices facilitates programming a plurality of memory cells to respective ones of N+1 possible data states using N+1 programming pulses. However, the currently implemented process accepts that some memory cells might not reach their desired threshold voltage in such a manner. For example, the bitline (or data line) voltage range is limited to about one volt (V) and has a wide program voltage sigma (PVS), sometimes causing lower tail bits of some voltage distributions, which represent data states, to remain below a program verify voltage after a programming operation and potentially cause read errors. Thus, there is an expectation that error correction schemes might resolve any such errors.

In various embodiments, the present disclosure explains how these lower tail bits of some distributions can be fully programmed, e.g., to be tightened by receiving the minor additional charge needed to pass program verification. For example, even after programming pulses further program memory cells that previously failed in program verification, some memory cells of a data state (e.g., one or more of the L1 memory cells) can be programmed while programming higher data states, e.g., L3 memory cells in this particular example. In this way, according to this example, L1 memory cells that twice failed a first analog program verify operation can complete programming and be less likely to result in read errors.

More specifically, various embodiments described herein seek to mitigate errors caused by memory cells not reaching their intended threshold voltages by further programming such memory cells while using one additional analog verify operation between programming pulses and one additional programming pulse at the end of the multi-level cell programing operation. While some approaches to ISPP programming have included a digital verify operation as well as an analog verify operation in between programming pulses, the present disclosure replaces the digital verify operation with an additional analog verify operation in order to determine a more granular program verify level for memory cells that have been programmed by the past two programming pulses during a multi-cell programming operation.

In various embodiments, for example, control logic of a memory device causes, in between applying programming pulses to selectively store data to multiple voltage levels of a plurality of memory cells, a second occurrence of a first analog verify operation to be performed on a first set of memory cells to identify one or more memory cells of a first subset of the first set of memory cells. In embodiments, the first subset of memory cells failed the first analog verify operation, and the one or more memory cells twice failed the first analog verify operation. In embodiments, the control logic also causes a first occurrence of a second analog verify operation to be performed at a second set of memory cells to identify a second subset of the second set of memory cells that failed the second analog verify operation. As used herein, a memory cell will be deemed the focus of a verification if the control gate voltage level, e.g., the verify voltage level, used during that verification corresponds to the intended data state for that memory cell. Further, at a subsequent programing operation of the first and second set of memory cells, a finalize analog voltage level can be applied to bitlines coupled to the one or more memory cells of the first subset of memory cells while an analog enable voltage level can be applied to bitlines coupled to the second subset of memory cells. The finalize analog voltage level can be higher than the analog enable voltage in order to allow a smaller amount of charge to finalize programming the one or more cells that twice failed the first analog verify operation.

Advantages of the present disclosure include, but are not limited to, improved read window budget (RWB) or read gaps between threshold voltage (Vt) distributions that distinguish data states within memory cells configured as MLC memory. The additional program pulse to clean up any lower tail bits of the final Vt distribution can be hidden under a level n+2 program pulse, thus saving in programming time. While for triple-level cell (TLC) memory, as an example, the present approach employs nine programming pulses (e.g., programming operations) and 14 program verify operations, there is still at least a 40% program time (tPROG) improvement over conventional ISPP. Additional advantages, as would be apparent those skilled in the art of SSPC and ISPP-based programming, will be further discussed hereafter.

1 FIG.A 100 110 110 140 130 110 illustrates an example computing systemthat includes a memory sub-systemin accordance with some embodiments of the present disclosure. The memory sub-systemcan include media, such as one or more volatile memory devices (e.g., memory device), one or more non-volatile memory devices (e.g., memory device), or a combination of such media or memory devices. The memory sub-systemcan be a storage device, a memory module, or a hybrid of a storage device and memory module.

130 The memory devicecan be a non-volatile memory device. One example of non-volatile memory devices is a negative-and (NAND) memory device. A non-volatile memory device is a package of one or more dice. Each die can include one or more planes. Planes can be groups into logic units (LUN). For some types of non-volatile memory devices (e.g., NAND devices), each plane includes a set of physical blocks. Each block includes a set of pages. Each page includes a set of memory cells (“cells”). A cell is an electronic circuit that stores information. Depending on the cell type, a cell can store one or more bits of binary information, and has various logic states that correlate to the number of bits being stored. The logic states can be represented by binary values, such as “0” and “1,” or combinations of such values.

130 The memory devicecan be made up of bits arranged in a two-dimensional or three-dimensional grid, also referred to as a memory array. Memory cells are formed onto a silicon wafer in an array of columns (also hereinafter referred to as bitlines) and rows (also hereinafter referred to as wordlines). A wordline can refer to one or more rows of memory cells of a memory device that are used with one or more bitlines to generate the address of each of the memory cells. The intersection of a bitline and wordline constitutes the address of the memory cell.

110 A memory sub-systemcan be a storage device, a memory module, or a hybrid of a storage device and memory module. Examples of a storage device include a solid-state drive (SSD), a flash drive, a universal serial bus (USB) flash drive, an embedded Multi-Media Controller (eMMC) drive, a Universal Flash Storage (UFS) drive, a secure digital (SD) and a hard disk drive (HDD). Examples of memory modules include a dual in-line memory module (DIMM), a small outline DIMM (SO-DIMM), and various types of non-volatile dual in-line memory module (NVDIMM).

100 The computing systemcan be a computing device such as a desktop computer, laptop computer, network server, mobile device, a vehicle (e.g., airplane, drone, train, automobile, or other conveyance), Internet of Things (IoT) enabled device, embedded computer (e.g., one included in a vehicle, industrial equipment, or a networked commercial device), or such computing device that includes memory and a processing device.

100 120 110 120 110 120 110 1 FIG.A The computing systemcan include a host systemthat is coupled to one or more memory sub-systems. In some embodiments, the host systemis coupled to different types of memory sub-system.illustrates one example of a host systemcoupled to one memory sub-system. As used herein, “coupled to” or “coupled with” generally refers to a connection between components, which can be an indirect communicative connection or direct communicative connection (e.g., without intervening components), whether wired or wireless, including connections such as electrical, optical, magnetic, etc.

120 120 110 110 110 The host systemcan include a processor chipset and a software stack executed by the processor chipset. The processor chipset can include one or more cores, one or more caches, a memory controller (e.g., NVDIMM controller), and a storage protocol controller (e.g., PCIe controller, SATA controller, CXL controller). The host systemuses the memory sub-system, for example, to write data to the memory sub-systemand read data from the memory sub-system.

120 110 120 110 120 130 110 120 110 120 110 120 1 FIG.A The host systemcan be coupled to the memory sub-systemvia a physical host interface. Examples of a physical host interface include, but are not limited to, a serial advanced technology attachment (SATA) interface, a compute express link (CXL) interface, a peripheral component interconnect express (PCIe) interface, universal serial bus (USB) interface, Fibre Channel, Serial Attached SCSI (SAS), a double data rate (DDR) memory bus, Small Computer System Interface (SCSI), a dual in-line memory module (DIMM) interface (e.g., DIMM socket interface that supports Double Data Rate (DDR)), etc. The physical host interface can be used to transmit data between the host systemand the memory sub-system. The host systemcan further utilize an NVM Express (NVMe) interface, Open NAND Flash Interface (ONFI) interface, or some other interface to access components (e.g., memory devices) when the memory sub-systemis coupled with the host systemby the physical host interface (e.g., PCIe or CXL bus). The physical host interface can provide an interface for passing control, address, data, and other signals between the memory sub-systemand the host system.illustrates a memory sub-systemas an example. In general, the host systemcan access multiple memory sub-systems via a same communication connection, multiple separate communication connections, and/or a combination of communication connections.

130 140 140 The memory devices,can include any combination of the different types of non-volatile memory devices and/or volatile memory devices. The volatile memory devices (e.g., memory device) can be, but are not limited to, random access memory (RAM), such as dynamic random access memory (DRAM) and synchronous dynamic random access memory (SDRAM).

130 Some examples of non-volatile memory devices (e.g., memory device) include negative-and (NAND) type flash memory and write-in-place memory, such as a three-dimensional cross-point (“3D cross-point”) memory device, which is a cross-point array of non-volatile memory cells. A cross-point array of non-volatile memory can perform bit storage based on a change of bulk resistance, in conjunction with a stackable cross-gridded data access array. Additionally, in contrast to many flash-based memories, cross-point non-volatile memory can perform a write in-place operation, where a non-volatile memory cell can be programmed without the non-volatile memory cell being previously erased. NAND type flash memory includes, for example, two-dimensional NAND (2D NAND) and three-dimensional NAND (3D NAND).

130 130 130 Each of the memory devicescan include one or more arrays of memory cells. One type of memory cell, for example, single level cells (SLC) can store one bit per cell. Other types of memory cells, such as multi-level cells (MLCs), triple level cells (TLCs), quad-level cells (QLCs), and penta-level cells (PLCs) can store multiple bits per cell. In some embodiments, each of the memory devicescan include one or more arrays of memory cells such as SLCs, MLCs, TLCs, QLCs, or any combination of such. In some embodiments, a particular memory device can include an SLC portion, and an MLC portion, a TLC portion, a QLC portion, or a PLC portion of memory cells. The memory cells of the memory devicescan be grouped as pages that can refer to a logical unit of the memory device used to store data. With some types of memory (e.g., NAND), pages can be grouped to form blocks.

130 Although non-volatile memory components such as 3D cross-point array of non-volatile memory cells and NAND type flash memory (e.g., 2D NAND, 3D NAND) are described, the memory devicecan be based on any other type of non-volatile memory, such as read-only memory (ROM), phase change memory (PCM), self-selecting memory, other chalcogenide based memories, ferroelectric transistor random-access memory (FeTRAM), ferroelectric random access memory (FeRAM), magneto random access memory (MRAM), Spin Transfer Torque (STT)-MRAM, conductive bridging RAM (CBRAM), resistive random access memory (RRAM), oxide based RRAM (OxRAM), negative-or (NOR) flash memory, and electrically erasable programmable read-only memory (EEPROM).

115 115 130 130 115 115 A memory sub-system controller(or controllerfor simplicity) can communicate with the memory devicesto perform operations such as reading data, writing data, or erasing data at the memory devicesand other such operations. The memory sub-system controllercan include hardware such as one or more integrated circuits and/or discrete components, a buffer memory, or a combination thereof. The hardware can include a digital circuitry with dedicated (i.e., hard-coded) logic to perform the operations described herein. The memory sub-system controllercan be a microcontroller, special purpose logic circuitry (e.g., a field programmable gate array (FPGA), an application specific integrated circuit (ASIC), etc.), or other suitable processor.

115 117 119 119 115 110 110 120 The memory sub-system controllercan be a processing device, which includes one or more processors (e.g., processor), configured to execute instructions stored in a local memory. In the illustrated example, the local memoryof the memory sub-system controllerincludes an embedded memory configured to store instructions for performing various processes, operations, logic flows, and routines that control operation of the memory sub-system, including handling communications between the memory sub-systemand the host system.

119 119 110 115 110 115 1 FIG.A In some embodiments, the local memorycan include memory registers storing memory pointers, fetched data, etc. The local memorycan also include read-only memory (ROM) for storing micro-code. While the example memory sub-systeminhas been illustrated as including the memory sub-system controller, in another embodiment of the present disclosure, a memory sub-systemdoes not include a memory sub-system controller, and can instead rely upon external control (e.g., provided by an external host, or by a processor or controller separate from the memory sub-system).

115 120 130 115 130 115 120 130 130 120 In general, the memory sub-system controllercan receive commands or operations from the host systemand can convert the commands or operations into instructions or appropriate commands to achieve the desired access to the memory devices. The memory sub-system controllercan be responsible for other operations such as wear leveling operations, garbage collection operations, error detection and error-correcting code (ECC) operations, encryption operations, caching operations, and address translations between a logical address (e.g., logical block address (LBA), namespace) and a physical address (e.g., physical block address) that are associated with the memory devices. The memory sub-system controllercan further include host interface circuitry to communicate with the host systemvia the physical host interface. The host interface circuitry can convert the commands received from the host system into command instructions to access the memory devicesas well as convert responses associated with the memory devicesinto information for the host system.

110 110 115 130 The memory sub-systemcan also include additional circuitry or components that are not illustrated. In some embodiments, the memory sub-systemcan include a cache or buffer (e.g., DRAM) and address circuitry (e.g., a row decoder and a column decoder) that can receive an address from the memory sub-system controllerand decode the address to access the memory devices.

130 135 115 130 115 130 130 110 130 135 115 In some embodiments, the memory devicesinclude local media controllersthat operate in conjunction with memory sub-system controllerto execute operations on one or more memory cells of the memory devices. An external controller (e.g., memory sub-system controller) can externally manage the memory device(e.g., perform media management operations on the memory device). In some embodiments, memory sub-systemis a managed memory device, which includes a raw memory devicehaving control logic (e.g., local media controller) on the die and a controller (e.g., memory sub-system controller) for media management within the same memory device package. An example of a managed memory device is a managed NAND (MNAND) device.

130 150 130 135 In some embodiments, the memory deviceincludes page buffers, which can be used to program data to the memory cells of the memory deviceand to read the data out of the memory cells. Control logic of the local media controllercan be configured to coordinate the timing and manner of applying one of three different voltage biases for selective slow program convergence voltage programming, as will be explained in detail. These three different bias voltages can be associated with, for example, program verify pass voltage (e.g., inhibit bias voltage), a selective slow program convergence voltage (e.g., PPV or a partially enabled voltage), and a program verify fail voltage (e.g., ground or Vss meant for fully enabling programming).

135 128 128 128 104 1 FIG.A In at least some embodiments, the local media controller(e.g., control logic) includes instruction registers, which represent computer-usable memory for storing computer-readable instructions. For some embodiments, the instruction registersrepresent firmware. Alternatively, the instruction registersrepresent a grouping of memory cells, e.g., reserved block(s) of memory cells, of an array of memory cells(see).

1 FIG.B 1 FIG.A 130 115 110 115 130 is a simplified block diagram of a first apparatus, in the form of a memory device, in communication with a second apparatus, in the form of a memory sub-system controllerof a memory sub-system (e.g., the memory sub-systemof), according to an embodiment. Some examples of electronic systems include personal computers, personal digital assistants (PDAs), digital cameras, digital media players, digital recorders, games, appliances, vehicles, wireless devices, mobile telephones and the like. The memory sub-system controller(e.g., a controller external to the memory device), can be a memory controller or other external host device.

130 104 104 1 FIG.B The memory deviceincludes an array of memory cellslogically arranged in rows and columns. Memory cells of a logical row are typically connected to the same access line (e.g., a wordline) while memory cells of a logical column are typically selectively connected to the same data line (e.g., a bitline). A single access line can be associated with more than one logical row of memory cells and a single data line can be associated with more than one logical column. Memory cells (not shown in) of at least a portion of the array of memory cellsare capable of being programmed to one of at least two target data states.

108 111 104 130 112 130 130 114 112 108 111 124 112 135 Row decode circuitryand column decode circuitryare provided to decode address signals. Address signals are received and decoded to access the array of memory cells. The memory devicealso includes input/output (I/O) control circuitryto manage input of commands, addresses and data to the memory deviceas well as output of data and status information from the memory device. An address registeris in communication with the I/O control circuitryand row decode circuitryand column decode circuitryto latch the address signals prior to decoding. A command registeris in communication with the I/O control circuitryand the local media controllerto latch incoming commands.

135 130 104 115 135 104 135 108 111 108 111 A controller (e.g., the local media controllerinternal to the memory device) controls access to the array of memory cellsin response to the commands and generates status information for the external memory sub-system controller, i.e., the local media controlleris configured to perform access operations (e.g., read operations, programming operations, and/or erase operations) on the array of memory cells. The local media controlleris in communication with row decode circuitryand column decode circuitryto control the row decode circuitryand column decode circuitryin response to the addresses.

135 118 121 118 135 104 118 121 104 118 112 118 112 115 121 118 118 121 150 130 150 104 122 112 135 115 The local media controlleris also in communication with a cache registerand a data register. The cache registerlatches data, either incoming or outgoing, as directed by the local media controllerto temporarily store data while the array of memory cellsis busy writing or reading, respectively, other data. During a program operation (e.g., write operation), data can be passed from the cache registerto the data registerfor transfer to the array of memory cells; then new data can be latched in the cache registerfrom the I/O control circuitry. During a read operation, data can be passed from the cache registerto the I/O control circuitryfor output to the memory sub-system controller; then new data can be passed from the data registerto the cache register. The cache registerand/or the data registercan form (e.g., can form at least a portion of) the page buffersof the memory device. The page bufferscan further include sensing devices such as a sense amplifier, to sense a data state of a memory cell of the array of memory cells, e.g., by sensing a state of a data line connected to that memory cell. A status registercan be in communication with I/O control circuitryand the local memory controllerto latch the status information for output to the memory sub-system controller.

130 115 135 132 132 130 130 115 134 115 134 The memory devicereceives control signals at the memory sub-system controllerfrom the local media controllerover a control link. For example, the control signals can include a chip enable signal CE #, a command latch enable signal CLE, an address latch enable signal ALE, a write enable signal WE #, a read enable signal RE #, and a write protect signal WP #. Additional or alternative control signals (not shown) can be further received over control linkdepending upon the nature of the memory device. In one embodiment, memory devicereceives command signals (which represent commands), address signals (which represent addresses), and data signals (which represent data) from the memory sub-system controllerover a multiplexed input/output (I/O) busand outputs data to the memory sub-system controllerover I/O bus.

134 112 124 134 112 114 112 118 121 104 For example, the commands can be received over input/output (I/O) pins [7:0] of I/O busat I/O control circuitryand can then be written into a command register. The addresses can be received over input/output (I/O) pins [7:0] of I/O busat I/O control circuitryand can then be written into address register. The data can be received over input/output (I/O) pins [7:0] for an 8-bit device or input/output (I/O) pins [15:0] for a 16-bit device at I/O control circuitryand then can be written into cache register. The data can be subsequently written into data registerfor programming the array of memory cells.

118 121 130 115 In an embodiment, cache registercan be omitted, and the data can be written directly into data register. Data can also be output over input/output (I/O) pins [7:0] for an 8-bit device or input/output (I/O) pins [15:0] for a 16-bit device. Although reference can be made to I/O pins, they can include any conductive node providing for electrical connection to the memory deviceby an external device (e.g., the memory sub-system controller), such as conductive pads or conductive bumps as are commonly used.

130 1 FIG.B 1 FIG.B 1 FIG.B 1 FIG.B It will be appreciated by those skilled in the art that additional circuitry and signals can be provided, and that the memory deviceofhas been simplified. It should be recognized that the functionality of the various block components described with reference tomay not necessarily be segregated to distinct components or component portions of an integrated circuit device. For example, a single component or component portion of an integrated circuit device could be adapted to perform the functionality of more than one block component of. Alternatively, one or more components or component portions of an integrated circuit device could be combined to perform the functionality of a single block component of. Additionally, while specific I/O pins are described in accordance with popular conventions for receipt and output of the various signals, it is noted that other combinations or numbers of I/O pins (or other I/O node structures) can be used in the various embodiments.

2 FIG. 1 FIG.B 2 FIG. 200 104 200 2020 202 2040 204 202 200 2040 104 135 is a schematic of portions of an array of memory cells, such as a NAND memory array, as could be used in a memory of the type described with reference toaccording to an embodiment, e.g., as a portion of the array of memory cells. Memory arrayincludes access lines, such as wordlinestoN, and data lines, such as bitlinestoM. The wordlinescan be connected to global access lines (e.g., global wordlines), not shown in, in a many-to-one relationship. For some embodiments, memory arraycan be formed over a semiconductor that, for example, can be conductively doped to have a conductivity type, such as a p-type conductivity, e.g., to form a p-well, or an n-type conductivity, e.g., to form an n-well. The bitlinescan include a plurality of bitlines, each selectively coupled to a respective memory cell of the plurality of memory cells of the array of memory cellsand operatively coupled to the control logic of the local media controller.

200 202 204 2060 206 206 216 2080 208 208 208 206 210 2100 210 212 2120 212 2100 210 214 2120 212 215 210 212 208 210 212 Memory arraycan be arranged in rows (each corresponding to a wordline) and columns (each corresponding to a bitline). Each column can include a string of series-connected memory cells (e.g., non-volatile memory cells), such as one of NAND stringstoM. Each NAND stringcan be connected (e.g., selectively connected) to a common source (SRC)and can include memory cellstoN. The memory cellscan represent non-volatile memory cells for storage of data. The memory cellsof each NAND stringcan be connected in series between a select gate(e.g., a field-effect transistor), such as one of the select gatestoM (e.g., that can be source select transistors, commonly referred to as select gate source), and a select gate(e.g., a field-effect transistor), such as one of the select gatestoM (e.g., that can be drain select transistors, commonly referred to as select gate drain). Select gatestoM can be commonly connected to a select line, such as a source select line (SGS), and select gatestoM can be commonly connected to a select line, such as a drain select line (SGD). Although depicted as traditional field-effect transistors, the select gatesandcan utilize a structure similar to (e.g., the same as) the memory cells. The select gatesandcan represent a number of select gates connected in series, with each select gate in series configured to receive a same or independent control signal.

210 216 210 2080 206 2100 2080 2060 210 206 216 210 214 A source of each select gatecan be connected to common source. The drain of each select gatecan be connected to a memory cellof the corresponding NAND string. For example, the drain of select gatecan be connected to memory cellof the corresponding NAND string. Therefore, each select gatecan be configured to selectively connect a corresponding NAND stringto the common source. A control gate of each select gatecan be connected to the select line.

212 204 206 2120 2040 2060 212 208 206 2120 208 2060 212 206 204 212 215 The drain of each select gatecan be connected to the bitlinefor the corresponding NAND string. For example, the drain of select gatecan be connected to the bitlinefor the corresponding NAND string. The source of each select gatecan be connected to a memory cellN of the corresponding NAND string. For example, the source of select gatecan be connected to memory cellN of the corresponding NAND string. Therefore, each select gatecan be configured to selectively connect a corresponding NAND stringto the corresponding bitline. A control gate of each select gatecan be connected to select line.

200 216 206 204 200 206 216 204 216 2 FIG. 2 FIG. The memory arrayincan be a quasi-two-dimensional memory array and can have a generally planar structure, e.g., where the common source, NAND stringsand bitlinesextend in substantially parallel planes. Alternatively, the memory arrayincan be a three-dimensional memory array, e.g., where NAND stringscan extend substantially perpendicular to a plane containing the common sourceand to a plane containing the bitlinesthat can be substantially parallel to the plane containing the common source.

208 234 236 234 236 208 230 232 208 236 202 2 FIG. Typical construction of memory cellsincludes a data-storage structure(e.g., a floating gate, charge trap, and the like) that can determine a data state of the memory cell (e.g., through changes in threshold voltage), and a control gate, as shown in. The data-storage structurecan include both conductive and dielectric structures while the control gateis generally formed of one or more conductive materials. In some cases, memory cellscan further have a defined source/drain (e.g., source)and a defined source/drain (e.g., drain). The memory cellshave their control gatesconnected to (and in some cases form) a wordline.

208 206 206 204 208 208 202 208 208 202 208 208 208 208 202 208 202 204 2040 2042 2044 208 208 202 204 2041 2043 2045 208 A column of the memory cellscan be a NAND stringor a number of NAND stringsselectively connected to a given bitline. A row of the memory cellscan be memory cellscommonly connected to a given wordline. A row of memory cellscan, but need not, include all the memory cellscommonly connected to a given wordline. Rows of the memory cellscan often be divided into one or more groups of physical pages of memory cells, and physical pages of the memory cellsoften include every other memory cellcommonly connected to a given wordline. For example, the memory cellscommonly connected to wordlineN and selectively connected to even bitlines(e.g., bitlines,,, etc.) can be one physical page of the memory cells(e.g., even memory cells) while memory cellscommonly connected to wordlineN and selectively connected to odd bitlines(e.g., bitlines,,, etc.) can be another physical page of the memory cells(e.g., odd memory cells).

2043 2045 204 200 2040 204 208 202 208 2020 202 206 202 2 FIG. 2 FIG. Although bitlines-are not explicitly depicted in, it is apparent from the figure that the bitlinesof the array of memory cellscan be numbered consecutively from bitlineto bitlineM. Other groupings of the memory cellscommonly connected to a given wordlinecan also define a physical page of memory cells. For certain memory devices, all memory cells commonly connected to a given wordline can be deemed a physical page of memory cells. The portion of a physical page of memory cells (which, in some embodiments, could still be the entire row) that is read during a single read operation or programmed during a single programming operation (e.g., an upper or lower page of memory cells) can be deemed a logical page of memory cells. A block of memory cells can include those memory cells that are configured to be erased together, such as all memory cells connected to wordlines-N (e.g., all NAND stringssharing common wordlines). Unless expressly distinguished, a reference to a page of memory cells herein refers to the memory cells of a logical page of memory cells. Although the example ofis discussed in conjunction with NAND flash, the embodiments and concepts described herein are not limited to a particular array architecture or structure, and can include other structures (e.g., SONOS, phase change, ferroelectric, etc.) and other architectures (e.g., AND arrays, NOR arrays, etc.).

3 3 FIGS.A-B 3 FIG.A 330 330 330 330 330 330 330 330 330 330 0 7 0 1 7 0 1 7 1 7 are graphs of conceptual depictions of threshold voltage distributions of a plurality of memory cells of different memory densities according to at least one embodiment.illustrates an example of threshold voltage distributions and their threshold voltage ranges for a population of a eight-level memory cells, often referred to as TLC memory cells. For example, such a memory cell might be programmed to a threshold voltage (Vt) that falls within one of eight different threshold voltage distributions-, each being used to represent a data state corresponding to a bit pattern of three bits. The threshold voltage distributiontypically has a greater width than the remaining threshold voltage distributions-as memory cells are generally all placed in the data state corresponding to the threshold voltage distribution, then subsets of those memory cells are subsequently programmed to have threshold voltages in one of the threshold voltage distributions-. As programming operations are generally more incrementally controlled than erase operations, these threshold voltage distributions-may tend to have tighter distributions.

330 330 330 330 330 330 330 330 330 330 330 127 0 1 2 3 4 5 6 7 0 1 2 The threshold voltage distributions,,,,,,, andmight each represent a respective data state, e.g., L0, L1, L2, L3, L4, L5, L6, and L7, respectively. The eight data states L0-L7 might be thought of as an initial data state L0 and seven remaining data states L1-L7. As an example, if the threshold voltage of a memory cell is within the first of the eight threshold voltage distributions, the memory cell in this case may be storing a data state L0 having a data value of logical ‘111’ and is typically referred to as the erased or initial data state of the memory cell. If the threshold voltage is within the second of the eight threshold voltage distributions, the memory cell in this case may be storing a data state L1 having a data value of logical ‘011’. If the threshold voltage is within the third of the eight threshold voltage distributions, the memory cell in this case may be storing a data state L2 having a data value of logical ‘001’, and so on. Table 1 provides one possible correspondence between the data states and their corresponding logical data values. Other assignments of data states to logical data values are known. Memory cells remaining in the lowest data state (e.g., the initial data state or L0 data state), as used herein, will be deemed to be programmed to the lowest data state. The information of Table 1 might be contained within the trim register, for example.

TABLE 1 Data State Logical Data Value L0 111 L1 11 L2 1 L3 101 L4 100 L5 0 L6 10 L7 110

330 330 330 332 332 332 330 330 332 332 330 1 7 1 1 1 1 2 7 2 7 1 In programming the memory cells represented by the threshold voltage distributions-, one or more programming pulses might be applied to control gates of the memory cells following by a verification. For example, in programming memory cells of the threshold voltage distribution, a verify voltage levelmight be applied to the control gates of those memory cells. If a memory cell having the data state L1 as its intended data state is deactivated in response to the verify voltage level, it might be deemed to have passed verification, such that it might be inhibited from programming for subsequent programming pulses. If that memory cell is activated in response to the verify voltage level, it might be deemed to have failed verification, such that it might be enabled, e.g., either partially or fully enabled, for programming for a subsequent programming pulse. Each threshold voltage distribution-might have a corresponding verify voltage level-, respectively, and might follow a similar logic process to determine whether to inhibit or enable their corresponding memory cells for subsequent programming pulses as discussed with reference to the threshold voltage distribution.

3 FIG.B 3 FIG.B 330 330 330 330 330 330 330 330 330 330 0 15 0 1 15 0 1 15 1 15 is another conceptual depiction of threshold voltage distributions of a plurality of memory cells of a second memory density, e.g., four digits of data per memory cell.illustrates an example of threshold voltage distributions and their distributions for a population of a sixteen-level memory cells, often referred to as QLC memory cells. For example, such a memory cell might be programmed to a threshold voltage (Vt) that falls within one of sixteen different threshold voltage distributions-, each being used to represent a data state corresponding to a bit pattern of four bits. The threshold voltage distributiontypically has a greater width than the remaining threshold voltage distributions-as memory cells are generally all placed in the data state corresponding to the threshold voltage distribution, then subsets of those memory cells are subsequently programmed to have threshold voltages in one of the threshold voltage distributions-. As programming operations are generally more incrementally controlled than erase operations, these threshold voltage distributions-may tend to have tighter distributions.

330 330 330 330 330 330 330 330 330 330 330 330 330 330 330 330 330 330 330 127 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 0 1 2 The threshold voltage distributions,,,,,,,,,,,,,,andmight each represent a respective data state, e.g., L0, L1, L2, L3, L4, L5, L6, L7, L8, L9, L10, L11, L12, L13, L14 and L15, respectively. The sixteen data states L0-L15 might be thought of as an initial data state L0 and fifteen remaining data states L1-L15. As an example, if the threshold voltage of a memory cell is within the first of the sixteen threshold voltage distributions, the memory cell in this case may be storing a data state L0 having a data value of logical ‘1111’ and is typically referred to as the erased or initial data state of the memory cell. If the threshold voltage is within the second of the sixteen threshold voltage distributions, the memory cell in this case may be storing a data state L1 having a data value of logical ‘0111’. If the threshold voltage is within the third of the sixteen threshold voltage distributions, the memory cell in this case may be storing a data state L2 having a data value of logical ‘0011’, and so on. Table 2 provides one possible correspondence between the data states and their corresponding logical data values. Other assignments of data states to logical data values are known. Memory cells remaining in the lowest data state (e.g., the initial data state or L0 data state), as used herein, will be deemed to be programmed to the lowest data state. The information of Table 2 might be contained within the trim register, for example.

TABLE 2 Data State Logical Data Value L0 1111 L1 111 L2 11 L3 1011 L4 1001 L5 1 L6 101 L7 1101 L8 1100 L9 100 L10 0 L11 1000 L12 1010 L13 10 L14 110 L15 1110

3 FIG.B 3 FIG.A 330 330 332 332 330 330 1 15 1 15 2 7 Although not depicted in, each threshold voltage distribution-might have a corresponding verify voltage level-, respectively, and might follow a similar logic process to determine whether to inhibit or enable their corresponding memory cells for subsequent programming pulses as discussed with reference to threshold voltage distribution-of.

4 4 FIGS.A-B 1 1 FIGS.A-B 400 400 206 204 400 401 403 405 407 409 411 413 415 419 421 433 435 437 439 441 447 449 451 453 455 400 417 431 462 413 401 403 405 407 409 411 415 419 421 433 435 437 439 441 447 449 451 453 455 431 427 429 423 425 462 458 460 443 445 are schematics of portions of a page buffer circuitas could be used in a memory of the type described with reference toaccording to some embodiments. Page buffer circuitmight be connected (e.g., selectively connected) to a NAND stringthrough a data line. Page buffer circuitmight include transistors,,,,,,,,,,,,,,,,,,, and. The page buffer circuitmight further include a sense capacitor, a sense amplifier latch, and a data latch. Transistormight be a p-type field-effect transistor (pFET), while transistors,,,,,,,,,,,,,,,,,, andmight be n-type field-effect transistors (nFETs). Sense amplifier latchmight include invertersandand transistorsand(e.g., nFETs). Data latch (e.g., PDC2)might include invertersandand transistorsand(e.g., nFETs).

204 401 403 403 404 403 216 401 402 401 405 The data linemight be connected to a first source/drain of transistorand a first source/drain of transistor. The control gate of transistormight be connected to a src_gate control signal node. The second source/drain of transistormight be connected to the common source. The control gate of transistormight be connected to a dw_gate control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor.

405 406 405 407 409 411 407 408 407 413 413 453 415 453 454 453 427 429 423 413 414 409 410 409 415 415 416 The control gate of transistormight be connected to a blclamp control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor, a first source/drain of transistor, and a first source/drain of transistor. The control gate of transistormight be connected to a blclamp2 control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor. The control gate of transistormight be connected to a first source/drain of transistorand the control gate of transistor. The control gate of transistormight be connected to a sab_bl_pre control signal node. The second source/drain of transistormight be connected to the input of inverter, the output of inverter, and a first source/drain of transistor. The second source/drain of transistormight be connected to a voltage node (e.g., vreg2). The control gate of transistormight be connected to an en_data control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor. The second source/drain of transistormight be connected to a voltage node (e.g., vreg0).

411 412 411 417 419 451 432 417 418 419 420 419 421 423 425 433 435 437 439 441 The control gate of transistormight be connected to a the_iso control signal node. The second source/drain of transistormight be connected to one side (e.g., a first electrode) of sense capacitor, a first source/drain of transistor, and the control gate of transistorthrough a tc signal node. The other side (e.g., a second electrode) of sense capacitormight be connected to a sense capacitor bias node (e.g., boost node). The control gate of transistormight be connected to a blc1 control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor, the second source/drain of transistor, a first source/drain of transistor, a first source/drain of transistor, a first source/drain of transistor, a first source/drain of transistor, a first source/drain of transistor, and a first source/drain of transistor.

433 434 433 447 447 448 435 436 435 449 449 450 449 447 The control gate of transistormight be connected to a en_sspc2 control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor. The second source/drain of transistormight be connected to a voltage node (e.g., vcc). The control gate of transistormight be connected to a dl_set control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor. The control gate of transistormight be connected to a d_latch control signal node. The second source/drain of transistormight be connected to the control gate of transistor.

421 422 421 451 451 452 451 The control gate of transistormight be connected to a sen control signal node. The second source/drain of transistormight be connected to a first source/drain of transistor. The second source/drain of transistormight be connected to a source bias node (e.g., src_gnd). The transistormight be referred to as a sense transistor.

423 431 424 425 426 425 427 429 427 428 429 430 The control gate of transistorof sense amplifier latchmight be connected to a drst_sa control signal node. The control gate of transistormight be connected to a dst_sa control signal node. The second source/drain of transistormight be connected to the output of inverterand to the input of inverter. A control input of invertermight be connected to a sen_sab control signal node. A control input of invertermight be connected to a lat_sab control signal node.

437 438 437 455 457 439 441 443 445 441 442 455 456 455 439 The control gate of transistormight be connected to a tccint_dis control signal node. The second source/drain of transistormight be connected to a first source/drain of transistorand to a voltage node (e.g., vprech). The control gate of transistormight be connected to the second source/drain of transistor, a first source/drain of transistor, and a first source/drain of transistor. The control gate of transistormight be connected to a blc2 control signal node. The control gate of transistormight be connected to a en_sa control signal node. The second source/drain of transistormight be connected to the second source/drain of transistor.

443 462 444 445 446 443 460 458 445 458 460 460 461 458 459 The control gate of transistorof data latchmight be connected to a drst2 control signal node. The control gate of transistormight be connected to a dst2 control signal node. The second source/drain of transistormight be connected to the output of inverterand to the input of inverter. The second source/drain of transistormight be connected to the output of inverterand to the input of inverter. A control input of invertermight be connected to a sen2b control signal node. A control input of invertermight be connected to a lat2b control signal node.

135 404 402 406 408 410 412 420 422 454 434 436 450 438 456 430 428 424 426 461 459 444 446 400 1 1 FIGS.A-B Control logic (e.g., of the local media controllerof) might be connected to the src_gate control signal node, the dw_gate control signal node, the blclamp control signal node, the blclamp2 control signal node, the en_data control signal node, the tc_iso control signal node, the BLC1 control signal node, the sen control signal node, the sab_bl_pre control signal node, the en_sspc2 control signal node, the dl_set control signal node, the d_latch control signal node, the tdcint_dis control signal node, the en_sa control signal node, the lat_sab control signal node, the sen_sab control signal node, the drst_sa control signal node, the dst_sa control signal node, the sen2b control signal node, thae lat2b control signal node, the drst2 control signal node, and the dst2 control signal nodeto control the operation of page buffer circuit.

400 206 431 400 431 462 4 4 FIGS.A-B Page buffer circuitmight be used to sense the data state of the selected memory cell of the NAND stringand latch the sensed data state in sense amplifier latchduring a read operation or a verify phase of a programming operation. Page buffer circuitmight also be used to program a target data state to the selected memory cell based on a state of the sense amplifier latchor a state of one or more data latches. Additional data latches (not shown in) might be connected in parallel with, and have a similar (e.g., same) structure as, the data latch.

5 FIG. 3 3 FIGS.A-B 5 FIG. 330 503 503 0 are graphs of diagrammatic illustrations that depict a population of memory cells during a programming operation to program selected memory cells to a target voltage using selective slow program convergence according to at least one embodiment. In various embodiments, the population of cells begin at an initial data state, L0, as was previously discussed with reference to threshold voltage distribution(scc). As the population of memory cells is further programmed, each subsequent program verify voltage level is checked in a program verify operation (also referred to as program verification herein) before a subset of memory cells associated with the next state (e.g., currently being programmed) are inhibited from programming. So, for example, as illustrated in, the L1 data state has been fully programmed and data state Ln−1 is being programmed by pulse_m in the upper graphic. Typically, therefore, the memory cells in the Vt range indicated by A would be inhibited while the memory cells in the Vt range indicated by B would be further programmed to generate data state Ln−1, for example. As can be seen, however, a subset of memory cells(or bits) have been left behind in a longer tail of data state Ln−1 than desired. If the subset of memory cellswere left at this lower Vt level, errors would likely occur in distinguishing between the L1 and Ln−1 data states.

503 503 503 According to disclosed embodiments, during a subsequent programming pulse (pulse_m+1), the bitline voltage for the subset of memory cellsmay be shifted to higher bitline voltage, e.g., to a finalize analog voltage level that enables the subset of memory cellsto be finished off so that they pass a second analog verify operation. This final programming of the subset of memory cellscan occur at the same time as programming the memory cells associated with the Ln−1 data state that also further programs memory cells for the Ln and Ln+1 to Lmax data states. Thus, as can be seen in the bottom graphic, the Ln−1 data state can now pass the program verify operation at a PV2 voltage level while the Ln data state is being verified at a PV3 voltage level. Thus, in embodiments, depending on a target voltage for a Vt level of a particular subset of memory cells, and depending on how many times one or more memory cells have failed a program verify operation, a different bitline voltage can be applied to selectively slow down some programming, causing programming memory cells at different rates depending on how close the Vt levels are to the program verify (PV) voltage level for those particular memory cells.

TABLE 3 Vbl@pulse_m + Vt shift Vt Region Status after Pulse_m 1 (in V) @pulse_m + 1 A Ln − 2 and below Inhibit None A Ln − 1 failed Finalize Analog 0~0.3 V B Ln − 1 passed Inhibit None C Ln failed Analog Enable 0~0.3 V D Ln passed Inhibit None C&D Ln + 1 & above Digital Low  0.8 V

7 7 FIGS.A-C Table 3 is an example of certain subsets of memory cells after pulse_m, with information by columns including: 1) the Vt region of the memory cells; 2) a status of the memory cells; 3) the bitline voltage level to be used for programming by the pulse_m+1 programming pulse; and 4) the Vt shift after the pulse_m+1 programing pulse has been applied. Depending on application and memory device technology, the bitline voltage levels (Vbl) at pulse_m+1 can vary. Just for a sense of relative values and ranges of these bitline voltage levels, in some embodiments, the inhibit voltage is somewhere around 2.0-2.4V, the finalize analog voltage is between 0.5-1.5V and generally expected to be higher than the analog enable voltage, the analog enable voltage is between 0-1.0V, and the digital low voltage is zero (e.g., 0V or approximately 0V). Also, the programming step or gate step voltage increase between pulse_m and pulse_m+1 is illustrated as 0.8V, but this value can also be expected to vary in differing embodiments or memory devices. These different voltage levels will be also be referenced hereinafter with reference to, for example.

6 FIG. 5 FIG. 7 7 FIGS.A-C 503 is a graph illustrating nine programming pulses and fourteen program verify operations performed across a population of triple-level memory cells (TLCs) according to an embodiment, only for purposes of explanation. In this graph, (in which L0 is not illustrated) each data state of the seven data states (L1-L7) of TLC memory can be programmed over a combination of three programming pulses according to at least one embodiment. As each programming pulse is applied to wordlines of the TLC memory cells, the population of memory cells associated with all of the data states are incrementally programmed according to SSPC-based programming (illustrated with the arrows drawn through additional SLC data state levels). Of the three programming pulses, the first two applied to memory cells of each respective data state also involve a program verify operation. The first programming pulse can be followed a single analog program verify operation while each subsequent programming pulse can be followed by two analog program verify operations, one for two prior programming levels (e.g., that clean up any remaining subset of memory cellssimilar as discussed with reference to) and the other for the immediate previous programming level (seefor more detail).

In embodiments, each subsequent programming pulse may increase by a gate step voltage (e.g., illustrated as 0.8V but which could be different, like 0.6V, 0.7V, 0.9V or the like) to incrementally increase the programmed Vt levels for each subsequent data state. Thus, for example, programming pulse #1 can be applied using fully enabled programming of all data state levels (L1-L7). Further, programming pulse #2 can be applied using SSPC-based programming to L1 memory cells that failed an L1 program verify operation and be applied using fully enabled programming for the rest of the data state levels (L2-L7). Further, programming pulse #3 can be applied to one or more of the L1 memory cells that still failed the program verify at the L1 program verify voltage, to a subset of L2 memory cells that failed a L2 program verify operation (e.g., using SSPC-based programming), and to the L3 memory cells (in addition to L4-L7 memory cells) using fully enabled programming. Similarly, programming pulse #4 can be applied to one or more of the L2 memory cells that still failed the program verify at the L2 program verify voltage, to a subset of L3 memory cells that failed a L3 program verify operation (e.g., using SSPC-based programming), and to the L4 memory cells (in addition to L5-L7 memory cells) using fully enabled programming.

7 7 FIGS.A-C In embodiments, this sort of programming pattern continues with varying programming pulse voltage levels depending on how close to being fully programmed the respective data state is until there are fewer than three data states left to program. Thus, programming pulse #8 can be applied to just L6 memory cells that still failed the L6 program verify operation and L7 memory cells (using SSPC-based programming). Further, programming pulse #9 can be applied to just L7 memory cells that still failed the L7 program verify operation. For a more specific description of the role of each program verify operation, please see.

7 FIG.A 7 FIG.B 1 1 FIGS.A-B 7 700 700 700 135 128 ,, FIB.C are flow diagrams of an example methodof program level-based programming with multiple analog program verify operations between programming pulses according to some embodiments. The methodcan be performed by processing logic that can include hardware (e.g., processing device, circuitry, dedicated logic, programmable logic, microcode, hardware of a device, integrated circuit, etc.), software (e.g., instructions run or executed on a processing device), or a combination thereof. In some embodiments, the methodis performed by the local media controller(or control logic) ofthat includes instructions registers. Although shown in a particular sequence or order, unless otherwise specified, the order of the processes can be modified. Thus, the illustrated embodiments should be understood only as examples, and the illustrated processes can be performed in a different order, and some processes can be performed in parallel. Additionally, one or more processes can be omitted in various embodiments. Thus, not all processes are required in every embodiment. Other process flows are possible.

7 FIG.A 6 FIG. 705 With initial reference to, assume that multiple sets of memory cells (to be programmed to various data states) are in the initial date state L0, also referred to as an erased state. At operation, a first set of memory cells (e.g., L1 memory cells) are programmed. For example, the processing logic causes the first set of memory cells to be programmed using a first programming pulse. During this first programming operation, the bitline voltages for L0 memory cells can be an inhibit voltage and the bitline voltages for the L1-L7 memory cells can be a digital low voltage. Thus, although the first set of memory cells is specifically referenced, it should be understood that other sets of memory cells (for higher data states) are also being programmed as was discussed with reference to.

710 135 At operation, a first analog verify operation is performed. For example, the processing logic (e.g., control logic of the local media controller) causes a first occurrence of a first analog verify operation to be performed on the first set of memory cells to determine a first subset of the first set of memory cells that failed the first analog verify operation. Thus, this first analog verify operation can be understood as an analog verify for L1 at PV1 (a first program verify voltage).

715 At operation, the second set of memory cells is programmed. For example, the processing logic causes the first subset of memory cells and a second set of memory cells to be programmed using a second programming pulse, where the second set of memory cells are L2 memory cells. In embodiments, the second programming pulse has a higher voltage level than the first programming pulse. In some embodiments, the bitline voltage is the inhibit voltage for L0 memory cells and also for the L1 memory cells that have passed the PV1 program verify operation, is the analog enable voltage for the L1 memory cells that have failed the PV1 program verify operation, and is the digital low voltage for memory cells that for L2-L7 memory cells yet to be programmed. Thus, while programming using the second programming pulse, the operations include causing an analog enable voltage level to be applied to bitlines, of a plurality of bitlines, coupled to the first subset of memory cells.

720 At operation, the first analog verify operation is performed again. For example, the processing logic causes a second occurrence of the first analog verify operation to be performed on the first set of memory cells (e.g., for L1 and PV1) to determine one or more memory cells of the first subset of memory cells that again failed the first analog verify operation.

725 At operation, a second program verify operation is performed. For example, the processing logic causes a first occurrence of a second analog verify operation to be performed on the second set of memory cells (e.g., L2 at PV2) to determine a second subset of the second set of memory cells that failed the second analog verify operation.

7 FIG.B 730 730 With additional reference to, at operation, a third set of memory cells is programmed. For example, the processing logic causes the one or more memory cells of the first subset of memory cells, the second subset of memory cells, and a third set of memory cells to be programmed using a third programming pulse having a higher voltage than the second programming pulse. In some embodiments, the bitline voltage is the inhibit voltage for the L0 memory cells, for the L1 memory cells that passed the first program verify operation, and for the L2 memory cells that passed the second program verify operation. Further, in embodiments, the bitline voltage is the digital low voltage for memory cells coupled to the L2-L7 memory cells. Further, also at operation, the processing logic causes a finalize analog voltage level to be applied to bitlines, of a plurality of bitlines, coupled to the one or more memory cells of the first subset of memory cells and causes an analog enable voltage level to be applied to bitlines, of the plurality of bitlines, coupled to the second subset of memory cells.

735 At operation, a second analog verify operation is performed. For example, the processing logic causes a second occurrence of the second analog verify operation to be performed on the second set of memory cells (e.g., L2 at PV2) to determine one or more memory cells of the second subset of memory cells that again failed the second analog verify operation.

740 At operation, a third analog verify operation is performed. For example, the processing logic causes a third analog verify operation to be performed on the third set of memory cells (e.g., L3 at PV3) to determine a third subset of the third set of memory cells that failed the third analog verify operation.

750 730 735 740 At operation, the processing logic causes operations,, andto be repeated for each programming level (e.g., data state level) up to a penultimate programming pulse to be applied.

7 FIG.C 755 755 With additional reference to, at operation, a final set of memory cells is programmed. For example, the processing logic causes a final set of memory cells to be programmed using a penultimate programming pulse having a higher voltage than a preceding programming pulse. In some embodiments, the bitline voltage is the inhibit voltage for the L0-L5 memory cells that are fully programmed, for the L6 memory cells that have passed the PV6 analog verify operation, and for the L7 memory cells that have passed the PV7 analog verify operation. Further, also at operation, the processing logic causes a finalize analog voltage level to be applied to bitlines, of a plurality of bitlines, coupled to the one or more memory cells of a sixth subset of memory cells (that twice failed the PV6 analog verify operation) and causes an analog enable voltage level to be applied to bitlines, of the plurality of bitlines, coupled to a seventh subset of memory cells that failed the PV7 analog verify operation.

760 At operation, a final analog verify operation is performed. For example, the processing logic causes a final analog verify operation to be performed at the final set of memory cells (e.g., L7 at PV7) to determine a final subset of the final set of memory cells that failed the final analog verify operation.

765 765 At operation, a final programming pulse is applied. For example, the processing logic causes the final subset of memory cells to be programmed using a final programming pulse. In embodiment, the first programming pulse through the final programming pulse are numbered one greater than a number of multi-level data states that were programmed at the plurality of memory cells, e.g., L0-L7. In embodiments, the bitline voltage is the inhibit voltage for L0-L6 memory cells and for L7 memory cells that passed the final analog verify operation. In embodiments, also at operation, the processing logic causes, while programming using the final programming pulse, an analog enable voltage level to be applied to bitlines coupled to the final subset of memory cells.

8 FIG. 1 FIG.A 1 FIG.A 1 FIG.A 800 800 120 110 135 illustrates an example machine of a computer systemwithin which a set of instructions, for causing the machine to perform any one or more of the methodologies discussed herein, can be executed. In some embodiments, the computer systemcan correspond to a host system (e.g., the host systemof) that includes, is coupled to, or utilizes a memory sub-system (e.g., the memory sub-systemof) or can be used to perform the operations of a controller (e.g., to execute an operating system to perform operations corresponding to the local media controllerof), also referred to as control logic herein. In alternative embodiments, the machine can be connected (e.g., networked) to other machines in a LAN, an intranet, an extranet, and/or the Internet. The machine can operate in the capacity of a server or a client machine in client-server network environment, as a peer machine in a peer-to-peer (or distributed) network environment, or as a server or a client machine in a cloud computing infrastructure or environment.

The machine can be a personal computer (PC), a tablet PC, a set-top box (STB), a Personal Digital Assistant (PDA), a cellular telephone, a web appliance, a server, a network router, a switch or bridge, or any machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. Further, while a single machine is illustrated, the term “machine” shall also be taken to include any collection of machines that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein.

800 802 804 810 818 830 The example computer systemincludes a processing device, a main memory(e.g., read-only memory (ROM), flash memory, dynamic random access memory (DRAM) such as synchronous DRAM (SDRAM) or Rambus DRAM (RDRAM), etc.), a static memory(e.g., flash memory, static random access memory (SRAM), etc.), and a data storage system, which communicate with each other via a bus.

802 802 802 828 800 812 820 Processing devicerepresents one or more general-purpose processing devices such as a microprocessor, a central processing unit, or the like. More particularly, the processing device can be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, or a processor implementing other instruction sets, or processors implementing a combination of instruction sets. Processing devicecan also be one or more special-purpose processing devices such as an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a digital signal processor (DSP), network processor, or the like. The processing deviceis configured to execute instructionsfor performing the operations and steps discussed herein. The computer systemcan further include a network interface deviceto communicate over the network.

818 824 828 818 135 828 804 802 800 804 802 824 818 804 110 1 FIG.A The data storage systemcan include a machine-readable storage medium(also known as a computer-readable medium) on which is stored one or more sets of instructionsor software embodying any one or more of the methodologies or functions described herein. The data storage systemcan further include the local media controller, which were previously discussed. The instructionscan also reside, completely or at least partially, within the main memoryand/or within the processing deviceduring execution thereof by the computer system, the main memoryand the processing devicealso constituting machine-readable storage media. The machine-readable storage medium, data storage system, and/or main memorycan correspond to the memory sub-systemof.

826 115 824 1 FIG.A In one embodiment, the instructionsinclude instructions to implement functionality corresponding to a controller (e.g., the memory sub-system controllerof). While the machine-readable storage mediumis shown in an example embodiment to be a single medium, the term “machine-readable storage medium” should be taken to include a single medium or multiple media that store the one or more sets of instructions. The term “machine-readable storage medium” shall also be taken to include any medium that is capable of storing or encoding a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present disclosure. The term “machine-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories, optical media, and magnetic media.

Some portions of the preceding detailed descriptions have been presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the ways used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of operations leading to a desired result. The operations are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, combined, compared, and otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.

It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. The present disclosure can refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage systems.

The present disclosure also relates to an apparatus for performing the operations herein. This apparatus can be specially constructed for the intended purposes, or it can include a general purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program can be stored in a computer readable storage medium, such as, but not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions, each coupled to a computer system bus.

The algorithms and displays presented herein are not inherently related to any particular computer or other apparatus. Various general purpose systems can be used with programs in accordance with the teachings herein, or it can prove convenient to construct a more specialized apparatus to perform the method. The structure for a variety of these systems will appear as set forth in the description below. In addition, the present disclosure is not described with reference to any particular programming language. It will be appreciated that a variety of programming languages can be used to implement the teachings of the disclosure as described herein.

The present disclosure can be provided as a computer program product, or software, that can include a machine-readable medium having stored thereon instructions, which can be used to program a computer system (or other electronic devices) to perform a process according to the present disclosure. A machine-readable medium includes any mechanism for storing information in a form readable by a machine (e.g., a computer). In some embodiments, a machine-readable (e.g., non-transitory computer-readable) medium includes a machine (e.g., a computer) readable storage medium such as a read only memory (“ROM”), random access memory (“RAM”), magnetic disk storage media, optical storage media, flash memory devices, etc.

In the foregoing specification, embodiments of the disclosure have been described with reference to specific example embodiments thereof. It will be evident that various modifications can be made thereto without departing from the broader spirit and scope of embodiments of the disclosure as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.

Classification Codes (CPC)

Cooperative Patent Classification codes for this invention. Click any code to explore related patents in that topic.

Patent Metadata

Filing Date

June 16, 2025

Publication Date

January 1, 2026

Inventors

Huai-Yuan Tseng
Eric Nien-Heng Lee
Akira Goda
Yoshihiko Kamata
Koichi Kawai

Want to explore more patents?

Browse 5M+ US patents with plain-English claim translations and AI-generated analysis.

Citation & reuse

Analysis on this page is generated by Patentable — an AI-powered patent intelligence platform. AI-generated summaries, explanations, and analysis may be reused with attribution and a visible link back to the canonical URL below. Patent abstracts and claims are USPTO public domain.

Cite as: Patentable. “LEVEL-BASED PROGRAMMING WITH MULTIPLE ANALOG PROGRAM VERIFY OPERATIONS BETWEEN PROGRAMMING PULSES” (US-20260004861-A1). https://patentable.app/patents/US-20260004861-A1

© 2026 Patentable. All rights reserved.

Patentable is a research and drafting-assistant tool, not a law firm, and does not provide legal advice. Documents we generate are drafts for review by a licensed patent attorney.

LEVEL-BASED PROGRAMMING WITH MULTIPLE ANALOG PROGRAM VERIFY OPERATIONS BETWEEN PROGRAMMING PULSES — Huai-Yuan Tseng | Patentable