This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2009-54188, filed on Mar. 6, 2009, the entire contents of which are incorporated herein by reference.
Embodiment(s) discussed herein relate to a device managing apparatus, a device initialization method, and a device system that execute an initialization processing to a device that stores user data.
When a recording medium, such as a magnetic disc, an optical magnetic disk, an optical disc, or the like, is used as a device for storing user data, it is required to preliminarily execute initialization of the recording medium, that is, format before actually writing user data.
Conventionally, it has been impossible to use the device before format of the entire device is completed. Accordingly, there has been a problem in that the length of the time required for completing format is too long. Consequently, a quick format for executing an initialization processing in a background of access to the device has been used.
In the quick format, in order to allow access right after initialization, a progress status of the initialization is managed by using a bitmap or the like. Then, when access to a format uncompleted area is required, the access is processed after the area is preferentially formatted.
Herein, in a device system that has a plurality of device control apparatuses managing access to a device and in which access to the device is duplicated, it is also required to duplicate the management of the progress status of the initialization. Consequently, in a conventional quick format, an update processing of a bitmap is executed and duplication of the bitmap is executed between the device control apparatuses at a timing when initialization of an area equivalent to one bit in a bitmap is completed.
However, when considering the time required for duplication of the format progress status, the time until the format is completed becomes shorter when the number of duplication of the format progress status to be executed is low.
That is, when frequency of the duplication of the progress status is considerably higher than generation frequency of access to the device during format, the time required for the format becomes long by the duplication processing. On the other hand, when frequency of the duplication of the progress status is considerably lower than generation frequency of access to the device during format, a number of accesses are forced to wait, causing lowering of access responsiveness and occurrence of time out. Further, since generation frequency of access is not constant, it has been difficult to obtain the optimum one value as for the timing for executing duplication of the format progress status.
The disclosed technique is made in the light of the aforementioned problems, and the object is to provide to a device control apparatus, a device initialization method, and a device system which make it possible to shorten the time required for format while ensuring access performance to a device.
A device management apparatus that executes an initialization processing to a device that stores user data includes a first initialization processing section for executing a first initialization processing in which a progress status of an initialization is notified to another device management apparatus every time when the initialization equivalent to a processing unit of the initialization processing is executed to the device, a second initialization processing section for executing a second initialization processing in which a progress status of an initialization is notified to the another device management apparatus every time when the initialization for the predetermined number of processing units is executed to the device, a monitoring unit for monitoring a status of access to the device and an operation state of the device, and a changeover section for changing over the first initialization processing and the second initialization processing based on a monitoring result.
The object and advantages of the various embodiments will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the various embodiments, as claimed.
Hereinafter, an embodiment of a device management apparatus, a device initialization method, and a device system disclosed by the invention will be described in detail based on the drawings. The invention is not limited by the embodiment.
The storage system shown in
The controller module 10 and the controller module 11 are respectively connected with a host (not shown). Herewith, access to the storages 21, 22 is duplicated.
The controller module 10 has a main controller 31, a memory 32, a host interface 33, and a device interface 34. The main controller 31 includes an access processing unit 41, a format processing unit 42, a device state monitoring unit 43. Each processing unit of the main controller 31 may be respectively provided by a wired logic, a PLD (Programmable Logic Device), or the like. The main controller 31 may be provided by an operation device such as a CPU (Central Processing Unit) or the like and each processing may be provided by software.
The access processing unit 41 receives an access requirement to the storage from the host via the host interface 33, and processes the access to the storages 21, 22 via the device interface 34.
The format processing unit 42 is a processing unit that executes an initialization processing of the device equipped in the storages 21, 22. The format processing unit 42 includes a format operation changeover section 42a, a normal quick format processing section 42b, and a high speed quick format processing section 42c.
The normal quick format processing section 42b and the high speed quick format processing section 42c respectively execute a quick format to the storages 21, 22. Herein, the quick format is a format system for executing an initialization processing in a background of access to the device. The normal quick format processing section 42b executes a normal quick format in which a progress status of the initialization is notified to the controller module 11 which is another device management apparatus every time when an initialization equivalent to a processing unit of the initialization processing is executed to duplicate the progress status of the initialization. On the other hand, the high quick format processing section 42c executes a high speed quick format in which a progress status of the initialization is notified to the controller module 11 which is another device management apparatus every time when an initialization for predetermined number of processing units of not less than two is executed to duplicate the progress status of the initialization. The format operation changeover section 42a changes over the normal quick format and the high speed quick format based on the monitoring result by the device state monitoring unit 43.
The device state monitoring unit 43 monitors the generation status of access to the storages 21, 22 and the operation state of the storages 21, 22.
The memory 32 is a storage for holding various data used in the controller module 10. The memory 32 includes a cache 32a, an IO processing status management table 32b, a quick format management table 32c, and a quick format bitmap 32d.
The cache 32a is used when the access processing unit 41 processes access to the storages 21, 22. Specifically, the access processing unit 41 holds an address of a writing destination and a content to be written in the storage when a writing request to the storage is received from the host, and returns a writing response to the host. Then, by executing a write back for actually writing the content held in the cache 32a to the storages 21, 22, the writing request from the host is reflected in the storages 21, 22.
The IO processing status management table 32b holds a monitored result of the device state monitoring unit 43. Specifically, The IO processing status management table 32b holds the type, response time, throughput, generation frequency of access, and the like of each device of the storages 21, 22.
The quick format management table 32c holds the information showing that which device is a target of format when the quick format is being executed by the format processing unit 42, a processing unit of the initialization processing, that is, that one bit on the quick format bit map 32d corresponds to how much amount in the device, that each bit of the quick format bitmap 32d corresponds to which address in the device, and the like. Note that, that one bit on the bitmap 32d corresponds to how much capacity on the device can be appropriately set. For example, one megabit in the device corresponds to one bit on the bitmap 32d.
The quick format bitmap 32d holds the progress status of the quick format. One bit on the bitmap is a processing unit of the initialization processing, and that one bit corresponds to how much capacity in the device, and the correspondence relationship between each bit and the real address in the device are regulated in the quick format management table 32c.
The example is illustrated in which the cache 32a, the IO status management table 32b, the quick format management table 32c, and the quick format bitmap 32d are held in the same memory 32. However, a different storage may be provided for every information, or the cache 32a, the IO status management table 32b, the quick format management table 32c, and the quick format bitmap 32d may be decentrally stored in a plurality of storages by any combination.
The controller module 11 has the inner structure similar to the controller module 10. Herein, the example in which there are two controller modules is illustrated. However, there may be not less than three controller modules.
The storage 21 executes a format request, specifically, a writing instruction of initial data in an area in the device corresponding to 1 bit in the bit map, and returns a format response with respect to the format request to the format processing unit 42 after the writing processing in the area in the device corresponding to 1 bit in the bit map is finished.
The format processing unit 42 updates the quick format bitmap 32d in response to the format response. Then, the format processing unit 42 transmits a bitmap update content to the controller module 11. A main controller 51 of the control module 11 reflects the received update content in a quick format bitmap 52d in a self memory 52 to duplicate the bitmap.
In the normal quick format, the normal quick format processing section 42b executes a format request, bitmap update, and bitmap duplication for every one bit of the quick format bitmap 32d.
In the high speed quick format, the high quick format processing section 42c reduces the frequency of bitmap duplication as compared with the normal quick format. That is, the high speed quick format processing section 42c executes bitmap duplication after the format equivalent to plurality of bits is executed. Accordingly, in the high quick format, the progress status of the format is grasped only at the controller module 10 side.
Note that the format request in the high speed format may be executed for every one bit, or for several bits integrally. Further, the quick format bitmap 32d may be used for the management of the local progress status at the controller module 10 side. Further, the management of the local progress status may be held in the quick format management table 32c.
When a wiring request to the device executing the format from the host is generated, the access processing unit 41 holds the content of writing request, that is, an address of a writing destination and a writing content in the cache 32a, and returns a writing response to the host. Next, the access processing unit 41 specifies the bit indicating the corresponding area with reference to the quick format management table 32c based on the writing destination address. Then, the access processing unit 41 judges whether or not format of the writing destination is completed based on the state of the bit corresponding to the writing destination.
As a result, when format of the writing destination is completed, the data in the cache is written in the device without change. When the format of the writing destination is not completed, first, format is executed to the unit area that is managed by the bitmap including the writing destination, and the data in the cache is written in the device.
In this manner, even when format is being executed, the writing request from the host can be processed. However, when judging whether or not format of the address of the writing request destination is completed, it is required that the progress status of the format is duplicated.
Accordingly, when the content in the cache is written in the device, it is necessary to wait for completion of the duplication of the progress status of the format. In the normal quick format, since duplication of the bitmap is executed at a high frequency, the waiting time until write back is executed is short. However, when the generation frequency of write back is low, the time for duplicating the bitmap itself becomes an extra time. In the high speed quick format, since the frequency of duplication of the bitmap is low, the time for the entire format can be shortened. However the wait time until write back is executed becomes long. Further, a number of accesses are forced to wait, causing lowering of access responsiveness and occurrence of time out.
Consequently, the format operation changeover section 42a changes over the normal quick format and the high speed quick format based on the generation status of the access to the storages 21, 22 and the operation state of the storages 21, 22.
Specifically, the format operation changeover section 42a changes over to the high speed quick format when there is no access from the host for a constant period, for example, several seconds to several minutes, during executing the normal quick format.
Then, during when the high speed quick format is executed, the format operation changeover section 42a accumulates the writing request from the host in the cache 32a during a constant period, for example, several seconds to several minutes, and stands by to write back to the device. Further, the format operation change over section 42a can change over to the normal quick format when the write cache reaches a constant ratio of the entire cache 32a.
Further, the format operation changeover section 42a can judge that effect to the host access by the high speed quick format is small when the access amount to the device from the host is not more than a constant value during the normal quick format to change over to the high speed quick format.
Further, the format operation changeover section 42a can continue the high speed quick format when a response time or a throughput of the storage shows a performance of not less than a constant value even when the high speed quick format is being executed, and can change over to the normal quick format when there is a performance deterioration. Specifically, when the interface between the controller module and the storage becomes a bottleneck than the interface between the controller modules, it is no problem to execute a duplication processing by the communication between controller modules, and since reliability can be assured by the duplication processing, it is efficient to continue the high speed quick format until there appears a performance deterioration in the processing with respect to the storage.
In this manner, the format operation changeover section 42a optimizes the resource in the apparatus without reducing access performance from an external part and without detracting reliability.
Then, the format processing unit 42 changes over from the normal quick format to the high speed quick format when there is no input or output from the host for a constant period. In the high speed quick format, it becomes a simplex format in which only the controller module 10 locally manages the progress status of the format. When the local management of the progress status is executed by using the quick format bitmap 32d, a time lag is generated until the contents of the quick format bit map 32d and the quick format bitmap 52d are matched. Further, when the local progress status management is executed except the quick format bitmap 32d, the contents of the quick format bitmap 32d and the quick format bitmap 52d are matched. However, a time lag is generated with respect to an actual progress status of the format.
The format processing unit 42 executes update and duplication of the bitmap every time the format is progressed by a predetermined amount. Further, when an access from the host is detected during the high speed quick format, the format processing unit 42 executes update and duplication of the bitmap for a part for which format is completed, and then, changes over to the normal format.
Next, a processing operation of the format processing unit will be further described with reference to
On the other hand, when an area of an uncompleted format is remained in the device (S102, No), the format operation changeover section 42a refers to the cache 32a and judges whether or not there is a write cache in the cache 32, that is, whether or not a writing request is generated (S103). When there is a write cache in the cache 32a (S103, Yes), the format operation changeover section 42a resets a timer (S107), makes the access processing unit 41 execute a write back processing (S108), and executes the normal quick format again (S101).
On the other hand, when there is no write cache in the cache 32 (S103, No), the format operation changeover section 42a adds a certain value to a timer value (S104), and executes the normal quick format (S101) when the value of the timer is less than a predetermined value (S105 No).
Then, when the value of the timer becomes not less than a predetermined value (S105, Yes), the format operation changeover section 42a resets the timer (S106), and changes over to the high speed quick format executed by the high quick format processing section 42c (S110). Then, the format processing unit 42 judges whether or not the format of the entire device is completed (S111), and when the format is completed (S111, Yes), the processing is finished.
On the other hand, when an area of uncompleted format remains in the device (S111, No), the format operation changeover section 42a refers to the cache 32a, and compares the write cache amount in the cache 32a with a predetermined threshold value (S112). As a result, when the cache amount is less than the predetermined threshold value (S112, No), the high speed quick format processing section 42c executes the high quick format again (S110). On the other hand, when the cache amount is not less than the predetermined threshold value (S112, Yes), the format processing unit 42 duplicates the progress status of the format (S113), and executes a write back processing of the data in the cache (S114), and returns to the normal quick format (S101).
The processing operation shown in
In the example shown in
Next, the high speed quick format processing section 42c judges whether or not the local progress reaches a predetermined amount (S403). When the local progress reaches the predetermined amount (S403, Yes), the high speed quick format processing section 42c updates the quick format bitmap 32d in the self controller (S404), duplicates the bitmap (S404), and finishes the high speed quick format processing. Further, when the progress of the format that is not duplicated reaches the predetermined amount (S403, No), the high speed quick format processing section 42c finishes the high speed quick format processing without change.
After step S502, or when format of the writing request destination is completed (S501, Yes), the access processing unit 41 executes a write back for reflecting the write cache to the device (S503), and the write back processing is finished.
As described above, in the embodiment, in the case where there is no access to the device during the quick format for a predetermined period, the progress management of the quick format is executed by a simplex at the controller module 10 side, and when the quick format is completed by a constant amount, the progress status is notified to the controller module 11 for duplication. In this manner, a necessary time of format can be shortened by changing the execution frequency of the duplication processing of the progress status based on the generation status of access and the state of the device.
Further, since format type is returned to the normal quick format depending on the frequency of access, the access performance to the device during executing the quick format can be assured.
Further, when the local management of the progress status is executed independent from the bitmap, further speeding up of the processing can be provided.
Similarly, during the high speed quick format, when format requests to the device are collectively executed, a format range per one time becomes large, so that the number of command processing between the controller module and the storage is reduced, the sequential property of the device inner operation is improved, and further speeding up the format processing can be provided.
Note that in the embodiment, description is made for the embodiment in the case where a bitmap is used for the management of the progress status. However, the disclosed technique is not limited to this, and any progress management can be applied. For example, the progress status of format is managed by holding the final address of the format that is sequentially executed and the address that is preferentially formatted by host access.
Similarly, the changeover of the normal quick format and the high speed quick format can be adequately combined for use according to the generation frequency and generation interval of access from the host, the operation state of the device, and the like.
The embodiments can be implemented in computing hardware (computing apparatus) and/or software, such as (in a non-limiting example) any computer that can store, retrieve, process and/or output data and/or communicate with other computers. The results produced can be displayed on a display of the computing hardware. A program/software implementing the embodiments may be recorded on computer-readable media comprising computer-readable recording media. The program/software implementing the embodiments may also be transmitted over transmission communication media. Examples of the computer-readable recording media include a magnetic recording apparatus, an optical disk, a magneto-optical disk, and/or a semiconductor memory (for example, RAM, ROM, etc.). Examples of the magnetic recording apparatus include a hard disk device (HDD), a flexible disk (FD), and a magnetic tape (MT). Examples of the optical disk include a DVD (Digital Versatile Disc), a DVD-RAM, a CD-ROM (Compact Disc-Read Only Memory), and a CD-R (Recordable)/RW. An example of communication media includes a carrier-wave signal.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the principles of the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiment(s) of the present invention(s) has(have) been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2009-54188 | Mar 2009 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
6681291 | Ikeuchi et al. | Jan 2004 | B2 |
6851022 | Ikeuchi et al. | Feb 2005 | B2 |
20030120674 | Morita et al. | Jun 2003 | A1 |
Number | Date | Country |
---|---|---|
2003-29933 | Jan 2003 | JP |
2003-29934 | Jan 2003 | JP |
2003-108316 | Apr 2003 | JP |
2003-241904 | Aug 2003 | JP |
Number | Date | Country | |
---|---|---|---|
20100228917 A1 | Sep 2010 | US |