According to one embodiment, a recording medium controller includes a recording medium, an input module, a reading module, and a writing module. The recording medium includes a write area and an escape area. The write area includes track groups. Each of the track groups is a unit for writing data and includes tracks. The input module receives a write command for data. The reading module reads data stored in the escape area and data from a first track group of the track groups. The writing module writes data received for the write command to the escape area, and writes merged data obtained by merging the data read from the escape area and the data read from the first track group to each track of a second track group of the track groups by using a shingle recording technique in which adjacent tracks are partly overlapped with each other.
|
8. A recording medium controlling method executed by a recording medium controller configured to use a recording technique of collectively rewriting all tracks included in a track group, which comprises a plurality of tracks and is a unit for writing data, by causing adjacent tracks to be partially overlapped with each other, wherein,
the recording medium controller comprises a recording medium comprising a write area having the plurality of the track groups and an escape area temporarily storing data therein, and the method comprisesshingled tracks, the method comprising:
receiving an update command for data recorded in the a first track group in a write area on a recording medium;
reading data from a the first track group, which includes the data to be updated by the update command, of the track groups; and
writing the data to be updated by the update command to the an escape area on the recording medium after receiving the update command, and rewriting merged data obtained by merging merge the data read from the escape area and the data read from the first track groupgroup, and write the merged data to each track comprised in a second track group of the track groups by using the recording techniquedifferent in physical location from the first track group in the write area on the recording medium.
0. 10. A recording apparatus, comprising:
a recording medium including:
a first area having first and second track groups that are in different physical locations on the recording medium from each other, each of the first and second track groups including first and second write tracks that each partially overlap the other, and
a second area for storing data; and
a controller configured to:
read first data from the first track group in response to a write command that references a first portion of the first data in the first track group;
write second data associated with the write command in the second area; and
write merged data in the second track group, the merged data including the first data from the first track group with the second data from the second area replacing the first portion.
0. 11. A recording medium controller, comprising:
a recording medium comprising thereon a write area having a plurality of track groups in different physical locations and an escape area for temporarily storing data therein;
a processor configured to, in response to a first command to update data in the write area:
read data from a first track group in the plurality of track groups, the first track group including data to be updated by the first command; and
write the data to be updated by the first command to the escape area after receiving the first command;
merge data from the escape area and data from the first track group; and
write the merged data to a second track group in the plurality of track groups by using a shingled recording technique, the second track group being at a physical location in the write area different from the first track group.
0. 18. A recording medium controlling method executed by a recording medium controller configured to use a recording technique of collectively rewriting all tracks included in a track group, which comprises a plurality of shingled tracks, the method comprising:
reading first data from a first track group in a plurality of track groups, the first data including a portion of the data to be updated; and
writing second data to the escape area after receiving a first command indicating that the portion of the data to be updated in the first data is to be updated with the second data, and writing merged data that combines the second data from the escape area and the first data from the first track group to a second track group in the plurality of track groups by using a shingled recording technique, the second track group being at a physical location separate from the first track group.
0. 20. A recording apparatus, comprising:
a recording disk medium including:
a first data area having a first track group at a first location and a second track group at a second location physically distinct from the first location, each of the first and second track groups including a first write track and a second write track partially overlapping with the first write track, and
a second data area; and
a processor configured to:
receive a write command for writing second data;
receive the second data associated with the write command;
write the second data into the second data area;
read first data from the first write track in the first track group;
write the first data on one of the first write track or the second write track in the second track group; and
write the second data on the other of the first write track or the second write track in the second track group.
1. A recording medium controllerconfigured to use a recording technique of collectively rewriting all tracks included in a track group, which comprises a plurality of tracks and is a unit for writing data, by causing adjacent tracks to be partially overlapped with each other, comprising:
a recording medium comprising thereon a write area having the a plurality of the shingled track groups and an escape area for temporarily storing data therein;
an input module configured to receive a processor configured to, after an update command for data recorded in the write area;
a reading module configured to; read data from a first shingled track group in the write area, which includes the first shingled track group including the data to be updated by according to the update command, of the first shingled track groups comprising a plurality of shingled tracks; and
a writing module configured to write the data to be updated by according to the update command to the escape area after receiving the update command, and to rewrite merged data obtained by merging merge the data read from the escape area and the data read from the first shingled track group, and write the merged data to each track comprised in a second shingled track group of the track groups by using the recording technique at a physical location in the write area different from the first shingled track group.
0. 30. A recording apparatus, comprising:
a recording disk medium including:
a first data area having a plurality of track groups, each including a first write track and a second write track partially overlapping with the first write track, and
a second data area in an outer edge region of the recording disk medium and having a plurality of non-overlapping write tracks; and
a processor configured to:
receive a first write command and a first address corresponding to a first physical location in the first data area;
receive first data associated with the first write command;
receive a second write command and a second address corresponding to a second physical location in the first data area different from the first physical location;
receive second data associated with the second write command;
write the first data into the second data area;
write the second data into the second data area;
read third data from the first data area; and
write a part of the read third data and the first data into the first data area at a third physical location after the writing of the first data and the second data into the second data area.
0. 31. A method of writing data to hard disk media which includes thereon a write area in which data is written to an area which partly overlaps with another area in which other data has been written and an escape area to temporarily store data, the method comprising:
writing first data in a first area in the write area;
writing second data in a second area in the write area, the second area partly overlapping with the first area;
receiving a first write command including first address information for writing third data to update a part of the first data stored in the first area;
receiving the third data associated with the first write command;
writing the third data to a third area that is in the escape area;
receiving a second write command including second address information;
receiving fourth data associated with the second write command;
writing the fourth data to a fourth area that is in the escape area;
after the execution of the writing of the fourth data to the fourth area, reading at least a part of the first data stored in the first area;
after the execution of the writing of the fourth data to the fourth area, reading the second data stored in the second area; and
writing fifth data comprising the third data and the part of the first data to a fifth area in the write area which is at different physical location in the write area from the first area.
2. The recording medium controller of
3. The recording medium controller of
the writing module is configured to write the data with the size to be updated by the update command to the escape area.
4. The recording medium controller of claims claim 2, wherein
the second track group is a spare area allocated as a spare, any logical address not being assigned to the spare area until the writing module rewrites the merged data; and
the writing module processor is configured to assign, after rewriting writing the merged data to the each track of the second shingled track group, a logical address to the second shingled track group, to delete a logical address of the first shingled track group, and to set allocate the first shingled track group as a new spare areaallocated as a spare.
5. The recording medium controller of
the input module is configured to receive an update command is for a data with a size storable in a track sectorof a track of the tracks, and
the writing module is configured to write the data with the size to be updated by the update command to the escape area.
6. The recording medium controller of claims claim 5, wherein
the second track group is a spare area allocated as a spare, any logical address not being assigned to the spare area until the writing module rewrites the merged data; and
the writing module processor is configured to assign, after rewriting writing the merged data to the each track of the second shingled track group, a logical address to the second shingled track group, to delete a logical address of the first shingled track group, and to set allocate the first shingled track group as a new spare areaallocated as a spare.
7. The recording medium controller of
the second track group is a spare area allocated as a spare, any logical address not being assigned to the spare area until the writing module rewrites the merged data; and
the writing module processor is configured to assign, after rewriting writing the merged data to the each track of the second shingled track group, a logical address to the second shingled track group, to delete a logical address of the first shingled track group, and to set allocate the first shingled track group as a new spare areaallocated as a spare.
9. The recording medium controlling method of
0. 12. The recording medium controller of claim 11, wherein the processor is configured to write the merged data to the second track group during an idle time.
0. 13. The recording medium controller of claim 12, wherein the first command is for a data size that is storable in a track sector.
0. 14. The recording medium controller of claim 12, wherein
the processor is configured to assign, after writing the merged data to the second track group, a logical address to the second track group, to delete a logical address of the first track group, and to allocate the first track group as a spare area.
0. 15. The recording medium controller of claim 11, wherein
the first command is for a data size that is storable in a track sector.
0. 16. The recording medium controller of claim 15, wherein
the processor is configured to assign, after writing the merged data to the second track group, a logical address to the second track group, to delete a logical address of the first track group, and to allocate the first track group as a spare area.
0. 17. The recording medium controller of claim 11, wherein
the processor is configured to assign, after writing the merged data to the second track group, a logical address to the second track group, to delete a logical address of the first track group, and to allocate the first track group as a spare area.
0. 19. The recording medium controlling method of claim 18, wherein the merged data is written to the second track group during an idle time.
0. 21. The recording apparatus of claim 20, wherein the processor is further configured to assign a logical address of the first track group to the second track group after writing the first data and the second data in the second track group.
0. 22. The recording apparatus of claim 21, wherein the processor is further configured to delete the logical address of the first track group.
0. 23. The recording apparatus of claim 20, further comprising:
a buffer memory to store the received second data before writing the second data into the second data area and to store the read first data.
0. 24. The recording apparatus of claim 20, wherein the first data area further has a third track group including a first write track and a second write track partially overlapping with the first write track.
0. 25. The recording apparatus of claim 20, wherein a capacity of the second data area is more than one gigabyte.
0. 26. The recording apparatus of claim 20, wherein the second data area is on the outer edge of the recording disk medium.
0. 27. The recording apparatus of claim 20, wherein tracks of the second data area are not overlapped and track width of the tracks of the second data area is wider than that of the tracks of the first data area.
0. 28. The recording apparatus of claim 20, further comprising:
an interface controller to receive the write command and the second data from the host.
0. 29. The recording apparatus of claim 20, wherein the processor is further configured to write the first data and the second data into the second track group during a time period during an idle time.
0. 32. The method according to the claim 31, wherein the escape area is located adjacent to an outer edge of a platter of the hard disk media.
0. 33. The method according to the claim 31, wherein a capacity of the escape area exceeds one gigabyte.
0. 34. The method according to the claim 33, wherein a single platter of the hard disk media has a capacity ranging from 500 gigabytes to one terabytes.
0. 35. The method according to the claim 31, wherein in the escape area, data is written to an area which overlaps with another area to which other data has been written.
0. 36. The method according to the claim 31, wherein in the escape area, data is written without shingling.
0. 37. The method according to the claim 31, further comprising:
receiving a third write command including third address information;
receiving sixth data associated with the third write command;
writing the sixth data directly to a sixth area in the write area without writing the sixth data to the escape area.
0. 38. The method according to the claim 37, wherein reading of the at least the part of the first data stored in the first area is carried out after the execution of the writing of the sixth data in the sixth area.
0. 39. The method according to the claim 31, further comprising, after execution of the writing of the fourth data to the fourth area, reading the third data stored in the third area, and merging the fifth data using a buffer memory.
|
This application is based upon and claims the benefit of priority from Japanese Patent Application No. 2010-124898, filed May 31, 2010, the entire contents of which are incorporated herein by reference.
Embodiments described herein relate generally to a recording medium controller configured to write data to a recording medium using the shingle recording technique, and to a method thereof.
A hard disk drive (HDD) comprising a magnetic disk has conventionally been used. The recent trend is to further increase the capacity of a hard disk. In order to increase the recording density for increasing the capacity, there has been disclosed a technique in which the track density is decreased by reducing track widths.
There has also been disclosed another technique for increasing the track density. In this technique, the track widths are decreased to an extent that data is written to adjacent tracks in a partly overlapping manner. Such a recording technique is often referred to as shingle recording. However, when this technique is applied, the data stored in the adjacent track in a partly overlapping manner is lost. Therefore, data writing must be performed per unit track group composed of a plurality of tracks (for example, see Japanese Patent Application Publication (KOKAI) No. 2006-338731).
However, employing the technique disclosed in Japanese Patent Application Publication (KOKAI) No. 2006-338731 takes long time to write data because the writing must be performed per unit track group.
A general architecture that implements the various features of the invention will now be described with reference to the drawings. The drawings and the associated descriptions are provided to illustrate embodiments of the invention and not to limit the scope of the invention.
In general, according to one embodiment, a recording medium controller comprises a recording medium, an input module, a reading module, and a writing module. The recording medium comprises a write area and an escape area temporarily storing data therein. The write area comprises track groups. Each of the track groups is a unit for writing data and comprises a plurality of tracks. The input module is configured to receive a write command for data. The reading module is configured to read data stored in the escape area and data from a first track group of the track groups. The writing module is configured to write data received for the write command to the escape area, and to write merged data obtained by merging the data read from the escape area and the data read from the first track group to each track comprised in a second track group of the track groups by using a shingle recording technique in which adjacent tracks are partly overlapped with each other.
An exemplary embodiment of a magnetic disk device using a recording medium controller and a recording medium controlling method is described below in greater detail with reference to the drawings. However, the embodiment described hereunder is not intended to limit the scope of the present invention in any way.
A mechanical structure of the magnetic disk device according to the embodiment will now be explained with reference to
A magnetic disk device 1 illustrated in
The spindle motor 12 rotates the magnetic disk 11. A magnetic head having a recording head and a reproducing head (neither of which is illustrated in
An electrical hardware configuration of the magnetic disk device 1 according to the embodiment will now be explained with reference to
In
A magnetic head 22 uses the recording head and the reproducing head comprised therein to read and to write data from and to the magnetic disk 11. As mentioned earlier, the magnetic head 22 is placed at the distal end of the actuator arm 15, and moved in the radius direction on the magnetic disk 11 by the VCM 16 driven by the motor driver 21. When the magnetic disk 11 is not under the rotation, for example, the magnetic head 22 is evacuated onto a ramp 23.
A head amplifier 24 amplifies a signal read using the magnetic head 22 from the magnetic disk 11, and outputs the signal to a read/write channel (RDC) 25. The head amplifier 24 also amplifies a signal received from the RDC 25 for writing data to the magnetic disk 11, and supplies the signal to the magnetic head 22.
The RDC 25 performs a code modulation on data received from a HDC 31 to be explained later and to be written to the magnetic disk 11, and supplies the data to the head amplifier 24. The RDC 25 also performs a code demodulation on a signal read from the magnetic disk 11 and received via the head amplifier 29, and outputs the signal to the HDC 31 as digital data.
A central processing unit (CPU) 26 is connected to a static random access memory (SRAM) 27 that is a working memory, a flash read-only memory (ROM) 28 that is a non-volatile memory, and a buffer random access memory (RAM) 29 used as a temporary memory. The CPU 26 controls the entire magnetic disk device 1 in accordance with firmware pre-stored in the flash ROM 28 and the magnetic disk 11. (This firmware comprises initial firmware and controlling firmware used for regular operations. The controlling firmware further comprises a magnetic disk controlling program, which is to be explained later. The initial firmware, which is executed initially upon booting, is stored in the flash ROM 28. The controlling firmware, which is used for regular operations, is stored in the magnetic disk 11. The controlling firmware is read once from the magnetic disk 11 to the buffer RAM 29 following a control performed by the initial firmware, and then stored in the SRAM 27.
The hard disk controller (HDC) 31 controls data transmissions and receptions performed between the magnetic disk device 1 and a host computer (hereinafter, simply referred to as “host”) 40 via an interface (I/F) bus, controls the buffer RAM 29, and performs error corrections on data. The buffer RAM 29 is used as a cache for data transmitted to and received from the host computer 40. The buffer RAM 29 is also used for temporarily storing therein data read from or to be written to the magnetic disk 11, and the controlling firmware read from the magnetic disk 11, for example.
The input module 301 receives data write commands or data read commands from the host 40 connected to the magnetic disk device 1. Examples of the data write commands comprise a write command for data having a size storable in a sector comprised in a single track of the magnetic disk 11, or sequential write commands for data having a larger size.
The writing module 302 controls writing data to the magnetic disk 11. When the writing module 302 according to the embodiment performs write controls, the writing module 302 needs to write data to a track having a width smaller than the main pole width of the magnetic head 22.
Therefore, the writing module 302 according to the embodiment performs writes using the shingle recording technique. The shingle recording technique is a technique for writing data in an overlapping manner while scanning an extremely small amount along the track direction by the recording head. Because the track width of the magnetic disk 11 used in the shingle recording technique is smaller than the main pole width of the recording head, data written to adjacent tracks partly overlap each other. Because the smaller track width can be used when the shingle recording technique is adopted, the density of a medium can be increased.
In the shingle recording technique, data in adjacent tracks is lost because the data in adjacent tracks are written in partly overlapping manner. Therefore, even when particular data in a certain track is to be updated, the particular data alone cannot be updated, but whole data in a number of tracks needs to be updated. In this embodiment, such unit of tracks is referred to as a track group. Here, an unused area is provided between the track groups. Thus, when data is written to one of the track groups, data in other one of the track groups adjacent the one of the track groups is protected from being overwritten.
The write area 402 comprises a plurality of track groups (a track group 403, for example). As mentioned earlier, each of the track groups comprises a plurality of tracks, each having a width smaller than the main pole width of the head performing the writes. The number of tracks comprised in the track groups is not limited, but the number of tracks in the following explanation is assumed to be 100.
The write area 402 comprises not only track groups assigned with logical addresses, but also those not assigned with logical addresses. In the embodiment, a track group not assigned with a logical address is referred to as a spare track group. The number of spare track groups allocated in the write area 402 is not limited, and a plurality of the spare track groups may be allocated. In the magnetic disk 11 according to the embodiment, the tracks comprised in the magnetic disk 11 are concentrically divided by head/zone. A number of sectors per track are different for the head/zone. More specifically, the number of sectors per track is larger in one of the heads/zones located nearer to the outer circumference. In other words, the capacity of the tracks is different for the heads/zones. Thus, in the magnetic disk 11 according to the embodiment, a spare track group is provided for each head/zone. In this manner, because a spare track is provided for each of the heads/zones, the entire data written in a single track can be written to a single spare track, even if the capacity of the tracks is different for each of the heads/zones.
The escape area 401 temporarily stores therein data to be written to the write area 402. Assuming that a single platter of the magnetic disk 11 has a capacity ranging from 500 gigabytes to one terabytes, the escape area 401 of several gigabytes is provided, for example.
The reason why the escape area 401 is comprised in the magnetic disk 11 will now be explained. To rewrite data using the shingle recording technique, the data in the entire track group needs to be rewritten. Therefore, much longer time is required than a conventional data rewriting technique. Thus, in the magnetic disk device 1 according to the embodiment, the temporary escape area 401 is provided. Then, at the time when the writing module 302 writes data in accordance with a write command, the data is temporarily written to the escape area 401 instead of the track group in the write area 402. In this manner, the time required for the writing is reduced.
The escape area 401 according to the embodiment is located on the outer side of the magnetic disk 11. In this manner, the writing and the reading speeds can be improved.
The escape area 401 may be a group of tracks each with a small track width so that data is written using the shingle recording technique. Alternatively, the escape area 401 may be a group of tracks each with a conventional track width so that data can be written without data of adjacent tracks being overlapped.
The reading module 303 reads at least one of the data stored in the escape area 401 and the data stored in the write area 402 when the input module 301 receives a read command or when the data written in the magnetic disk 11 is to be updated.
Therefore, in the embodiment, when the input module 301 receives an update command for a part of a track or a sector (e.g., the sector 503) of a track group to which data from the host 40 is already stored, the writing module 302 writes data corresponding to the update command to a track or a sector (e.g., sector 504) of the escape area 401.
After the writing, the writing module 302 reassigns a logical address that has previously been assigned to the track or the sector to be updated (e.g., the sector 503) to the track or the sector in the escape area 401 (e.g., sector 504). This process ends the writing performed for the update command received by the input module 301.
When such process is performed continuously, the capacity of the escape area 401 will be overused. Thus, to avoid overusing the capacity of the escape area 401, in the magnetic disk device 1 according to the embodiment, the data stored in the escape area 401 is written to the write area 402. This writing process is performed during an idle time excluding a time during which the input module 301 is performing processes in response to the read or write commands.
In the writing process performed during the idle time, the data stored in the escape area 401 and the data stored in the track group that is being updated arc merged. In other words, in the magnetic disk device 1 according to the embodiment, because the merging is performed during the idle time, the merging does not interrupt executions of processes performed for read or write commands issued by the host 40, and the executions of such processes are not delayed.
During the idle time, the merging module 304 merges the data read from the escape area 401 and the data read from the track group in the write area 402, each of which is read by the reading module 303, by using a buffer (not illustrated).
The writing module 302 then writes the data merged by the merging module 304 to each of the tracks comprised in a spare track group, which is arranged separately from the track group read by the reading module 303.
As illustrated in
After completing writing the data of the track group, the writing module 302 reassigns the logical address assigned to the track group 501 which is the target of the updating to the spare track group 601, and deletes the logical address of the original track group 501. Consequently, the track group 501 is set as a new spare track group.
In the process illustrated in
In the magnetic disk device 1 according to the embodiment, when a write is performed using the shingle recording technique, the escape area 401 in the magnetic disk 11 is used. However, because the capacity of the escape area 401 is limited, it is necessary not to overuse the capacity.
If all of the write commands received by the input module 301 are for data of relatively small blocks, all of the data can be stored in the escape area 401 without overusing the escape area 401. However, if the input module 301 receives sequential write commands, which are often observed in copying a large file or the like, the escape area 401 will be overused. If the amount of data stored in the escape area 401 increases, a number of the writing of the data of the tracks by the shingle recording technique increases. Accordingly, the performance will deteriorate significantly.
Hence, in the magnetic disk device 1 according to the embodiment, when the input module 301 receives sequential write commands, the writing module 302 begins to write data for the write commands to the escape area 401. Then, at the timing when a logical address specified as a target address for the sequential writes changes from the address of the first track group for writing data to the address of the next track group, the writing module 302 starts writing the subsequent data directly to the spare track group thereafter. When the writing module 302 completes writing data to the spare track group, the writing module 302 assigns a logical address to the spare track group, and sets the track group originally being updated as new spare track group. If the write commands still continue, the writing module 302 further continues writing data to the spare track group that is newly made available. Sequential write commands can be handled by repeating this process.
During the idle time and after completing writing data for the sequential write commands according to the process explained above, the magnetic disk device 1 merges the data written to the escape area 401 and the data stored in the track groups originally being updated. The merging process is the same as the process illustrated in
Furthermore, the magnetic disk device 1 explained in the first embodiment can support a multi-threaded write. In other words, because the magnetic disk 11 has a spare track group for each of the heads/zones, by allowing a multi-threaded write to use the respective spare tracks for the different heads/zones, the writing module 302 can write data to a plurality of track groups simultaneously.
Even if the targets of the multi-threaded write commands are in the same heads/zones, such command can be handled by providing spare track groups at positions that maximize the track capacity in the magnetic disk 11 and making such spare track groups available for any heads/zones.
The writing in response to the write command issued in the magnetic disk device 1 according to the embodiment will now be explained.
First, the input module 301 receives a write command issued by the host 40 (S701). The input module 301 then receives the data to be written, transferred from the host (S702). It is assumed herein that the data has a size storable in a track or a sector comprised in a track group, and the data does not rewrite the entire track group.
Upon receipt of the write command for data having such size, the writing module 302 calculates a physical location in the escape area for storing the data (S703). The physical location in the escape area may be at any location, and may be calculated sequentially based on the write request. In this manner, the writing module 302 calculates the location in the escape area having no relationship with the location for writing the data specified in the write command.
The writing module 302 then writes the data to the calculated physical location on the magnetic disk 11 (S704). The writing module 302 then determines if the write is completed (S705). If the writing module 302 determines that the write is not completed (No at S705), the writing module 302 continues writing the data at S704.
By contrast, when the writing module 302 determines that the write is completed (Yes at S705), the writing module 302 assigns a logical address, which is previously assigned to a target location in the track groups specified in the write command, to the escape area in which the data is stored. Then, the writing module 302 deletes the logical address of the target location to prevent such an address from being referred to, and ends the process.
A process of writing data stored in the escape area 401 to a track group in the magnetic disk device 1 according to the embodiment will now be explained.
First, the reading module 303 sets a track group for reading data (S801). The track group for reading data is determined based on whether any data in the escape area is available for being merged with the data stored in such a track group, for example.
The reading module 303 then reads the data stored in the tracks comprised in the set track group (S802). The reading module 303 then determines if there is any data that should be merged with the data read from the tracks based on the set logical address (S803).
If the reading module 303 determines that there is no data that should be merged (No at S803), S806 is performed without any intervening process.
By contrast, if the reading module 303 determines that there is some data that should be merged (Yes at S803), the reading module 303 reads the data temporarily stored in the escape area so that such data can be merged with the data read from the tracks at S802 (S804).
The merging module 304 then merges the data read at S804 and the data read from the tracks at S802 (S805).
The writing module 302 then writes the data to the tracks in the spare track group (S806). The writing module 302 writes the merged data when there is some data that should be merged, and writes the data read at S802 when there is no data that should be merged.
The writing module 302 then determines if the write of the data is completed in all of the tracks comprised in the spare track group (S807). If the writing module 302 determines that the write is not completed (No at S807), the reading module 303 starts reading the data from the tracks again at S802.
By contrast, if the writing module 302 determines that the write of the data is completed in all of the tracks comprised in the spare track group (Yes at S807), the writing module 302 changes the logical addresses so that the track group that has been read is reallocated as a new spare track group and the spare track group to which data has been written is reallocated as a regular track group that makes the data available for reading, and ends the process (S808). At this time, the writing module 302 also changes the logical address assigned to the escape area.
By the process described above, the data temporarily stored in the escape area can be comprised in the regular track groups.
In the magnetic disk device 1 according to the embodiment, the data is read and written by means of the configurations described above. In this manner, even when data is recorded to the magnetic disk 11 using the shingle recording technique, the time required for rewriting the data can be reduced. Furthermore, when the data is to be copied from a track group to a spare track group, because only the spare track group is rewritten, a data loss can be avoided even when the power shuts down unexpectedly. As described above, the technique adopted in the magnetic disk device 1 is suitable for actual production environment.
In the magnetic disk device 1 according to the embodiment, when a write command, especially a write command for data in a small unit, e.g., sectors, is received, the data is once written to the escape area 401, then written to the track groups as described above. Therefore, in the magnetic disk device 1, the write can be completed in a shorter time than the time required for writing data in the entire track group. Thus, the number of tracks comprised in a track group can be increased compared with a conventional example.
In the magnetic disk device 1 according to the embodiment, when data is written using the shingle recording technique, the spare track group is used. The data in a track group and the data in the escape area are merged, and the merged data is written to the spare track group. In this manner, the data is protected against a loss caused by the data being overwritten, and against an unexpected power shutdown.
In the magnetic disk device 1 according to the embodiment, during sequential writes, the data is written to the spare track group instead of the escape area, whereby the escape area is protected against overuse and performance degradation is prevented.
Furthermore, in the magnetic disk device 1 according to the embodiment, the spare track group may be provided in plurality to allow a multi-threaded write to be handled. In addition, by providing a common spare track group to each of the heads/zones of the magnetic disk 11, versatility can be improved.
The magnetic disk controlling program executed by the CPU 26 in the magnetic disk device 1 according to the embodiment is provided in a manner pre-installed in the flash ROM 28.
Alternatively, the magnetic disk controlling program executed by the CPU 26 in the magnetic disk device 1 according to the embodiment may be provided in a manner recorded in a computer-readable recording medium such as a compact disk read-only memory (CD-ROM), a flexible disk (FD), a compact disk recordable (CD-R), and a digital versatile disk (DVD) as a file in an installable or an executable format.
Furthermore, the magnetic disk controlling program executed by the CPU 26 in the magnetic disk device 1 according to the embodiment may be provided in a manner stored in a computer connected to a network such as the Internet to be made available for downloads via the network. The magnetic disk controlling program executed by the CPU 26 in the magnetic disk device 1 according to the embodiment may also be provided or distributed over a network such as the Internet.
The magnetic disk controlling program executed by the CPU 26 in the magnetic disk device 1 according to the embodiment has a modular structure comprising each of the modules explained above (the input module, the writing module, the reading module, and the merging module). As the actual hardware, the CPU 26 reads the magnetic disk controlling program from the flash ROM 28 and executes the same. Accordingly, each of the modules is loaded to the main memory, and the input module, the writing module, the reading module, and the merging module are provided on the main memory.
In other words, the various modules of the systems described herein can be implemented as software applications, hardware and/or software modules, or components on one or more computers, such as servers. While the various modules are illustrated separately, they may share some or all of the same underlying logic or code.
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel embodiments described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the embodiments described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents arc intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Nitta, Tatsuo, Tanaka, Hideaki, Haga, Tatsuya, Hongawa, Tadashi, Shinbori, Takahiro
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
6185063, | Feb 13 1997 | Seagate Technology LLC | Methods and apparatus for overlapping data tracks on a storage medium |
6335842, | Aug 20 1997 | TDK Corporation | Magnetic recording apparatus with a head error detection circuit |
7490212, | Sep 29 2003 | HGST NETHERLANDS B V | System and method for writing data to dedicated bands of a hard disk drive |
7965465, | Mar 11 2009 | Western Digital Technologies, INC | Techniques for storing shingle blocks in a cache memory using a data storage device |
7996645, | Sep 29 2003 | Western Digital Technologies, INC | Log-structured file system for disk drives with shingled writing |
8108602, | Sep 29 2003 | Western Digital Technologies, INC | Log-structured file system for disk drives with shingled writing |
8179627, | Jun 10 2010 | Seagate Technology LLC | Floating guard band for shingle magnetic recording |
8271801, | Nov 19 2009 | Western Digital Technologies, INC | Implementing data confidentiality and integrity of shingled written data |
8756399, | Jan 25 2006 | Seagate Technology LLC | Mutable association of a set of logical block addresses to a band of physical storage blocks |
8896953, | Dec 26 2012 | Kabushiki Kaisha Toshiba | Disk storage apparatus and method for shingled magnetic recording |
9007710, | Aug 27 2014 | Seagate Technology | Rewrite operation for recording bands |
9047923, | Jun 18 2014 | Seagate Technology LLC | Fast shingled tracks recording |
20040128470, | |||
20050069298, | |||
20050071537, | |||
20060123284, | |||
20070183071, | |||
20090300269, | |||
20100232048, | |||
20100232057, | |||
JP2001243021, | |||
JP2005293774, | |||
JP2006338731, | |||
WO9945534, | |||
WO9945534, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jan 29 2015 | Kabushiki Kaisha Toshiba | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Jul 17 2024 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Mar 01 2025 | 4 years fee payment window open |
Sep 01 2025 | 6 months grace period start (w surcharge) |
Mar 01 2026 | patent expiry (for year 4) |
Mar 01 2028 | 2 years to revive unintentionally abandoned end. (for year 4) |
Mar 01 2029 | 8 years fee payment window open |
Sep 01 2029 | 6 months grace period start (w surcharge) |
Mar 01 2030 | patent expiry (for year 8) |
Mar 01 2032 | 2 years to revive unintentionally abandoned end. (for year 8) |
Mar 01 2033 | 12 years fee payment window open |
Sep 01 2033 | 6 months grace period start (w surcharge) |
Mar 01 2034 | patent expiry (for year 12) |
Mar 01 2036 | 2 years to revive unintentionally abandoned end. (for year 12) |