This US non-provisional patent application claims priority under 35 USC § 119 to Korean Patent Application No. 10-2015-0022302, filed on Feb. 13, 2015, the entirety of which is hereby incorporated by reference.
The present disclosure relates to semiconductor memory devices and, more particularly, to a storage device including a semiconductor memory device and an operating method thereof.
In general, semiconductor memory devices may be classified into volatile memory devices such as DRAMs and SRAMs and nonvolatile memory devices such as EEPROMs, FRAMs, PRAMs, RRAMs, MRAMs, and flash memories. Volatile memory devices lose their stored data when their power supplies are interrupted, while nonvolatile memory devices retain their stored data even when their power supplies are interrupted. In particular, a flash memory has advantages such as high program speed, low power consumption, and large data storage capacity. Therefore, storage devices based on a flash memory have been widely used.
Storage devices based on a flash memory include a solid state drive (SSD) that has been replacing a hard disk drive (HDD) and a memory card such as an SD card and an MMC. Since such a semiconductor memory device is fabricated with a small size, it may be embedded in a handheld electronic device. An embedded storage device may be, for example, an embedded SSD (eSSD) or an embedded MMC (eMMC). The eSSM may be used in a laptop computer, a tablet PC or an e-book, and the eMMC may be used in a mobile device.
Such a storage device includes a flash memory and a memory controller. Data is transmitted between the flash memory and the memory controller at high speed. The storage device uses a data strobe signal DQS to stably transmit the data. However, a pulse width of the data strobe signal DQS may be reduced by resistance of a signal line or the like. If the pulse width of the data strobe signal DQS becomes narrow, data may not be stably transmitted.
The present disclosure relates to a storage device and an operating method of the storage device.
A storage device according to example embodiments of the disclosure includes a storage device configured to store data and a memory controller connected to the memory device through a data strobe line and a plurality of data lines. The storage device adds a predetermined specific pattern in front of data and processes data input following the specific pattern as valid data during a read or write operation.
In example embodiments, the specific pattern may be provided in alignment with a data strobe signal (DQS) latency cycle. The memory controller may detect a specific pattern input from the memory device during a read operation and process data input following the detected specific pattern as valid data when the detected specific pattern matches an internally stored specific pattern.
In example embodiments, the memory controller may recognize a mismatch of the specific pattern as a malfunction and perform a random-out operation or stop performing the random-out operation when the specific pattern mismatches. The memory controller may perform the random-out operation after changing a data input/output speed with the memory device, changing a reference voltage provided to the memory device, changing a DQS latency cycle or resetting the memory device.
In example embodiments, the memory controller may detect a specific pattern input from the memory controller during the write operation and process data input following the specific pattern as valid data when the detected specific pattern matches an internally stored specific pattern.
In example embodiments, the specific pattern may include at least one of a block address, a page address, and a column address provided from the memory controller or a seed value provided from the memory controller. The memory device may recognize a mismatch of the specific pattern as a malfunction, process a program state as a program failure, and provide a pattern mismatch result to the memory controller through a status bit when the specific pattern mismatches.
Example embodiments of the disclosure provide an operating method of a storage device including a memory device configured to store data and a memory controller connected to the memory device through a data strobe line and a plurality of data lines. The operating method includes: generating a specific pattern; providing the specific pattern through the data lines in alignment with a dummy DQS signal; and providing valid data in alignment with a DQS signal after providing the specific pattern. The data input following the specific pattern may be processed as valid data.
A memory device according to example embodiments of the disclosure includes: a data input/output (I/O) circuit and a pattern logic circuit. The data I/O circuit receives a pattern in alignment with a dummy data strobe signal and receives data in alignment with a data strobe signal upon completely receiving the pattern. The pattern logic circuit identifies a pattern match if at least a portion of the received pattern is determined to match a corresponding portion of an expected pattern.
The forgoing and other features of the disclosure will be described below in more detail with reference to the accompanying drawings that illustrate non-limiting embodiments of the disclosure in which like reference characters refer to like parts throughout the different views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating principles of the disclosure. In the drawings:
Example embodiments will now be described more fully with reference to the accompanying drawings, in which some example embodiments are shown. Example embodiments may, however, be embodied in many different forms and should not be construed as being limited to the embodiments set forth herein; rather, these example embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of example embodiments of the disclosure to those of ordinary skill in the art. In the drawings, the thicknesses of layers and regions are exaggerated for clarity. Like reference characters and/or numerals in the drawings denote like elements, and thus their description may be omitted.
Storage devices based on a flash memory include a solid state drive (SSD) that has been replacing a hard disk drive (HDD) and a memory card such as an SD card and an MMC. Since such a semiconductor memory device is fabricated with a small size, it may be embedded in a handheld electronic device. An embedded storage device may be, for example, an embedded SSD (eSSD) or an embedded MMC (eMMC). The eSSM may be used in a laptop computer, a tablet PC or an e-book, and the eMMC may be used in a mobile device.
Referring to
The memory controller 120 may receive the data strobe signal DQS and receive read data from the flash memory 110 through the data lines. Data output signals (e.g., DQ1 to DQ8) may be output in alignment with a rising edge or a falling edge of the data strobe signal DQS. In an example in
Referring to
A first high pulse width of the data strobe signal DQS may be narrowed by resistance of a signal line or the like. The high pulse width of the data strobe signal DQS may be narrowed to a degree of a hatched portion A in
The storage device 100 may set the dummy DQS signal and define the number of dummy DQS cycles in various ways. For example, the storage device 100 may define the number of the dummy DQS cycles using a set feature operation.
The number of dummy DQS cycles is also called a DQS latency cycle. Although the DQS latency cycle is 1 in
In such an abnormal case, the memory controller 120 may not recognize the first pulse of the DQS signal. If the memory controller 120 cannot recognize the first pulse of the DQS signal, it may misunderstand a valid data strobe signal and valid data transmitted subsequently as a dummy data strobe signal and dummy data. That is, the memory controller 120 may store only the valid data D3 and D4 and not the valid data D1 and D2 in the FIFO circuit 122. This problem may also occur during a write operation.
The memory controller 220 may receive a write request from a host and provide a write enable signal nWE to the flash memory 210. A DQS generator 221 in the memory controller 220 may internally generate a data strobe signal. The DQS generator 221 may provide the data strobe signal DQS to the flash memory 210.
The flash memory 210 may receive the data strobe signal DQS and prepare to receive write data from the memory controller 220. The write data may be center-aligned with the data strobe signal DQS to be provided to the flash memory 210. In an example in
A storage device according to example embodiments of the disclosure adds a specific pattern in front of valid data to overcome the disadvantage that a width of a DQS signal may be narrowed so as to cause the storage device to misrecognize valid data as dummy data. For example, the storage device sets the dummy data DM1 and DM2 shown in
A storage device according to example embodiments of the disclosure processes data input following a specific pattern as valid data when transmitting and receiving the specific pattern in a dummy DQS cycle. Thus, the storage device may be prevented from mistakenly processing the valid data as dummy data.
The storage device 1000 may include one piece of flash memory or a storage medium such as embedded SSD (eSSD), embedded MMC (eMMC), and universal flash storage (UFS). In addition, the storage device 1000 may include a storage medium based on a nonvolatile memory such as MRAM, PRAM, RRAM, and FRAM or a volatile memory such as DRAM and SRAM.
Continuing to refer to
In an embodiment of the present disclosure, a three-dimensional (3D) memory array is provided. The 3D memory array is monolithically formed in one or more physical levels of arrays of memory cells having an active area disposed above a silicon substrate and circuitry associated with the operation of those memory cells, whether such associated circuitry is above or within such substrate. The term “monolithic” means that layers of each level of the array are directly deposited on the layers of each underlying level of the array.
In an embodiment of the present disclosure, the 3D memory array includes vertical NAND strings that are vertically oriented such that at least one memory cell is located over another memory cell. The at least one memory cell may comprise a charge trap layer. Each vertical NAND string may include at least one select transistor located over memory cells, the at least one select transistor having the same structure with the memory cells and being formed monolithically together with the memory cells.
The following patent documents, which are hereby incorporated by reference, describe suitable configurations for three-dimensional memory arrays, in which the three-dimensional memory array is configured as a plurality of levels, with word lines and/or bit lines shared between levels: U.S. Pat. Nos. 7,679,133; 8,553,466; 8,654,587; 8,559,235; and US Pat. Pub. No. 2011/0233648.
Still referring to
The data I/O circuit 1120 may include a pattern control logic 1121. The pattern control logic 1121 may generate or detect a specific pattern. The pattern control logic 1121 may separately include a pattern generator (not shown) to generate a specific pattern and a pattern detector (not shown) to detect a specific pattern.
A specific pattern is a patterned version of data provided in alignment with a transition of a dummy DQS signal and is a known-pattern that the memory device 1100 and the memory controller 120 establish previously. The specific pattern may be an established pattern or may be formed using a block address, a page address, a column address or a seed value. The specific pattern and data may be provided to the memory controller 1200 from the memory device 1100 through data output signals DQ1 to DQ8.
Operations of generating a specific pattern by the data I/O circuit 1120 and providing the specific pattern and read data to the memory controller 1200 by the data I/O circuit 1120 will be described in further detail later with reference to
The memory controller 1200 may sequentially receive the specific pattern and the data from the memory device 1100 and sequentially store the specific pattern and the data in latch circuits LAT1 to LAT8 of a first-in-first-out (FIFO) circuit 1220. A specific pattern PTTN stored in the FIFO circuit 1220 may be provided to the pattern control logic 1230 and data DATA may be provided to internal control logic 1210.
The pattern control logic 1230 may receive a start signal START from the internal control logic 1210 and start a pattern detection operation. The pattern control logic 1230 may provide an end signal END to the internal control logic 1210 when the pattern detection operation is terminated.
When the start signal START is input, the pattern control logic 1230 may inspect whether the specific pattern PTTN input from the FIFO circuit 1220 matches a previously established known-pattern. The pattern control logic 1230 may determine whether a specific pattern matches the known-pattern, based on pattern information INFO input from the internal control logic 1210. The pattern information INFO may include a block address, a page address, a column address, a seed value, and the like.
The pattern control logic 1230 may perform a pattern detection operation and provide a matching signal MATCH of a specific pattern to the internal control logic 1210 as a result of the pattern detection operation. When the specific pattern matches, the internal control logic 1210 may process data DATA input from the FIFO circuit 1220 as valid data.
When the specific pattern mismatches, the internal control logic 1210 may perform an error protection operation. The internal control logic 1210 does not perform an ECC decoding operation to correct a data error but provides a column address to the memory device 1100 to re-perform the read operation. This read operation is also called a random-out operation. When the random-out operation is performed, the internal control logic 1210 may change various operation conditions.
For example, the internal control logic 1210 may perform a random-out operation after decreasing an input/output (I/O) speed. Alternatively, the internal control logic 1210 may perform a random-out operation after adjusting a reference voltage Vref provided to the memory device 1100 from the memory controller and adjusting a DQS latency cycle. Alternatively, the internal control logic 1210 may perform a random-out operation after resetting the memory device 1100. Detailed embodiments of the random-out operation will be described later.
The data I/O circuit 1120 receives a read enable signal nRE from the memory controller 1200 (S110).
The data I/O circuit 1120 receives the read enable signal nRE to generate a data strobe signal DQS after a predetermined time elapses (S120). The DQS signal is generated in alignment with a transition of the read enable signal nRE.
The data I/O circuit 1120 generates specific patterns (S130). Specific patterns may be generated using the pattern control logic 1121. The pattern control logic 1121 may generate a specific pattern using a block address, a page address or a column address provided from the memory controller 1200. Alternatively, the pattern control circuit 1121 may generate a specific pattern using data or a seed.
The data I/O circuit 1120 provides the specific pattern to the memory controller 1200 through the data output signals DQ1 to DQ8 (S140). The specific pattern may be provided during a DQS latency cycle in alignment with a dummy DQS signal.
The data I/O circuit 1120 provides read data to the memory controller 1200 through the data output signals DQ1 to DQ8 after providing all the specific patterns (S150). The read data is provided in alignment with the DQS signal.
Referring to
However, the dummy DQS may be severely distorted, as shown in
Referring to
The memory device 1100 may add a specific pattern in front of valid data, as shown in
According to the method illustrated in
The memory controller 1200 receives specific patterns from the memory device 1100 and sequentially stores the received specific patterns in the latch circuits LAT1 to LAT8 of the FIFO circuit 1220 (S210). The specific patterns PTTN stored in the FIFO circuit 1220 are provided to the pattern control logic 1230.
The pattern control logic 1230 performs a pattern detection operation and inspects whether the input specific patterns PTTN match a previously established known-pattern (S220). The pattern control logic 1230 may determine whether the specific patterns PTTN match, based on pattern information INFO input from the internal control logic 1210. The pattern information INFO may include a block address, a page address, a column address, a seed, and the like.
The pattern control logic 1230 may provide a matching signal when all the specific patterns SP1 to SP6 match. Alternatively, the pattern control logic 1230 may provide the matching signal to the internal control logic 1210 even when only some of the specific patterns SP1 to SP6 (e.g., SP5 and SP6) match. That is, the pattern control logic 1230 may provide the matching signal to the internal control logic 1210 when the fifth and sixth specific patterns SP5 and SP6 match although the first specific pattern SP1 mismatches.
The internal control logic 1210 processes data DATA read from the memory device 1100 as valid data when a specific pattern matches (S230). The pattern control logic 1230 of the memory controller 1200 may detect the specific patterns SP1 to SP6 during a dummy DQS cycle and provide a matching signal MATCH to the internal control logic 1210. The internal control logic 1210 may recognize data D1 input following the specific patterns SP1 to SP6 as valid data when the specific pattern matches. Thus, the memory controller 1200 may accurately read valid data irrespective of the distortion of a dummy DQS signal.
The internal control logic 1210 changes operation conditions and performs a random-out operation when the specific pattern does not match (S240). The internal control logic 1210 does not perform an ECC decoding operation but provides a column address to the memory device 1100 to re-perform a read operation. When performing the random-out operation, the internal control logic 1210 may change various operation conditions. Embodiments of changing operation conditions will be described in detail with reference to
Even when a specific pattern mismatches, the storage device 1000 may decrease the I/O speed and re-perform a random-out operation, as shown in
However, there may parasitic resistance Rp or parasitic capacitance at a signal line between the memory controller 1200 and the memory device 1100. In addition, a fabrication process problem or defect may occur at the pad 1130 of the memory device 1100. In this case, the reference voltage Vref provided to the memory device 1100 from the memory controller 1200 may drop. Referring to the example in
When the reference voltage Vref decreases due to parasitic resistance or the like, a specific pattern may mismatch. When the specific pattern mismatches, the storage device 1000 may increase a reference voltage and re-perform a random-out operation, as shown in
As described above, the storage device 1000 may perform a random-out operation after decreasing I/O speed, increasing a reference voltage Vref or adjusting a DQS latency cycle. Alternatively, when the specific pattern mismatch is not resolved, the storage device 1000 may re-perform the random-out operation after resetting the memory device 1100.
A pattern control logic 2230 of the memory controller 2200 may receive a start signal START from an internal control logic 2210 and generate a specific pattern. The internal control logic 2210 may provide information INFO for the specific pattern, e.g., a block address, a page address, a column address or a seed value. The pattern control logic 2230 may provide an end signal END to the internal control logic 2210 when all specific patterns are generated.
A specific pattern PTTN generated at a pattern control logic 2230 and data DATA output from the internal control logic 2210 may be sequentially stored in latch circuits LAT1 to LAT8 of a first-in-first-out (FIFO) circuit 2220. The specific pattern and the data stored in the FIFO circuit 2220 are provided to the memory device 2100 in alignment with a DQS signal.
A data input/output (I/O) circuit 2120 of the memory device 2100 may receive the specific pattern and the data through the data output signals DQ1 to DQ8. A pattern control logic 2121 of the data I/O circuit 2120 may perform a pattern detection operation. When the specific pattern matches, the data DATA input from the memory controller 2200 may be processed as valid data and stored in the memory cell array 2110.
When the specific pattern mismatches, the pattern control logic 2121 may process a program state as a program failure and provide a pattern mismatch result to the memory controller 2200 through a status bit. The memory controller 2200 may receive the program failure result and re-perform a write operation. When re-performing the write operation, the memory controller 2200 may change various operation conditions.
For example, the memory controller 2200 may re-perform a write operation after decreasing I/O speed. Alternatively, the storage device 2000 may re-perform a write operation after adjusting a reference voltage Vref provided to the memory device 2100 from the memory controller 2200 or after adjusting a DQS latency cycle. Alternatively, the memory controller 2200 may re-perform a write operation after resetting the memory device 2100. An example of changing conditions of a write operation by the memory controller 2200 will be fully understood with reference to the above-described read operation.
A storage device according to example embodiments of the disclosure may use a cyclic redundancy check (CRC) or a gray code to enhance reliability of a specific pattern.
A storage device according to example embodiments of the disclosure may be applied to various products. The storage device according to example embodiments of the disclosure may be implemented not only with electronic devices such as a personal computer, a digital computer, a camcorder, a handheld phone, an MP3 player, a PMP, a PSP, and a PDA but also with a memory card, a USB memory, a solid state drive (SSD), and the like.
The host 3100 may write data into the memory card 3200 or may read data stored in the memory card 3200. The host controller 3110 may transmit a command CMD (e.g., write command), a clock signal CLK generated by a clock generator (not shown) in the host 3100, and data DAT through the host connection unit 3120.
The card controller 3220 may store data in the flash memory 3230 in synchronization with a clock signal generated by a clock generator (not shown) in the card controller 3220 in response to a write command received through the card connection unit 3210. The flash memory 3230 may store data transmitted from the host 3100. For example, when the host 3100 is a digital camera, the flash memory 3230 may store image data
The host 4100 may include an application 4110, an operating system (OS) 4120, a processor 4130, a random access memory (RAM) 4140, and an eMMC driver 4150. The eMMC 4200 may include a flash memory 4210 and an eMMC controller 4220. The eMMC controller 4220 may include a central processing unit (CPU) and a random access memory (RAM). The CPU 4221 may drive eMMC firmware 4223 using the RAM 4222.
As illustrated in
The controller 5200 may be connected to the host and the nonvolatile memory device 5100. The controller 5200 may be configured to access the nonvolatile memory device 5100 in response to a request from the host. For example, the controller 5200 may be configured to control read, write, erase, and background operations of the nonvolatile memory device 5100. The controller 5200 may be configured to provide an interface between the memory device 5100 and the host. The controller 5200 may be configured to drive firmware for controlling the nonvolatile memory device 5100.
As illustrated in
As illustrated in
The storage device 6000 may be electrically connected to the CPU 7100, the RAM 7200, the user interface 7300, and the power supply 7400 through a system bus 7500. Data provided through the user interface 7300 or data processed by the CPU 7100 may be stored in the storage device 6000.
As shown in
As described above, a storage device according to example embodiments of the disclosure adds a specific pattern to a dummy DQS cycle and processes data input following the dummy DQS cycle as valid data. Thus, valid data may be prevented from being mistakenly processed as dummy data or invalid data.
The above-disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other features, which fall within the true spirit and scope of the disclosure. Thus, to the maximum extent allowed by law, the scope of the disclosure is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description. While some example embodiments have been particularly shown and described, it will be understood by one of ordinary skill in the art that variations in form and detail may be made therein without departing from the spirit and scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2015-0022302 | Feb 2015 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
6003118 | Chen | Dec 1999 | A |
6323705 | Shieh et al. | Nov 2001 | B1 |
6584021 | Heyne et al. | Jun 2003 | B2 |
6731163 | Huckins et al. | May 2004 | B2 |
6895522 | Johnson et al. | May 2005 | B2 |
7028208 | Johnson et al. | Apr 2006 | B2 |
7321525 | Matsui | Jan 2008 | B2 |
7372745 | Kitamura | May 2008 | B2 |
7405984 | Hughes | Jul 2008 | B2 |
7679133 | Son et al. | Mar 2010 | B2 |
7719904 | Lee | May 2010 | B2 |
7755955 | Seo | Jul 2010 | B2 |
7778094 | Park et al. | Aug 2010 | B2 |
7889581 | Wakasa | Feb 2011 | B2 |
7999589 | Lin | Aug 2011 | B2 |
8018260 | Papageorgiou et al. | Sep 2011 | B2 |
8553466 | Han et al. | Oct 2013 | B2 |
8559235 | Yoon et al. | Oct 2013 | B2 |
8654587 | Yoon et al. | Feb 2014 | B2 |
20040034736 | Horn | Feb 2004 | A1 |
20100039875 | Stott | Feb 2010 | A1 |
20110233648 | Seol et al. | Sep 2011 | A1 |
20130064025 | Chen | Mar 2013 | A1 |
20130262907 | Zitlaw | Oct 2013 | A1 |
20140269119 | Na | Sep 2014 | A1 |
20140281193 | Schaefer | Sep 2014 | A1 |
Number | Date | Country |
---|---|---|
2007-226308 | Sep 2007 | JP |
2011-141781 | Jul 2011 | JP |
2012-088852 | May 2012 | JP |
10-2010-0031373 | Mar 2010 | KR |
10-2011-0138209 | Dec 2011 | KR |
Number | Date | Country | |
---|---|---|---|
20160239220 A1 | Aug 2016 | US |