1. Field of the Invention
The present invention relates to an information processing apparatus, an information processing method, and a program and, in particular, to an information processing apparatus, an information processing method, and a program that convert data into a file system format employed by a medium, such as a disk or a flash memory, and record and reproduce the data onto and from the medium.
For example, the present invention relates to an information processing apparatus, an information processing method, and a program that allow an application designed for recording and reproducing data in a format of a Blu-ray Disc™ file system to record and reproduce data onto and from a medium of a format other than a Blu-ray Disc™ file system format (such as a flash memory).
2. Description of the Related Art
A plurality of types of medium, such as a flash memory and a disk medium including a Blu-ray Disk™, have been used in order to record a television program using a recorder or a moving image captured by a video camera.
In order to manage data items recorded on such a data recording medium, a file system is used. A file system defines rules for ensuring data recording and reproduction using a medium. Examples of the rules include an amount of data per unit of data recorded in the medium, an amount of data per unit of data reproduced from the medium, a file structure or a directory structure, a correspondence between a real data item and a management data item, and a file name setting rule.
For example, FAT (File Allocation Table) and UDF (Universal Disk Format) generally used for an optical disk, such as a Blu-ray Disc™, are developed. Note that FAT is described in, for example, Japanese Unexamined Patent Application Publication No. 2008-262381, and UDF is described in, for example, Japanese Unexamined Patent Application Publication Nos. 2007-305171 and 2004-350251.
These file systems have rules specific to the file systems. For example, an amount of data per unit recorded in the medium, an amount of data per unit reproduced from the medium, and a file name setting rule differ from file system to file system. More specifically, FAT32 defines a maximum file size as 4 GB. However, in the UDF, a maximum file size is far larger than 4 GB.
A data recording and reproduction application running in an apparatus that uses a Blu-ray Disc™ as a data recording and reproduction medium generates data to be recorded and sets a file name in accordance with the rule defined by the UDF. Most of the files of recorded data generated by the UDF compliant application have a size far larger than 4 GB. Accordingly, data of the file generated by the application can be read or written from and to a UDF formatted medium (e.g., a Blu-ray Disc™). However, the data are unable to be written to a medium having a file system different from the UDF (e.g., a flash memory that employs the FAT).
Accordingly, the present invention provides an information processing apparatus, an information processing method, and a program that allow an application for generating data to be recorded and for reproducing the data using a particular file system to process data based on a different file system.
More specifically, the present invention provides an information processing apparatus, an information processing method, and a program that support recording media of different file systems (e.g., a Blu-ray Disc™ and a flash memory).
According to an embodiment of the present invention, an information processing apparatus includes an application execution unit configured to generate data to be recorded onto a medium that records data or reproduce data read from the medium, a file system unit configured to manage data recorded on the medium using a file system, and a file conversion unit configured to perform conversion between a first file format processable by the application execution unit and a second file format defined by the file system. The file conversion unit converts a file of the first file format generated by the application execution unit into a file of the second file format having an allowable size defined by the file system and supplies the converted file to the file system unit in the form of a file to be recorded.
The file conversion unit can separate a file of the first file format generated by the application execution unit into a plurality of files, each having an allowable maximum file size defined by the file system and supply the generated separate files to the file system unit in the form of files to be recorded.
The file conversion unit can assign a file name to each of the separate file names, and the file name can include information regarding a file name of the file separated into the separate files and information regarding arrangement of the separate file.
The file conversion unit can receive a data read request from the application execution unit and acquire the file names of separate files recorded on the medium using a file name contained in the data read request, and the file conversion unit can output, to the file system unit, a read request having parameters representing the acquired file names of separate files.
The file conversion unit can concatenate a plurality of separate files read from the medium by the file system unit, generate a readout file requested by the application execution unit, and supply the generated readout file to the application execution unit.
The file conversion unit can receive the file read from the medium and subjected to editing processing performed by the application execution unit and convert the file. When the editing processing will result in data deletion, the file conversion unit can identify a file to be edited having the second format and including data to be deleted by the data deletion, and the file conversion unit can perform a file conversion process including at least one of updating of the file to be edited and deleting of the file to be edited in accordance with a data state after the data deletion and supply the edited file to the file system unit as a file to be recorded.
The file conversion unit can receive the file read from the medium and subjected to editing processing performed by the application execution unit and convert the file. When the editing processing will result in data insertion, the file conversion unit can identify a file to be edited having the second format and including data to be inserted by the data insertion, and the file conversion unit can perform a file conversion process including at least one of updating of the file to be edited and generating of a new file having the second file format in accordance with a data state after the data insertion and supply the edited file to the file system unit as a file to be recorded.
According to another embodiment of the present invention, an information processing method for use in an information processing apparatus is provided. The method includes the steps of generating data to be recorded onto a medium that records data or reading data from the medium and reproducing data using an application execution unit of the information processing apparatus, performing conversion between a first file format processable by the application execution unit and a second file format defined by a file system employed by the medium using a file conversion unit of the information processing apparatus, and recording, onto the medium, a file generated in the step of performing conversion between the first file format and the second file format and having the second file format using a media interface of the information processing apparatus. The step of performing conversion between the first file format and the second file format involves converting a file of the first file format generated by the application execution unit into a file of the second file format having an allowable size defined by the file system and supplying the converted file to a file system unit of the information processing apparatus in the form of a file to be recorded.
According to still another embodiment of the present invention, a program for causing an information processing apparatus to perform information processing is provided. The program includes the steps of generating data to be recorded onto a medium that records data or reproduce data from the medium using an application execution unit of the information processing apparatus, performing conversion between a first file format processable by the application execution unit and a second file format defined by a file system employed by the medium using a file conversion unit of the information processing apparatus, and recording, onto the medium, a file generated in the step of performing conversion between the first file format and the second file format and having the second file format using a media interface of the information processing apparatus. The step of performing conversion between the first file format and the second file format involves converting a file of the first file format generated by the application execution unit into a file of the second file format having an allowable size defined by the file system and supplying the converted file to a file system unit of the information processing apparatus in the form of a file to be recorded.
Note that by using a computer-readable recording medium or a communication medium, the program can be provided to, for example, an image processing apparatus or a computer system that can execute a variety of program code. By providing such a program in a computer-readable format, the processes in accordance with the program can be performed in the image processing apparatus or a computer system.
Further features and advantages of the present invention will become apparent from the following detailed description of exemplary embodiments with reference to the attached drawings. In addition, as used herein, the term “system” refers to a logical combination of a plurality of devices; the plurality of devices is not necessarily included in one body.
According to the embodiments of the present invention, when a file generated by the application execution unit does not comply with the specification of a file system employed by a recording medium, the file conversion unit is provided between the application execution unit and the file system unit that manages data recorded onto the medium. The file conversion unit converts the file generated by the application execution unit into a file having a file format allowable by the file system and supplies the converted file to the file system unit as a file to be recorded. This configuration allows data to be recorded or reproduced even in a configuration in which a file system employed by the application execution unit differs from a file system employed by the data recording medium.
An information processing apparatus, an information processing method, and a program according to embodiments of the present invention are described in detail below with reference to the accompanying drawings. The descriptions are made in the following order:
1. Configuration and Outline of Processing of Information Processing Apparatus
2. Structure of Data Recorded on First Medium (Blu-ray Disc™)
3. Data Recording and Reproduction Process onto and from Medium with File Separation Process and File Concatenation Process
4. File Separation Process, File Concatenation Process, and File Name Conversion Rule
5. Data Storing Structure of Second Medium and File Recognized by Application in File Conversion Process
6. File Conversion Process Performed during File Editing
7. Other Exemplary Configurations of Information Processing Apparatus
1. Configuration and Outline of Processing of Information Processing Apparatus
An exemplary configuration of an information processing apparatus according to an embodiment of the present invention and exemplary processing performed by the information processing apparatus are described first.
The information processing apparatus 100 further uses a second medium 112 mounted therein. Data is recorded onto the second medium 112 and is managed by using a file system different from that of the first medium 111. An example of the second medium 112 is a flash memory. Like the processing for the first medium 111, the information processing apparatus 100 records and reproduces data onto and from the second medium 112.
As shown in
The data processing unit 101 includes a central processing unit (CPU) having a program execution function of executing a variety of data processing programs. For example, the data processing unit 101 executes an application program that performs data recording and reproduction operations. The data processing unit 101 records data, such as broadcast data received through the communication unit 102, onto a medium and reproduces data recorded on the medium.
The communication unit 102 receives an airwave broadcast signal, performs communication over the Internet, or performs communication with an external apparatus. The input unit 103 serves as, for example, a user operation unit. The input unit 103 accepts a variety of input operations, such as an input of data recording instruction or a data reproduction instruction. Note that the input unit 103 can be operated by remote control and receive remote control information. The output unit 104 includes a display and a speaker. The output unit 104 outputs an image and sound. The memory 105 includes a random access memory (RAM) and a read only memory (ROM). The memory 105 is used as an area for storing an application program (hereinafter simply referred to as an “application”) executed by the data processing unit 101. The memory 105 is further used as a parameter area and a work area of the application. Still furthermore, the memory 105 is used as a buffer area of data to be recorded onto a medium.
The first media interface 106 is used when data is recorded and reproduced onto and from the first medium 111 (e.g., a Blu-ray Disc™). In response to a request received from the data processing unit 101, the first media interface 106 writes data onto the first medium 111 or reads data recorded on the first medium 111. The second media interface 107 is used when data is recorded and reproduced onto and from the second medium 112 (e.g., a flash memory). In response to a request received from the data processing unit 101, the second media interface 107 writes data onto the second medium 112 or reads data recorded on the second medium 112.
Data management using a first file system (e.g., UDF) is performed for the first medium 111. In contrast, data management using a second file system (e.g., File Allocation Tables 32 (FAT32)) is performed for the second medium 112.
A data recording and reproduction application executed by the data processing unit 101 performs data processing in accordance with only one of the two different file systems. In this example, the data recording and reproduction application performs data processing in accordance with the first file system (e.g., UDF) employed by the first medium 111 (e.g., a Blu-ray Disc™).
That is, a recording file generated by the application executed in the data processing unit 101 is a data file that has a data size and a file name that are compatible with UDF. In addition, when reproducing data, the data processing unit 101 performs processing in accordance with the data size and the file name that are compatible with UDF.
Accordingly, when performing data recording and reproduction processing using the first medium 111, the data recording and reproduction application executed in the data processing unit 101 can perform the processing without any problem.
However, it is difficult for the data recording and reproduction application alone to record and reproduce data onto and from the second medium 112 (e.g., a flash memory) that employs the second file system (e.g., FAT32).
Therefore, according to the present embodiment, in order to record and reproduce data onto and from the second medium 112, the information processing apparatus performs a file conversion process using the data processing unit 101. The processing performed by the data processing unit 101 is described in detail next with reference to
Among these sub-units, the encryption processing sub-unit 151 and the application execution sub-unit (the recording and reproduction processing sub-unit) 152 perform processing using the first file system (e.g., UDF) employed by the first medium 111 and, more specifically, in accordance with the unit of processing data, the file size, and the file name convention defined by the first file system.
The encryption processing sub-unit 151 encrypts data to be recorded onto a medium or decrypts encrypted data read from a medium. More specifically, for example, the encryption processing sub-unit 151 performs encrypting and decrypting processing in accordance with the Advanced Access Content System (AACS), which is a standard for content distribution and digital rights management. According to the specification of the AACS, content is separated into units (CPS units), and each of the units is encrypted using an encryption key (a CPS unit key). This AACS standard is designed for the encryption process structure used when content is recorded onto a Blu-ray Disc™, which is the first medium 111. The unit of data subjected to the encryption process performed by the encryption processing sub-unit 151 complies with the unit of data to be recorded of a Blu-ray Disc™.
In addition, the application execution sub-unit 152 performs processing in accordance with the standard of the first file system (e.g., UDF) employed by the first medium 111. Accordingly, the size and name of a data file to be recorded comply with the specification of the first file system.
The second-media support file system sub-unit 154 manages data when data is recorded and reproduced onto and from the second medium 112. The second-media support file system sub-unit 154 writes or reads data onto and from the second medium 112 that employs, for example, FAT32.
The file conversion processing sub-unit 153 converts a data format used for the encryption processing sub-unit 151 and the application execution sub-unit 152 that use the first file system into a data format used for the second-media support file system sub-unit 154 that writes and reads data using the second file system and vice versa.
For example, the file conversion processing sub-unit 153 performs the following processes.
When recording data generated or processed by the encryption processing sub-unit 151 or the application execution sub-unit 152 onto the second medium 112, the file conversion processing sub-unit 153 converts the data format of the data received from the encryption processing sub-unit 151 or the application execution sub-unit 152 into a format that satisfies the specification of the second file system employed by the second medium 112. Thereafter, the file conversion processing sub-unit 153 supplies the converted data to the second-media support file system sub-unit 154.
In addition, when reading data recorded on the second medium 112 and supplying the data to the encryption processing sub-unit 151 or the application execution sub-unit 152, the file conversion processing sub-unit 153 converts the data format of the data read from the second medium 112 by the second-media support file system sub-unit 154 into a format that satisfies the specification of the first file system. Thereafter, the file conversion processing sub-unit 153 supplies the converted data to the encryption processing sub-unit 151 or the application execution sub-unit 152.
An example of the processing performed by the file conversion processing sub-unit 153 is described in more detail with reference to
(Layer a) the encryption processing sub-unit 151 and the application execution sub-unit 152,
(Layer b) the file conversion processing sub-unit 153, and
(Layer c) the second-media support file system sub-unit 154.
In Layer a, the encryption processing sub-unit 151 and the application execution sub-unit 152 perform processing in accordance with the specification of the first file system employed by the first medium 111. A recording file 181 [00001.mts] for the first medium 111 is illustrated in
In Layer c, the second-media support file system sub-unit 154 performs processing in accordance with the specification of the second file system employed by the second medium 112. Three recording files 182-1 to 182-3 ([00001—01] to [00001—03]) for the second medium 112 are illustrated in
In Layer b, the file conversion processing sub-unit 153 is disposed between the layer a (the encryption processing sub-unit 151 and the application execution sub-unit 152) and the layer c (the second-media support file system sub-unit 154). When a file is exchanged between the layers a and c, the file conversion processing sub-unit 153 converts the file format so that the file is processable in each of the layers. More specifically, the file conversion processing sub-unit 153 converts the file size and the file name.
For example, suppose that the second file system employed by the second medium 112 is the FAT32 while the first file system employed by the first medium 111 is the UDF. The maximum file size defined by FAT32 is 4 GB, while the maximum file size defined by UDF is a value far larger than 4 GB.
In such a case, when recording the data generated by the encryption processing unit 151 or the application execution unit 152 onto the second medium 112, the file conversion processing unit 153 splits the data file generated by the encryption processing unit 151 or the application execution unit 152 into a plurality of separate files each having a size smaller than or equal to 4 GB. The file conversion processing unit 153 then supplies the plurality of separate files to the second-media support file system unit 154 as files to be recorded.
That is, the data file generated by the encryption processing sub-unit 151 or the application execution sub-unit 152 is the file [00001.mts] shown in
In addition, when the second-media support file system sub-unit 154 supplies a file read from the second medium 112 to the encryption processing sub-unit 151 or the application execution sub-unit 152, the file conversion processing sub-unit 153 performs the following processing. That is, the file conversion processing sub-unit 153 concatenates the three recording files 182-1 to 182-3 ([0000101] to [00001—03]), each having a size smaller than or equal to 4 GB, shown in
2. Structure of Data Recorded on First Medium (Blu-ray Disc™)
The structure of data recorded on the first medium (Blu-ray Disc™) is described next with reference to
Directories [AACS] and [BDAV] are generated immediately beneath the root directory [Root]. The [AACS] directory stores, for example, encryption key information defined by the specification of the above-described AACS. More specifically, a CPS unit key file that contains key information used for encryption and decryption of content to be recorded onto a medium and a media key block (MKB) file which is a key block used for acquiring a key from a CPS unit key are set in the [AACS] directory.
The [BDAV] directory is a directory in which actual data of recorded content and reproduction control information used for a reproduction process are set. More specifically, the [BDAV] directory contains index information (info.bdav.file) including the title of the content, a menu thumbnail (Files for Menu.Thumbnail) including still image content, a playlist (PLAYLIST) serving as reproduction control information regarding moving image content, clip information (CLIPINF), and a stream (STREAM) which is actual data of the content. For example, a file containing the actual data of the recorded content (a stream file) is recorded in the stream directory (STREAM).
Each of [00001.mts] to [00003.mts] shown in
The playlist contains play items each of which specifies data to be reproduced. A play item corresponds to a clip information item including reproduction span information. By using the playlist, a particular clip information item is selected. In addition, the clip information item contains reproduction span indication information regarding stream data serving as the actual data of content. Using the clip information, stream data is selectively read, and a stream reproduction process is performed.
As illustrated in
In the directory structure shown in
Each of the stream files [00001.mts], [00002.mts], and [00003.mts] shown in
3. Data Recording and Reproduction Process onto and from Medium with File Separation Process and File Concatenation Process
A data recording process and a data reproduction process onto and from a medium with a file separation process and a file concatenation process are described next.
As described above, when data generated by the encryption processing sub-unit 151 or the application execution sub-unit 152 that performs data processing in accordance with the first file system employed by the first medium 111 is recorded onto the second medium 112, the data is converted into data that complies with the specification of the second file system.
In the following descriptions, it is assumed that the first file system is UDF, and the second file system is FAT32. However, the present embodiment is not limited to such a combination. The present embodiment is applicable to the processing in which the processing performed in the application execution sub-unit differs from the processing that uses the file system employed by a medium in use (the second medium in the present embodiment).
As described above, the maximum file size defined by FAT32 is 4 GB, while the maximum file size defined by UDF is a value far larger than 4 GB.
The outline of the processing performed by the file conversion processing sub-unit 153 is as follows.
That is, when performing a data recording and reproduction process or a data editing process using the second medium 112, the application execution sub-unit 152 or the encryption processing sub-unit 151 separates a file or concatenates files so as to maintain the maximum file size limitation (4 GB) defined by the second file system (FAT32) employed by the second medium 112.
Note that, in the present embodiment, in general, a file that is processed by the application execution sub-unit 152 or the encryption processing sub-unit 151 and that may have a size larger than 4 GB is a stream file which contains the actual data of content. Accordingly, the file conversion processing sub-unit 153 performs a file conversion process, including a file separation process or a file concatenation process, on a stream file. In contrast, the file conversion processing sub-unit 153 does not perform the file conversion process on a file other than a stream file, that is, a file having a size smaller than or equal to 4 GB (e.g., a management file or a reproduction control file).
The file conversion process further includes a file name conversion process. That is, as shown in
The processing performed by the file conversion processing sub-unit 153 is schematically described with reference to the following two cases:
(A) a process performed when data is recorded onto the second medium 112, and
(B) a process performed when data is reproduced from the second medium 112.
(A) Process Performed when Data is Recorded onto Second Medium 112
In order to record data onto the second medium 112, the file conversion processing sub-unit 153 performs the following processes:
(a1) separating stream data having a size larger than the maximum file size defined by the second file system,
(a2) assigning a file name to each of a separate files, and
(a3) delivering the separate files to the second-media support file system sub-unit 154.
(B) Process Performed when Data is Reproduced from Second Medium 112
The file conversion processing sub-unit 153 examines from which separate files a stream file requested by the application execution sub-unit 152 or the encryption processing sub-unit 151 is formed. The file conversion processing sub-unit 153 then reads the separate files and concatenates the read separate files into one file. Thereafter, the file conversion processing sub-unit 153 delivers the concatenated file to the application execution sub-unit 152 or the encryption processing sub-unit 151.
For example, when the application execution sub-unit 152 requests playing back of content from a specified point of time, the file conversion processing sub-unit 153 converts information indicating the byte position in the concatenated file into the byte position in the separate file. Note that conversion from the specified point of time into the byte position in the concatenated file is performed in an application layer. More specifically, the following sequence of processes is performed:
(b1) determining, using the stream file name and the byte position in the file, from which byte position of which separate file data reproduction is to be started,
(b2) submitting an instruction to read data from the byte position in the separate file to the second-media support file system sub-unit 154, and
(b3) delivering the data read out by the second-media support file system sub-unit 154 to the application execution sub-unit 152 or the encryption processing sub-unit 151.
The sequence of processes performed by the file conversion processing sub-unit 153 is described in detail next with reference to the flowchart illustrated in
The processing performed by the file conversion processing sub-unit 153 when data is recorded onto the second medium 112 is described first with reference to the flowchart illustrated in
In the flowchart shown in
First, in step S101, the application execution sub-unit 152 submits a file write processing instruction. Note that this processing flow is performed when a medium to which data is written is the second medium. More specifically, in step S101, the application execution sub-unit 152 submits a file write processing instruction having a parameter indicating the name of a file to be written.
In step S102, the file conversion processing sub-unit 153 detects the file write processing instruction submitted by the application execution sub-unit 152.
In step S103, the file conversion processing sub-unit 153 analyzes the file write processing instruction submitted by the application execution sub-unit 152 and recognizes the type and size of a file to be written.
If, in step S104, the file conversion processing sub-unit 153 determines that the type of the file is a stream file, the processing proceeds to step S105. However, if, in step S104, the file conversion processing sub-unit 153 determines that the type of the file is not a stream file, the processing proceeds to step S111, where the file write processing instruction received from the application execution sub-unit 152 is directly output to the second-media support file system sub-unit 154.
As noted above, it is ensured that a file other than a stream file has a size smaller than or equal to the maximum size allowed by the file system employed by the second medium (4 GB). Accordingly, a write instruction of a file other than a stream file is directly output to the second-media support file system sub-unit 154. Thereafter, the processing proceeds to step S121, where the second-media support file system sub-unit 154 directly uses the write instruction generated by the application execution sub-unit 152 and writes data to the second medium.
However, if, in step S104, the file conversion processing sub-unit 153 determines that the type of the file is a stream file, the processing proceeds to step S105. When the type of the file is a stream file, the file size may be larger than the maximum size allowed by the file system employed by the second medium (4 GB). In such a case, the file size is determined in step S105.
If the file size is larger than the maximum file size allowed by the file system employed by the second medium (4 GB), the processing proceeds to step S106. However, the file size is not larger than the maximum file size, the processing proceeds to step S112.
In step S112, a file name is assigned to a file to be written having a size smaller than or equal to the allowable maximum file size (4 GB). Note that the file conversion processing sub-unit 153 converts the file name of the file (the original file) generated by the application execution sub-unit 152 into the name of a file to be recorded onto the second medium in accordance with a predetermined rule. An example of the conversion process is described in more detail below.
For example, when the file name is set, the file name conversion process is performed in step S112 so as to satisfy the following conditions:
(a) setting a file name that is allowed by the second file system employed by the second medium, and
(b) setting identification information indicating that the file generated by the application execution sub-unit 152 (the original file) is not separated.
After the file name is set in step S112, the processing proceeds to step S121, where the second-media support file system sub-unit 154 writes the file onto the second medium using the file name set in step S112. Note that the file name conversion may be performed only when the file has been separated. If the file has not been separated, the setting may be made so that no file name conversion is performed.
If, in step S105, it is determined that the file size is larger than the allowable maximum file size of the file system employed by the second medium (4 GB), the processing proceeds to step S106. In step S106, the file is separated, and a file name is set for each of the separate files. That is, a plurality of separate files each having a size smaller than or equal to the allowable maximum file size of the file system employed by the second medium (4 GB) are generated, and a file name is set for each of the generated separate files.
Note that, as described above, the file conversion processing sub-unit 153 converts the file name of the file (the original file) generated by the application execution sub-unit 152 into the name of a file to be recorded onto the second medium in accordance with a predetermined rule. In addition, when performing a file separating process, the file conversion processing sub-unit 153 separates a file in accordance with a predetermined rule. For example, the file conversion processing sub-unit 153 assigns, to each of a plurality of separate files, a file name including the identification information regarding the original file and the arrangement information regarding the separate file. The file name setting rule and the separation rule are described in more detail below.
For example, the file name setting rule for a separate file satisfies the following conditions:
(a) setting a file name that is allowed by the second file system employed by the second medium for the separate file, and
(b) setting a file name including identification information indicating that the file is generated from a file (an original file) generated by the application execution sub-unit 152 through a file separation process.
After the file name is set in step S106, the processing proceeds to step S107.
In step S107, the file conversion processing sub-unit 153 outputs, to the second-media support file system sub-unit 154, a file write instruction having a parameter indicating the file names assigned to the separate files. In step S121, the second-media support file system sub-unit 154 writes all of the separate files onto the second medium using the file names assigned to the separate files in step S106.
An exemplary processing performed by the file conversion processing sub-unit 153 when data recorded on the second medium 112 is reproduced is described next with reference to
First, in step S201, the application execution sub-unit 152 submits a file read instruction. Note that this processing flow is applied to the case in which a medium to be read is the second medium. In step S201, the application execution sub-unit 152 submits the file read instruction having parameters indicating the file name of a file to be read and the byte position corresponding to the read start position in the file.
In step S202, the file conversion processing sub-unit 153 detects the file read instruction submitted from the application execution sub-unit 152.
Subsequently, in step S203, the file conversion processing sub-unit 153 analyzes the file read instruction submitted from the application execution sub-unit 152 and determines the file type of the file to be read.
If, in step S204, the file conversion processing sub-unit 153 determines that the file type indicates a stream file, the processing proceeds to step S205. However, in step S204, the file conversion processing sub-unit 153 determines that the file type does not indicate a stream file, the processing proceeds to step S208, where the file conversion processing sub-unit 153 directly outputs the file read instruction received from the application execution sub-unit 152 to the second-media support file system sub-unit 154.
As illustrated in
Therefore, when reading a file, the file conversion processing sub-unit 153 directly outputs the file read instruction received from the application execution sub-unit 152 to the second-media support file system sub-unit 154 in step S208. In step S211, the second-media support file system sub-unit 154 reads a file from the second medium directly using the file read instruction output from the application execution sub-unit 152.
However, if, in step S204, the file conversion processing sub-unit 153 determines that the file type indicates a stream file, the processing proceeds to step S205. When the file type indicates a stream file, the file size may be larger than the maximum file size defined by the file system employed by the second medium (4 GB). Accordingly, as illustrated by the flowchart shown in
In step S205, the file conversion processing sub-unit 153 identifies a file that contains the data to be read and specified by the application execution sub-unit 152 using the arguments (the parameters) of the read instruction submitted by the application execution sub-unit 152 (i.e., the file name of the original file and the byte position from which the data is to be read in the original file). Furthermore, in step S206, the file conversion processing sub-unit 153 computes the file name of a second-medium file that contains the data to be read and specified by the application execution sub-unit 152 and the byte position from which the data is to be read in the file.
As described above with reference to the flowchart shown in
Subsequently, in step S207, the file conversion processing sub-unit 153 submits, to the second-media support file system sub-unit 154, a read instruction having parameters indicating the file name of the file to be read and the byte position from which data is to be read in the file.
In step S211, the second-media support file system sub-unit 154 reads the file from the second medium in accordance with the read instruction submitted from the file conversion processing sub-unit 153 in step S207.
Thereafter, the file conversion processing sub-unit 153 performs processing indicated by the flowchart shown in
However, if, in step S301, the readout file is a stream file, the processing proceeds to step S302, where the file conversion processing sub-unit 153 further determines whether the readout file is a separate file.
If the readout file is not a separate file, the processing proceeds to step S312, where the file conversion processing sub-unit 153 converts the file name of the file read from the second medium to the original file name and outputs the file to the application execution sub-unit 152. Thereafter, the file readout process is completed. Note that the file name conversion rule is predetermined. The file conversion processing sub-unit 153 converts the file name in accordance with the predetermined rule. However, as noted above, the file name conversion may be performed only when the file separation process is performed. In such a case, the processing performed in step S312 may be removed.
However, if, in step S302, the readout file is a separate file, the processing proceeds to step S303. In step S303, the separate files read from the second medium are concatenated, and an unseparated original file is generated. In addition, the original file name is assigned to the file. Thereafter, the file is output to the application execution sub-unit 152, and the processing is completed. Note that the file separation rule, the file concatenation rule, and the file name conversion rule are predetermined. The file conversion processing sub-unit 153 concatenates the separate files and assigns the file name to the concatenated file in accordance with the predetermined rules. In this way, the original file name is restored from the names of the separate file names and is output to the application execution sub-unit 152. By providing the file conversion processing sub-unit 153, the same module can be used as the application execution sub-unit 152 even when data is reproduced from the first medium 111 that has a less strict condition in terms of a file size and is reproduced from the second medium 112 that has a strict condition in terms of a file size. Accordingly, manufacturing of a reproduction apparatus can be advantageously facilitated.
As described above with reference to the flowcharts illustrated in
4. File Separation Process, File Concatenation Process, and File Name Conversion Rule
As described above, when recording and reproducing a stream file onto and from a second medium, the file conversion processing sub-unit 153 performs one of the file separation process and the file concatenation process. The file conversion processing sub-unit 153 further performs the file name conversion process. These processes are performed in accordance with the predetermined rules.
The file separation process and the file concatenation process are described first with reference to
For example, the separation rule can include one of the following conditions (a) to (d) as shown in
(a) The file separation point is set so as to be a multiple of a sector boundary (2048 bytes) set for a medium that employs the first file system (a Blu-ray disc™);
(b) The file separation point is set so as to be a multiple of an aligned unit (6144 bytes) subjected to an encryption process, which is a unit of the content recorded in a medium that employs the first file system (a Blu-ray disc™)
(c) The file separation point is set so as to be a multiple of 1 MB; and
(d) The file is separated by 3 GB.
A file is separated using one of the rules (a) to (d). In addition, when files are concatenated, the files are concatenated using the separation points determined in accordance with one of the rules (a) to (d).
An example of the file name conversion rule is described next with reference to
(a) A serial number xxx is used for the extension of the separate files (the serial number xxx may be decimal, hexadecimal, or base-36). Examples of the file name (in the case of a decimal xxx) include [00001.001], [00001.002], [00001.003] . . . or [00001.000], [00001.001], [00001.002], . . .
(b) The file extension continues to be “mts”. A serial number xx is appended to the filename (the serial number xx may be decimal, hexadecimal, or base-36). Examples of the file name (in the case of a decimal xxx) include [00001—1.mts], [00001—02.mts], [00001—03.mts] . . . or [00001—00.mts], [00001—01.mts], [00001—02.mts], . . .
When the separation process is performed, a file name is assigned to each of the separate files using one of the above-described rules (a) and (b). Thereafter, the separate files are recorded onto the second medium. In contrast, when the concatenation process is performed, the original file name is restored for the concatenated file using an operation that is the reverse of the operation used when the separation process is performed.
While the file name conversion process performed when a file is separated has been described with reference to
5. Data Storing Structure of Second Medium and File Recognized by Application in File Conversion Process
An exemplary data structure of data recorded on the second medium in accordance with the specification of the second file system and an example of a file recognized by the application execution sub-unit 152 through the file conversion process performed by the file conversion processing sub-unit 153 are described next with reference to the drawings subsequent to
Directories [AACS] and [BDAV] are generated immediately beneath the root directory [Root]. The [AACS] directory stores, for example, encryption key information in accordance with the specification of the above-described AACS. More specifically, a CPS unit key file that contains key information used for encryption and decryption of content to be recorded onto a medium and a media key block (MKB) file which is a key block used for acquiring a key from a CPS unit key are set in the [AACS] directory.
The [BDAV] directory is a directory in which actual data of recorded content and reproduction control information used for a reproduction process are set.
More specifically, the [BDAV] directory contains index information (info.bday.file) including the title of the content, a menu thumbnail (Files for Menu.Thumbnail) including still image content, a playlist (PLAYLIST) serving as reproduction control information regarding moving image content, clip information (CLIPINF), and a stream (STREAM) which is actual data of the content. For example, a file containing the actual data of the recorded content (a stream file) is recorded in the stream directory (STREAM).
The files [info.bday.file] to [CLIPINFO] in the AACS directory setting file and the BDAV directory setting file are similar to those illustrated in
A file set in the stream directory [STREAM] 201 located as the last sub-directory of the BDAV directory shown in
In the directory setting illustrated in
A plurality of separate files 211 [00002—01.mts], 212 [00002—02.mts], . . . generated by separating the original file [00002.mts] are set in the sub-directory 210 [FRAGMENT—00002]. Similarly, a plurality of separate files 221 [00004—01.mts], 222 [00004—02.mts], . . . generated by separating the original file [00004.mts] are set in the sub-directory 220 [FRAGMENT—00004].
Note that a stream file that is not located beneath a sub-directory [FRAGMENT_xxxxx] (e.g., the stream file [00001.mts] 202 or the stream file [00003.mts] shown in
Unlike the directory setting shown in
That is, in the example shown in
For example, a stream file separated by the file conversion processing sub-unit 153 is recorded onto the second medium 112 using one of the directory setting illustrated in
However, when such separate recorded files are read from the second medium 112 and are supplied to the application execution sub-unit 152 or the encryption processing sub-unit 151, the above-described processing illustrated using the flowcharts of
As a result of the processing, the directory structure recognized by the application execution sub-unit 152 or the encryption processing sub-unit 151 differs from the directory structure that contains separate files as shown in
As shown in
6. File Conversion Process Performed during File Editing
The processing performed by the file conversion processing sub-unit 153 when the file conversion processing sub-unit 153 reads separate files recorded on the second medium 112 and the application execution sub-unit 152 edits the file (e.g., data deletion or data insertion) is described next.
In some cases, the application execution sub-unit 152 reads a file recorded on the second medium 112 and edits the data in the file. Examples of data editing include data deletion or data insertion. The application performs such processing on an original file [xxxxx.mts]. However, in this case, the original file [xxxxx.mts] is a concatenated file of a plurality of separate files [xxxxx—01.mts] to [xxxxx_nn.mts] recorded on the second medium 112.
When the application execution sub-unit 152 performs an editing process, the edited separate files [xxxxx—01.mts] to [xxxxx_nn.mts] may not be directly recorded onto the second medium 112. For example, through data deletion, all data in a separate file may be removed. In addition, through data insertion, the size of a separate file may exceed 4 GB.
Accordingly, when the application execution sub-unit 152 performs an editing process, it may be necessary for the file conversion processing sub-unit 153 to remove a separate file, add a separate file, or update a separate file in accordance with the edited stream file. The processing performed by the file conversion processing sub-unit 153 when a data editing process is performed is described next with reference to
(6-1) Exemplary Processing Performed during Data Deletion, and
(6-2) Exemplary Processing Performed during Data Insertion.
(6-1) Exemplary Processing Performed during Data Deletion
The processing performed by the file conversion processing sub-unit 153 when separate files recorded on the second medium 112 are read and data is deleted from the file by the application execution sub-unit 152 is described first.
When data is deleted, one of the following cases occurs:
(Case 1) All data to be deleted is contained in a single separate file to be edited,
(Case 2) Data to be deleted spans two neighboring separate files to be edited, and
(Case 3) Data to be deleted spans three or more continuous separate files to be edited.
The file conversion processing sub-unit 153 reconstructs the separate files in accordance with the one of the above-described cases. The data deletion processes performed in the above-described cases are sequentially described below with reference to
(Case 1) Case in which all Data to be Deleted is Contained in Single Separate File to be Edited
The processing performed in the case in which all the data to be deleted is contained in a single separate file to be edited is described first with reference to
(a) A file to be edited (a concatenated original file to be edited by an application),
(b) Files to be edited (separate files to be edited that are recorded in a second medium),
(c) Data subjected to editing processing,
(d) Edited file (edited separate files to be recorded onto the second medium), and
(e) Edited file (an original file generated by concatenating the separate files edited by the application).
In
In
Note that [(new)] is attached to the serial number portion of an update separate file (e.g., [f01 (new)]). Similarly, [(new)] is attached to the serial number portion of an update concatenated file (e.g., [F (new)]). Also, note that [f01 (new)] and [F (new)] indicate that these files are updated files of the separate file [f01] and the concatenated file [F], respectively. The file names of these files are not changed.
When stream file recorded on the second medium 112 is edited by the application execution sub-unit 152, a data readout process that is similar to the data reproduction process indicated by the flowchart illustrated in
In the data readout process, the files to be edited (the separate files indicated by (b) in
Note that the file conversion processing sub-unit 153 maintains, in a memory, the names of the separate files that form the concatenated file supplied to the application execution sub-unit 152 and the data start and end positions of the separate files. Such data position information includes the concatenated data positions of the separate file (i.e., separation positions). The file conversion processing sub-unit 153 separates the file or concatenates the files using one of the rules illustrated in
The application execution sub-unit 152 edits the file to be edited (indicated by (a) in
In the deletion process (Case 1) illustrated in
The application execution sub-unit 152 edits the file to be edited (indicated by (a) in
After the editing processing is performed, the application execution sub-unit 152 submits a write instruction to write the edited file (the concatenated file) [F (new)] indicated by (e) in
More specifically, the file conversion processing sub-unit 153 determines the correspondence between the data start and end positions including the concatenation data position (the separation position) of each of the separate files and the edited file (the concatenated file) indicated by (e) in
In this example, the data between the points “in” and “out” shown in
On the basis of the determination, the file conversion processing sub-unit 153 separates the edited file (the concatenated file) received from the application execution sub-unit 152 and indicated by (e) in
That is, in terms of the separate file [f01] including the deleted data (the data between the points “in” and “out”), the file conversion processing sub-unit 153 generates an updated file [f01 (new)] that does not include the deleted data. The data in the other separate files [f00], [f02], and [f03] remain unchanged. Accordingly, the file conversion processing sub-unit 153 does not update the separate files.
In this way, the separate files [f00], [f01 (new)], [f02], and [f03], some of which have been updated, are supplied from the file conversion processing sub-unit 153 to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
(Case 2) Case in which Data to be Deleted Spans Two Neighboring Separate Files to Be Edited
The processing performed in the case in which the data to be deleted spans two neighboring separate files to be edited is described next with reference to
(a) A file to be edited (a concatenated original file to be edited by an application),
(b) Files to be edited (separate files to be edited that are recorded in a second medium),
(c) Data subjected to editing processing,
(d) Edited file (edited separate files to be recorded onto the second medium), and
(e) Edited file (an original file generated by concatenating the separate files edited by the application).
As in
When the application execution sub-unit 152 edits a stream file recorded on the second medium 112, the files to be edited indicated by (b) in
In addition, the file conversion processing sub-unit 153 maintains, in a memory, the names of the separate files that form the concatenated file supplied to the application execution sub-unit 152 and the data start and end positions of each of the separate files.
The application execution sub-unit 152 performs, for example, editing processing instructed by the user on the file to be edited indicated by (a) in
In the deletion process illustrated in
The application execution sub-unit 152 performs, for example, editing processing instructed by the user on the file to be edited indicated by (a) in
After the editing processing is performed, the application execution sub-unit 152 submits a write instruction to write the edited file (the concatenated file) [F (new)] indicated by (e) shown in
More specifically, the file conversion processing sub-unit 153 recognizes the correspondence between the data start and end positions of each of the separate files including the concatenation point of the file maintained in the memory and the edited file (the concatenated file) indicated by (e) shown in
In this example, the data between the points “in” and “out” shown in
On the basis of the determination, the file conversion processing sub-unit 153 separates the edited file (the concatenated file) indicated by (e) shown in
That is, for the separate files [f01] and [f02] including the data to be deleted, the file conversion processing sub-unit 153 generates updated files [f01 (new)] and [f02 (new)] that do not contain the deleted data. The data in the other separate files [f00] and [f03] remain unchanged before and after the editing processing is performed. Accordingly, these separate files are not updated.
The separate files [f00], [f01 (new)], [f02 (new)], and [f03], some of which have been updated, are supplied from the file conversion processing sub-unit 153 to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
(Case 3) Case in Which Data to Be Deleted Spans Three or More Continuous Separate Files to Be Edited
The processing performed in the case in which the data to be deleted spans three or more continuous separate files to be edited is described next with reference to
(a) A file to be edited (a concatenated original file to be edited by an application),
(b) Files to be edited (separate files to be edited that are recorded in a second medium),
(c) Data subjected to editing processing,
(d1) Edited file (edited separate files to be recorded onto the second medium before the file names are changed),
(d2) Edited files (edited separate files to be recorded onto the second medium after the file names are changed), and
(e) Edited file (an original file generated by concatenating the separate files edited by the application).
As in
When the application execution sub-unit 152 edits a stream file recorded on the second medium 112, the files to be edited indicated by (b) in
In addition, the file conversion processing sub-unit 153 maintains, in a memory, the names of the separate files that form the concatenated file supplied to the application execution sub-unit 152 and the data start and end positions of each of the separate files.
The application execution sub-unit 152 performs, for example, editing processing instructed by the user on the file to be edited indicated by (a) in
In the deletion process illustrated in
The application execution sub-unit 152 performs, for example, editing processing instructed by the user on the file to be edited indicated by (a) in
After the editing processing is performed, the application execution sub-unit 152 submits a write instruction to write the edited file (the concatenated file) [F (new)] indicated by (e) shown in
More specifically, the file conversion processing sub-unit 153 recognizes the correspondence between the data start and end positions of each of the separate files including the concatenation point of the file maintained in the memory and the edited file (the concatenated file) indicated by (e) shown in
In this example, the data between the points “in” and “out” shown in
On the basis of the determination, the file conversion processing sub-unit 153 separates the edited file (the concatenated file) indicated by (e) shown in
That is, from among the separate files [f00], [f01], and [f02] including the data to be deleted, the file conversion processing sub-unit 153 removes the separate file [f01] having all the data to be deleted. For the separate files [f00] and [f02] including the data that still remain, the file conversion processing sub-unit 153 generates updated files [f00 (new)] and [f02 (new)] that do not contain the deleted data. The data in the other separate file [f03] remain unchanged before and after the editing processing is performed. Accordingly, this separate file is not updated.
In the update process, the separate files [f00 (new)], [f02 (new)], and [f03] are generated. However, the file names of the separate files are not serial numbers.
For example, when the name of the original file (the concatenated file) is [00001.mts], the full file names of the separate files indicated by (d2) shown in
[f00 (new)]=[00001—00.mts],
[f02 (new)]=[00001—02.mts], and
[f03]=[00001—03.mts].
Accordingly, [00001—01.mts] is missing.
As described above with reference to
However, as indicated by (d1) in
If it is difficult to satisfy the serial number rule for the names of separate files, the file conversion processing sub-unit 153 changes the file names of the separate files. That is, the file names of the separate files are changed (renamed) so that the serial number rule for the names of separate files is satisfied. That is, as indicated by (d2) in
For example, let [00001.mts] denote the file name of the original file (the concatenated file). Then, the full file names of the separate files are represented as follows:
[f00 (new)]->[f00 (new)]=[00001—01.mts] (not renamed),
[f02 (new)]->[f01 (new-rn)]=[00001—01.mts] (renamed), and
[f03 (new)]->[f02 (rn)]=[00001—02.mts].
As a result of renaming, the separate files corresponding to the updated concatenated file F [00001.mts] indicated by (e) in
[00001—00.mts],
[00001—01.mts], and
[00001—02.mts].
These three separate files are recorded onto the second medium 112.
In this way, by changing the file names so that the serial number rule for the names of separate files is satisfied and recording the files onto the second medium 112, the separate files can be reliably read from the second medium 112 in a readout process.
As described above with reference to the flowcharts illustrated in
The flowchart in
(A) whole sequence,
(B) sequence of processes in Case 1 (refer to
(C) sequence of processes in Case 2 (refer to
(D) sequence of processes in Case 3 (refer to
The whole sequence (A) is described first. The whole sequence (A) represents the sequence performed by the file conversion processing sub-unit 153 when the file conversion processing sub-unit 153 detects submission of an instruction to write data onto the second medium 112 after data editing including data deletion performed by the application execution sub-unit 152 is completed.
Upon detecting submission of an instruction to write the edited data onto the second medium 112, the file conversion processing sub-unit 153 receives the edited data from the application execution sub-unit 152. Thereafter, in step S501, the file conversion processing sub-unit 153 analyzes the edited data. At that time, the file conversion processing sub-unit 153 uses the data stored in the memory when the file conversion processing sub-unit 153 supplied the data to be edited to the application execution sub-unit 152, as described above with reference to
In step S501, the file conversion processing sub-unit 153 identifies the separate file including the start position “in” and the end position “out” of the data to be deleted. Note that, at that time, the separate file to be edited is identified. In this case, suppose that files A and B are identified, where
file A=a separate file including the start position “in” of the data to be deleted, and
file B=a separate file including the end position “out” of the data to be deleted.
In step S502, the file conversion processing sub-unit 153 determines whether the files A and B identified in step S501 are the same. If the files A and B are the same, the processing proceeds to step S510, where the sequence of processes (B) in Case 1 is performed. This sequence of processes corresponds to the process illustrated in
However, if, in step S502, the files A and B are not the same, the processing proceeds to step S503, where it is determined whether the file A is immediately adjacent to the file B. If the file A is immediately adjacent to the file B, the processing proceeds to step S520, where the sequence of processes (C) in Case 2 is performed. This sequence of processes corresponds to the process illustrated in
However, if, in step S503, the file A is not immediately adjacent to the file B, the processing proceeds to step S530, where the sequence of processes (D) in Case 3 is performed. This sequence of processes corresponds to the process illustrated in
The sequence of processes (B) in Case 1 illustrated in
In such a case, in step S511, the file conversion processing sub-unit 153 generates an updated separate file [file A (new)] by deleting the data between the points “in” and “out” in the file A (=the file B). The file conversion processing sub-unit 153 does not update the separate files other than the update separate file [file A (new)]. This process corresponds to the process for generating an edited file (edited separate files) indicated by (d) in
The separate files generated through the processing performed in step S511 are supplied to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
The sequence of processes (C) in Case 2 illustrated in
In such a case, in step S521, the file conversion processing sub-unit 153 generates an updated separate file [file A (new)] by deleting the data between the point “in” and the end point of the file A from the file A.
In addition, in step S522, the file conversion processing sub-unit 153 generates an updated separate file [file B (new)] by deleting the data between the beginning of the file B and the point “out” (the deletion end point) from the file B. The file conversion processing sub-unit 153 does not update the separate files other than the update separate files [file A (new)] and [file B (new)]. The processing performed in steps S521 and S522 corresponds to the process for generating an edited file (an edited separate file) indicated by (d) in
The separate files generated through the processing performed in steps S521 and S522 are supplied to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
The sequence of processes (D) in Case 3 illustrated in
In such a case, in step S531, the file conversion processing sub-unit 153 generates an updated separate file [file A (new)] by deleting the data between the point “in” and the end point of the file A from the file A.
In addition, in step S532, the file conversion processing sub-unit 153 generates an updated separate file [file B (new)] by deleting the data between the start point of the file B and the point “out” (the deletion end point) from the file B.
Furthermore, in step S533, the file conversion processing sub-unit 153 deletes separate files located between the files A and B. The processing performed in steps S531 to S533 corresponds to the process for generating an edited file (edited separate files) indicated by (d1) in
Subsequently, in step S534, the file conversion processing sub-unit 153 changes (renames) the names of the files so that the separate files subsequent to the file B which includes the point “out” (the deletion end point) have the file names that are serial numbers. The processing performed in step S534 corresponds to the process for generating an edited file (edited separate files) indicated by (d2) in
The separate files generated through the processing performed in steps S531 to 5534 are supplied to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
(6-2) Exemplary Processing Performed during Data Insertion
The processing performed by the file conversion processing sub-unit 153 when separate files recorded on the second medium 112 are read and data is inserted into the file by the application execution sub-unit 152 is described next.
When data is inserted, one of the following cases occurs:
(Case 1) The file size of a separate file after data is inserted is within the maximum size defined by the file system,
(Case 2) The file size of a separate file after data is inserted exceeds the maximum file size defined by the file system and, therefore, it is necessary to separate the file into two separate files, and
(Case 3) The file size of a separate file after data is inserted exceeds the maximum size defined by the file system and, therefore, it is necessary to separate the file into three or more separate files.
The file conversion processing sub-unit 153 reconstructs the separate files in accordance with the one of the above-described cases. The data insertion processes performed in the above-described cases are described below with reference to
(Case 1) Case in which File Size of Separate File after Data is Inserted is within Maximum Size Defined by File System
The case in which the file size of a separate file after data is inserted is within the maximum size defined by the file system is described with reference to
In the present embodiment, the second medium 112 is used for data recording and reproduction that complies with the specifications of the second file system (FAT32). The maximum file size defined by the second file system is 4 GB.
(a) A file to be edited (a concatenated original file to be edited by an application),
(b) Files to be edited (separate files to be edited that are recorded in a second medium),
(c) Data subjected to editing processing,
(d) Edited file (edited separate files to be recorded onto the second medium), and
(e) Edited file (an original file generated by concatenating the separate files edited by the application).
In
In
Note that [(new)] is attached to the serial number portion of an update separate file (e.g., [f01 (new)]). Similarly, [(new)] is attached to the serial number portion of an update concatenated file (e.g., [F (new)]). Also, note that [f01 (new)] and [F (new)] indicate that these files are updated files of the separate file [f01] and the concatenated file [F], respectively. The file names of these files are not changed.
When stream file recorded on the second medium 112 is edited by the application execution sub-unit 152, a data readout process that is similar to the data reproduction process indicated by the flowchart illustrated in
In the data readout process, the files to be edited (the separate file indicated by (b) in
Note that the file conversion processing sub-unit 153 maintains, in a memory, the names of the separate files that form the concatenated file supplied to the application execution sub-unit 152 and the data start and end positions of the separate files. Such data position information includes the concatenated data positions of the separate file (i.e., separation positions). The file conversion processing sub-unit 153 separates the file or concatenates the files using one of the rules illustrated in
The application execution sub-unit 152 edits the file to be edited (indicated by (a) in
In the data insertion process (Case 1) illustrated in
The application execution sub-unit 152 edits the file to be edited (indicated by (a) in
After the editing processing is performed, the application execution sub-unit 152 submits a write instruction to write the edited file (the concatenated file) [F (new)] indicated by (e) in
More specifically, the file conversion processing sub-unit 153 determines the correspondence between the data start and end positions including the concatenation data position (the separation position) of each of the separate files and the edited file (the concatenated file) indicated by (e) in
In this example, the insertion data 311 is inserted at the points “in” shown in
On the basis of the determination, the file conversion processing sub-unit 153 separates the edited file (the concatenated file) received from the application execution sub-unit 152 and indicated by (e) in
That is, in terms of the separate file [f01] into which the data is inserted, the file conversion processing sub-unit 153 generates an updated file [f01 (new)] that includes the inserted data. The data in the other separate files [f00], [f02], and [f03] remain unchanged before and after the editing processing is performed. Accordingly, the file conversion processing sub-unit 153 does not update the separate files.
In this way, the separate files [f00], [f01 (new)], [f02], and [f03], some of which have been updated, are supplied from the file conversion processing sub-unit 153 to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
(Case 2) Case in which File Size of Separate File after Data is Inserted Exceeds Maximum Size Defined by File System and it is Necessary to Split File into Two Separate Files
The case in which the file size of the separate File after data is inserted exceeds the maximum size defined by the file system and it is necessary to split the file into two separate files is described next with reference to
(a) A file to be edited (a concatenated original file to be edited by an application),
(b) Files to be edited (separate files to be edited that are recorded in a second medium),
(c) Data subjected to editing processing,
(d) Edited file (edited separate files to be recorded onto the second medium), and
(e) Edited file (an original file generated by concatenating the separate files edited by the application).
As in
When the application execution sub-unit 152 edits a stream file recorded on the second medium 112, the files to be edited indicated by (b) in
In addition, the file conversion processing sub-unit 153 maintains, in a memory, the names of the separate files that form the concatenated file supplied to the application execution sub-unit 152 and the data start and end positions of each of the separate files.
The application execution sub-unit 152 performs, for example, editing processing instructed by the user on the file to be edited indicated by (a) in
After the editing processing is performed, the application execution sub-unit 152 submits a write instruction to write the edited file (the concatenated file) [F (new)] indicated by (e) shown in
More specifically, the file conversion processing sub-unit 153 recognizes the correspondence between the data start and end positions of each of the separate files including the concatenation point of the file maintained in the memory and the edited file (the concatenated file) indicated by (e) shown in
In this example, the insertion data 311 is inserted at the point “in” shown in
On the basis of the determination, the file conversion processing sub-unit 153 separates the edited file (the concatenated file) received from the application execution sub-unit 152 and indicated by (e) in
That is, in terms of the separate file [f01] into which the data is inserted, the file conversion processing sub-unit 153 generates an updated file [edited f01] that includes the inserted data. In addition, the file conversion processing sub-unit 153 further separates the file [edited f01] so that each of the separate files has a file size smaller than or equal to the maximum file size defined by the file system (4 GB for FAT32). As indicated by (d) in
Furthermore, when the additional separation process is performed, the file names of the separate files are changed. That is, since the number of edited separate files is larger than the number of separate files to be edited, the serial number rule for the names of separate files is not satisfied unless new file names are set. According to the serial number rule for the names of separate files, separate files generated by separating an original file have file extensions or file names that are serial numbers. That is, the serial number rule for the names of separate files is the rule described above with reference to
If it is difficult to satisfy the serial number rule for the names of separate files, the file conversion processing sub-unit 153 changes the file names of the separate files. That is, the file names of the separate files are changed (renamed) so that the serial number rule for the names of separate files is satisfied. That is, as indicated by (d) in
In this way, the separate files [f00], [f01 (new)], [f02 (new-rn)], [f03 (rn)], and [f04 (rn)], some of which have been updated, are supplied from the file conversion processing sub-unit 153 to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
As described above, by changing the file names so that the serial number rule for the names of separate files is satisfied and recording the files onto the second medium 112, the separate files can be reliably read from the second medium 112 in a readout process.
(Case 3) Case in which File Size of Separate File after Data is Inserted Exceeds Maximum Size Defined by File System and it is Necessary to Separate File into Three or More Separate Files
The case in which the file size of the separate File after data is inserted exceeds the maximum size defined by the file system and it is necessary to separate the file into three or more separate files is described next with reference to
(a) A file to be edited (a concatenated original file to be edited by an application),
(b) Files to be edited (separate files to be edited that are recorded in a second medium),
(c) Data subjected to editing processing,
(d) Edited file (edited separate files to be recorded onto the second medium), and
(e) Edited file (an original file generated by concatenating the separate files edited by the application).
As in
When the application execution sub-unit 152 edits a stream file recorded on the second medium 112, the files to be edited indicated by (b) in
In addition, the file conversion processing sub-unit 153 maintains, in a memory, the names of the separate files that form the concatenated file supplied to the application execution sub-unit 152 and the data start and end positions of each of the separate files.
The application execution sub-unit 152 performs, for example, editing processing instructed by the user on the file to be edited indicated by (a) in
After the editing processing is performed, the application execution sub-unit 152 submits a write instruction to write the edited file (the concatenated file) [F (new)] indicated by (e) shown in
More specifically, the file conversion processing sub-unit 153 recognizes the correspondence between the data start and end positions of each of the separate files including the concatenation point (the separation point) of the file maintained in the memory and the edited file (the concatenated file) indicated by (e) shown in
In this example, the insertion data 313 is inserted at the point “in” shown in
On the basis of the determination, the file conversion processing sub-unit 153 separates the edited file (the concatenated file) received from the application execution sub-unit 152 and indicated by (e) in
That is, in terms of the separate file [f01] into which the data is inserted, the file conversion processing sub-unit 153 generates an updated file [edited f01] that includes the inserted data. In addition, the file conversion processing sub-unit 153 further separates the file [edited f01] so that each of the separate files has a file size smaller than or equal to the maximum file size defined by the file system (4 GB for FAT32). As indicated by (d) in
Furthermore, when the additional separation process is performed, the file names of the separate files are changed. That is, since the number of edited separate files is larger than the number of separate files to be edited, the serial number rule for the names of separate files is not satisfied unless new file names are set. According to the serial number rule for the names of separate files, separate files generated by separating an original file have file extensions or filenames that are serial numbers. That is, the serial number rule for the names of separate files is the rule described above with reference to
If it is difficult to satisfy the serial number rule for the names of separate files, the file conversion processing sub-unit 153 changes the file names of the separate files. That is, the file names of the separate files are changed (renamed) so that the serial number rule for the names of separate files is satisfied. That is, as indicated by (d) in
In this way, the separate files [f00], [f01 (new)], [f02 (new-rn)], [f03 (new-rn)], [f04 (rn)], and [f05 (rn)], some of which have been updated, are supplied from the file conversion processing sub-unit 153 to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
As described above, by changing the file names so that the serial number rule for the names of separate files is satisfied and recording the files onto the second medium 112, the separate files can be reliably read from the second medium 112 in a readout process.
As described above with reference to the flowcharts illustrated in
The flowchart in
(A) whole sequence,
(B) sequence of processes in Case 1 (refer to
(C) sequence of processes in Case 2 (refer to
(D) sequence of processes in Case 3 (refer to
Upon detecting submission of an instruction to write data onto the second medium 112, the file conversion processing sub-unit 153 receives the edited data from the application execution sub-unit 152. Thereafter, in step S701, the file conversion processing sub-unit 153 analyzes the edited data. At that time, the file conversion processing sub-unit 153 uses the data stored in the memory when the file conversion processing sub-unit 153 supplied the data to be edited to the application execution sub-unit 152, as described above with reference to
In step S701, the file conversion processing sub-unit 153 defines the separate file including the start position “in” at which data is inserted and a file formed by the insertion data as follows:
file A=the separate file including the start position “in” at which data is inserted, and
file B=a file formed by the insertion data.
In step S702, the file conversion processing sub-unit 153 determines whether the sum of the sizes of the files A and B obtained in step S701 satisfies the specification defined by the file system employed by the second medium 112. That is, it is determined whether the sum is less than or equal to 4 GB when the second medium 112 is a FAT32 compatible medium. If the sum of the file sizes satisfies the specification defined by the file system employed by the second medium 112, the processing proceeds to step S710, where the processing for Case 1 (B) is performed. This processing corresponds to the processing illustrated in
However, if, in step S702, the sum of the file sizes does not satisfy the specification defined by the file system employed by the second medium 112, the processing proceeds to step S703, where it is further determined whether the file size of the file B (the insertion data) satisfies the specification defined by the file system employed by the second medium 112. If the file size of the file B satisfies the specification defined by the file system employed by the second medium 112, the processing proceeds to step S720, where the processing for Case 2 (C) is performed. This processing corresponds to the processing illustrated in
However, if, in step S703, the file size of the file B (the insertion data) does not satisfy the specification defined by the file system employed by the second medium 112, the processing proceeds to step S730, where the processing for Case 3 (D) is performed. This processing corresponds to the processing illustrated in
The sequence of processes performed in Case 1 (B) shown in
In such a case, in step S711, the file conversion processing sub-unit 153 generates an updated separate file [file A (new)] including the file B (the insertion data) inserted at the point “in” in the file A. The file conversion processing sub-unit 153 does not update the separate files other than the update separate files [file A (new)]. This processing corresponds to the processing for generating an edited file (a separate file) indicated by (d) in
The separate files generated through the processing performed in step S711 are supplied to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
The sequence of processes (C) of Case 2 illustrated in
In such a case, in step S721, the file conversion processing sub-unit 153 acquires an updated separate file [edited file A] generated by inserting the file B at the insertion data point (the point “in”) of the file A and expanding the file A. Thereafter, in step S722, the file conversion processing sub-unit 153 further separates the separate file [edited file A] including the insertion data into two separate files each having a size smaller than or equal to the allowable maximum file size.
As indicated by (d) shown in
Subsequently, in step S723, the names of the separate files are changed (renamed) so that the serial number rule for the names of separate files is satisfied. That is, the names of the separate files are renamed so that the serial number rule for the names of separate files illustrated in
The separate files generated through the processing performed in steps S721 to S723 are supplied to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
The sequence of processes (D) of Case 3 illustrated in
In such a case, in step S731, the file conversion processing sub-unit 153 acquires an updated separate file [edited file A] generated by inserting the file B at the insertion data point (the point “in”) of the file A and expanding the file A. Thereafter, in step S732, the file conversion processing sub-unit 153 further splits the separate file [edited file A] including the insertion data into two separate files each having a size smaller than or equal to the allowable maximum file size.
As indicated by (d) shown in
Subsequently, in step S733, the names of the separate files are changed (renamed) so that the serial number rule for the names of separate files is satisfied. That is, the names of the separate files are renamed so that the serial number rule for the names of separate files illustrated in
The separate files generated through the processing performed in steps S731 to S733 are supplied to the second-media support file system sub-unit 154 and are recorded onto the second medium 112.
7. Other Exemplary Configurations of Information Processing Apparatus
While the foregoing embodiments have been described with reference to the process performed by an apparatus having a configuration including a plurality of media serving as data recording media (e.g., the information processing apparatus shown in
As shown in
The media interface 507 and the recording medium 512 correspond to the second media interface 107 and the second medium 112 in the configuration shown in
In the configuration shown in
Although the invention has been described in conjunction with specific embodiments thereof, it is evident that many alternatives, modifications and variations will be apparent to those skilled in the art within the spirit and broad scope of the invention. That is, the present invention has been described with reference to various examples, and it should not be construed that the technical scope of the invention is limited thereto. It should be understood that the scope of the invention is to be determined only from the appended claims.
The above-described series of processes can be executed by hardware, software, or a combination thereof. When the above-described series of processes are executed by software, the programs that defines the sequence of processes can be installed in a memory of a computer incorporated in dedicated hardware and be executed. Alternatively, the programs can be installed in a general-purpose computer that can execute a variety of processes and be executed. For example, the programs can be prerecorded in a recording medium. In addition to being installed from the recording medium, the programs can be received via a network, such as a local area network (LAN) or the Internet and be installed in a recording medium, such as a hard disk, incorporated in a computer.
It should be noted that the steps described in the present specification may be executed in not only in the above-described sequence, but also in parallel or independently in accordance with the processing power of the apparatus that executes the steps or the necessity of the processing. In addition, as used herein, the term “system” refers to a logical combination of a plurality of devices; the plurality of devices is not necessarily included in one body.
The present application contains subject matter related to that disclosed in Japanese Priority Patent Application JP 2009-032056 filed in the Japan Patent Office on Feb. 13, 2009, the entire content of which is hereby incorporated by reference.
It should be understood by those skilled in the art that various modifications, combinations, sub-combinations and alterations may occur depending on design requirements and other factors insofar as they are within the scope of the appended claims or the equivalents thereof.
Number | Date | Country | Kind |
---|---|---|---|
2009-032056 | Feb 2009 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
20040268043 | Hoshizawa et al. | Dec 2004 | A1 |
20050060279 | Xue | Mar 2005 | A1 |
20050271358 | Inata et al. | Dec 2005 | A1 |
20070285524 | Murata | Dec 2007 | A1 |
Number | Date | Country |
---|---|---|
2003-189074 | Jul 2003 | JP |
2006-79552 | Mar 2006 | JP |
2006-523882 | Oct 2006 | JP |
2007-11504 | Jan 2007 | JP |
2007-179492 | Jul 2007 | JP |
2008-98765 | Apr 2008 | JP |
2008-159233 | Jul 2008 | JP |
WO 2006030767 | Mar 2006 | WO |
WO 2006126679 | Nov 2006 | WO |
Entry |
---|
Advanced Access Content System (AACS), “Recordable Video Book”, http://www.aacsla.com/specifications/AACS—Spec—Recordable—Final—0—96.pdf, Revision 0.94, Feb. 12, 2007, 22 pages. |
Advanced Access Content System (AACS), “Blu-ray Disc Recordable Book”, http://www.aacsla.com/specifications/AACS—Spec—BD—Recordable—Final—0.96.pdf, Revision 0.94 RC1, Feb. 12, 2008, 57 pages. |
Advanced Access Content System (AACS), “Prepared Video Book”, http://www.aacsla.com/specifications/AACS—Spec—Prepared—Video—Final—0.94.pdf, Revision 0.94, Feb. 12, 2008, 42 pages. |
Advanced Access Content System (AACS), “Blu-ray Disc Prepared Video Book”, http://www.aacsla.com/specifications/AACS—Spec—BD—Prepared—Final—0.94.pdf, Revision 0.94 RC1, Feb. 12, 2008, 49 pages. |
Number | Date | Country | |
---|---|---|---|
20100211556 A1 | Aug 2010 | US |