Pipelining in a Memory
A system including a memory cell array including a plurality of memory cells, and a writing device to generate multiple back-to-back write pulses to write to target memory cells from among the plurality of memory cells, the multiple back-to-back write pulses overlapping during an overlap duration, the overlap duration being adjustable based on a performance parameter of the memory cell array.
Latest Spansion LLC Patents:
The present disclosure generally relates to pipelining in a memory that allows pre-charging or partially operating on a next target location in the memory while operating on a current target location in the memory. Operating on a target location may include programming data to the target location or erasing data from the target location. As discussed below, the above pipelining improves, for example, the throughput associated with the memory.
BRIEF SUMMARYSystems, methods, and computer program products for pipelining in a memory are described herein.
In an embodiment of the present disclosure, a system includes a first memory cell, a second memory cell, and a programming device. The programming device is configured to generate respective first and second programming pulses to program the first and second memory cells. The first and second programming pulses overlap during an overlap duration, the overlap duration being adjustable based on a performance parameter of the first and second memory cells.
The present disclosure also contemplates a method including generating respective first and second programming pulses to program first and second memory cells, the first and second programming pulses overlapping during an overlap duration that may be adjusted based on a performance parameter of the first and second memory cells, and programming the first and second memory cells using the first and second programming pulses.
Further features and advantages of the disclosure, as well as the structure and operation of various embodiments of the invention, are described in detail below with reference to the accompanying drawings. It is noted that the disclosure is not limited to the specific embodiments described herein. Such embodiments are presented herein for illustrative purposes only. Additional embodiments will be apparent to persons skilled in the relevant art(s) based on the teachings contained herein.
The accompanying drawings, which are incorporated herein and form part of the specification, illustrate embodiments of the present invention and, together with the description, further serve to explain the principles of the invention and to enable a person skilled in the relevant art(s) to make and use embodiments of the invention.
This specification discloses one or more embodiments that incorporate the features of this invention. The disclosed embodiment(s) merely exemplify the invention. The scope of the invention is not limited to the disclosed embodiment(s). The invention is defined by the claims appended hereto.
The embodiment(s) described, and references in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” etc., indicate that the embodiment(s) described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is understood that it is within the knowledge of one skilled in the art to effect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
The exemplary embodiments described herein are provided for illustrative purposes, and are not limiting. Other exemplary embodiments are possible, and modifications may be made to the exemplary embodiments within the spirit and scope of the invention. Therefore, the Detailed Description is not meant to limit the invention. Rather, the scope of the invention is defined only in accordance with the following claims and their equivalents.
The following Detailed Description of the exemplary embodiments will so fully reveal the general nature of the invention that others can, by applying knowledge of those skilled in relevant art(s), readily modify and/or adapt for various applications such exemplary embodiments, without undue experimentation, without departing from the spirit and scope of the invention. Therefore, such adaptations and modifications are intended to be within the meaning and plurality of equivalents of the exemplary embodiments based upon the teaching and guidance presented herein. It is to be understood that the phraseology or terminology herein is for the purpose of description and not of limitation, such that the terminology or phraseology of the present specification is to be interpreted by those skilled in relevant art(s) in light of the teachings herein.
In one example, operations on the memory cells comprised in the memory sector 100 include programming data to the memory cells and/or erasing data from the memory cells. In a given sector, data may be programmed to or data may be erased from only the memory cells connected to a single wordline at a given time. The presently proposed pipelining is applicable to programming data to memory cells and also to erasing data from memory cells.
The presently proposed pipelining with respect to programming data to memory cells will now be discussed. Programming of memory cells may be conducted using a method known as a hot electron injection method. In one example using the hot electron injection method, memory cells may be programmed or written to sequentially. The memory cells may be partitioned into groups, and the groups may be programmed sequentially. For example, a controller (not shown) may identify the memory cells that are to be programmed and may partition the identified memory cells into groups. Once the groups are partitioned, the controller may determine the locations of all the memory cells within the groups. For example, a first group G1 may include memory cells W1-1, W1-7 (not shown), and W1-13 (not shown); a second group G2 may include memory cells W1-3, W1-9 (not shown), and W1-15 (not shown); and a third group (G3 may include memory cells W1-5, W1-11 (not shown), and W1-17 (not shown). To program the identified memory cells of a given group, a voltage associated with the wordline connected to the identified target memory cells may initially be ramped up to a first voltage. Then, voltages associated with the bitlines connected to the drains of the target memory cells are ramped up to a second voltage level, while the bitlines connected to the sources of the target memory cells are maintained at a very low voltage (e.g., near ground) level.
The above voltage levels at the wordline and the bitlines enable the operation of the associated non-volatile memory cells. Now, when the memory cells included in the first group G1, the second group G2, and the third group G3 are to be programmed, the controller determines the locations of the memory cells included in the first group G1, the second group G2, and the third group G3.
In this example, as seen from
As is shown in the conventional example of
Embodiments of the present disclosure describe pipelining during programming of memory cells to, e.g., improve the programming/writing performance and increase throughput associated with the memory. In one embodiment, the pipelining includes partially overlapping the programming pulses, while considering the inherent metal parasitics of the non-volatile memory cells, limitations of the supply voltages used to charge the bitline, the current consumption limitation associated with the device including the memory, and on requirements of the core cell technology. The exemplary pipelining to program cells are connected to the same Wordline will now be described with respect to
The power supplies 421, 422, and 423 provide respective voltages V1, V2, V3 to the ramp control circuit 410 and/or to each of the bitline drivers 431-435. The relationship between the voltages V1, V2, and V3 may be described as V1<V2<V3, where V3 may substantially be equal to the steady-state voltage associated with the bitlines of the memory cells to be programmed. The controller 401 provides control signals to the ramp control circuit 410, which in turn provides ramp and discharge signals (e.g., lowramp, midramp, highramp, bitline_discharge) to each of the bitline drivers 431-435 based on the control signals. The bitline drivers 431-435 charge and discharge the respective bitlines associated with the memory cells to be programmed based on the received voltages V1, V2, and V3 and the ramp and discharge signals. As described below in further detail, the ramp-up stage for each bitline includes three sections (e.g., a low-voltage section, a mid-voltage section, and a high-voltage section) of charging, each section being driven by a respective power supply. For example, the power supply1 421 drives/charges the bitline through the low-voltage section to voltage V1 (e.g., 1.5 V), the power supply2 422 drives/charges the bitline through the mid-voltage section to voltage V2 (e.g., 3V), and the power supply3 423 drives/charges the bitline through the high-voltage section to voltage V3 (e.g., 4.5 V).
In an exemplary operation, and with reference to
Unlike the programming illustrated in
In one example, programming pulse P1 is asserted at time t1 to enable programming of memory cells W1-1, W1-7, and W1-13 and is de-asserted at time t1′ when these memory cells have been programmed. Programming pulse P2 is asserted at time t2 to enable programming of memory cells W1-3, W1-9, and W1-15 and is de-asserted at time t2′ when these memory cells have been programmed. As seen in
For example, as described above with respect to
At this point, the steady-state commences and the bitline driver 431 maintains the highramp1 signal to allow the memory cells W1-1, W1-7, and W1-13 to be programmed. Now, at time t2, pulse P2 that enables programming of memory cells W1-3, W1-9, and W1-15 is asserted. Also, at time t2, the bitline driver 432 asserts the lowramp3 signal to enable the power supply1 421 to charge/drive bitlines B3, B9, and B15 through their respective low-voltage sections. Once the voltages associated with bitlines B3, B9, and B15 reach V1, for example, the bitline driver 431 de-asserts the lowramp3 signal and asserts the midramp3 signal to enable the power supply2 422 to charge/drive bitlines B3, B9, and B15 through their respective mid-voltage sections. Once the voltages associated with bitlines B3, B9, and B15 reach V2, for example, the bitline driver 431 de-asserts the midramp3 signal and asserts the highramp3 signal to enable the power supply3 423 to charge/drive bitlines B3, B9, and B15 through their respective high-voltage sections. Once the voltage associated with bitlines B3, B9, and B15 reach the steady-state level VW1-3, for example, the ramp-up stage is concluded.
Additionally, at time t1′, the bitline driver 431 de-asserts the highramp1 signal and asserts the bitline_discharge1 signal to discharge the voltage associated with bitlines B1, B7, and B13. At time t1′, the memory cells W1-1, W1-7, and W1-13 included in group G1 have been programmed. At time t2′, the bitline driver 431 de-asserts the highramp3 signal and asserts the bitline_discharge3 signal to discharge the voltage associated with bitlines B3, B9, and B15. At time t2′, the memory cells W1-3, W1-9, and W1-15 included in group G2 have been programmed.
The programming of additional memory cells, e.g., the memory cells included in group G3 may be carried out in a similar manner as described above with respect to the programming of memory cells included in group G1 and G2. In one example, it is within the scope of the present disclosure to program groups of memory cells using respective programming pulses and/or programming individual memory cells using respective programming pulses (as discussed above) as long as the programming pulses are staggered, as proposed.
The overlap duration between times t2 and t1′ is the first predetermined overlap duration during which the programming pulse P1, which programs memory cells W1-1, W1-7, and W1-13, and the programming pulse P2, which programs memory cells W1-3, W1-9, and W1-15, are staggered. It is to be noted that the illustration of any predetermined overlap duration is exemplary, and that the duration of any predetermined overlap duration may be shorter or longer as long as the steady-state stages of any two staggered pulses do not overlap. For example, the maximum overlap duration between times t2 and t1′ is equal to the duration of the ramp-up stage of memory cells W1-3, W1-9, and W1-15.
Additionally or optionally, additional subsequent programming pulses may be asserted to program the identified memory cells. In this embodiment, the controller 401 may verify whether all the memory cells that are to be programmed have in fact been programmed. For example, the controller 401 may verify whether the respective threshold voltages associated with the transistors of the respective memory cells to be programmed have reached their respective predetermined threshold voltages. When the controller 401 determines that all the respective threshold voltages associated with the transistors of the respective memory cells to be programmed have reached their perspective predetermined threshold voltages, the controller 401 may not need to assert the additional subsequent programming pulses to program the memory cells.
However, when the controller 401 determines that a threshold voltage associated with a transistor of a given memory cell to he programmed has not reached its predetermined threshold voltage, the controller 401 may subsequently re-assert the complete sequence of programming pulses P1, P2, and P3 as discussed above with respect to
In one example, it is within the scope of the present disclosure to program groups of memory cells using respective programming pulses and/or programming individual memory cells using respective programming pulses (as discussed above) as long as the programming pulses are staggered, as proposed.
In another example, the proposed pipelining during programming of memory cells improves the programming/writing performance and increases throughput associated with the memory. For example, the partial (or substantially complete) overlapping of the programming pulses, while being mindful of the inherent metal parasitics of the non-volatile memory cells, limitations of the supply voltages used to charge the bitline, the current consumption limitation associated with the device including the memory, and the requirements of the core cell technology allows faster and more efficient programming of the memory cells. For example, some memory architectures allow for only a given delta in voltage at a given time between voltages applied across the memory cells to avoid structural damage to the memory.
In a further example, predetermined overlap durations may be dynamically adjusted or customized based on the behavior of the non-volatile memory cells during, for example, the ramp-up and steady-state stages. Additionally or alternatively, the predetermined overlap durations may be dynamically adjusted based on environmental operating conditions of the system such as ambient temperature. Additionally or alternatively, the predetermined overlap durations may be dynamically adjusted based on a threshold voltage distribution of respective transistors associated with the memory cells and/or a predetermined current consumption by a memory comprising the memory cells to be programmed.
It is to be appreciated that the Detailed Description section, and not the Summary and Abstract sections, is intended to be used to interpret the claims. The Summary and Abstract sections may set forth. one or more but not all exemplary embodiments of the present invention as contemplated by the inventor(s), and thus, are not intended to limit the present invention and the appended claims in any way.
The present invention has been described above with the aid of functional building blocks illustrating the implementation of specified functions and relationships thereof. The boundaries of these functional building blocks have been arbitrarily defined herein for the convenience of the description. Alternate boundaries can be defined so long as the specified functions and relationships thereof are appropriately performed.
The foregoing description of the specific embodiments will so fully reveal the general nature of the invention that others can, by applying knowledge within the skill of the art, readily modify and/or adapt for various applications such specific embodiments, without undue experimentation, without departing from the general concept of the present invention. Therefore, such adaptations and modifications are intended to be within the meaning and range of equivalents of the disclosed embodiments, based on the teaching and guidance presented herein. It is to be understood that the phraseology or terminology herein is for the purpose of description and not of limitation, such that the terminology or phraseology of the present specification is to be interpreted by the skilled artisan in light of the teachings and guidance.
The breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
The claims in the instant application are different than those of the parent application or other related applications. The Applicant therefore rescinds any disclaimer of claim scope made in the parent application or any predecessor application in relation to the instant application. The Examiner is therefore advised that any such previous disclaimer and the cited references that it was made to avoid, may need to be revisited. Further, the Examiner is also reminded that any disclaimer made in the instant application should not be read into or against the parent application.
Claims
1. A system comprising:
- a memory cell array including a plurality of memory cells; and
- a writing device configured to generate multiple back-to-back write pulses configured to write to target memory cells from among the plurality of memory cells, the multiple back-to-back write pulses overlapping during an overlap duration, the overlap duration being configured to be adjusted based on a performance parameter of the memory cell array.
2. The system of claim 1, wherein the performance parameter comprises a current required to pre-charge and to program a target memory cell.
3. The system of claim 1, wherein the performance parameter comprises a current required to pre-charge and to erase a target memory cell.
4. The system of claim 1, wherein the performance parameter comprises a predetermined current consumption by a memory comprised of the memory cell array.
5. The system of claim 1, wherein, during the overlap duration, a ramp-up period of a bitline associated with writing to a subsequent target memory cell substantially overlaps a steady-state period of a bitline associated with writing to a current target memory cell.
6. The system of claim 5, wherein the ramp-up period of the bitline associated with writing to the subsequent target memory cell includes a plurality of ramp-up stages, the plurality of ramp-up stages being driven by respective ramp-up voltages.
7. The system of claim 5, comprising:
- a ramp control circuit configured to: receive a plurality of ramp-up voltages; and drive, during the ramp-up period, a plurality of ramp-up stages of the bitline associated with writing to the subsequent target memory cell by applying a respective one of a plurality of ramp-up voltages.
8. The system of claim 7, wherein the ramp control circuit is configured to sequentially apply the plurality of ramp-up voltages to drive the plurality of ramp-up stages.
9. The system of claim 7, wherein the ramp control circuit is configured to receive the plurality of ramp-up voltages from respective independent voltage supplies, each independent voltage supply having a respective regulator.
10. The system of claim 7, wherein the ramp control circuit is configured to receive the plurality of ramp-up voltages from a single voltage supply generating the plurality of ramp-up voltages, each ramp-up voltage being regulated independently.
11. A method in a system for writing to memory cells, the method comprising:
- generating back-to-back first and subsequent write pulses to enable writing to target memory cells, the first and subsequent programming pulses overlapping during an overlap duration that is adjustable based on a performance parameter of the system; and
- writing to the target memory cells using the first and subsequent write pulses.
12. The method of claim 11, wherein the performance parameter comprises a current required to precharge and program a target memory cell.
13. The method of claim 11, wherein the performance parameter comprises a current required to precharge and to erase a target memory cell.
14. The method of claim 11, wherein the performance parameter comprises a desired current consumption associated with writing to the target memory cells.
15. The method of claim 11, wherein the writing includes substantially overlapping, during the overlap duration, a ramp-up period of a bitline associated with writing to a subsequent target memory cell with a steady-state period of a bitline associated with writing to a current target memory cell.
16. The method of claim 15, wherein the ramp-up period of the bitline associated with writing to the subsequent target memory cell includes a plurality of ramp-up stages, the plurality of ramp-up stages being driven by respective ramp-up voltages.
17. The method of claim 15, comprising:
- receiving a plurality of ramp-up voltages; and
- driving, during the ramp-up period, a plurality of ramp-up stages of the bitline associated with writing to the subsequent target memory cell by applying a respective one of the plurality of ramp-up voltages.
18. The method of claim 17, wherein the applying comprises sequentially applying the respective one of the plurality of ramp-up voltages to drive the plurality of ramp-up stages.
19. The method of claim 17, wherein the receiving a plurality of ramp-up voltages includes receiving the plurality of ramp-up voltages from corresponding respective voltage supplies.
20. The method of claim 17, wherein the receiving a plurality of ramp-up voltages includes receiving the plurality of ramp-up voltages from a single voltage supply, the single voltage supply being concurrently and individually regulated based on required output voltages.
Type: Application
Filed: Mar 8, 2013
Publication Date: Sep 11, 2014
Patent Grant number: 9142270
Applicant: Spansion LLC (Sunnycale, CA)
Inventors: Michael ACHTER (Mountain View, CA), Evrim BINBOGA (Pleasanton, CA), Marufa KANIZ (Santa Clara, CA), Murni MOHD-SALLEH (Santa Clara, CA)
Application Number: 13/790,979
International Classification: G11C 7/12 (20060101);