[go: up one dir, main page]

WO2006009069A1 - 半導体記憶装置、書き換え処理方法およびプログラム - Google Patents

半導体記憶装置、書き換え処理方法およびプログラム Download PDF

Info

Publication number
WO2006009069A1
WO2006009069A1 PCT/JP2005/013041 JP2005013041W WO2006009069A1 WO 2006009069 A1 WO2006009069 A1 WO 2006009069A1 JP 2005013041 W JP2005013041 W JP 2005013041W WO 2006009069 A1 WO2006009069 A1 WO 2006009069A1
Authority
WO
WIPO (PCT)
Prior art keywords
memory
value
data storage
rewrite
storage unit
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Ceased
Application number
PCT/JP2005/013041
Other languages
English (en)
French (fr)
Inventor
Kozo Nishimura
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Panasonic Holdings Corp
Original Assignee
Matsushita Electric Industrial Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Matsushita Electric Industrial Co Ltd filed Critical Matsushita Electric Industrial Co Ltd
Priority to JP2006529143A priority Critical patent/JP4679521B2/ja
Priority to US11/631,482 priority patent/US7633816B2/en
Publication of WO2006009069A1 publication Critical patent/WO2006009069A1/ja
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/34Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
    • G11C16/3404Convergence or correction of memory cell threshold voltages; Repair or recovery of overerased or overprogrammed cells
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C29/00Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
    • G11C29/04Detection or location of defective memory elements, e.g. cell constructio details, timing of test signals
    • G11C2029/0409Online test

Definitions

  • the present invention relates to a semiconductor memory device, and in particular, a semiconductor memory device having a memory cell having two or more memory states and having a rewrite speed or a degree of deterioration due to rewrite depending on which memory state is rewritten, Method Methods and programs.
  • Non-volatile memory represented by flash memory is a low-power-consumption memory that can retain its memory even after the power is turned off. It can be used for memory cards such as digital cameras and BI OS memory on personal computers. It's being used.
  • the stored value of the memory cell of the flash memory is, for example, 0 when a predetermined amount or more of electrons are accumulated in the floating gate, and less than a predetermined amount of electrons are accumulated in the floating gate. 1 is determined by the amount of electrons accumulated in the floating gate.
  • the flash memory cannot rewrite the stored value if the source electrode or the drain electrode is kept grounded, and rewrites the stored value unless all the voltages (source, drain and gate voltages) are controlled. I can't. However, controlling three voltages for each memory cell complicates the circuit and increases the size of the device.
  • the gate voltage is controlled in units of sectors composed of memory cells.
  • Patent Document 1 a spare sector is provided separately from the original sector, and data is stored in a memory cell of a sector with a small number of erasures.
  • a semiconductor memory device that eliminates variations in the number of erasures for each. When the variation in the number of erases for each sector is eliminated, the generation of defective sectors is suppressed, so that the memory body can be used for a longer period.
  • Patent Document 1 Japanese Patent Laid-Open No. 2002-366420 (Page 1-21, Fig. 1)
  • an object of the present invention is to provide a semiconductor memory device that can use a memory body for a longer period of time in a semiconductor memory device whose performance deteriorates due to rewriting of memory.
  • another object of the present invention is to provide a semiconductor memory device that can further shorten the rewrite time.
  • a semiconductor memory device is a semiconductor memory device having a memory cell that has two or more storage states and has a different rewrite speed or a degree of deterioration due to rewrite depending on which storage state is rewritten.
  • a memory main body comprising a plurality of data storage units configured to store a value of 1 bit as a whole, a process of reading the stored value of the memory cell, and a process of rewriting the stored value of the memory cell Read / rewrite control unit, calculation unit that calculates the storage value of the data storage unit by calculation using the stored value of the memory cell included in the data storage unit, and the storage value of the data storage unit that is calculated by the calculation unit and input from the outside
  • the comparison unit that compares the values and outputs a signal indicating a match or mismatch, and the stored value in the data storage unit when the comparison unit outputs a signal indicating a mismatch
  • a rewrite cell determining unit that determines a memory cell whose stored value is to be changed in order to change to the same value as the input value.
  • the calculation unit may include an exclusive logic circuit. In that case, each data storage unit should have a data capacity of 3 or more odd bits.
  • the number of memory cells included in the data storage unit may differ depending on the data storage unit.
  • the read / write control unit includes an individual rewrite process for rewriting the memory cell storage value for each memory cell, and a batch rewrite process for rewriting the memory cell memory value in units of one or more data storage units. By doing either, you can change the stored value of the data storage unit.
  • the memory body may be a flash memory.
  • the individual rewriting process is a writing process
  • the batch rewriting process is an erasing process.
  • the memory cell further includes a specific rewrite cell determination unit that determines a memory cell belonging to the data storage unit that does not need to change a stored value and has a data capacity for an even number of bits that can be rewritten.
  • the rewrite control unit may be characterized by individually rewriting the memory cell memory determined by the specific rewrite cell determination unit when performing batch rewrite processing.
  • One memory cell may be a multi-value memory cell having a data capacity for a plurality of bits.
  • a rewrite processing method for a semiconductor memory device includes a semiconductor memory device having memory cells that have two or more memory states, and the rewrite speed or the degree of deterioration due to rewrite differs depending on whether or not rewrite is performed to the shifted memory state.
  • the write processing method is determined by determining the one that stores the value input by the external force from the plurality of data storage units that are configured by a plurality of memory cells and store a value of 1 bit as a whole.
  • the stored value of the data storage unit is obtained by calculation using the stored value of the memory cell constituting the data storage unit, and the stored value of the data storage unit obtained by the calculation is compared with the value input from the outside. If there is a mismatch, the memory value to be changed is determined in order to change the stored value of the data storage unit to the same value as the externally input value. And rewrites the stored value of the memory cells that are determined to change the stored value.
  • a program according to the present invention is a semiconductor memory device having memory cells having two or more storage states and having different rewrite speeds or different degrees of deterioration due to rewrite depending on whether or not the rewritten storage states are rewritten.
  • a program for performing rewrite processing consisting of a plurality of data storage units composed of a plurality of memory cells and storing a value of 1 bit as a whole.
  • the value stored from the outside is determined, and the stored value of the data storage unit is determined by calculation using the stored value of the memory cell constituting the determined data storage unit.
  • the stored value in the data storage unit is compared with the value input from the outside to determine whether there is a match, and when the determination result does not match, the stored value in the data storage unit is the same value as the value input by the external force
  • the memory cell whose memory value should be changed is determined and the stored value is changed.
  • the semiconductor device stores and stores one bit of data as a plurality of bits of data, the number of rewrites of each memory cell is reduced, and the memory body can be stored for a longer period of time. Can be used over.
  • the memory cell memory determined by the specific rewrite cell determination unit may be rewritten at the same time when the batch rewrite process is performed.
  • rewrite processing performed at different timings can be reduced. Therefore, since the time until the next batch rewriting can be gained, the rewriting time can be shortened. If the stored value of even-numbered bits of data is rewritten at this time, the stored value of the data storage unit will not change.
  • FIG. 1 is a block diagram of a semiconductor memory device according to a first embodiment of the present invention.
  • FIG. 2 is a block diagram showing a detailed configuration of a control calculation unit.
  • FIG. 3 is a flowchart showing processing in a control calculation unit.
  • FIG. 4 is a continuation of FIG.
  • FIG. 5 is a continuation of FIG.
  • FIG. 6 is a diagram showing changes in memory values of memory cell MC [k] and data storage unit B [m] due to rewriting.
  • FIG. 7 is a diagram showing changes in stored values due to rewriting in a conventional semiconductor memory device.
  • FIG. 8 is a block diagram of a semiconductor memory device according to a second embodiment of the present invention.
  • FIG. 9 is a diagram showing, in a time series, changes in stored values in the data storage units B [l], B [9] and B ′ [9].
  • FIG. 10 is a block diagram of a semiconductor memory device according to a third embodiment of the present invention.
  • FIG. 11 is a diagram for explaining a rewrite process.
  • FIG. 12 is a block diagram of a semiconductor device that executes a program according to a fourth embodiment of the present invention.
  • FIG. 13 is a continuation of FIG. 3, and is a flowchart showing processing performed by execution of the program. Explanation of symbols
  • FIG. 1 is a block diagram of a semiconductor memory device 1 according to the first embodiment of the present invention.
  • the semiconductor memory device 1 includes a control calculation unit 10 and a memory body 20.
  • the memory body 20 includes a plurality of nonvolatile memory cells MC [k] (k is a natural number) for 1-bit storage that can continue to hold memory even after the power is turned off.
  • the memory cell MC [k] will be described as a flash memory cell including a source electrode, a drain electrode, a floating gate, and a gate electrode on a semiconductor substrate.
  • the stored value when the amount of accumulated electrons in the floating gate is greater than or equal to a predetermined amount is set to 0, and the stored value when the amount of accumulated electrons in the floating gate is less than the predetermined amount is set to 1.
  • the memory cells MC [k] are arranged in a matrix in the memory cell arrangement area of the memory body 20.
  • Each data storage unit B [m] (m is a natural number) includes three memory cells MC [k]!
  • one sector S [n] (n is a natural number) is composed of three data storage units B [m].
  • Memory cells MC [k] existing in the same sector S [n] are connected to the same word line (voltage supply line).
  • FIG. 2 is a block diagram mainly showing the configuration of the control arithmetic unit 10 in the semiconductor memory device 1 shown in FIG. 3 to 5 are flowcharts showing processing in the control calculation unit 10 when data to be stored is input.
  • FIGS. 2 the configuration and operation of the semiconductor storage device 1 will be described with reference to FIGS.
  • the control operation unit 10 includes a read control unit 11, a comparison unit 12, a rewrite cell determination unit 13, a rewrite control unit 14, and a logic operation unit 16.
  • the stored value of the memory cell MC [k] is 1, and the stored value of the data storage unit B [m] obtained from the stored value of the memory cell MC [k] is also 1! /,
  • the read control unit 11 stores the data for each input 1-bit data B [ m] is determined (step S11 in FIG. 3).
  • the read control unit 11 sends the address signal AD (k) indicating the positions of the three memory cells MC [k] included in the determined data storage unit B [m] and the read command signal R to the memory body 20 Output to.
  • the stored values of the three memory cells MC [k] are read out by the rewrite cell determination unit 13 and the logic operation unit 16.
  • the logical operation unit 16 calculates 1 when the number of input 1s is an odd number, and calculates 0 when the number of input 1s is an even number. XOR) arithmetic circuit.
  • the logical operation unit 16 obtains an exclusive OR of the stored values of the three input memory cells MC [k] as the stored value of the data storage unit B [m] (step S12).
  • the comparison unit 12 compares the two input values, and if they match (YES in step S13), it indicates that it is not necessary to rewrite the stored value in the data storage unit B [m].
  • a coincidence signal Ca is output (step S14), and in the case of a disagreement (NO in step S13), a disagreement signal Cb is output indicating that the stored value of the data storage unit B [m] is required (Step S15).
  • the rewrite cell determination unit 13 receives the match signal Ca or the mismatch signal Cb and the stored value of the memory cell MC [k] constituting the data storage unit B [m]. The rewrite cell determination unit 13 determines not to rewrite when the coincidence signal Ca is input.
  • the rewrite cell determination unit 13 determines whether the storage value of the memory cell MC [kmin] whose k is the minimum value kmin is 1 (see FIG. 4 steps S 20 and S 21). If the stored value of the memory cell MC [kmin] is 1 (YES in step S21), the rewrite cell determining unit 13 determines to write to the memory cell MC [kmin] (step S26). Then, as shown in FIG. 2, the rewrite cell determination unit 13 outputs a write instruction signal W ′ for instructing writing to the rewrite control unit 14, and also sets the address of the memory cell MC [k] to be written.
  • the address signal AD (k) shown is output to the memory body 20.
  • step S22 If the memory value MC of the memory cell MC [kmin] is ⁇ (NO in step S21), the rewrite cell determination unit 13 adds 1 to k (step S22), It is determined whether the value (specifically kmin + 1) is equal to or less than kmax (step S23).
  • kmax is the maximum value of k in the memory cell MC [k] constituting the data storage unit B [m] for rewriting data.
  • step S23 If it is the following (YES in step S23), the rewrite cell determination unit 13 determines whether the stored value of the memory cell MC [k] is 1, and if 1 (YES in step S2 1) ), It is determined to write to the memory cell MC [k] (step S26). Then, the rewrite cell determination unit 13 outputs a write instruction signal W ′ for instructing writing to the rewrite control unit 14, and also an address signal AD (indicating the address of the memory cell MC [k] to be written. k) is output to the memory 20.
  • the erasure is performed.
  • the stored value of the memory cell MC [k] of the other data storage unit B [m] belonging to the sector S [n] to be read is read and each data storage unit B [ Calculate the stored value of [m]. If there is a data storage unit B [m] whose stored value is 0, the memory cell MC [k] having the smallest k value among the memory cells MC [k] constituting the data storage unit B [m]. ] Is determined to be written after the erase operation (step S25).
  • the rewrite cell determination unit 13 erases the erase instruction signal E instructing to perform the erase operation.
  • the rewrite cell determination unit 13 outputs a write instruction signal W ′ instructing writing after the erasing operation to the rewrite control unit 14 and also indicates a memory cell MC [k] address to be written.
  • the address signal AD (k) is output to the memory body 20.
  • the write enable signal We which is a strobe signal indicating the write timing
  • the erase enable signal Ee which is a strobe signal indicating the erase timing
  • the rewrite control unit 14 also receives a forced write signal Eo and a forced erase signal Wo.
  • the rewrite control unit 14 receives a write enable signal We having a value of 1! If this is the case (YES in step S31 in FIG. 5), the write command signal W is output to the memory body 20 (step S32).
  • the rewrite control unit 14 receives a write enable signal We having a value of 0 !, and is unable to write to the memory cell. If there is (NO in step S31), it waits for a state where writing is possible (YES in step S31), and outputs a write command signal W to the memory body 20 (step S32).
  • the memory body 20 When the write command signal W is input, the memory body 20 writes 0 to the memory cell MC [k] specified by the address signal AD (k) (step S33). As a result, the stored value in the data storage unit B [m] is rewritten.
  • the rewrite control unit 14 receives the erase enable signal Ee having a value of 1! Of YES ), And output the erase command signal E to the memory body 20.
  • the rewrite control unit 14 receives an erase enable signal having a value of 0 and is not in an erasable state (N in step S34). 0) Wait for the state to be erasable (YES in step S34), and output the erase command signal E to the memory 20 (step S35).
  • the erase command signal E is input, the memory body 20 performs an erase operation on the sector S [n] including the memory cell MC [k] designated by the address signal AD (k) (step S36).
  • the rewrite control unit 14 waits for a state where writing is possible thereafter. (Step S37), write command signal W is output (Step S38). As a result, the rewrite cell determination unit 13 determines that writing is performed after erasure, and writing is performed on the memory cell MC [k] (step S39). Thus, the stored value of the desired data storage unit B [m] is rewritten.
  • FIG. 6 part (a) shows changes in the stored values of the data storage units B [1] to B [3] constituting the sector S [l].
  • the part (b) indicates the stored value of the memory cells MC [1] to MC [3] and the stored value of the data storage unit B [l], which are changed so as to obtain the stored value of (a). It shows.
  • portions (c) and (d) are similar to the portion (b) in that the memory cells MC [4] to MC [ 6] and the stored values of MC [7] to MC [9] and the stored values of the data storage units B [2] and B [3] are shown.
  • FIG. 7 shows a conventional case in which 1-bit binary data is stored in one memory cell MC ′ [k] for 1-bit storage when storing the same value as in FIG. 6 (a). It shows the changes in the memory values of memory cells MC, [1] to MC, [3] in the semiconductor memory device.
  • the memory cells MC, [1] to MC, [3] are memory cells in the same sector.
  • the part (a) corresponds to the part of FIG. 6 (a)
  • the part (b) corresponds to the parts of FIGS. 6 (b), (c) and (d).
  • FIG. 0 is written to the memory cell MC [1] shown in b) and the memory cell MC [7] shown in FIG. 6 (d).
  • the memory values of the memory cells MC [1] to [3] and MC [7] to MC [9] are all (011), and the data storage units B [l] and B [3] The stored value of becomes 0.
  • the stored value in data storage B [2] is the same as the stored data value 1, so the stored values in memory cells MC [1] to MC [3] cannot be rewritten! /.
  • FIG. 7 (b) In order to change the stored value from (001) to (100) as shown in (4) and (5) of FIG. 7 (a), as shown in FIG. 7 (b), The memory cells MC ′ [1] to MC ′ [3] are erased. Then, a verification process is performed to confirm that the memory values of memory cells MC, [1] to MC, [3] are all 1, and the memory is not required to have a memory value of 1. 0 is written to cells MC '[2] and MC' [3].
  • the erase operation was performed only once, but in the conventional semiconductor memory device, the erase operation was performed four times. Since the lifetime of the flash memory is determined by the number of times of erasure, the binary data for 1 bit to be stored is represented by the binary data for a plurality of bits and stored as in the semiconductor memory device 1 according to this embodiment. For example, the number of rewrites of each memory cell MC [k] is reduced, and the memory body 20 can be used for a longer period of time.
  • rewriting is performed only when the stored value of the data storage unit B [m] and the input data value do not match, so unnecessary rewriting is performed. Can be suppressed. As a result, the number of erasures can be reduced, and the memory body 20 can be used for a longer period. In addition, the rewriting time can be shortened.
  • the rewrite cell determination unit 13 rewrites the stored value of the data storage unit B [m] rather than “erase” which shortens the lifetime of the memory cell MC [k] or requires a rewrite time. , Select “Write” preferentially. Also, for example, when the number of memory cells MC [k] to be written is 1 and when the stored value of the data storage unit B [m] obtained is 3 is the same When there are a plurality of rewrite methods, the rewrite cell determination unit 13 selects a rewrite method with the smallest number of memory cells MC [k] to be written. As described above, in the semiconductor memory device 1, the processing that causes the deterioration of the memory main body 20 is performed as much as possible.
  • the memory main body 20 can be used for a longer period of time. Further, the rewrite time can be shortened by reducing the number of times of erasure.
  • the number of data storage units B [m] constituting one sector S [n] and the number of memory cells MC [k] constituting one data storage unit B [m] are as described above. It is not limited to the number used in the explanation. In the semiconductor memory device 1, the number of times of erasure decreases as the number of data storage parts B [m] constituting one sector S [n] decreases, and the memory cell MC constituting the data storage part B [n] The number of [k] increases and decreases.
  • the power described in the present embodiment as an example of the flash memory can be used for a longer period of time by reducing the number of times of writing of at least one of 0 to 1 or 1 to 0, in particular.
  • This is effective for a semiconductor memory device in which the effect of shortening the writing time or the effect of shortening the writing time can be obtained.
  • the lifetime of a ferroelectric memory is determined by the number of rewrites, that is, the number of polarization inversions, so that the effect of extending the life can be obtained by applying the present invention.
  • binary data of 2 bits or more is stored in one memory cell.
  • Value flash memory cells may be used.
  • a multi-level memory cell that stores binary data of 2 bits in one memory cell, it corresponds to the memory capacity MC [1] of the first bit in the first memory and the memory capacity S of the second bit.
  • memory cell MC [2] corresponds to the memory memory cell MC [3] of the first bit in the second memory cell. It corresponds to the second memory memory cell MC [4].
  • multilevel memory cells are used, the number of memory cells constituting the data storage unit can be reduced as compared with the case of using memory cells for 1-bit storage. Therefore, the use of multilevel memory cells may make it possible to reduce the size of a semiconductor memory device compared to the case of using memory cells for 1-bit storage. If the memory cell has the above effect, a multi-level memory other than a flash memory may be adopted. For example, a magnetic memory (MRAM), a ferroelectric memory (FeRAM), etc. You can adopt! / ⁇ .
  • MRAM magnetic memory
  • FeRAM ferroelectric memory
  • the semiconductor memory device according to the present invention is useful as a semiconductor memory device incorporated in a system LSI. It can also be applied to applications such as FPGA (Field Programmable Gate Array) configurable system LSI.
  • FPGA Field Programmable Gate Array
  • the semiconductor memory device 1 may be composed of two or more separate components such as a card that is a memory body and a device that reads and rewrites the memory of the card.
  • FIG. 8 is a block diagram of the semiconductor memory device 2 according to the second embodiment of the present invention.
  • the semiconductor memory device 2 includes a control calculation unit 10 and a memory main body 20a.
  • the memory body 20a includes a plurality of non-volatile memory cells MC [k] (k is a natural number) for 1-bit storage, which can continue to store memory even after the power is turned off.
  • the memory main body 20a similarly to the first embodiment, the memory main body 20a will be described as a flash memory. Then, the storage value of the memory cell MC [k] when the amount of accumulated electrons in the floating gate is equal to or larger than a predetermined amount is set to 0, and the memory cell MC [k] when the amount of accumulated electrons in the floating gate is less than the predetermined amount.
  • the stored value of is 1.
  • the memory cells MC [k] are arranged in a matrix in the memory cell arrangement region of the memory body 20a. Note that the structure and operation of the control arithmetic unit 10 of the semiconductor memory device 2 according to the present embodiment are the same as those described in the first embodiment, and a description thereof will be omitted.
  • One data storage unit B [m] (m is a natural number) includes three or five memory cells MC [k].
  • the data storage unit B [l] has three memory cells MC [1] to MC [3], and the data storage unit B [9] has five memory cells MC [25] to MC [ [29]
  • one sector S [n] (n is a natural number) is composed of one data storage unit B [m].
  • Memory cells MC [k] existing in the same sector S [n] are connected to the same word line (voltage supply line).
  • Times t41 to t44 shown in FIG. 9 (a) indicate times when the stored value of the data storage unit B [l] is rewritten in the order of 1, 0, 1, 0. Also, times tl 1 to tl7 shown in FIG. 9 (a) indicate times at which the stored values in the data storage unit B [9] are rewritten in the order of 1, 0, 1, 0, 1, 0, 1. .
  • the semiconductor memory device 2 has a large number of memory cells MC [k] for the kind of data that is frequently rewritten so that the memory can be used for a longer period of time.
  • Data storage B [m] is allocated.
  • the data storage unit B [9] has its stored value rewritten more frequently than the data storage unit B [l], so the data storage unit B [9] Is allocated more memory cells MC [k] than data storage B [l].
  • FIG. 9 (b) shows a data storage unit B [9] having five memory cells MC [k] and data having three memory cells MC [k] when the same rewriting is performed. It shows the difference in the rewrite timing of the stored value between storage B and [9].
  • tl l to tl7 shown in FIG. 9 (b) indicate the rewrite time in the data storage unit B [9]
  • tl l 'to tl7' are the data storage unit B '[9]
  • the rewrite time in is shown.
  • the data storage section B [9] with a large number of memory cells MC [k] Erasing is performed at a later rewrite stage than the data storage B '[9] with a small number of cells MC [k].
  • a single memory cell may be a memory cell of a multi-value memory that can store multiple bits.
  • FIG. 10 is a block diagram of the semiconductor memory device 3 according to the third embodiment of the present invention.
  • the semiconductor memory device 3 includes a control calculation unit 10b and a memory main body 20b.
  • the memory body 20b includes a plurality of non-volatile memory cells MC [k] (k is a natural number) for 1-bit storage that can continue to hold memory even after the power is turned off.
  • the memory main body 20b will be described as a flash memory.
  • the memory cells MC [k] are arranged in a matrix in the memory cell arrangement region of the memory body 20b.
  • Each data storage unit B [m] (m is a natural number) includes five memory cells MC [k].
  • the gate voltage control for each sector is not performed, and the erasure is performed for each memory cell MC [k].
  • the control operation unit 10b includes a read control unit 11, a comparison unit 12, a rewrite cell determination unit 13, a rewrite control unit 14, and an erase cell determination unit 15.
  • the processing performed in the control calculation unit 10b will be described mainly with respect to the processing in the erased cell determination unit 15 which is a component specific to the present embodiment, and the processing in the other components is described. Since it is the same as the process described in the first embodiment, it is omitted.
  • the data storage unit B [m] is erased by erasing the memory cell MC [k] one by one. It is also possible to change the stored value. However, since other processing cannot be performed while the erase operation is being performed, in the semiconductor memory device 3, when the stored value of the data storage unit B [m] is changed by erasing, the data storage unit The erase operation is simultaneously performed on all the memory cells MC [k] in B [m].
  • the stored value of the data storage unit B [7] is rewritten in the order of 1, 0 as shown in FIG. 11 (c).
  • the stored values of the memory cells MC [31] to MC [35] after the last rewrite in the period P are (00011).
  • the stored value of the data storage unit B [13] is 1, and the stored values of the memory cells MC [61] to MC [65] are (00111).
  • the data storage unit B [2] At the time Te, that is, at the timing when the erasing operation is performed on the data storage unit [1], the data storage unit B [2] The stored value is 0 4 An erase operation is performed on the memory cells MC [6] to MC [9]. As a result, the stored values of the memory cells MC [6] to MC [10] become (11111). Note that the stored value in data storage B [2] after the erasure operation is the same as that before the erasure operation. Such rewriting without changing the stored value of the data storage unit B [m] is hereinafter referred to as data update.
  • Data update is also performed on the data storage units B [7] and B [13]. As shown in Fig. 11 (c), at time Te, the erase operation is performed on the two memory cells MC [32] and MC [33], which are stored in memory B [7]. Is done.
  • the memory cell MC [k] from which the memory is erased is determined by the erase cell determining unit 15 shown in FIG. Specifically, when the rewrite cell determination unit 13 determines the memory cell M [k] whose stored value of the data storage unit B [m] is changed by erasure, the rewrite cell determination unit 13 determines the erase cell. The signal is output to part 15.
  • the erase cell determination unit 15 Upon receiving the signal from the rewrite cell determination unit 13, the erase cell determination unit 15 reads the stored value of the memory main body 20b, and simultaneously determines the memory cell MC [k] to be erased and rewritten.
  • the erase instruction signal E ′ is output to the control unit, and the address signal of the memory MC [k] to be erased is output to the memory body 20b.
  • the rewrite control unit 14 Upon receiving the erase instruction signal E ', the rewrite control unit 14 outputs an erase command signal E to the memory main body 20b at a erasable timing. In the memory body 20 that has received the erase command signal E, the erase operation is simultaneously performed on the memory cell MC [k] at the specified address.
  • the semiconductor storage device 3 can reduce the erase operation performed at different timings and reduce the rewrite time by performing "data update" on the data storage unit that does not require the stored value to be changed. Can do. Therefore, according to the semiconductor memory device 3, higher speed writing can be realized.
  • the memory 20b may have a lifetime that is slightly shorter than that of the memory according to the first embodiment. However, since the 1-bit data value is re-represented as a multi-bit data value and stored, It will be longer than the lifetime of the memory body.
  • the erasure cell determination unit 15 erases the memory in consideration of whether or not the data is a kind of data accompanied by periodic rewrite, the time until the next rewrite, the rewrite frequency, etc. Memory cell MC [k] is determined.
  • the memory cell on which the erase operation is performed may be any memory cell MC [31] to MC “33”.
  • the stored value in the data storage unit B [m] should be the same before / after the erase operation (before data update) and after the erase operation (after data update). Even when data is updated to shorten the rewrite time, the average number of erasures in each memory cell will increase drastically if the erasure operation is not concentrated on a specific memory cell MC [k].
  • the memory body 20b can be used for a long time.
  • the rewrite cell determination unit 13 determines whether the memory cell MC [k] to be written after the erase operation belongs to the same sector S [n]. Then, the stored value of the memory cell MC [k] was read, and the stored value of the data storage unit B [m] was calculated. However, since the sector S [n] is not configured in the semiconductor memory device 3 according to the present embodiment, the rewrite cell determination unit 13 does not need to perform writing after erasing.
  • FIG. 12 is a block diagram of a semiconductor device provided with a program that executes the same process as the rewrite process of the semiconductor memory device described in the first embodiment.
  • This semiconductor device includes a CPU 30, a storage unit 40, and a memory body 20b.
  • the connection between the CPU 30 and the memory main body 20b can be changed by hardware connection or via FPGA (Field Programmable Gate Array).
  • the memory body 20b is the same as that described in the first embodiment, and a detailed description thereof is omitted.
  • Each memory cell M C [k] included in the memory body 20b is assigned an address AD (k)!
  • the memory unit 40 is a control calculation that the CPU 30 refers to when rewriting the memory of the memory body 20b. It is a memory that stores programs and control data and is not subject to rewriting.
  • the control calculation program is a read control program P 1 which is a normal read program, a rewrite cell determination program P2 for determining a rewrite cell, a rewrite control program P3 for executing a memory rewrite control of the memory cell MC [k], It includes a comparison program P4 that performs data comparison and a logical operation program P5 that calculates read data.
  • the read control program Pl, the rewrite cell determination program P2, the rewrite control program P3, the comparison program P4, and the logic operation program P5 are the rewrite control unit 11 and rewrite described in the first embodiment and shown in FIG. 2, respectively.
  • This is a program for executing the same processing as that executed by the cell determination unit 13, the rewrite control unit 14, the comparison unit 12, and the logical operation unit 16.
  • the control data includes data necessary for execution of the control operation program.
  • the CPU 30 When data to be stored is input, the CPU 30 reads a program held by the storage unit 40 and executes the processing shown in the flowcharts of Figs. 3 and 13 described below.
  • the upper 7 bits of the address signal output by CPU30 are read instruction signal R, write instruction signal W, erase instruction signal E, forced erase signal Eo, forced write signal Wo, erase enable signal Ee, and write enable signal We.
  • the remaining 25 bits are the address signal AD (k) of the memory cell MC [k] whose memory is to be rewritten.
  • the memory value of ⁇ memory cell MC [k] is 1, and the memory value of data storage unit B [m] obtained from the memory value of memory cell MC [k] is also 1! / RU
  • the CPU 30 executes the read control program P1 and stores the data for each input 1-bit data. [m] is determined (step SI 1 in FIG. 3).
  • the CPU 30 executes the comparison program P4 and compares the 1-bit binary data value to be stored with the calculated stored value. To do. If they match (YES in step S13), it is not necessary to rewrite the stored value in the data storage unit B [m] (step S14). In this case, rewriting is not performed. On the other hand, if they do not match (NO in step S13), it is necessary to rewrite the stored value in the data storage unit B [m] (step S15).
  • the CPU 30 executes the rewriting cell determination program P2 to determine the memory cell MC [k] whose rewritten memory value is to be rewritten. Specifically, first, it is determined whether the memory value of the memory cell MC [kmin] in which k is the minimum value kmin is 1 (steps S20 and S21 in FIG. 13). If the stored value of the memory cell MC [kmin] is 1 (YES in step S21), the rewrite cell determining unit 13 determines to write to the memory cell MC [kmin] (step S26).
  • step S21 If the stored value SO of the memory cell MC [kmin] is (NO in step S21), 1 is added to k (step S22), and the value of k after the addition (specifically, kmin + 1) Determine whether the force is less than or equal to kmax (step S23).
  • kmax is the maximum value of k in the memory cell MC [k] constituting the data storage unit B [m] for rewriting data.
  • step S23 When the value of k is equal to or less than 3 ⁇ 4 max (YES in step S23), the CPU 30 determines whether the stored value of the memory cell MC [k] is 1, and if 1 (1 in step S21). YES), it is determined to write to the memory cell MC [k] (step S26).
  • the memory cell MC [k] constituting the data storage unit B [m] is stored. All the values are 0.
  • the rewrite cell determination unit 13 determines to perform an erasing operation on the sector S [n] including the data storage unit B [m] whose rewritten value is to be rewritten (step S24 in FIG. 4).
  • the CPU 30 decides to perform the erasing operation, it executes the read control program P1 to execute the read control program P1 from the other data storage unit B [m] belonging to the sector S [n] to be erased. Read the stored value of k]. Then, the CPU 30 executes the logical operation program P5 to calculate the stored value of each data storage unit B [m]. And the data storage unit whose stored value is 0 If there is B [m], it is decided to write to the memory cell MC [k] having the smallest k value among the memory cells MC [k] constituting the data storage section B [m] after the erase operation. (Step S25).
  • the CPU 30 performs a read instruction signal R, a write instruction signal W, an erase instruction signal E, a forced erase signal Eo, a forced write signal Wo, an erase rice to execute the determined erase and Z or write.
  • Enable signal Ee, write enable signal We, and address signal AD (k) are output (step S27).
  • the stored value of the desired data storage unit B [m] is rewritten.
  • the CPU 30 executes the reading program P1 to read the stored value, and the data storage unit B [m] force is q pieces. Read the stored value of memory cell MC [k]. Next, the CPU 30 executes the logical operation program P5 to obtain an exclusive OR of the q values read out, and the obtained value is stored in the memory body 20b and externally as the obtained value. Output.
  • the memory body 20b can be used for a longer period of time, and the rewrite time can be shortened. An effect can be obtained.
  • the storage unit 40 has an erase cell determination program P6 for executing the same processing as the erase cell determination unit 15 shown in FIG. I just need it. Then, after deciding to perform the erase operation in step S24 of FIG. 13, the erase cell determination program P6 is executed, and it is desirable to perform erase simultaneously from other memory cells MC [m].
  • MC [m] should be specified. Here, whether or not the memory cell MC [m] is desired to be erased at the same time, whether it is a kind of data accompanied by periodic rewriting, the time until the next rewriting, the rewriting frequency If it comes to be judged in consideration of!
  • the semiconductor memory device according to the present invention is useful as a non-volatile memory device, and more specifically as a semiconductor memory device for incorporating a system LSI.
  • FPGAs can be used for applications such as configurable system LSIs.

Landscapes

  • Read Only Memory (AREA)

Abstract

 制御演算部(10)の比較部(12)は、メモリ本体(20)に記憶する1ビットデータと、そのデータを記憶するために割り当てられたデータ格納部B[m]の記憶値とを比較する。データ格納部B[m]は、3つのメモリセルMC[k]を備えており、データ格納部B[m]の記憶値は、3つのメモリセルMC[k]の排他的論理和を演算する論理演算部(16)において求められる。比較部(12)で不一致が判断されると、書き換えセル決定部(13)は、3つのメモリセルMC[k]の中から、記憶値の書き換えを行うメモリセルMC[k]を決定する。データ格納部B[m]の記憶値を書き換える際に、そのデータ格納部B[m]に書き込み可能なメモリセルMC[k]がある場合、消去よりも優先的に書き込みが行われる。

Description

明 細 書
半導体記憶装置、書き換え処理方法およびプログラム
技術分野
[0001] 本発明は、半導体記憶装置関し、特に、 2以上の記憶状態を持ち、いずれの記憶 状態に書き換えるかによって書き換え速度または書き換えによる劣化程度が異なるメ モリセルを備えた半導体記憶装置、書き換え処理方法方法およびプログラムに関す る。
背景技術
[0002] フラッシュメモリに代表される不揮発性メモリは、電源を切った後も記憶を保持し続 けられる低消費電力なメモリとして、デジタルカメラ等のメモリカードや、パソコンの BI OSの記憶などに利用されている。
[0003] フラッシュメモリのメモリセルの記憶値は、例えば、フローティングゲートに所定量以 上の電子が蓄積されているときは 0であり、フローティングゲートに所定量未満の電子 が蓄積されて 、るときは 1であると 、うように、フローティングゲートに蓄積されて 、る 電子量によって決められる。
[0004] 上記のようにメモリセルの記憶値が決められたときに、一般に、メモリセルの記憶値 を 0にする書き換えは「書き込み」と呼ばれ、 1にする書き換えは「消去」と呼ばれて!/ヽ る。「書き込み」は、ゲート電圧をソース電圧およびドレイン電圧よりも十分高くすること によって行われ、この操作により、ソース領域力もフローティングゲートに電子が注入 される。一方、「消去」は、ソース電圧をゲート電圧よりも十分に高くすることによって行 われ、この操作により、フローティングゲートに蓄積されている電子がソース領域に引 き抜かれる。消去操作が行われると、フローティングゲート下の絶縁膜は損傷を受け るので、フラッシュメモリの寿命は消去回数によって決められる。
[0005] ところで、フラッシュメモリは、ソース電極またはドレイン電極を接地し続けたままでは 記憶値を書き換えることができず、全ての電圧 (ソース、ドレインおよびゲート電圧)を 制御しなければ記憶値を書き換えることができない。し力しながら、メモリセル毎に 3 つの電圧を制御すると回路が煩雑になり、装置が大型化するので、一般に複数個の メモリセルでなるセクタ単位でゲート電圧の制御が行われている。
[0006] セクタ単位でゲート電圧が制御される場合には、「書き込み」はメモリセル単位で行 われるが、「消去」はセクタ単位で行われる。具体的には、ある 1つのメモリセルの記 憶値を 0から 1へと書き換える場合に、まず、そのメモリセルを含むセクタの^モリセ ルの記憶が消去され、次いで、メモリセルの記憶値が 1になっていることを確認するべ リファイ処理が行われ、その後、記憶値を 1にする必要が無力つたメモリセルに 0が書 き込まれる。これにより、最終的には、所望のメモリセルの記憶値のみが 0から 1に書 き換免られたこと〖こなる。
[0007] セクタ単位で消去操作が行われると、記憶値を書き換える必要がないメモリセルの 記憶も消去されるので、各メモリセルの消去回数が増え、メモリセルひいてはメモリ本 体の性能が劣化する。
[0008] したがって、特許文献 1に開示されているように、本来のセクタとは別に予備セクタ を設けておき、消去回数が少ないセクタのメモリセルにデータを記憶していくことによ つて、セクタ毎の消去回数のばらつきを解消する半導体記憶装置が提案されている 。セクタ毎の消去回数のばらつきが解消されると、不良セクタの発生が抑制されるの で、メモリ本体をより長期にわたって使用することができる。
特許文献 1:特開 2002— 366420号公報 (第 1— 21ページ、第 1図)
発明の開示
発明が解決しょうとする課題
[0009] し力しながら、セクタを単位として消去操作を行う以上、本来ならば必要がな 、メモ リセルに対しても消去操作を行うことになるので、メモリセルに余計な損傷を与えてし まうことは避けられない。よって、如何にして不揮発性メモリのメモリ本体を長期使用 できるようにするかが課題になって!/、る。
[0010] ところで、近年、メモリセルサイズの小型化やメモリの大容量ィ匕が進んでいるため、 長期使用できるならば、必要なメモリセル数が多くなるという不利益はさほど考慮しな くともよいという場面が出てくることが考えられている。特に、長期にわたって使用でき るだけでなぐ消去を行う際の書き換え時間を短縮できるならば、必要となるメモリセ ル数の増加や回路の複雑ィ匕という不利益を上回る利益が得られる場合もある。 [0011] それ故に、本発明は、記憶の書き換えによって性能が劣化する半導体記憶装置に おいて、メモリ本体をより長期にわたって使用できる半導体記憶装置を提供すること を目的としている。また、これに加えて、書き換え時間をより短縮できる半導体記憶装 置を提供することも目的としている。
課題を解決するための手段
[0012] 本発明に係る半導体記憶装置は、 2以上の記憶状態を持ち、いずれの記憶状態に 書き換えるかによって書き換え速度または書き換えによる劣化程度が異なるメモリセ ルを備えた半導体記憶装置であって、複数のメモリセルで構成されて全体で 1ビット 分の値を記憶するデータ格納部を複数備えてなるメモリ本体と、メモリセルの記憶値 を読み出す処理と、メモリセルの記憶値を書き換える処理とを行う読み出し書き換え 制御部と、データ格納部が備えるメモリセルの記憶値を用いた演算でデータ格納部 の記憶値を求める演算部と、演算部が求めたデータ格納部の記憶値と外部から入力 された値とを比較し、一致または不一致を示す信号を出力する比較部と、比較部が 不一致を示す信号を出力したときに、データ格納部の記憶値を外部力 入力された 値と同じ値に変更するために記憶値を変更すべきメモリセルを決定する書き換えセ ル決定部とを備える。
[0013] 演算部は、排他的論理回路を含んでいてもよい。その場合には、各データ格納部 は、 3以上の奇数ビット分のデータ容量を有して 、ればよ 、。
[0014] データ格納部が備えるメモリセルの個数は、データ格納部によって異なっていても よい。
[0015] 読み出し書き換え制御部は、メモリセルの記憶値をメモリセル毎に書き換える個別 書き換え処理と、メモリセルの記憶値を 1個以上のデータ格納部を単位として書き換 える一括書き換え処理と、のいずれかを行うことによって、データ格納部の記憶値を 変更するようになって 、てもよ 、。
[0016] メモリ本体はフラッシュメモリであってもよぐその場合には、個別書き換え処理は書 き込み処理であり、一括書き換え処理は消去処理となる。
[0017] メモリセルの記憶値を、 0または 1のうち一方の値に書き換える第 1の書き換えに要 する時間が、他方の値に書き換える第 2の書き換えに要する時間よりも短いときに、 個別書き換え処理によって前記第 1の書き換えが行われ、一括書き換え処理によつ て第 2の書き換えが行われることを特徴とする。
[0018] 記憶値を変更する必要がないデータ格納部に属する、第 2の書き換えを行うことが できる偶数ビット分のデータ容量を有するメモリセルを判断する特定書き換えセル判 断部をさらに備え、読み出し書き換え制御部は、一括書き換え処理を行うときに、特 定書き換えセル判断部において判断されたメモリセルの記憶を個別に書き換えること を特徴としていてもよい。
[0019] メモリセルは、 1個で複数ビット分のデータ容量を有する多値メモリセルであってもよ い。
[0020] 本発明に係る半導体記憶装置の書き換え処理方法は、 2以上の記憶状態を持ち 、 ずれの記憶状態に書き換えるかによって書き換え速度または書き換えによる劣化程 度が異なるメモリセルを備えた半導体記憶装置の書き込み処理方法であって、複数 のメモリセルで構成されて全体で 1ビット分の値を記憶する複数のデータ格納部の中 から、外部力 入力された値を記憶するものを決定し、決定されたデータ格納部を構 成するメモリセルの記憶値を用いた演算でデータ格納部の記憶値を求め、演算で求 めたデータ格納部の記憶値と外部から入力された値とを比較して一致の有無を判断 し、判断結果が不一致であったときに、データ格納部の記憶値を前記外部から入力 された値と同じ値に変更するために記憶値を変更すべきメモリセルを決定し、記憶値 を変更することが決定されたメモリセルの記憶値を書き換える。
[0021] また、本発明に係るプログラムは、 2以上の記憶状態を持ち 、ずれの記憶状態に書 き換えるかによつて書き換え速度または書き換えによる劣化程度が異なるメモリセル を備えた半導体記憶装置の書き換え処理を行うためのプログラムであって、複数のメ モリセルで構成されて全体で 1ビット分の値を記憶する複数のデータ格納部の中から
、外部から入力された値を記憶するものを決定し、決定されたデータ格納部を構成す るメモリセルの記憶値を用いた演算で当該データ格納部の記憶値を求め、演算で求 めたデータ格納部の記憶値と外部から入力された値とを比較して一致の有無を判断 し、判断結果が不一致であったときにデータ格納部の記憶値を外部力 入力された 値と同じ値に変更するために記憶値を変更すべきメモリセルを決定し、記憶値を変 更することが決定されたメモリセルの記憶値を書き換えることを CPUに実行させる、 プログラム。
発明の効果
[0022] 本発明に係る半導体装置は、記憶する 1ビット分のデータを、複数ビット分のデータ で表し直して記憶するので、個々のメモリセルの書き換え回数が少なくなり、メモリ本 体をより長期にわたって使用することができる。
[0023] また、データ格納部にすでに記憶されて!、る記憶値とこれから記憶する記憶値とを 比較して、不一致の場合のみ書き換えを行えば、必要のない書き換えを抑制できる。 これにより消去回数を減らすことができ、メモリ本体をより長期にわたって使用すること ができ、また、書き換え時間を短縮することもできる。
[0024] また、書き換えが頻繁に行われるデータが分力つて 、る場合、そのデータを、メモリ セルの個数が多いデータ格納部に記憶すれば、消去回数を減らすことができ、より 長期にわたってメモリ本体を使用することができる。
[0025] また、 1個のデータ格納部が 3以上の奇数ビット分のデータ容量を有していれば、 一括書き換え処理前と一括書き換え処理後とで、データ格納部の記憶値が変化する ため、一括書き換え後に個別書き換え処理を行う必要がない。よって、書き換え時間 を短縮することができる。
[0026] また、書き換え処理時間が長い書き換えを個別に行って、書き換え処理時間が短 い書き換えを一括して行うよりも、書き換え処理時間が長い書き換えを一括して行つ て、書き換え処理時間が短い書き換えを個別に行う方が書き換え時間を短縮するこ とがでさる。
[0027] 一括書き換え処理を行って 、る間に他の書き換えができな 、場合、一括書き換え 処理を行うときに、同時に特定書き換えセル判断部で判断されたメモリセルの記憶も 書き換えるようにすれば、異なるタイミングで行われる書き換え処理を減らすことがで きる。よって、次回に一括書き換えを行うまでの時間を稼ぐことができるため、書き換 え時間を短縮することができる。このときに偶数ビット分のデータの記憶値を書き換え れば、データ格納部の記憶値は変化しな 、。
図面の簡単な説明 [0028] [図 1]図 1は、本発明の第 1実施形態に係る半導体記憶装置のブロック図である。
[図 2]図 2は、制御演算部の詳細な構成を示すブロック図である。
[図 3]図 3は、制御演算部における処理を示すフローチャートである。
[図 4]図 4は、図 3の続図である。
[図 5]図 5は、図 4の続図である。
[図 6]図 6は、書き換えによるメモリセル MC[k]およびデータ格納部 B[m]の記憶値 の変化を示した図である。
[図 7]図 7は、従来の半導体記憶装置における書き換えによる記憶値の変化を示した 図である。
[図 8]図 8は、本発明の第 2の実施形態に係る半導体記憶装置のブロック図である。
[図 9]図 9は、データ格納部 B[l]、 B[9]および B' [9]における記憶値の変化を時系 列で示した図である。
[図 10]図 10は、本発明の第 3の実施形態に係る半導体記憶装置のブロック図である [図 11]図 11は、書き換え処理を説明するための図である。
[図 12]図 12は、本発明の第 4の実施形態に係るプログラムを実行する半導体装置の ブロック図である。
[図 13]図 13は、図 3の続図であって、プログラムの実行によって行われる処理を示す フローチャートである。 符号の説明
[0029] 1 半導体記憶装置
2 半導体記憶装置
3 半導体記憶装置
10 制御演算部
10a 制御演算部
10b 制御演算部
11 読み出し制御部
12 比較部 13 書き換えセル決定部
14 書き換え制御部
15 消去セル決定部
16 論理演算部
20 メモリ本体
20a メモリ本体
20b メモリ本体
発明を実施するための最良の形態
[0030] (第 1の実施形態)
図 1は、本発明の第 1の実施形態に係る半導体記憶装置 1のブロック図である。半 導体記憶装置 1は、制御演算部 10と、メモリ本体 20とを備えている。
[0031] メモリ本体 20は、電源を切った後も記憶を保持し続けられる、 1ビット記憶用の不揮 発性のメモリセル MC[k] (kは自然数)を複数備えている。本実施形態において、メ モリセル MC [k]は、半導体基板上にソース電極、ドレイン電極、フローティングゲート 、およびゲート電極を備えたフラッシュメモリセルであるとして説明する。そして、フロ 一ティングゲートの電子蓄積量が所定量以上であるときの記憶値を 0とし、フローティ ングゲートの電子蓄積量が所定量未満であるときの記憶値を 1とする。なお、図 1に は示していないが、メモリセル MC[k]は、メモリ本体 20のメモリセル配置領域にマトリ ックス状に配置されている。
[0032] 各データ格納部 B [m] (mは自然数)は、 3個のメモリセル MC [k]を備えて!/、る。ま た、 3個のデータ格納部 B[m]で 1個のセクタ S [n] (nは自然数)が構成されている。 同じセクタ S [n]内に存在するメモリセル MC [k]は、同じワード線 (電圧供給線)に接 続されている。
[0033] メモリセル MC [k]の記憶値を 1から 0に書き換える場合、フローティングゲートに所 定量以上の電荷が蓄積されるように、ゲート電極に高電圧が印加される。この書き換 えは、ソースおよびドレイン電圧が個別に制御されることにより、メモリセル MC[k]単 位で行われる。以下、このような書き換えを「書き込み」という。
[0034] 一方、メモリセル MC[k]の記憶値を 0から 1に書き換える場合、フローティングゲー トに蓄積されている電荷をソース領域に引き抜くために、ソース電極に高電圧が印加 される。この書き換えは、セクタ S [n]単位で行われる。以下、この書き換えを「消去」と いう。
[0035] 図 2は、図 1に示す半導体記憶装置 1のうち、制御演算部 10の構成を主に示したブ ロック図である。また、図 3〜図 5は、記憶するデータが入力されたときの制御演算部 10における処理を示すフローチャートである。以下、図 2〜図 5を用いて、半導体記 憶装置 1の構成および動作について説明する。
[0036] 図 2に示すように、制御演算部 10は、読み出し制御部 11、比較部 12、書き換えセ ル決定部 13、書き換え制御部 14、および、論理演算部 16を備えている。初期状態 において、 ^モリセル MC[k]の記憶値は 1になっており、メモリセル MC[k]の記憶 値から求められるデータ格納部 B [m]の記憶値も 1になって!/、る。
[0037] 図 2の制御演算部 10に、メモリ本体 20に記憶するデータが入力されると、読み出し 制御部 11は、入力された 1ビットデータ毎に、そのデータを記憶するデータ格納部 B [m]を決定する(図 3のステップ S 11)。読み出し制御部 11は、決定したデータ格納 部 B [m]に含まれる 3個のメモリセル MC [k]の位置を示すアドレス信号 AD (k)と、読 み出し命令信号 Rとをメモリ本体 20に出力する。
[0038] 3個のメモリセル MC[k]の記憶値は、書き換えセル決定部 13と論理演算部 16とに 読み出される。論理演算部 16は、入力された 1の個数が奇数である場合は 1を算出 し、入力された 1の個数が偶数である場合には 0を算出する、図示していない排他的 論理和 (XOR)演算回路を備えている。論理演算部 16は、データ格納部 B[m]の記 憶値として、入力された 3個のメモリセル MC[k]の記憶値の排他的論理和を求める( ステップ S 12)。
[0039] 比較部 12には、これから記憶しょうとする 1ビットのバイナリデータ値と、論理演算部 16の演算値とが入力される。比較部 12は、入力された 2つの値を比較して、一致し ている場合 (ステップ S 13の YES)には、データ格納部 B[m]の記憶値の書き換えが 不要であることを示す一致信号 Caを出力し (ステップ S 14)、不一致の場合 (ステップ S 13の NO)には、データ格納部 B[m]の記憶値の書き換えが必要であることを示す 不一致信号 Cbを出力する (ステップ S 15)。 [0040] 書き換えセル決定部 13には、一致信号 Caまたは不一致信号 Cb、および、データ 格納部 B [m]を構成するメモリセル MC [k]の記憶値が入力される。書き換えセル決 定部 13は、一致信号 Caが入力された場合、書き換えを行わないことを決定する。
[0041] 一方、書き換えセル決定部 13は、不一致信号 Cbが入力された場合には、 kが最小 値 kminであるメモリセル MC [kmin]の記憶値が 1であるかどうかを判断する(図 4のス テツプ S 20および S 21)。メモリセル MC [kmin]の記憶値が 1であれば (ステップ S 21 の YES)、書き換えセル決定部 13は、メモリセル MC [kmin]に書き込みを行うことを 決定する (ステップ S 26)。そして、図 2に示すように書き換えセル決定部 13は、書き 込みを指示する書き込み指示信号 W'を書き換え制御部 14に出力し、また、書き込 みを行うメモリセル MC[k]のアドレスを示すアドレス信号 AD (k)をメモリ本体 20に出 力する。
[0042] また、メモリセル MC [kmin]の記憶値力 ^であれば (ステップ S21の NO)、書き換え セル決定部 13は、 kに 1を加算して (ステップ S22)、加算後の kの値 (具体的には kmi n+ 1)が、 kmax以下であるかどうかを判断する(ステップ S23)。ここで、 kmaxは、デ ータの書き換えを行うデータ格納部 B[m]を構成するメモリセル MC[k]の中の、最大 の kの値である。
[0043] kの値カ!^ 以下である場合には(ステップ S23の YES)、書き換えセル決定部 13 は、メモリセル MC[k]の記憶値が 1であるかどうかを判断し、 1であれば (ステップ S2 1の YES)、メモリセル MC[k]に書き込みを行うことを決定する(ステップ S26)。そし て、書き換えセル決定部 13は、書き込みを指示する書き込み指示信号 W'を書き換 え制御部 14に出力し、また、書き込みを行うメモリセル MC[k]のアドレスを示すアド レス信号 AD (k)をメモリ本体 20に出力する。
[0044] kに 1を加算していくことによって、 kの値カ1^&よりも大きくなつた場合には (ステツ プ S23の NO)、これは、データ格納部 B[m]を構成するメモリセル MC[k]の記憶値 が全て 0になっていることを示している。この場合、書き換えセル決定部 13は、記憶 値を書き換えるデータ格納部 B[m]を含むセクタ S [n]に対して消去操作を行うことを 決定する(4の図ステップ S 24)。
[0045] 書き換えセル決定部 13は、消去操作を行うことを決定した場合には、消去が行わ れるセクタ S [n]に属する他のデータ格納部 B [m]のメモリセル MC [k]の記憶値を読 み出し、図示していない排他的論理和演算回路で、各データ格納部 B[m]の記憶値 を演算する。そして、記憶値が 0であるデータ格納部 B[m]があれば、そのデータ格 納部 B [m]を構成するメモリセル MC [k]のうち kの値が最小のメモリセル MC [k]に、 消去操作後に書き込みを行うことを決定する (ステップ S25)。
[0046] そして、書き換えセル決定部 13は、消去操作を行うことを指示する消去指示信号 E
'を書き換え制御部 14に出力し、また、消去操作を行うメモリセル MC[k]のアドレス を示すアドレス信号 AD (k)をメモリ本体 20に出力する。次いで、書き換えセル決定 部 13は、消去操作後に書き込みを行うことを指示する書き込み指示信号 W'を書き 換え制御部 14に出力し、また、書き込みを行うメモリセル MC[k]のアドレスを示すァ ドレス信号 AD (k)を、メモリ本体 20に出力する。
[0047] 図 2に示す書き換え制御部 14には、書き込みのタイミングを示すストローブ信号で ある書き込みィネーブル信号 We、消去のタイミングを示すストローブ信号である消去 ィネーブル信号 Eeも入力される。また、書き換え制御部 14には、強制書き込み信号 Eoおよび強制消去信号 Woも入力される。
[0048] 書き換え制御部 14は、書き込み指示信号 W'が入力されたときに、値が 1の書き込 みィネーブル信号 Weが入力されて!、て、メモリセルへの書き込みが可能な状態であ れば(図 5のステップ S31の YES)、メモリ本体 20に書き込み命令信号 Wを出力する (ステップ S32)。
[0049] 一方、書き換え制御部 14は、書き込み指示信号 W'が入力されたときに、値が 0の 書き込みィネーブル信号 Weが入力されて!、て、メモリセルへの書き込みが不可能な 状態であれば (ステップ S31の NO)、書き込みが可能な状態になるのを待って (ステ ップ S31の YES)、メモリ本体 20に書き込み命令信号 Wを出力する(ステップ S32)。
[0050] メモリ本体 20は、書き込み命令信号 Wが入力されると、アドレス信号 AD (k)によつ て指定されたメモリセル MC[k]に対して 0を書き込む (ステップ S33)。これにより、デ ータ格納部 B [m]の記憶値が書き換えられる。
[0051] また、書き換え制御部 14は、消去指示信号 E'が入力されたときに、値が 1の消去ィ ネーブル信号 Eeが入力されて!、て、消去可能な状態であれば (ステップ S34の YES )、メモリ本体 20に消去命令信号 Eを出力する。
[0052] 一方、書き換え制御部 14は、消去指示信号 E'が入力されたときに、値が 0の消去 ィネーブル信号が入力されて 、て、消去が可能な状態でなければ (ステップ S34の N 0)、消去可能な状態になるのを待って (ステップ S34の YES)、メモリ本体 20に消去 命令信号 Eを出力する (ステップ S35)。メモリ本体 20は、消去命令信号 Eが入力され ると、アドレス信号 AD (k)によって指定されたメモリセル MC[k]を含むセクタ S [n]に 対して消去操作を行う(ステップ S36)。
[0053] 消去操作によって、セクタ S [n]に含まれる^モリセル MC[k]の記憶値は 1になる ので、この後、書き換え制御部 14は、書き込みが可能な状態になるのを待って (ステ ップ S37)、書き込み命令信号 Wを出力する (ステップ S38)。これにより、書き換えセ ル決定部 13にお 、て消去後に書き込みを行うことが決定されて 、たメモリセル MC [ k]に書き込みが行われる (ステップ S39)。以上により、所望のデータ格納部 B[m]の 記憶値が書き換えられる。
[0054] なお、書き換え制御部 14に、強制書き込み信号 Woや強制消去信号 Eoが入力さ れた場合も、書き換え制御部 14は、書き込みまたは消去操作を行って、メモリ本体 2 0の記憶値を書き換える。
[0055] また、メモリ本体 20に記憶されているデータを読み出す場合には、読み出し制御部 11からメモリ本体 20に、記憶値を読み出した!/、データ格納部 B [m]の 3個のメモリセ ル MC [k]の位置を示すアドレス信号 AD (k)と、読み出し命令信号 Rとが入力される 。そして、メモリ本体 20から論理演算部 16に、 3個のメモリセル MC[k]の値が読み出 される。論理演算部 16は、入力された 3値の排他的論理和を求め、求められた値を、 メモリ本体 20に記憶されて 、た値として外部に出力する。
[0056] 次に、図 6および図 7を用いて、本実施形態に係る半導体記憶装置 1と、従来の半 導体記憶装置との違いを説明する。図 6において、(a)の部分は、セクタ S [l]を構成 するデータ格納部 B[1]〜B[3]の記憶値の変化を示している。また、(b)の部分は、 (a)の記憶値が得られるように変化させた、メモリセル MC [ 1]〜MC [3]の記憶値と、 データ格納部 B[l]の記憶値とを示している。また、(c)および (d)の部分は、(b)の 部分と同様に、(a)の記憶値が得られるように変化させた、メモリセル MC[4]〜MC[ 6]および MC [7]〜MC [9]の記憶値と、データ格納部 B [2]および B [3]の記憶値と を示している。
[0057] また、図 7は、図 6 (a)と同じ値を記憶するときに、 1ビットのバイナリデータを 1ビット 記憶用の 1個のメモリセル MC' [k]で記憶する、従来の半導体記憶装置におけるメ モリセル MC, [1]〜MC, [3]の記憶値の変化を示している。なお、メモリセル MC, [ 1]〜MC,[3]は、同一セクタ内のメモリセルである。図 7において、(a)の部分は図 6 (a)の部分に相当し、(b)の部分は図 6 (b)、(c)および (d)の部分に相当する。
[0058] 図 6 (a)の(1)および(2)に示すように、まず、メモリ本体 20の記憶値を、初期値で ある(111)から(010)にするために、図 6 (b)に示すメモリセル MC[1]と、図 6 (d)に 示すメモリセル MC [7]とに 0が書き込まれる。これにより、メモリセル MC[1]〜[3]お よび MC[7]〜MC[9]の記憶値力 いずれも(011)になり、データ格納部 B[l]およ び B [3]の記憶値が 0になる。なお、データ格納部 B [2]の記憶値は、記憶するデー タ値と同じ 1なので、メモリセル MC [1]〜MC [3]の記憶値は書き換えられな!/、。
[0059] 次に、図 6 (a)の(2)および(3)に示すように、データ格納部 B[1]〜B[3]の記憶値 を(010)から(000)にするために、図 6 (c)に示すメモリセル MC [4]に 0が書き込ま れる。これにより、データ格納部 B[2]の記憶値が 0になる。
[0060] 次に、図 6 (a)の(3)および (4)に示すように、データ格納部 B[1]〜B[3]の記憶値 を (000)から (001)にするために、図 6 (d)に示すように、メモリセノレ MC [8]に 0力 S書 き込まれる。これにより、データ格納部 B [3]の記憶値が 1になる。
[0061] 次に、図 6 (a)の(4)および(5)に示すように、データ格納部 B[1]〜B[3]の記憶値 を(001)から(100)にするために、図 6 (b)および(d)に示すように、メモリセル MC [ 2]および [9]に 0が書き込まれる。これにより、データ格納部 B[l]の記憶値が 1にな り、データ格納部 B [3]の記憶値が 0になる。
[0062] 次に、図 6 (a)の(5)および(6)に示すように、データ格納部 B[1]〜B[3]の記憶値 を(100)から(110)にするために、図 6 (c)に示すように、メモリセル MC [5]に 0が書 き込まれる。これにより、データ格納部 B [2]の記憶値が 1になる。
[0063] 次に、図 6 (a)の(6)および(7)に示すように、データ格納部 B[1]〜B[3]の記憶値 を(110)から(100)にするために、メモリセル MC [6]に 0が書き込まれる。これにより 、データ格納部 B [2]の記憶値が 0になる。
[0064] 次に、図 6 (a)の(7)および(8)に示すように、データ格納部 B[1]〜B[3]の記憶値 を(100)から(110)にするために、セクタ S [l]に対して消去操作が行われる。これに より、図 6 (b)〜(d)に示すように、メモリセル MC [1]〜 [9]の記憶が消去されて、記 憶値が全て 1になる。この後、メモリセル MC[1]〜MC[9]の記憶値が 1になっている ことを確認するべリファイ処理が行われ、次いで、データ格納部 B [3]の記憶値を 0に するために、図 6 (c)に示すようにメモリセル MC [7]に 0が書き込まれる。
[0065] 次に、図 7を用いて従来の半導体記憶装置における書き換えを説明する。まず、図 7 (a)の(1)および(2)に示すように、記憶値を(111)から(010)にするために、図 7 ( b)に示すようにメモリセル MC, [3]に 0が書き込まれる。
[0066] 次に、図 7 (a)の(2)および(3)に示すように、記憶値を (010)から(000)にするた めに、図 7 (b)に示すようにメモリセル MC' [2]に 0が書き込まれる。
[0067] 次に、図 7 (a)の(3)および (4)に示すように、記憶値を (000)から(001)にするた めに、まず、図 7 (b)に示すように、メモリセル MC' [1]〜MC' [3]の記憶が消去され る。そして、メモリセル MC, [1]〜MC, [3]の記憶値が全て 1になったことを確認する ベリファイ処理が行われ、記憶値を 1にする必要がな力つたメモリセル MC, [1]およ び MC' [2]に 0が書き込まれる。
[0068] 次に、図 7 (a)の(4)および(5)に示すように、記憶値を (001)から(100)にするた めに、図 7 (b)に示すように、メモリセル MC' [1]〜MC' [3]の記憶が消去される。そ して、メモリセル MC, [1]〜MC, [3]の記憶値が全て 1になったことを確認するべリフ アイ処理が行われ、記憶値を 1にする必要がな力つたメモリセル MC' [2]および MC' [3]に 0が書き込まれる。
[0069] 次に、図 7 (a)の(5)および(6)に示すように、記憶値を(100)から(110)にするた めに、図 7 (b)に示すようにメモリセル MC' [1]〜MC' [3]の記憶が消去される。そし て、メモリセル MC, [1]〜MC, [3]の記憶値が全て 1になったことを確認するべリファ ィ処理が行われ、記憶値を 1にする必要がな力つたメモリセル MC' [3]に 0が書き込 まれる。
[0070] 次に、図 7 (a)の(6)および(7)に示すように、記憶値を(110)から(100)にするた めに、図 7 (b)に示すようにメモリセル MC' [2]に 0が書き込まれる。
[0071] 最後に、図 7 (a)の(7)および (8)に示すように、記憶値を(100)から(110)にする ために、まず、図 7 (b)に示すようにメモリセル MC' [1]〜MC' [3]の記憶が消去さ れる。そして、メモリセル MC, [1]〜MC, [3]の記憶値が全て 1になったことを確認す るべリファイ処理が行われ、記憶値を 1にする必要がな力つたメモリセル MC' [3]に 0 が書き込まれる。
[0072] 以上に説明した書き換えにおいて、本実施形態に係る半導体記憶装置 1では、消 去操作が 1回だけ行われたが、従来の半導体記憶装置では、消去操作が 4回も行わ れた。フラッシュメモリの寿命は消去回数で決まるので、本実施形態に係る半導体記 憶装置 1のように、記憶する 1ビット分のバイナリデータを複数ビット分のバイナリデー タで表し直して記憶するようにすれば、個々のメモリセル MC [k]の書き換え回数が 少なくなり、メモリ本体 20をより長期にわたって使用することができる。
[0073] また、消去の場合、ベリファイ処理を行う必要があることなどから、書き込みよりもデ ータ書き換えに時間を要するが、本実施形態に係る半導体記憶装置 1を用いれば、 消去回数を減らすことができるので、書き換え時間を短縮できる。
[0074] また、本実施形態に係る半導体記憶装置 1では、データ格納部 B [m]の記憶値と 入力されたデータ値とが不一致の場合にのみ書き換えを行うので、必要のない書き 換えを抑制できる。これにより、消去回数を減じることができ、メモリ本体 20をより長期 にわたつて使用することができる。また、書き換え時間を短縮することもできる。
[0075] また、書き換えセル決定部 13は、データ格納部 B[m]の記憶値を書き換えるときに 、メモリセル MC [k]の寿命を縮めたり書き換え時間を要したりする「消去」よりも、「書 き込み」を優先的に選択する。また、例えば、書き込みを行うメモリセル MC[k]の個 数が 1個であるときと 3個であるときとで得られるデータ格納部 B [m]の記憶値が同じ になる場合のように、書き換え方法が複数ある場合、書き換えセル決定部 13は、書き 込みを行うメモリセル MC [k]の数ができるだけ少な 、書き換え方法を選択する。この ように、半導体記憶装置 1では、メモリ本体 20の劣化原因となる処理をできるだけ行 わな 、ようにして 、るので、メモリ本体 20をより長期にわたつて使用することができる。 また、消去回数を減らすことによって、書き換え時間を短縮することもできる。 [0076] なお、 1つのセクタ S [n]を構成するデータ格納部 B[m]の個数や、 1つのデータ格 納部 B [m]を構成するメモリセル MC [k]の個数は、上記説明に用いた個数に限定さ れるわけではない。半導体記憶装置 1において、消去回数は、 1つのセクタ S [n]を 構成するデータ格納部 B[m]の数が少ないほど少なくなり、また、データ格納部 B[n ]を構成するメモリセル MC [k]の数が多 、ほど少なくなる。
[0077] ただし、 1つのデータ格納部 B [m]を構成するメモリセル MC [k]の数が偶数の場合 には、メモリセル MC[k]の記憶値が全て 0であるとき(消去前)と、全て 1であるとき( 消去後)とでデータ格納部 B[m]の記憶値が同じになる。よって、セクタ単位で消去 が行われる場合、 1つのデータ格納部を構成するメモリセル MC[k]の数を奇数にし ておけば、消去前と消去後とでのデータ格納部 B[m]の記憶値が変わるために、消 去後にさらに書き込みを行ってデータ格納部 B[m]の記憶値を変える必要がないた め、書き換え時間を短縮することができる。
[0078] なお、本実施形態ではフラッシュメモリを例に説明した力 本発明は、特に、 0から 1 または 1から 0の少なくともいずれか一方の書き込み回数を減じることによってより長 期の使用が可能になったり、書き込み時間の短縮ィ匕などの効果が得られたりする半 導体記憶装置に対して有効である。例えば強誘電体メモリ(FeRAM ferroelectric Ra ndom Access Memory)は、書き換え回数、すなわち分極反転回数によって寿命が決 まるので、本発明の適用により長寿命化の効果が得られる。
[0079] なお、フラッシュメモリ以外のメモリの場合でも、書き換え処理時間が長い書き換え を一括して行って、書き換え処理時間が短い書き換えを個別に行うことができれば、 書き換え処理時間が短い書き換えを一括して行って、書き換え処理時間が長い書き 換えを個別に行うよりも、書き換え時間を短縮することができる。
[0080] また、本実施形態では、 1ビット記憶用のメモリセルを用いて説明したが、本発明に 係る半導体記憶装置には、 1つのメモリセルで 2ビット以上のバイナリデータを記憶す る多値のフラッシュメモリセルを用いてもよい。例えば 1つのメモリセルで 2ビットのバイ ナリデータを記憶する多値メモリセルの場合、 1番目のメモリにおける 1ビット目の記憶 力 Sメモリセル MC[1]に相当し、 2ビット目の記憶力 Sメモリセル MC [2]に相当する。そ して、 2番目のメモリセルにおける 1ビット目の記憶カ モリセル MC [3]に相当し、 2ビ ット目の記憶カ モリセル MC [4]に相当するという具合になる。
[0081] 多値メモリセルを用いれば、 1ビット記憶用のメモリセルを用いるよりも、データ格納 部を構成するメモリセルの数を減らすことができる。よって、多値メモリセルを用いれ ば、 1ビット記憶用のメモリセルを用いる場合よりも半導体記憶装置を小型化できる場 合もある。なお、上記効果が得られるメモリセルで有れば、フラッシュメモリ以外の多 値メモリを採用してもよぐ例えば、磁気メモリ(MRAM ;Magnetoresistive Random Ac cess Memory)や強誘電体メモリ (FeRAM)などを採用してもよ!/ヽ。
[0082] なお、本発明に係る半導体記憶装置は、システム LSI内蔵用の半導体記憶装置等 として有用である。また、 FPGA (Field Programmable Gate Array)ゃコンフギュラブ ルシステム LSI等の用途にも応用できる。
[0083] なお、本発明に係る半導体記憶装置 1は、メモリ本体であるカードと、カードの記憶 の読み出しおよび書き換えを行う装置というように、 2以上の別な構成要素でなって いてもよい。
[0084] (第 3の実施形態)
図 8は、本発明の第 2の実施形態に係る半導体記憶装置 2のブロック図である。半 導体記憶装置 2は、制御演算部 10と、メモリ本体 20aとを備えている。
[0085] メモリ本体 20aは、電源を切った後も記憶を保持し続けられる、 1ビット記憶用の不 揮発性のメモリセル MC[k] (kは自然数)を複数備えている。本実施形態でも、第 1の 実施形態と同様に、メモリ本体 20aは、フラッシュメモリであるとして説明する。そして、 フローティングゲートの電子蓄積量が所定量以上であるときのメモリセル MC[k]の記 憶値を 0とし、フローティングゲートの電子蓄積量が所定量未満であるときのメモリセ ル MC [k]の記憶値を 1とする。なお、図 8には示していないが、メモリセル MC[k]は 、メモリ本体 20aのメモリセル配置領域にマトリックス状に配置されている。なお、本実 施形態に係る半導体記憶装置 2の制御演算部 10の構造とその動作は、第 1の実施 形態で説明したものと同じであるため説明を省略する。
[0086] 1つのデータ格納部 B[m] (mは自然数)は、 3個または 5個のメモリセル MC[k]を 備えている。例えば、データ格納部 B[l]は、 3個のメモリセル MC[1]〜MC[3]を備 えており、データ格納部 B [9]は、 5個のメモリセル MC [25]〜MC [29]を備えてい る。また、 1つのデータ格納部 B[m]で 1つのセクタ S [n] (nは自然数)が構成されて いる。同じセクタ S [n]内に存在するメモリセル MC[k]は、同じワード線 (電圧供給線 )に接続されている。
[0087] 次に、図 9を用いて、半導体記憶装置 2におけるデータの書き換えを説明する。図 9
(a)は、データ格納部 B[l]および B[9]における記憶値の書き換えを示している。図 9 (a)に示す時刻 t41〜t44は、データ格納部 B[l]の記憶値が 1、 0、 1、 0の順に書 き換えられる時刻を示している。また、図 9 (a)に示す時刻 tl l〜tl7は、データ格納 部 B[9]の記憶値が、 1、 0、 1、 0、 1、 0、 1の順に書き換えられる時刻を示している。
[0088] 半導体記憶装置 2では、データ格納部 B[m]毎にセクタ S [n]が構成されているの で、図 9 (a)に示すように、半導体記憶装置 2のデータ格納部 B[m]の記憶値の書き 換えは、データ格納部 B[m]毎に独立して行われる。
[0089] 記憶値の書き換えがデータ格納部 B[m]毎に行われると、あるデータ格納部 B[m] の記憶を消去するときに、他のデータ格納部 B[m]の記憶が消去されることがない。 よって、半導体記憶装置 2を用いれば、従来の記憶装置を用いた場合よりも消去回 数を減らすことができるので、より長期にわたってメモリ本体 20bを使用することができ る。
[0090] また、半導体記憶装置 2は、さらに、より長期にわたってメモリを使用することができ るように、頻繁に書き換えが行われる種のデータに対して、メモリセル MC[k]の数が 多いデータ格納部 B[m]が割り当てられている。例えば、図 9 (a)に示すように、デー タ格納部 B[9]は、データ格納部 B[l]よりも頻繁に記憶値が書き換えられるので、デ ータ格納部 B[9]には、データ格納部 B[l]よりも多くのメモリセル MC[k]が割り当て られている。
[0091] 図 9 (b)は、同じ書き換えを行う場合に、 5個のメモリセル MC[k]を有するデータ格 納部 B[9]と、 3個のメモリセル MC[k]を有するデータ格納部 B, [9]とでの記憶値の 書き換えタイミングの違 、を示して 、る。
[0092] 図 9 (b)に示す tl l〜tl7は、データ格納部 B[9]における書き換え時刻を示してお り、また、 tl l '〜tl7'は、データ格納部 B' [9]における書き換え時刻を示している。 図 9 (b)に示すように、メモリセル MC[k]の個数が多いデータ格納部 B[9]は、メモリ セル MC[k]の個数が少ないデータ格納部 B' [9]よりも遅い書き換え段階で消去が 行われる。
[0093] よって、データの書き換えを繰り返した場合、メモリセル MC [k]の数が多ければ、 消去回数が少なくなるために、より長期にわたってメモリ本体 20を使用できる。消去 が行われた場合、消去後にベリファイ処理が必要になるので、データの書き換えに、 書き込みよりも長い時間を要する。よって、書き換えが頻繁に行われるデータが分か つている場合、そのデータを、メモリセル MC [k]の個数が多いデータ格納部 B[m] に記憶すれば、より長期にわたってメモリを使用することができ、また、書き換え時間 を短縮することができる。
[0094] なお、本実施形態においてメモリセルは、 1つで多ビットを記憶できる多値メモリのメ モリセルであってもよい。
[0095] (第 3の実施形態)
図 10は、本発明の第 3の実施形態に係る半導体記憶装置 3のブロック図である。半 導体記憶装置 3は、制御演算部 10bと、メモリ本体 20bとを備えている。
[0096] メモリ本体 20bは、電源を切った後も記憶を保持し続けられる、 1ビット記憶用の不 揮発性のメモリセル MC[k] (kは自然数)を複数備えている。なお、本実施形態でも、 第 1および第 2の実施形態と同様に、メモリ本体 20bはフラッシュメモリであるとして説 明する。図 10には示していないが、メモリセル MC[k]は、メモリ本体 20bのメモリセル 配置領域にマトリックス状に配置されて 、る。
[0097] データ格納部 B [m] (mは自然数)は、それぞれ 5つのメモリセル MC [k]を備えて いる。本実施形態に係る半導体記憶装置 3では、セクタ毎のゲート電圧制御は行わ れず、メモリセル MC[k]毎に消去が行われる。
[0098] 制御演算部 10bは、読み出し制御部 11、比較部 12、書き換えセル決定部 13、書 き換え制御部 14、および、消去セル決定部 15を備えている。本実施形態において、 制御演算部 10bで行われる処理にっ 、ては、本実施形態特有の構成要素である消 去セル決定部 15における処理を中心に説明し、それ以外の構成要素における処理 は、第 1の実施形態で説明した処理と同じであるため省略する。
[0099] 図 11を用いて、半導体記憶装置 3におけるデータの書き換えを説明する。図 11に おいて、(a)は、データ格納部 B[l]における書き換えを、(b)は、データ格納部 B[2 ]における書き換えを、(c)は、データ格納部 B [7]における書き換えを、(d)は、デー タ格納部 B[ 13]における書き換えを時系列で示している。
[0100] 図 11 (a)に示すように、期間 Pの間に、データ格納部 B[l]の記憶値は、 0、 1、 0、 1 、 0の順に書き換えられる。そして、この期間 Pにおける最後の書き換え後のメモリセ ル MC [1]〜MC[5]の記憶値は全て 0になっている。そして、時刻 Teに行われる次 の書き換えでは、メモリセル MC[1]〜MC[5]に対して消去操作が行われる。
[0101] メモリセル MC [1]〜MC[5]はセクタを構成していないので、各メモリセル MC[k] の記憶を一つずつ消去して行くことによって、データ格納部 B[m]の記憶値を変えて 行くことも可能である。しかしながら、消去操作が行われている間は他の処理を行うこ とができないので、半導体記憶装置 3では、消去によってデータ格納部 B[m]の記憶 値を変える場合には、そのデータ格納部 B[m]内の全てのメモリセル MC[k]に対し て同時に消去操作が行われる。
[0102] ところで、期間 Pの間に、データ格納部 B [2]の記憶値は、図 11 (b)に示すように、 1 、 0、 1の順に書き換えられる。そして、期間 Pにおける最後の書き換え後のメモリセル MC [6]〜MC[10]の記憶値は、(00001)になっている。
[0103] また、期間 Pの間に、データ格納部 B [7]の記憶値は、図 11 (c)に示すように、 1、 0 の順に書き換えられる。そして、期間 Pにおける最後の書き換え後のメモリセル MC[ 31]〜MC[35]の記憶値は、(00011)になっている。
[0104] また、図 11 (d)に示すように、期間 Pの間においてデータ格納部 B[ 13]の記憶値は 1であり、メモリセル MC[61]〜MC[65]の記憶値は、(00111)になっている。
[0105] 先に説明したとおり、消去処理が行われる間には、書き込みなどの他の処理は行え ない。よって、半導体記憶装置 3は、データ格納部 B[m]の記憶値を書き換えるため に消去操作を行う場合に、記憶値を書き換える必要がな 、データ格納部 B[m]の一 部または全部のメモリセル MC[k]に対しても消去操作を行い、これにより、異なるタ イミングで行われる消去操作の回数を減らして 、る。
[0106] 具体的には、図 11 (b)に示すように、時刻 Teのときに、つまりデータ格納部 [1]に 対して消去操作が行われるタイミングで、データ格納部 B [2]の、記憶値が 0である 4 個のメモリセル MC [6]〜MC [9]に対して消去操作が行われる。これにより、メモリセ ル MC [6]〜MC[10]の記憶値は、(11111)になる。なお、消去操作後のデータ格 納部 B [2]の記憶値は、消去操作前と同じ 1である。このようにデータ格納部 B[m]の 記憶値を変化させずに行う書き換えを、以下ではデータ更新という。
[0107] データ更新は、データ格納部 B [7]および B[ 13]に対しても行われる。図 11 (c)に 示すように、時刻 Teのときに、データ格納部 B[7]の、記憶値力^である 2個のメモリ セル MC [32]および MC [33]に対して消去操作が行われる。
[0108] また、図 11 (d)に示すように、時刻 Teのときに、データ格納部 B[ 13]の、記憶値が 0である 2個のメモリセル MC [61]および MC [62]に対して消去操作が行われる。
[0109] 以上のように、あるデータ格納部 B[m]に対して消去操作を行うときに、他のデータ 格納部 B[m]が備える、記憶値が 0である偶数個のメモリセル MC[k]に対しても消去 操作を行えば、次に消去操作が行われるまでの時間を稼ぐことができ、半導体記憶 装置 3における書き換え時間を短縮することができる。
[0110] 記憶が消去されるメモリセル MC [k]は、図 10に示す消去セル決定部 15で決定さ れる。具体的には、書き換えセル決定部 13において、消去によってデータ格納部 B[ m]の記憶値が変えられるメモリセル M[k]が決定されたときに、書き換えセル決定部 13は、消去セル決定部 15に信号を出力する。
[0111] 消去セル決定部 15は、書き換えセル決定部 13から信号を受けると、メモリ本体 20 bの記憶値を読み出して、同時に記憶を消去するメモリセル MC[k]を決定し、書き換 え制御部に消去指示信号 E'を出力し、また、消去するメモリ MC[k]のアドレス信号 をメモリ本体 20bに出力する。
[0112] 書き換え制御部 14は、消去指示信号 E'を受けると、消去可能なタイミングで、メモ リ本体 20bに消去命令信号 Eを出力する。消去命令信号 Eを受けたメモリ本体 20で は、指定されたアドレスのメモリセル MC[k]に対して、同時に消去操作が行われる。
[0113] 半導体記憶装置 3は、記憶値を変える必要がないデータ格納部に対して「データ 更新」を行うことによって、異なるタイミングで行われる消去操作を減らすことができ、 書き換え時間を短縮することができる。よって、半導体記憶装置 3によれば、より高速 な書き込みを実現することができる。なお、本実施形態に係る半導体記憶装置 3のメ モリ本体 20bの寿命は、第 1の実施形態に係るメモリ本体の寿命よりも若干短くなるお それもあるが、 1ビットデータ値を複数ビットデータ値で表し直して記憶して 、るので、 従来のメモリ本体の寿命よりは長くなる。
[0114] なお、消去セル決定部 15は、周期的な書き換えを伴う種のデータであるかどうかと いうことや、次の書き換えまでの時間、書き換え頻度等を考慮して、記憶を消去する 適当なメモリセル MC [k]を決定する。
[0115] なお、図 11 (c)では、データ格納部 B[7]のメモリセル MC[31]〜MC[35]のうち、 直前に 0を書き込んだ 2つのメモリセル MC [32]および MC [33]に対して消去操作 を行った力 消去操作が行われるメモリセルは、どのメモリセル MC[31]〜MC「33」 であってもよい。つまり、消去操作前 (データ更新前)と消去操作後 (データ更新後)と でデータ格納部 B [m]の記憶値が同じになって!/、ればよ 、。書き換え時間を短縮す るためにデータ更新が行われる場合でも、特定のメモリセル MC[k]に対して集中し て消去操作が行われなければ、各メモリセルにおける平均消去回数は極端に増加せ ず、メモリ本体 20bを長期にわたって使用することができる。
[0116] なお、第 1の実施形態では、書き換えセル決定部 13は、同じセクタ S [n]に属する、 消去操作後に書き込みを行うメモリセル MC [k]を決定するために、メモリ本体 20か らメモリセル MC [k]の記憶値を読み出し、データ格納部 B [m]の記憶値を演算した 。し力しながら、本実施形態に係る半導体記憶装置 3では、セクタ S [n]が構成されて いないので、書き換えセル決定部 13は、消去後に書き込みを行う必要はない。
[0117] (第 4の実施形態)
図 12は、第 1の実施形態で説明した半導体記憶装置の書き換え処理と同じ処理を 実行するプログラム備えた半導体装置のブロック図である。この半導体装置は、 CPU 30、記憶部 40およびメモリ本体 20bを備えている。 CPU30とメモリ本体 20bとはハ 一ドウエアで結線される力、または、 FPGA (Field Programmable Gate Array)を介し て接続の変更が可能になっている。メモリ本体 20bは、第 1の実施形態で説明したも のと同じであり、その詳細な説明は省略する。メモリ本体 20bが備える各メモリセル M C [k]には、アドレス AD (k)が付されて!、る。
[0118] 記憶部 40はメモリ本体 20bの記憶を書き換える際に CPU30が参照する制御演算 プログラムや制御用データを格納した、書き換え対象ではないメモリである。ここで、 制御演算プログラムは、通常の読み出しプログラムである読み出し制御プログラム P 1 、書き換えセルを決定する書き換えセル決定プログラム P2、メモリセル MC[k]の記 憶書き換え制御を実行する書き換え制御プログラム P3、データ比較を行う比較プロ グラム P4、読み出しデータを計算する論理演算プログラム P5を含んでいる。読み出 し制御プログラム Pl、書き換えセル決定プログラム P2、書き換え制御プログラム P3、 比較プログラム P4および論理演算プログラム P5は、それぞれ、第 1の実施形態で説 明し図 2に示した読み出し制御部 11、書き換えセル決定部 13、書き換え制御部 14、 比較部 12および論理演算部 16が実行する処理と同じ処理を実行するためのプログ ラムである。また、制御用データは、制御演算プログラムの実行に必要なデータを含 んでいる。
[0119] CPU30は、記憶するデータが入力された際に、記憶部 40が保持するプログラムを 読み出して、以下に説明する図 3および図 13のフローチャートに示した処理を実行 する。 CPU30が出力するアドレス信号の上位 7ビットは、読み出し指示信号 R、書き 込み指示信号 W、消去指示信号 E、強制消去信号 Eo、強制書き込み信号 Wo、消 去ィネーブル信号 Eeおよび書込ィネーブル信号 Weであり、残りの 25ビットは記憶を 書き換えるメモリセル MC [k]のアドレス信号 AD (k)である。初期状態において、 ^ モリセル MC [k]の記憶値は 1になっており、メモリセル MC [k]の記憶値から求めら れるデータ格納部 B[m]の記憶値も 1になって!/、る。
[0120] メモリ本体 20bに記憶するデータが半導体装置に入力されると、 CPU30は読み出 し制御プログラム P1を実行して、入力された 1ビットデータ毎にそのデータを記憶す るデータ格納部 B [m]を決定する(図 3のステップ SI 1)。
[0121] 次に CPU30は、決定したデータ格納部 B[m]を構成する q個(qは奇数であって、 図 12では q = 3)のメモリセル MC [k]の記憶値を用 、て論理演算プログラム P2を実 行し、データ格納部 B [m]の記憶値として q個のメモリセル MC [m]の記憶値の排他 的論理和 (XOR)を求める (ステップ S 12)。より具体的には、「1」を記憶するメモリセ ル MC [k]の個数が奇数である場合には「1」が、偶数である場合には「0」がデータ格 納部 B[m]の記憶値として算出される。 [0122] データ格納部 B[m]の記憶値が算出されると、 CPU30は比較プログラム P4を実行 して、これ力 記憶しょうとする 1ビットのバイナリデータ値と、求めた記憶値とを比較 する。そして、一致している場合 (ステップ S 13の YES)には、データ格納部 B[m]の 記憶値の書き換えが不要とであり(ステップ S 14)、この場合には書き換えは行わない 。一方、不一致の場合には (ステップ S13の NO)、データ格納部 B[m]の記憶値の 書き換えが必要であるとなる (ステップ S 15)。
[0123] 書き換えが必要である場合には、 CPU30は、書き換えセル決定プログラム P2を実 行して、記憶値を書き換えるメモリセル MC [k]を決定する。具体的には、まず、 kが 最小値 kminであるメモリセル MC [kmin]の記憶値が 1であるかどうかを判断する(図 1 3のステップ S20および S21)。メモリセル MC [kmin]の記憶値が 1であれば (ステップ S21の YES)、書き換えセル決定部 13は、メモリセル MC [kmin]に書き込みを行うこ とを決定する (ステップ S 26)。
[0124] また、メモリセル MC [kmin]の記憶値力 SOであれば (ステップ S21の NO)、 kに 1を加 算して (ステップ S22)、加算後の kの値(具体的には kmin+ 1)力 kmax以下である 力どうかを判断する (ステップ S23)。ここで、 kmaxは、データの書き換えを行うデータ 格納部 B [m]を構成するメモリセル MC [k]の中の、最大の kの値である。
[0125] kの値カ¾max以下である場合には(ステップ S23の YES)、 CPU30はメモリセル M C [k]の記憶値が 1であるかどうかを判断し、 1であれば (ステップ S21の YES)、メモリ セル MC[k]に書き込みを行うことを決定する(ステップ S26)。
[0126] kに 1を加算することによって kの値が kmaxよりも大きくなつた場合には (ステップ S2 3の NO)、データ格納部 B[m]を構成するメモリセル MC[k]の記憶値が全て 0にな つていることになる。この場合には、書き換えセル決定部 13は、記憶値を書き換える データ格納部 B[m]を含むセクタ S [n]に対して消去操作を行うことを決定する (4の 図ステップ S 24)。
[0127] CPU30は、消去操作を行うことを決定した場合には、読み出し制御プログラム P1 を実行して消去を行うセクタ S [n]に属する他のデータ格納部 B[m]からメモリセル M C [k]の記憶値を読み出す。そして、 CPU30は、論理演算プログラム P5を実行して 各データ格納部 B[m]の記憶値を演算する。そして、記憶値が 0であるデータ格納部 B [m]があれば、そのデータ格納部 B [m]を構成するメモリセル MC [k]のうち kの値 が最小のメモリセル MC[k]に、消去操作後に書き込みを行うことを決定する (ステツ プ S25)。
[0128] そして、 CPU30は、決定した消去および Zまたは書き込みを実行するための読み 出し指示信号 R、書き込み指示信号 W、消去指示信号 E、強制消去信号 Eo、強制書 き込み信号 Wo、消去イネ一ブル信号 Ee、書込ィネーブル信号 Weおよびアドレス信 号 AD (k)を出力する (ステップ S27)。これにより、所望のデータ格納部 B[m]の記憶 値が書き換えられる。
[0129] また、メモリ本体 20bに記憶されているデータを読み出す場合には、 CPU30は、読 み出しプログラム P 1を実行して、記憶値を読み出した 、データ格納部 B [m]力も q個 のメモリセル MC[k]の記憶値を読み出す。次に、 CPU30は、論理演算プログラム P 5を実行して、読み出した q個の値の排他的論理和を求め、求められた値を、メモリ本 体 20bに記憶されて 、た値として外部に出力する。
[0130] 第 1の実施形態で説明した半導体記憶装置と同様に、本実施形態に係るプロダラ ムを実行することによって、メモリ本体 20bをより長期にわたって使用でき、また、書き 換え時間を短縮できるといった効果を得ることができる。
[0131] なお、第 3の実施形態で説明した処理を行うためには、記憶部 40が、図 10に示し た消去セル決定部 15と同じ処理を実行するための消去セル決定プログラム P6を備 えていればよい。そして、図 13のステップ S24で消去操作を行うことを決定した後に、 消去セル決定プログラム P6を実行して、その他のメモリセル MC[m]の中から、同時 に消去を行うことが望ましいメモリセル MC [m]を特定すればよい。ここで、同時に記 憶の消去を行うことが望ましいメモリセル MC [m]かどうかは、周期的な書き換えを伴 う種のデータであるかどうかということや、次の書き換えまでの時間、書き換え頻度等 を考慮して判断されるようになって 、ればよ!/、。
産業上の利用可能性
[0132] 本発明に係る半導体記憶装置は、不揮発性記憶装置として有用であり、より具体 的には、システム LSI内蔵用等の半導体記憶装置としても有用である。また、 FPGA ゃコンフギユラブルシステム LSI等の用途にも応用できる。

Claims

請求の範囲
[1] 2以上の記憶状態を持ち、いずれの記憶状態に書き換えるかによって書き換え速 度または書き換えによる劣化程度が異なるメモリセルを備えた半導体記憶装置であ つて、
複数の前記メモリセルで構成されて全体で 1ビット分の値を記憶するデータ格納部 を複数備えてなるメモリ本体と、
前記メモリセルの記憶値を読み出す処理と、前記メモリセルの記憶値を書き換える 処理とを行う読み出し書き換え制御部と、
前記データ格納部が備えるメモリセルの記憶値を用いた演算で当該データ格納部 の記憶値を求める演算部と、
前記演算部が求めたデータ格納部の記憶値と外部力 入力された値とを比較し、 一致または不一致を示す信号を出力する比較部と、
前記比較部が不一致を示す信号を出力したときに、前記データ格納部の記憶値を 前記外部から入力された値と同じ値に変更するために記憶値を変更すべきメモリセ ルを決定する書き換えセル決定部とを備えた半導体記憶装置。
[2] 前記演算部は、排他的論理回路を含む、請求項 1に記載の半導体記憶装置。
[3] 前記各データ格納部は、 3以上の奇数ビット分のデータ容量を有することを特徴と する、請求項 2に記載の半導体記憶装置。
[4] 前記データ格納部が備えるメモリセルの個数は、前記データ格納部によって異なる ことを特徴とする、請求項 1に記載の半導体記憶装置。
[5] 前記読み出し書き換え制御部は、
前記メモリセルの記憶値をメモリセル毎に書き換える個別書き換え処理と、 前記メモリセルの記憶値を 1個以上の前記データ格納部を単位として書き換える 一括書き換え処理と、のいずれかを行うことによって、前記データ格納部の記憶値を 変更することを特徴とする、請求項 1に記載の半導体記憶装置。
[6] 前記メモリ本体はフラッシュメモリであって、
前記個別書き換え処理は書き込み処理であり、
前記一括書き換え処理は消去処理であることを特徴とする、請求項 5に記載の半 導体記憶装置。
[7] メモリセルの記憶値を、 0または 1のうち一方の値に書き換える第 1の書き換えに要 する時間が、他方の値に書き換える第 2の書き換えに要する時間よりも短いときに、 前記個別書き換え処理によって前記第 1の書き換えが行われ、
前記一括書き換え処理によって前記第 2の書き換えが行われることを特徴とする、 請求項 5に記載の半導体記憶装置。
[8] 記憶値を変更する必要がないデータ格納部に属する、前記第 2の書き換えを行うこ とができる偶数ビット分のデータ容量を有するメモリセルを判断する特定書き換えセ ル判断部をさらに備え、
前記読み出し書き換え制御部は、前記一括書き換え処理を行うときに、前記特定 書き換えセル判断部において判断されたメモリセルの記憶を個別に書き換えることを 特徴とする、請求項 7に記載の半導体記憶装置。
[9] 前記メモリセルは、 1個で複数ビット分のデータ容量を有する多値メモリセルである ことを特徴とする、請求項 1に記載の半導体記憶装置。
[10] 2以上の記憶状態を持ち、いずれの記憶状態に書き換えるかによって書き換え速 度または書き換えによる劣化程度が異なるメモリセルを備えた半導体記憶装置の書 き換え処理方法であって、
複数の前記メモリセルで構成されて全体で 1ビット分の値を記憶する複数のデータ 格納部の中から、外部力 入力された値を記憶するものを決定し、
前記決定されたデータ格納部を構成するメモリセルの記憶値を用いた演算で、当 該データ格納部の記憶値を求め、
前記演算で求めたデータ格納部の記憶値と、前記外部から入力された値とを比較 して一致の有無を判断し、
前記判断結果が不一致であったときに、前記データ格納部の記憶値を前記外部か ら入力された値と同じ値に変更するために記憶値を変更すべきメモリセルを決定し、 前記記憶値を変更することが決定されたメモリセルの記憶値を書き換える、半導体 記憶装置の書き換え処理方法。
[11] 2以上の記憶状態を持ち、いずれの記憶状態に書き換えるかによって書き換え速 度または書き換えによる劣化程度が異なるメモリセルを備えた半導体記憶装置の書 き換え処理を行うためのプログラムであって、
複数の前記メモリセルで構成されて全体で 1ビット分の値を記憶する複数のデータ 格納部の中から、外部力 入力された値を記憶するものを決定し、前記決定された データ格納部を構成するメモリセルの記憶値を用いた演算で当該データ格納部の記 憶値を求め、前記演算で求めたデータ格納部の記憶値と前記外部力 入力された 値とを比較して一致の有無を判断し、前記判断結果が不一致であったときに前記デ ータ格納部の記憶値を前記外部力 入力された値と同じ値に変更するために記憶 値を変更すべきメモリセルを決定し、前記記憶値を変更することが決定されたメモリセ ルの記憶値を書き換えることを CPUに実行させる、プログラム。
PCT/JP2005/013041 2004-07-21 2005-07-14 半導体記憶装置、書き換え処理方法およびプログラム Ceased WO2006009069A1 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2006529143A JP4679521B2 (ja) 2004-07-21 2005-07-14 半導体記憶装置、書き換え処理方法およびプログラム
US11/631,482 US7633816B2 (en) 2004-07-21 2005-07-14 Semiconductor memory device, rewrite processing method therefor, and program thereof

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2004213173 2004-07-21
JP2004-213173 2004-07-21

Publications (1)

Publication Number Publication Date
WO2006009069A1 true WO2006009069A1 (ja) 2006-01-26

Family

ID=35785182

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2005/013041 Ceased WO2006009069A1 (ja) 2004-07-21 2005-07-14 半導体記憶装置、書き換え処理方法およびプログラム

Country Status (3)

Country Link
US (1) US7633816B2 (ja)
JP (1) JP4679521B2 (ja)
WO (1) WO2006009069A1 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017174486A (ja) * 2016-03-23 2017-09-28 華邦電子股▲ふん▼有限公司Winbond Electronics Corp. オプションコード供与回路及びその供与方法

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20240339143A1 (en) * 2020-11-11 2024-10-10 Sony Semiconductor Solutions Corporation Semiconductor storage apparatus

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS5387636A (en) * 1977-01-12 1978-08-02 Hitachi Ltd Memory write unit
JPH04289599A (ja) * 1991-01-10 1992-10-14 Nec Corp 不揮発性メモリ
JP2003324150A (ja) * 2002-02-27 2003-11-14 Ricoh Co Ltd 半導体集積回路装置及びその製造方法

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR970008188B1 (ko) * 1993-04-08 1997-05-21 가부시끼가이샤 히다찌세이사꾸쇼 플래시메모리의 제어방법 및 그것을 사용한 정보처리장치
JP4772214B2 (ja) 2001-06-08 2011-09-14 ルネサスエレクトロニクス株式会社 不揮発性記憶装置及びその書き換え制御方法
JP4646608B2 (ja) * 2004-11-26 2011-03-09 パナソニック株式会社 半導体記憶装置

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS5387636A (en) * 1977-01-12 1978-08-02 Hitachi Ltd Memory write unit
JPH04289599A (ja) * 1991-01-10 1992-10-14 Nec Corp 不揮発性メモリ
JP2003324150A (ja) * 2002-02-27 2003-11-14 Ricoh Co Ltd 半導体集積回路装置及びその製造方法

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017174486A (ja) * 2016-03-23 2017-09-28 華邦電子股▲ふん▼有限公司Winbond Electronics Corp. オプションコード供与回路及びその供与方法

Also Published As

Publication number Publication date
US20080049535A1 (en) 2008-02-28
JPWO2006009069A1 (ja) 2008-05-01
JP4679521B2 (ja) 2011-04-27
US7633816B2 (en) 2009-12-15

Similar Documents

Publication Publication Date Title
US11150808B2 (en) Flash memory system
US7679965B2 (en) Flash memory with improved programming precision
US7334080B2 (en) Nonvolatile memory with independent access capability to associated buffer
JP4129381B2 (ja) 不揮発性半導体記憶装置
KR101127413B1 (ko) 개선된 부분 페이지 프로그램 능력을 가진 비휘발성 메모리및 제어
KR100805840B1 (ko) 캐시를 이용한 플래시 메모리 장치 및 그것의 프로그램방법
JP5086972B2 (ja) 不揮発性半導体記憶装置のためのページバッファ回路とその制御方法
US20020085419A1 (en) Nonvolatile semiconductor memory device and data input/output control method thereof
US7782667B2 (en) Method of operating a flash memory device
US20100208519A1 (en) Semiconductor memory device and method of reading the same
JP5264887B2 (ja) マルチビットプログラミング装置およびマルチビットプログラミング方法
US20110145485A1 (en) Method for managing address mapping table and a memory device using the method
EP2301034A1 (en) Fast, low-power reading of data in a flash memory
JP7095568B2 (ja) メモリコントローラ及びこれを備えるフラッシュメモリシステム
US8040730B2 (en) Nonvolatile memory device
JP2006107719A (ja) 不揮発性メモリ装置及びそれのプログラム方法
US8085593B2 (en) Method of inputting address in nonvolatile memory device and method of operating the nonvolatile memory device
JP4679521B2 (ja) 半導体記憶装置、書き換え処理方法およびプログラム
JP2007140733A (ja) 半導体処理装置及び半導体集積回路
JP2010129154A (ja) 不揮発性半導体記憶装置
US8854887B2 (en) Nonvolatile memory device and method of programming the same
CN111415693B (zh) 存储器
JP2011198409A (ja) 不揮発性メモリ
CN109545262B (zh) 半导体存储装置和用于控制半导体存储装置的方法
JP2003006053A (ja) データ処理装置

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KM KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NG NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SM SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GM KE LS MW MZ NA SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IS IT LT LU LV MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 2006529143

Country of ref document: JP

WWE Wipo information: entry into national phase

Ref document number: 11631482

Country of ref document: US

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase
WWP Wipo information: published in national office

Ref document number: 11631482

Country of ref document: US