This application is based upon and claims the benefit of priority from Japanese Patent Applications No. 2012-176383, filed Aug. 8, 2012; and No. 2013-119959, filed Jun. 6, 2013, the entire contents of all of which are incorporated herein by reference.
Embodiments described herein relate generally to an information recording apparatus, information playback apparatus, and formatting method.
There is known a recording system which divides recording data to generate a plurality of divided recording data, and distributively records these divided recording data on a plurality of information recording media. There is also known a recording system which divides recording data not corresponding to important data to generate a plurality of divided recording data, distributively records these divided recording data on a plurality of information recording media, and records recording data corresponding to important data on one or more information recording media without dividing it. Further, there is known a recording system which generates parity data from a plurality of divided recording data, distributively records these divided recording data on a plurality of information recording media, and records the parity data on another information recording medium.
As described above, there is known a recording system which records parity data on an information recording medium for parity data other than a plurality of information recording media for recording data. However, the storage capacity of an information recording medium may not be effectively used depending on circumstances. A demand has arisen for a technique capable of effectively using the storage capacity of an information recording medium in a case in which parity data is recorded.
A general architecture that implements the various features of the embodiments will now be described with reference to the drawings. The drawings and the associated descriptions are provided to illustrate the embodiments and not to limit the scope of the invention.
Various embodiments will be described hereinafter with reference to the accompanying drawings.
In general, according to one embodiment, an information recording apparatus includes a divider, a generator, and a recorder. The divider is configured to divide recording data into a plurality of recording data blocks for each predetermined recording unit. The generator is configured to set, as a first block set, n recording data blocks recorded in corresponding areas in file system management areas of n, first to nth (n: integer, n≧2) storages, and generate first parity data from the n recording data blocks forming the first block set. The recorder is configured to record the n recording data blocks forming the first block set and the first parity data.
The system 100 can parallelly record/play back data (recording data) on/from four BD-R media out of five BD-R media inserted into the five BD-R drives, and a parity on/from one BD-R medium. For example, the format of the BD-R medium uses UDF1.5.
As shown in
The main controller 101 controls the overall system 100 (optical disc drive 102, data processor 103, data input/output unit 104, and eject controller 105). The optical disc drive 102 records various data on a plurality of optical discs, and reads various data from them, details of which will be described later. The data processor 103 divides various data, generates various data, and checks data (data block) based on parity data, details of which will be described later. The eject controller 105 controls execution of ejection. The data input/output unit 104 receives data from a PC 200 and outputs data to it.
When the system 100 is connected to the PC 200, dedicated drives (Drive Top and Drive Bottom) are installed in the five BD-R drives connected in parallel. Accordingly, the system 100 regards the five BD-R drives (five BD-R media) as one large-capacity storage device (to be referred to as a drive system hereinafter), similar to HDD RAID and the like. The PC 200 handles the system 100 as one large-capacity storage device.
For example, data recorded in the system 100 seems to be recorded in one large-capacity storage, as shown in
Terms used in the embodiment will be defined.
Recorded final logical cluster address: the final logical cluster address of data recorded on the media set
x shown in
Recorded final Disc: the final Disc of data recorded on the media set
Disc4 shown in
Next, the sequence of recording processing in the system including the connected PC 200 will be explained with reference to
Recording data to be recorded and a recording destination are designated in the application software. As described above, the recording destination seems to be one large-capacity storage when viewed from layers above the dedicated drives, that is, the application software, OS, and File System in
The operations of the dedicated drives in the system and the sequence of recording processing in the system will be explained with reference to
W-01. Reception of Recording Data
The system 100 receives, from the PC 200, recording data (Data1 in
W-02. Creation of Divided Data
The system 100 divides the recording data (Data1 in
W-03. Allocation of Recording Destination of Divided Recording Data Block
The system 100 allocates the recording destinations of a plurality of divided recording data blocks to the respective BD-Rs (to the UDF management areas of the respective BD-Rs).
Details of this processing will be explained below.
W-03-01. Acquisition of Start Logical Cluster Address and Disc of Recordable Area
First, the system 100 reads the respective BD-Rs, acquires the recorded final logical cluster address and recorded final Disc of the media set, and obtains the start logical cluster address and Disc of a recordable area. When the recorded final Disc is Disc4 (see
W-03-02. Allocation of Recording Destination to Each Divided Recording Data Block
The system 100 successively allocates a plurality of divided recording data blocks created in W-02 to the start cluster address and Disc (recording destination) of the recordable area acquired in W-03-01. For example, when recording divided recording data blocks in
W-04: Calculation of Parity
The system 100 calculates a parity to be added to a plurality of divided recording data blocks in order to improve reliability.
Details of the parity calculation processing will be explained with reference to
W-04-01. Skip of Parity Calculation
To calculate a parity, all data from Disc1 to Disc4 need to be prepared for areas of corresponding logical cluster addresses. If data are insufficient, no parity can be calculated, so the parity calculation processing is skipped. Since the system 100 successively records data, if data has not been recorded in an area of a corresponding logical cluster address on Disc4 out of areas of the corresponding logical cluster addresses on Disc1 to Disc4 (NO in W-04-a), the system 100 determines that all data for Disc1 to Disc4 have not been prepared. For example, when all data have not been recorded in four areas of logical cluster addresses 0 on Disc1 to Disc4, all data have not been prepared, and the system 100 determines to skip the parity calculation processing (W-04-01).
W-04-02. Calculation of Parity
If data are to be recorded in areas of corresponding logical cluster addresses on Disc1 to Disc4 (NO in W-04-b), the system 100 calculates a parity based on the data to be recorded in the areas of the corresponding logical cluster addresses on Disc1 to Disc4 (W-04-02). As described above, the system 100 successively records data. Thus, if there is a divided recording data block allocated to an area of the corresponding logical cluster address on Disc4 out of areas of the corresponding logical cluster addresses on Disc1 to Disc4, the system 100 records divided recording data blocks in the areas of the corresponding logical cluster addresses on Disc1 to Disc4.
As shown in
For example, when the system 100 generates divided recording data blocks shown in
W-05. Recording on Media set
The system 100 instructs the respective BD Drives to record the allocated divided recording data blocks. In response to this, the respective BD Drives can parallelly record the allocated divided recording data blocks in the respective media.
The recording processing in the system 100 has been described.
Next, Eject processing for a media set will be explained with reference to
E-01. Updating of Info Area
The system 100 performs Info Area update processing upon receiving an Eject instruction (command).
Info Area will be explained.
Info Area is an area where a temporary parity created from currently recorded information is recorded at a logical cluster address at which no divided recording data block has been written up to Disc4. Info Area is an area set outside the UDF management area.
For example, in
Details of Info Area update processing will be explained with reference to
The system 100 checks whether data recording processing has been performed after a currently set media set is inserted (I-01). If recording processing has never been performed (NO in I-01), the system 100 performs Eject processing for the media set. If recording processing has been performed, the system 100 acquires, from Drive Bottom, the final logical cluster address (to be referred to as a recorded final logical cluster address hereinafter: x shown in
A case in which a media set is inserted again upon completion of Eject processing for the media set, Data2 and Data3 are additionally written, and then Eject processing is received again will be explained with reference to
The recorded final Disc in this state is Disc2, and the recorded final logical cluster address is y. The system 100 calculates a temporary parity P-y′ from a divided recording data block D2-m of Disc1 and a divided recording data block D3-1 of Disc2 that are recorded at the recorded final logical cluster address y. Since recording has been completed up to address N, the system 100 records the calculated temporary parity P-y′ in Info Area at next address N+1 on Disc3 which is a Disc next to the recorded final Disc. Similarly, the system 100 records management information (Info) at Info Area addresses N+1 on Disc1 and Disc5.
E-02. Eject Processing
Upon completion of recording in Info Area, as needed, the system 100 performs Eject processing for the media set.
Next, data playback processing will be described.
For example, the system 100 may be in units of LBA (Logical Block Addresses) to access data, to reproduce the data. In addition, it is 32LBA=1 cluster.
When a media set is inserted, Drive Top in the system 100 checks Info Area recorded on a BD-R, and acquires a recorded final Disc and recorded final logical cluster address from Info (for example, Info1 shown in
As shown in
Details of the parity check by Drive Top will be explained with reference to
R-01. Calculation of Information of Target Data
Upon receiving a playback request from the PC 200, Drive Top calculates the following information for target data on the media set based on the address and size of data requested from File System (R-01):
(1) start logical cluster address
(2) start Disc
(3) end logical cluster address
(4) end Disc
If a playback request for Data1 formed from D1-1, . . . , D1-n is received in the data recording situation shown in
R-02. Parity Check for Data Except for End Logical Cluster address
Since the system 100 successively records data on the media set, Drive Top performs a parity check using parities recorded on Disc5 except for the end logical cluster address (R-02).
R-03-R-08. Parity Check for Data at End Logical Cluster address
A parity check for the end logical cluster address will be described.
A case in which the end logical cluster address precedes the recorded final logical cluster address of the media set (NO(a) in R-03) will be explained. When playing back Data1 shown in
Next, a case in which the end logical cluster address of divided data is the same as the recorded final logical cluster address of the media set (YES(b) in R-03) will be explained.
If the recorded final Disc=Disc4, as shown in
If the recorded final Disc≠Disc4, as shown in
In the embodiment, an example of the recording destination of a temporary parity has been explained with reference to
For example, as shown in
As shown in
Further, when the system 100 additionally writes D4-1 and D5-1, as shown in
In this manner, data are sequentially recorded even in the additional information recording area. Even when a recording medium such as BD-R is applied, a temporary parity can be recorded without any problem. When a temporary parity is recorded at logical cluster address N in the additional information recording area of one Disc (Disc2) (one temporary parity is recorded), as shown in
The embodiment has described a case in which Info Area is automatically updated in correspondence with an Eject instruction. However, the Info Area update timing is not limited to this, and Info Area can be updated at various timings. For example, Info Area may be updated by a manual operation to the system 100. More specifically, upon receiving an Info Area update instruction corresponding to an Info Area update operation by the user, the system 100 performs Read for a media set, checks a logical cluster address where no parity is recorded, and records Info data and a temporary parity at this cluster address in Info Area.
The embodiment will be summarized.
The system 100 can divide recording data, parallelly write the divided recording data blocks in parallelly connected recording media, and parallelly read them out. The recording and readout speeds can therefore be increased.
The system 100 can easily implement parallel recording/playback of data using a parity in a write-once storage medium.
By using a parity, the system 100 can detect a read error caused by disc damage upon carrying a storage medium, and alteration using another apparatus.
Since a parity for an area where parallel recording data are not completely recorded is temporarily saved in an area outside the file system management area, the system 100 can prevent a parity error without wasting the capacity of a storage medium.
Note that software can execute all the processes described above. Hence, the above-described processes can be implemented by only installing, in the system 100, a program for executing these processes, and executing the program.
For example, the system 100 can download the program from the server, store the downloaded program, and complete the installation of the program. Alternatively, the system 100 can read the program from a computer-readable storage medium, store the read program, and complete the installation of the program.
At least one embodiment described above can provide an information recording apparatus capable of efficiently recording parity data, and a formatting method. Also, at least one embodiment described above can provide an information playback apparatus capable of playing back recording data by using efficiently recorded parity data.
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 are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Number | Date | Country | Kind |
---|---|---|---|
2012-176383 | Aug 2012 | JP | national |
2013-119959 | Jun 2013 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5696933 | Itoh et al. | Dec 1997 | A |
5809516 | Ukai et al. | Sep 1998 | A |
7016601 | Yoneya et al. | Mar 2006 | B1 |
8422850 | Nakane | Apr 2013 | B2 |
Number | Date | Country |
---|---|---|
05-073226 | Mar 1993 | JP |
2004-342204 | Dec 2004 | JP |
2005-302111 | Oct 2005 | JP |
2010-123167 | Jun 2010 | JP |
Number | Date | Country | |
---|---|---|---|
20140043949 A1 | Feb 2014 | US |