The present invention relates to a flash memory device and more particularly to a method for storing data used in an initial power up.
As the demand for mobile devices such as a camcorder, a digital camera, a portable phone, an MP3 (MPEG-1 Layer3) player, etc. increases, efforts also increase to enhance the flash memory device.
A NAND flash memory device employed in the mobile device operates in accordance with an application program, wherein option of the NAND flash memory device is determined in accordance with the operation characteristics of the mobile device.
The applications requiring the mobile device has increased accordingly as new techniques are developed. Hence, a method for providing flexible options to the NAND flash memory device has been required.
In
The memory cell array 110 includes the memory cells.
The surrounding circuit 120 is connected to the memory cell array 110 and includes a page buffer for programming data in the memory cells or reading data from the memory cells.
The controller 130 outputs a control signal for controlling operation of the surrounding circuit 120.
The fuse circuit 150 has a plurality of sub-fuse circuits for storing data, and generates administrative information for controlling operation of the flash memory device 100 by combining information stored in the sub-fuse circuits. Here, the administrative information includes voltage setting information, etc. for operating optimally the flash memory device 100 in accordance with a system used in the flash memory device 100. The administrative information is stored in the initial data latching circuit 140 when the flash memory device 100 is operated at the initial power up so that the controller 130 uses the administrative information.
However, the sub-fuse circuits occupy much space compared to a transistor, thereby affecting the size of a memory chip which has become highly integrated. In addition, if the sub-fuse circuit is cut, the sub-fuse circuit may not be connected again. As a result, yield may be lowered due to a cutting error.
It is a feature of the present invention to provide a flash memory device and a method of operating the same for reducing space which a sub-fuse circuit occupies, storing administrative information in a memory cell array and using the administrative information.
A flash memory device according to one example embodiment of the present invention includes a memory cell array configured to have memory cells for storing data, and store initial data in a part of the memory cells; a page buffer circuit configured to have page buffers for providing data to be programmed in the memory cell or reading data from the memory cell; a controller configured to control the page buffer circuit so that the initial data stored in the memory cell array are read when operation of the flash memory device is started, discriminate error of the read initial data, and amend the error of the initial data; and an initial data latching circuit configured to latch the initial data of which the error is amended by the controller.
The flash memory device further includes an X decoder configured to select a word line of the memory cell array in accordance with an address inputted through an input/output controller; and an Y decoder coupled to the page buffers, configured to transmit data to be programmed to the page buffer by coupled to a data input/output line, or output read data transmitted from the page buffer to the data input/output line.
The controller includes a data evaluating circuit configured to discriminate whether or not error is occurred to the initial data read by the page buffer circuit, and transmit data to which error is not occurred to the initial data latching circuit; and a storing means configured to store address information of the memory cell array in which the initial data are stored.
The memory cell array has an initial data storing circuit for storing the initial data in accordance with an address set by the controller.
The initial data storing circuit includes a first data means configured to store the initial data to be stored in the initial data latching circuit; and a second data means configured to store data having logic level opposed to the data in the first data means.
The data evaluating circuit includes a control signal outputting means configured to compare the data of the first data means with the data of the second data means and output a control signal in accordance with the comparing result; and a data transmitting circuit configured to transmit the data of the first data means to the initial data latching circuit in accordance with the outputted control signal.
The control signal outputting means is a logic combination device for performing logic combination of the data of the first data means and the data of the second data means, and outputting result of the logic combination.
The control signal outputting circuit outputs the control signal for controlling the data transmitting circuit so that first data are transmitted to the initial data latching circuit in case that the data of the second data means has logic level opposed to the data of the first data means.
The initial data storing circuit includes a third data means configured to store the initial data stored in the initial data latching circuit; and a fourth data means configured to store error verifying data for controlling error of the initial data stored in the third data means.
The fourth data means stores the error verifying data, wherein logic level of the error verifying data in case that number of ‘1’ data in the third data means is even number is different from that of the error verifying data in case that number of ‘1’ data in the third data means is odd number.
The data evaluating circuit controls the page buffer circuit so that the initial data are again read in case that error is occurred to the read data.
A method of operating a flash memory device according to one example embodiment of the present invention includes performing a power on reset operation in accordance with input of a power; reading initial data in accordance with address information of a predetermined memory cell; and storing temporarily the read initial data, and controlling operation of the flash memory device in accordance with the stored initial data.
The method further includes discriminating whether or not error is occurred to the read initial data; and amending the error of the initial data in case that it is discriminated that the error is occurred to the read initial data.
The step of amending the error includes reading again data of the memory cell for storing data to which error is occurred.
The method further includes changing the initial data by storing data outputted from an outside device in accordance with address information related to the initial data.
As described above, embodiments of the present invention relate to storing administrative information in a memory cell array, thereby reducing space occupied by a sub-fuse circuit.
Hereinafter, the embodiments of the present invention will be explained in more detail with reference to the accompanying drawings.
In
The memory cell array 210 has the memory cells coupled to the bit lines and the word lines, and an initial data storing circuit 211 using memory cells corresponding to addresses assigned by the controller 270.
The memory cells of the initial data storing circuit 211 store administrative information for initial operation of the flash memory device 200, and stores data through various methods to control errors in the stored initial data.
The page buffer circuit 220 has the page buffers coupled to a pair of bit lines.
The page buffers have latch circuits for temporarily storing data to be programmed to a memory cell and providing the stored data, and for temporarily storing data read from a memory cell.
The page buffers read data from the memory cell, and provide the read data to an outside device (not shown) through an input/output path provided by the Y decoder 230 and the input/output controller 280. In addition, the page buffers transmit read data to the controller 270 when data related to initialization are read.
The Y decoder 230 provides a path between the page buffers of the page buffer circuit 220 and the input/output controller 280 in accordance with an input address.
The X decoder 240 selects a word line of the memory cell array 210 in accordance with the input address.
The initial data latching circuit 250 receives the initial data read from the initial data storing circuit 211 through the controller 270, and temporarily stores the received data.
The high voltage supplying circuit 260 generates a voltage for a program operation or a read operation in accordance with the controller 270, and outputs the generated voltage.
The controller 270 has a data evaluating circuit 271 for controlling operation of the flash memory device 200, determining whether or not an error has occurred to the initial data provided from the page buffer circuit 220, and transmitting initial data (to which error has not occurred) to the initial data latching circuit 250. Additionally, the controller 270 has a storing circuit 272 for storing an algorithm for controlling operation of the flash memory device 200. The storing circuit contains the address of the memory cells in the memory cell array 210 which store the initial data.
The data evaluating circuit 271 detects an error in accordance with the initial data stored in the initial data storing circuit 211, and transmits only data to which an error has not occurred to the initial data latching circuit 250. Here, determination of an error occurrence is different in accordance with the data stored in the initial data storing circuit 211.
The data are stored in the initial data storing circuit 211 so that an error occurring when the data are read is easily detected and amended.
An operation of latching the initial data stored in the initial data storing circuit 211 to the initial data latching circuit 250 when the flash memory device 200 operates at the initial time after power on will be described in detail.
In
In step S330, each of function blocks in the flash memory device 200 performs an initial operation in accordance with the transmitted power on reset signal. Here, the initial operation is controlled by the controller 270, and sets the condition of the circuits to predetermined conditions. That is, the initial operation means (or unit) a minimal setting for normal operation of the flash memory device 200.
In the case that the initialization is finished, the controller 270 latches initial data as administrative information for controlling to operate normally the flash memory device 200 to the initial data latching circuit 250. To perform the above process, the controller 270 transmits a read busy R/B signal in step S340.
In step S350, the controller 270 controls the page buffer circuit 220 so that the initial data stored in the initial data storing circuit 211 are read under the condition that the R/B signal is transmitted, amends the error of the read data, and latches the amended initial data to the initial data latching circuit 250. To perform the above process, the controller 270 should know in advance the address of the initial data storing circuit 211 in which the initial data are stored.
In step S360, in the case that the initial data are latched in the initial data latching circuit 250, the controller 270 releases the R/B signal so that other operations may be performed.
Hereinafter, the step S350 will be described in detail.
In
In step S352, the page buffer circuit 220 reads the data.
Address information of the initial data storing circuit 211 is stored in the storing circuit 272 of the controller 270.
In step S353, the X decoder 240 selects a word line of the initial data storing circuit 211 in accordance with the set of the address, and the page buffer circuit 220 reads data by selecting a column address. Then, the page buffer circuit 220 outputs the read data to the controller 270.
The controller 270 verifies errors in the initial data transmitted from the page buffer circuit 220, and transmits the initial data (to which an error has not occurred) to the initial data latching circuit 250.
The initial data latching circuit 250 latches and stores the initial data transmitted from the data evaluating circuit 271 of the controller 270.
In steps S354 and S356, the process of reading the initial data are repeated with increasing column address related to the address set to the initial data storing circuit 211.
In step S360, if the read of the initial data related to every address is finished, the R/B signal is released.
A method of detecting an error in the initial data and amending the error varies in accordance with the initial data stored in the initial data storing circuit 211.
The initial data of the present embodiment are inverted before they are stored. That is, a first data group 410 and a second data group 420 (inverted) store data as shown in
For example, the initial data are stored in the first data group 410 as first data to fourth data D0 to D3. Inverted data of the first to fourth data D0 to D3 are stored in the second data group 420 as fifth data to eighth data D4 to D7.
The data of the first data group 410 and the second data group 420 are read, and then an error from the read data is verified. Then, the data are transmitted to the initial data latching circuit 250.
The initial data latching circuit 250 has a first latch circuit 251 to an eighth latch circuit 258. Here, the data outputted from the data evaluating circuit 271 are stored in sequence in the first latch circuit 251 to the eighth latch circuit 258.
First data shown in
The data evaluating circuit 271 compares the data read from the first data group 410 with the data read from the second data group 420. In the case that the logic level of the data read from the first data group 410 is an inverse of the data read from the second data group 420, it is determined that the data are normally read. However, in case that logic level of the data read from the first data group 410 is identical to that of the data read from the second data group 420, it is determined that an error has occurred in the read operation. In this case, the data are not transmitted to the initial data latching circuit 250.
In the case that it is determined that an error has occurred, the read operation is performed again.
Hereinafter, the data evaluating circuit 271 for verifying the error will be described.
In
The data transmitting circuit 273 receives in sequence the initial data of the first data group 410, and transmits the received initial data to the initial data latching circuit 250 when the control signal having a high level is inputted.
The exclusive OR gate XOR is a logic gate for outputting a signal having a high level only when the received data have logic levels that are opposite to each other. Accordingly, the data transmitting circuit 273 transmits the received initial data to the initial data latching circuit 250 only when the data of the first data group 410 has a logic level opposite to the data of the second data group 420.
As described above, the data transmitting circuit 273 does not transmit the initial data to the initial data latching circuit 250 only when the data of the first data group 410 has the same logic level as the data of the second data group 420 accordingly as an error has occurred in the read operation. Additionally, the controller 270 determines that an error has occurred in the read operation, and controls the page buffer circuit 220 to reread the initial data.
Hereinafter, a method of storing the initial data, determining an error and amending the error (except the above method of discriminating the error by comparing the data of the first data group 410 with the data of the second data group 420) will be described.
In
As shown in
The data evaluating circuit 271 classifies the initial data outputted from the page buffer circuit 220 as shown in
To change the initial data stored in the initial data storing circuit 211, data to be changed are inputted through the input/output controller 280. Then, the controller 270 performs a program operation of data by setting address of the initial data storing circuit 211, and so the initial data may be changed.
In one example embodiment of the present invention, the initial data storing circuit 211 may be included in an extra storing array and not the memory cell array 210.
In brief, since a part of the memory cell array 210 is assigned for storing the initial data, fuse circuits occupying much space are not needed. As a result, layout area of the flash memory device 200 may be reduced.
Any reference in this specification to “one embodiment,” “an embodiment,” “example embodiment,” etc., means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of such phrases in various places in the specification are not necessarily all referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with any embodiment, it is submitted that it is within the purview of one skilled in the art to affect such feature, structure, or characteristic in connection with other ones of the embodiments.
Although embodiments have been described with reference to a number of illustrative embodiments thereof, it should be understood that numerous other modifications and embodiments can be devised by those skilled in the art that will fall within the spirit and scope of the principles of this disclosure. More particularly, various variations and modifications are possible in the component parts and/or arrangements of the subject combination arrangement within the scope of the disclosure, the drawings and the appended claims. In addition to variations and modifications in the component parts and/or arrangements, alternative uses will also be apparent to those skilled in the art.
Number | Date | Country | Kind |
---|---|---|---|
2007-79480 | Aug 2007 | KR | national |
This application is a divisional of U.S. patent application Ser. No. 11/962,054 filed on Dec. 20, 2007, now U.S. Pat. No. 7,684,242 which claims priority from Korean Patent Application No. 2007-79480 filed on Aug. 8, 2007, the contents of which are incorporated herein by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
5961611 | Oh | Oct 1999 | A |
6751122 | Kawai et al. | Jun 2004 | B2 |
6898119 | Imamiya et al. | May 2005 | B2 |
6930954 | Imamiya et al. | Aug 2005 | B2 |
7061799 | Kawai et al. | Jun 2006 | B2 |
7196950 | Kanda et al. | Mar 2007 | B2 |
7254060 | Kawai et al. | Aug 2007 | B2 |
7355916 | Bauser | Apr 2008 | B2 |
7362644 | Yang et al. | Apr 2008 | B2 |
7388782 | Tokiwa | Jun 2008 | B2 |
7415568 | Kawabata et al. | Aug 2008 | B2 |
7486559 | Morooka et al. | Feb 2009 | B2 |
7551488 | Tanikawa et al. | Jun 2009 | B2 |
7617351 | Min et al. | Nov 2009 | B2 |
7660155 | Byeon | Feb 2010 | B2 |
7684242 | Cha et al. | Mar 2010 | B2 |
7965557 | Kang | Jun 2011 | B2 |
20040085814 | Kawai et al. | May 2004 | A1 |
Number | Date | Country |
---|---|---|
1700356 | Nov 2005 | CN |
55-090000 | Jul 1980 | JP |
57-127997 | Aug 1982 | JP |
59-058698 | Apr 1984 | JP |
61-052758 | Mar 1986 | JP |
62-140152 | Jun 1987 | JP |
02-291095 | Nov 1990 | JP |
07-064454 | Mar 1995 | JP |
10-144093 | May 1998 | JP |
2003-085994 | Mar 2003 | JP |
2004-311010 | Nov 2004 | JP |
2006-185535 | Jul 2006 | JP |
2007-035245 | Feb 2007 | JP |
1020050059984 | Jun 2005 | KR |
WO 03073430 | Sep 2003 | WO |
Number | Date | Country | |
---|---|---|---|
20100177565 A1 | Jul 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11962054 | Dec 2007 | US |
Child | 12729190 | US |