1. Field of the Invention
The present invention relates to a storing apparatus, and more particularly to a storing apparatus equipped with a flash memory.
2. Description of the Related Art
In recent years, a semiconductor storing apparatus having a large storage capacity, such as a flash memory, has been used in various devices in order to store data.
A flash memory performs the writing and the reading of data on a unit basis of what is called a block, and may happen to include a defective block to which data writing cannot effected normally owing to the manufacturing process of the memory or a subsequently happened cause. Accordingly, the flash memory is arranged to have a portion of a storage area thereof as a substitute block for such a defective block so that the data to be written into the defective block is written instead into the substitute block. Moreover, the technique of informing a user of a warning when the remaining amount of substitute blocks becomes smaller than a set value was also proposed (see, for example, Japanese Patent Application Laid-Open Publication No. 2003-085054).
A detachable storing apparatus, such as a memory card, equipped with a flash memory is used to be mounted on various host devices. A host device has its specific type of data to be treated, size of data to be written, data rate, and the like, which are different from those of other host devices, respectively. Even if the lowering of the remaining amount of substitute blocks is, consequently, warned in the conventional manner, it may happen depending on the host device that the remaining amount of the substitute blocks is really not enough for the capacity to be secured at the time of writing data to cause a writing error.
For example, in the case of a host device in which the amount of data to be written at one time is large, the probability of using many substitute blocks at one time of writing is higher than that of a device in which the amount of data to be written at one time is small.
A scope of the invention is to solve the problem like this and provide an apparatus capable of suitably informing a user of the state of the remaining amount of substitute blocks in accordance with a host device.
A storing apparatus of the present invention comprises: a communication unit configured to communicate with an external device; a register arranged to store information temporarily; a memory having a plurality of blocks including substitute blocks for defective blocks; and a control unit configured to control writing data into the memory, and to communicate a notice to the external device with the communication unit if a remaining amount of the substitute blocks becomes equal to or less than a threshold value specified by threshold value information stored in the register, wherein the control unit reads out threshold value information from the memory to store the read-out threshold value information into the register, and changes the threshold value information stored in the register by using threshold value information received from the external device with the communication unit.
Further features of the present invention will become apparent from the following description of exemplary embodiments with reference to the attached drawings.
Exemplary embodiments of the present invention will now be described in detail in accordance with the accompanying drawings.
In the storing apparatus 100, a host interface (I/F) 101 communicates commands and data between the host device 200 and the storing apparatus 100. In the present embodiment, the host I/F 102 communicates with the host device 200 in conformity with the specifications of Advanced Technology Attachment (ATA). A controller 102 includes a central processing unit (CPU) to control the operation of the storing apparatus 100 in accordance with a command received from the host device 200. A ROM 103 is a read-only memory, and stores a control program to be executed by the controller 102. The data stored in the ROM 103 cannot be rewritten by the host device 200. An internal register 104 temporarily stores the register information defined by a standard under the control of the controller 102. The controller 102 refers to the register information stored in the internal register 104 as the occasion demands to rewrite the resister information. The controller 102 moreover includes a flash memory interface (not illustrated) for transmitting and receiving data to and from a flash memory 105. The flash memory 105 is composed of a publicly known flash memory chip, and writes and reads out data under the control of the controller 102.
At the time of mount processing of the storing apparatus 100, the controller 102 reads out these pieces of management information from the management information area 105a to store the read-out management information into the internal register 104 as register information. Moreover, the controller 102 updates the management information stored in the internal register 104 at the time of the writing or the reading-out of data by the host device 200. The controller 102 further copies the updated management information stored in the internal register 104 into the management information area 105a at suitable timing to backup the information. As described later, the controller 102 does, however, not copy the threshold value information stored in the internal register 104 into the management information area 105a. The timing of copying is, for example, every time for a regular interval or the time of a disconnection of the communication between the storing apparatus 100 and the host device 200.
The user area 105b is an area for storing the data transmitted from the host device 200. The substitute area 105c is assigned as an area in which the data to be recorded in a defective block is written when the defective block has been produced in the user area 105b.
A writing process of data in the storing apparatus 100 will next be described.
When the host I/F 101 receives a data writing command and the data from the host device 200, the controller 102 starts the flow. The controller 102, first, confirms the received writing address (S201). The controller 102 then writes the received data into the designated address of the flash memory 105 (S202). The controller 102 next checks whether any writing errors of the written data have occurred or not (S203). A publicly known method can be used for the checking process of the writing errors.
If a writing error has occurred, the controller 102 executes substitution process (S204). Moreover, if no writing errors have occurred and the data writing has normally been completed, the controller 102 waits the next command. The controller 102 assigns an address of the flash memory 105 (physical address) to an address (logical address) instructed from the external device, and produces a conversion table showing the correspondences between each logical address and each physical address. Then, when a defective block occurs, the controller 102 changes the conversion table in order that the physical address of a substitute block may be assigned to the designated logical address. The controller 102 saves the changed conversion table into the management information area 105a.
The controller 102 checks whether the substitute blocks have enough capacity to write the data thereinto or not in a case in which the result of the detection of the remaining amount of the substitute blocks shows that the remaining amount of the substitute blocks exists (not zero) (S302). If the remaining amount of substitute blocks does not exist, the controller 102 transmits a report indicating the writing error to the host device 200 through the host I/F 101 (S307).
On the other hand, if the remaining amount of substitute blocks exists to be enough to write the data, the controller 102 writes the data into any one of the remaining substitute blocks (S303). Then, the controller 102 updates the content of the remaining amount information of the substitute blocks which information is stored in the internal register 104 in order to decrease the remaining amount by the number of used substitute blocks (S304). The controller 102 next compares the remaining amount of the substitute blocks after the update and a threshold value to check whether the remaining amount of the substitute blocks is larger than the threshold value or not (S305). The threshold value will be described later. The internal register 104 is a volatile memory in order to store data temporarily. When the information of the internal register 104 changes, the controller 102 performs the backup of the information into the management information area 105a of the flash memory 105.
If the remaining amount of the substitute blocks is larger than the threshold value, the controller 102 terminates the process as it is. On the other hand, if the remaining amount of the substitute blocks is equal to or less than the threshold value, the controller 102 transmits warning information indicating that the remaining amount of the substitute blocks is small to the host device 200 through the host I/F 101 (alarming unit) (S306).
The processing of the threshold value information of a remaining amount of substitute blocks in the storing apparatus 100 will, next, be described. In the storing apparatus 100, when the storing apparatus 100 is mounted on the host device 200, or when the storing apparatus 100 performs mount process at the time of the power activation thereof, the storing apparatus 100 reads out the threshold value information stored in the management information area 105a of the flash memory 105 beforehand to store the read-out threshold value information into the internal register 104. Furthermore, if the storing apparatus 100 receives a rewrite request of the threshold value information from the host device 200, the storing apparatus 100 rewrites the threshold value information stored in the internal register 104 by using the threshold value information transmitted from the host device 200.
In the mount process, the controller 102 reads out threshold value information of substitute blocks from the management information area 105a of the flash memory 105 (S401). The controller 102 then stores the read-out threshold value information into the internal register 104 (S402). At this time, the controller 102 stores the threshold value information into the vender unique area of the internal register 104. Moreover, a previously determined value in consideration of the characteristics and the like of the storing apparatus 100 is set the threshold value designated by the threshold value information.
In
The controller 102 next compares the changed threshold value with the remaining amount of the substitute blocks to check whether the remaining amount of the substitute blocks is larger than the threshold value or not (S405). If the remaining amount of the substitute blocks is larger than the threshold value, the controller 102 terminates the process as it is. On the other hand, if the remaining amount of the substitute blocks is equal to or less than the threshold value, the controller 102 transmits warning information indicating that the remaining amount of the substitute blocks is small to the host device 200 through the host I/F 101 (S406).
On and after this step, the threshold value to be compared in the processing at the step S305 will be the threshold value designated by the threshold value information changed by the host device 200. Consequently, it is possible to set the threshold value suitable for the size of data written by the host device 200 and the type of the data.
The threshold value information set by the host device 200 in such a way is not copied into the management information area 105a by the controller 102. Consequently, if the storing apparatus 100 having the threshold value information set by the host device 200 is ejected by the host device 200 and is mounted on another host device, then the storing apparatus 100 again reads out threshold value information from the management information area 105a of the flash memory 105 to store the read-out threshold value into the internal register 104. That is, the storing apparatus 100 reads out the threshold value information from the management information area 105a to store the read-out threshold value information into the internal register 104 as the initial value of the threshold value at every mount process of the storing apparatus 100. There will consequently be no chances of comparing a threshold value set by another host device with a remaining amount of substitute blocks.
Incidentally, although a piece of threshold value information is stored in the management information area 105a in the present embodiment, the present embodiment may also be arranged to prepare a plurality of pieces of threshold value information indicating values different from one another and to automatically change the threshold value to be set according to the size of data to be written at one time by the host device 200.
For example, two pieces of threshold value information indicating a threshold value 1 and a threshold value 2 (threshold value 1>threshold value 2), respectively, are arranged to be stored in the management information area 105a. Then, if the size of the data to be written in conformity with a data writing command from the host device 200 is larger than a predetermined size, the threshold value 1 is written into the internal register 104; otherwise the threshold value 2 is stored in the internal register 104.
Moreover, the plurality of pieces of threshold value information may also be selected according to the type of data to be written by the host device 200. The storing apparatus 100 may also be configured as follows: for example, if the data to be written is image data of a moving image, a still image, or the like, then the controller 102 selects the threshold value 1; if the data is document data, then the controller 102 selects the threshold value 2. Moreover, three or more pieces of threshold value information may be prepared.
Moreover, the storing apparatus 100 may also be arranged as follows: zero is set as the threshold value information stored in the management information area 105a, and then zero is stored in the internal register 104 as the initial value of the threshold value at the time of mount process. This case results in transmitting no warnings to the host device 200 until the remaining amount of substitute blocks becomes zero. Because some host devices need no warnings, the storing apparatus 100 configured as described above may avoid transmitting warnings hollowly to such host devices.
As described above, the present embodiment rewrites the threshold value information stored in the internal register 104 by using the threshold value information transmitted from the host device 200 at the time of mount processing. The threshold value of the remaining amount of substitute blocks suitable for the host device 200 can consequently be set.
Moreover, because the present embodiment reads out threshold value information from the management information area 105a to store the read-out threshold value information into the internal register 104 at every mount process, the present embodiment may avoid also comparing the threshold value set by the host device 200 beforehand with the remaining amount of substitute blocks.
A second embodiment will, next, be described.
The present embodiment is arranged to store threshold value information into the ROM 103 beforehand in addition to the control program of the controller 102. The threshold value information is then read-out from the ROM 103, and the threshold value information stored in the management information area 105a is updated at the time of the mount process of the storing apparatus 100 of the present embodiment. After that, if the storing apparatus 100 receives a change request of the threshold value information from the host device 200, the storing apparatus 100 changes the threshold value information stored in the management information area 105a by using the threshold value information transmitted from the host device 200. At the time of the substitution process illustrated in
As described above, in the present embodiment, threshold value information is read-out from the ROM 103 and the threshold value information stored in the management information area 105a of the flash memory 105 is updated at the time of mount process. So, the threshold value information stored in the management information area 105a of the flash memory is reset to the threshold value information stored in the ROM 103 every time the mount process is executed. Then, the threshold value information stored in the management information area 105a is changed by the host device 200, and thereby the threshold value of the remaining amount of substitute blocks suitable for the host device 200 can be set.
In the second embodiment, threshold value information is read out from the ROM 103 at the time of mount processing of the storing apparatus 100 to update the threshold value information stored in the management information area 105a. On the other hand, in the present embodiment, threshold value information is read out from the ROM 103 at the time of unmount process of the storing apparatus 100 to update the threshold value information stored in the management information area 105a Incidentally, the system configuration of the present embodiment is the same as that of the second embodiment, and the description thereof is accordingly omitted here. Moreover, the unmount process is the process for disconnecting the communication with the host device 200 when the power source of the host device 200 is turned off or when the storing apparatus 100 is ejected from the host device 200.
Incidentally, also in the present embodiment, if the storing apparatus 100 receives a request of changing the threshold value information from the host device 200 while the system is operating, the storing apparatus 100 changes the threshold value information stored in the management information area 105a at the time of unmount process. Then, in the substitution process illustrated in
As described above, in the present embodiment, threshold value information is read out from the ROM 103 at the time of unmount process to update the threshold value information stored in the management information area 105a of the flash memory 105. Consequently, even if the threshold value information stored in the management information area 105a is erased or changed by mistake by the host device 200, the threshold value information stored in the management information area 105a can be initialize by the threshold value information stored in the ROM 103.
Moreover, the second and the third embodiments may also be arranged to store a plurality of pieces of threshold value information into the ROM 103, select and read out any one piece of the plurality of pieces of threshold value information, and store the read-out piece of threshold value information into the management information area 105a similarly to the first embodiment.
Moreover, the process of the embodiments described above may also be carried out by the program codes of software realizing the respective functions, which software is recorded on a storing medium provided to the system or the apparatus. The computer (or the CPU or the microprocessor unit (MPU)) of the system or the apparatus then reads out and executes the program codes stored in the storing medium, and thereby the functions of the embodiments described above can be realized. In this case, the program codes read-out from the storing medium themselves result in realizing the functions of the embodiments described above, and the storing medium storing the program codes constitutes the present invention. As the storing medium for supplying such program codes, for example, a floppy (registered trademark) disk, a hard disk, an optical disk, or a magneto-optical disk can be used. Alternatively, a compact disc read-only memory (CD-ROM), a compact disc-recordable (CD-R), magnetic tape, a nonvolatile memory card, a ROM, or the like can also be used.
The present invention has hereinbefore been described in detail on the basis of its preferable embodiments, but the present invention is not limited to those specific embodiments. Various modes without departing from the spirit and scope of the invention are also included in the present invention. Furthermore, each embodiment described above expresses only an embodiment of the present invention, and it is also possible to suitably combine each embodiment.
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2010-077997 filed on Mar. 30, 2010, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2010-077997 | Mar 2010 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5812639 | Bartholomew et al. | Sep 1998 | A |
6411394 | Nakamura et al. | Jun 2002 | B1 |
6629123 | Hunt | Sep 2003 | B1 |
6829190 | Snyder et al. | Dec 2004 | B1 |
7343514 | Yamato et al. | Mar 2008 | B2 |
7813176 | Hunt | Oct 2010 | B2 |
7920200 | Azuma | Apr 2011 | B2 |
7944501 | Suzuki | May 2011 | B2 |
8276018 | Kursun et al. | Sep 2012 | B2 |
8286028 | Matsuda et al. | Oct 2012 | B2 |
20010043761 | Shimizu et al. | Nov 2001 | A1 |
20020040433 | Kondo | Apr 2002 | A1 |
20020101257 | Kawahara et al. | Aug 2002 | A1 |
20030171850 | Kobayashi et al. | Sep 2003 | A1 |
20030179712 | Kobayashi et al. | Sep 2003 | A1 |
20040044649 | Yamato et al. | Mar 2004 | A1 |
20040141204 | Sakai et al. | Jul 2004 | A1 |
20040237103 | Kondo et al. | Nov 2004 | A1 |
20050034041 | Casarsa | Feb 2005 | A1 |
20050134942 | Kondo et al. | Jun 2005 | A1 |
20060002199 | Nakajima et al. | Jan 2006 | A1 |
20060015508 | Kondo et al. | Jan 2006 | A1 |
20060067164 | Takai et al. | Mar 2006 | A1 |
20070146529 | Suzuki | Jun 2007 | A1 |
20070286244 | Koyabu et al. | Dec 2007 | A1 |
20080147961 | Seki et al. | Jun 2008 | A1 |
20080155133 | Honjo et al. | Jun 2008 | A1 |
20080220724 | Roh et al. | Sep 2008 | A1 |
20080263667 | Kondo | Oct 2008 | A1 |
20080320317 | Funahashi et al. | Dec 2008 | A1 |
20090070543 | Oh et al. | Mar 2009 | A1 |
20090111486 | Burstrom | Apr 2009 | A1 |
20090113485 | Inukai | Apr 2009 | A1 |
20090235103 | Yamashiro | Sep 2009 | A1 |
20100023672 | Gorobets et al. | Jan 2010 | A1 |
20100318844 | Matsuda et al. | Dec 2010 | A1 |
20110007901 | Ikeda et al. | Jan 2011 | A1 |
20110019974 | Konoshima | Jan 2011 | A1 |
20110055481 | Murakami | Mar 2011 | A1 |
20110157319 | Mashitani et al. | Jun 2011 | A1 |
20110193861 | Mashitani et al. | Aug 2011 | A1 |
20110238927 | Hatano | Sep 2011 | A1 |
Number | Date | Country |
---|---|---|
2003-085054 | Mar 2003 | JP |
Number | Date | Country | |
---|---|---|---|
20110246841 A1 | Oct 2011 | US |