A controller of an IRD generates a provisional id for uniquely identifying an event within the unit. Then, an event within the unit is read from a Resource Schedule Board (RSB), and a record id (event id) of the event is extracted. A provisional id, which is different from the registered record ids within the related unit, is searched for. The searched provisional id is set to be the record id and is combined with a global unique id (GUID) of the unit, thereby generating an Object id. As a result, the Object id for uniquely identifying the event within a bus is speedily determined.

Patent
   6513064
Priority
Sep 14 1998
Filed
Sep 13 1999
Issued
Jan 28 2003
Expiry
Sep 13 2019
Assg.orig
Entity
Large
16
4
all paid
1. An information processing apparatus connected to an external information processing apparatus via a network, said information processing apparatus comprising:
management means for managing management information; and
generation means for generating, based on first identification information for identifying said management means and second identification information for identifying the management information within an area managed by said management means, third identification information for identifying the management information within said network.
5. An information processing method for use in an information processing apparatus connected to an external information processing apparatus via a network, said information processing apparatus comprising management means for managing management information, said information processing method comprising the generation step of generating, based on first identification information for identifying said management means and second identification information for identifying the management information within an area managed by said management means, third identification information for identifying the management information within said network.
6. A recording medium for recording a program executable by a computer, said program for controlling an information processing apparatus connected to an external information processing apparatus via a network, said information processing apparatus comprising management means for managing management information, said program comprising the generation step of generating, based on first identification information for identifying said management means and second identification information for identifying the management information within an area managed by said management means, third identification information for identifying the management information within said network.
7. An information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function, said information processing apparatus comprising:
generation means for generating a provisional id for an event which controls the sub-unit;
extraction means for extracting an event id of an authenticated event;
comparison means for comparing the provisional id generated by said generation means with the event id extracted by said extraction means; and
authentication means for authenticating the provisional id as the event id according to a comparison result obtained by said comparison means.
11. An information processing method for use in an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function, said information processing method comprising:
a generation step of generating a provisional id for an event which controls the sub-unit;
an extraction step of extracting an event id of an authenticated event;
a comparison step of comparing the provisional id generated in said generation step with the event id extracted in said extraction step; and
an authentication step of authenticating the provisional id as the event id according to a comparison result obtained in said comparison step.
12. A recording medium for recording a program executable by a computer, said program for controlling an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function, said program comprising:
a generation step of generating a provisional id for an event which controls the sub-unit;
an extraction step of extracting an event id of an authenticated event;
a comparison step of comparing the provisional id generated in said generation step with the event id extracted in said extraction step; and
an authentication step of authenticating the provisional id as the event id according to a comparison result obtained in said comparison step.
13. An information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function, said information processing apparatus comprising:
storage means for storing reservation information concerning a reservation of the sub-unit;
supply means for reading out the reservation information stored in said storage means and supplying the reservation information to said external information processing apparatus in response to a request from said external information processing apparatus; and
addition means for adding identification information to the reservation information of the sub-unit to be stored in said storage means, said identification information including a value unique to said information processing apparatus that has reserved the sub-unit and a value unique to the reservation of the sub-unit set by said information processing apparatus.
17. An information processing method for use in an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function, said information processing method comprising:
a storage control step of controlling storage of reservation information concerning a reservation of the sub-unit;
a supply step of reading out the reservation information stored by processing of said storage control step and of supplying the reservation information to said external information processing apparatus in response to a request from said external information processing apparatus; and
an addition step of adding identification information to the reservation information of the sub-unit to be stored by processing of said storage control step, said identification information including a value unique to said information processing apparatus that has reserved the sub-unit and a value unique to the reservation of the sub-unit set by said information processing apparatus.
19. An information processing apparatus connected to via a network an external information processing apparatus including at least one sub-unit for executing a predetermined function, said information processing apparatus comprising:
reading means for reading reservation information concerning a reservation of the sub-unit stored in storage means of said external information processing apparatus when the sub-unit of said external information processing apparatus is reserved; and
writing means for adding identification information to the reservation information of the sub-unit of said external information processing apparatus in accordance with a reading result obtained by said reading means and for writing the reservation information into said external information processing apparatus, said identification information including a value unique to said information processing apparatus that has reserved the sub-unit of said external information processing apparatus and a value unique to the reservation of the sub-unit set by said information processing apparatus.
21. An information processing method for use in an information processing apparatus connected to via a network an external information processing apparatus including at least one sub-unit for executing a predetermined function, said information processing method comprising:
a reading step of reading reservation information concerning a reservation of-the sub-unit stored in storage means of said external information processing apparatus when the sub-unit of said external information processing apparatus is reserved; and
a writing step of adding identification information to the reservation information of the sub-unit of said external information processing apparatus in accordance with a reading result obtained by processing of said reading step and of writing the reservation information into said external information processing apparatus, said identification information including a value unique to said information processing apparatus that has reserved the sub-unit of said external information processing apparatus and a value unique to the reservation of the sub-unit set by said information processing apparatus.
18. A recording medium for recording an information processing program executable by a computer, said information processing program for use in an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function, said program comprising:
a storage control step of controlling storage of reservation information concerning a reservation of the sub-unit;
a supply step of reading out the reservation information stored by processing of said storage control step and of supplying the reservation information to said external information processing apparatus in response to a request from said external information processing apparatus; and
an addition step of adding identification information to the reservation information of the sub-unit to be stored by processing of said storage control step, said identification information including a value unique to said information processing apparatus that has reserved,the sub-unit and a value unique to the reservation of the sub-unit set by said information processing apparatus.
22. A recording medium for recording an information processing program executable by a computer, said information processing program for use in an information processing apparatus connected to via a network an external information processing apparatus including at least one sub-unit for executing a predetermined function, said program comprising:
a reading step of reading reservation information concerning a reservation of the sub-unit stored in storage means of said external information processing apparatus when the sub-unit of said external information processing apparatus is reserved; and
a writing step of adding identification information to the reservation information of the sub-unit of said external information processing apparatus in accordance with a reading result obtained by processing of said reading step and of writing the reservation information into said external information processing apparatus, said identification information including a value unique to said information processing apparatus that has reserved the sub-unit of said external information processing apparatus and a value unique to the reservation of the sub-unit set by said information processing apparatus.
2. An information processing apparatus according to claim 1, further comprising storage means for storing the management information in such a manner that the management information is readable by said external information processing apparatus via said network.
3. An information processing apparatus according to claim 1, wherein said network is formed by using an IEEE-1394 serial data bus.
4. An information processing apparatus according to claim 1, wherein the first identification information for identifying said management means is a global unique id.
8. An information processing apparatus according to claim 7, wherein the event id uniquely corresponds to the event according to an authentication operation performed by said authentication means.
9. An information processing apparatus according to claim 7, wherein said network is formed by an IEEE-1394 serial data bus.
10. An information processing apparatus according to claim 7, further comprising combination means for combining the event id with a value unique to said information processing apparatus that has reserved the sub-unit, thereby generating a value unique to said network.
14. An information processing apparatus according to claim 13, wherein the value unique to said information processing apparatus is a global unique id, and the value unique to the reservation is a record id.
15. An information processing apparatus according to claim 13, further comprising:
input means for inputting reservation information concerning the reservation of the sub-unit;
search means for searching for the identification information corresponding to the reservation information stored in said storage means; and
setting means for setting a value which is not stored in said storage means as a value unique to the reservation information newly input by said input means and set by said information processing apparatus in accordance with a search result obtained by said search means.
16. An information processing apparatus according to claim 13, further comprising:
reading means for reading reservation information stored in storage means of said external information processing apparatus when a sub-unit of said external information processing apparatus is reserved; and
writing means for adding identification information to reservation information of the sub-unit of said external information processing apparatus in accordance with a reading result obtained by said reading means and for writing the reservation information into said storage means of said external information processing apparatus, said identification information including a value unique to said information processing apparatus that has reserved the sub-unit of said external information processing apparatus and a value unique to the reservation of the sub-unit of said external information processing apparatus set by said information processing apparatus.
20. An information processing apparatus according to claim 19, wherein the value unique to said information processing apparatus is a global unique id, and the value unique to the reservation is a record id.

1. Field of the Invention

The present invention generally relates to information processing apparatuses, information processing methods, and recording media. More particularly, the invention relates to an information processing apparatus which is connected to other information processing apparatuses via an IEEE-1394 serial data bus and which reliably and individually controls built-in sub-units. The invention also pertains to an information processing method used in the above type of information processing apparatus and to a recording medium implementing this method.

2. Description of the Related Art

Audio/visual (AV) machines that can transmit information to each other via a network using an IEEE-1394 serial data bus are being developed. In this network, it is possible to control the AV machines connected to the network by using a predetermined command (AV/C Command Transaction Set). For example, a video picture received by an Integrated Receiver Decoder (IRD) 71 for receiving digital satellite broadcasts can be recorded, as shown in FIG. 1, on a Digital Video Cassette Recorder (DVCR) 81 connected to the IRD 71 via an IEEE-1394 serial data bus 2 (hereinafter simply referred to as the "bus 2"). Additionally, what is called "recording reservations" can be made by using the IRD 71 and the DVCR 81.

According to the recording reservation processing, a controller 72 of the IRD 71 controls the IRD 71 and the DVRC 81. More specifically, the recording-reservation settings (channel, recording start time, etc.) are made on the IRD 71, and when the recording start time is reached, the controller 72 of the IRD 71 controls a tuner sub-unit 73 to select the reserved (set) channel and to output a received video signal to the DVCR 81 via the bus 2. Simultaneously, the controller 72 transmits a recording start command to a VCR sub-unit 84 of the DVCR 81 via the bus 2. In response to the recording start command transmitted from the controller 72, the VCR sub-unit 84 of the DVCR 81 records the video signal supplied from the tuner sub-unit 73 on magnetic tape (not shown).

As discussed above, it is possible to control the operation of the DVCR 81 from another machine (in the example shown in FIG. 1, the IRD 71) connected to the DVCR 81 via the bus 2. In this case, there may be a danger that what is called "double-booking" occurs.

For example, when a recording reservation (recording reservation A) of a digital satellite broadcast is input into the IRD 71, the reservation information is stored in the controller 72 of the IRD 71. Thereafter, if a recording reservation (recording reservation B) of a terrestrial analog broadcast, which is to be broadcast at the same time as the recording reservation A, is input into the DVCR 81, a controller 82 of the DVCR 81 receives and stores the recording reservation B since the information concerning the recording reservation A input into the IRD 71 has not been reported to the DVCR 81. Thus, upon reaching the time when both the recording reservation A and the recording reservation B are started, video pictures are inconveniently supplied from both the tuner sub-unit 73 of the IRD 71 and an analog tuner block 83 of the DVCR 81 to the VCR sub-unit 84 of the DVCR 81.

The above inconvenience originates from the fact that reservation information managed by an AV machine is not available for another AV machine connected via the bus 2.

In order to overcome the above-described drawback, a CS mode is conventionally provided for the DVCR 81. According to the CS mode, the DVCR 81 is controlled only by the controller 72 of the IRD 71 and enters the recording standby position. After the recording reservation A is input into the IRD 71, the DVCR 81 is set in the CS mode, thereby preventing the occurrence of double-booking.

However, since the DVCR 81 set in the CS mode goes into the reservation standby position, it cannot execute processing, such as reproduction of video signals, thereby decreasing the ease of operation.

Additionally, there is no method for uniquely specifying events, such as recording reservations, transmitted to the bus 2. It is thus necessary to generate a command for each AV machine related to the event, thereby decreasing the ease of operation.

Information (recording start time, etc.) managed by an AV machine is not reported to the other AV machines. Because of this, when the AV machines simultaneously output information to the bus 2, the amount of information may exceed the bandwidth of the bus 2, causing transmission errors to occur.

Accordingly, in view of the above background, it is an object of the present invention to improve the ease of reserve-recording operation and to inhibit the occurrence of double-booking by mutually searching information managed by the individual AV machines connected to a bus.

In order to achieve the above object, according to one aspect of the present invention, there is provided an information processing apparatus connected to an external information processing apparatus via a network. The information processing apparatus includes a management unit for managing management information. A generation unit generates, based on first identification information for identifying the management unit and second identification information for identifying the management information within an area managed by the management unit, third identification information for identifying the management information within the network.

The aforementioned information processing apparatus may further include a storage unit for storing the management information in such a manner that the management information is readable by the external information processing apparatus via the network.

The network may be formed by using an IEEE-1394 serial data bus.

The first identification information for identifying the management unit may be a global unique ID.

According to another aspect of the present invention, there is provided an information processing method for use in an information processing apparatus connected to an external information processing apparatus via a network. The information processing apparatus includes a management unit for managing management information. The information processing method includes the generation step of generating, based on first identification information for identifying the management unit and second identification information for identifying the management information within an area managed by the management unit, third identification information for identifying the management information within the network.

According to still another aspect of the present invention, there is provided a recording medium for recording a program executable by a computer, the program for controlling an information processing apparatus connected to an external information processing apparatus via a network. The information processing apparatus includes a management unit for managing management information. The program includes the generation step of generating, based on first identification information for identifying the management unit and second identification information for identifying the management information within an area managed by the management unit, third identification information for identifying the management information within the network.

According to a further aspect of the present invention, there is provided an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function. The information processing apparatus includes a generation unit for generating a provisional ID for an event which controls the sub-unit. An extraction unit extracts an event ID of an authenticated event. A comparison unit compares the provisional ID generated by the generation unit with the event ID extracted by the extraction unit. An authentication means authenticates the provisional ID as the event ID according to a comparison result obtained by the comparison unit.

The event ID may uniquely correspond to the event according to an authentication operation performed by the authentication unit.

The network may be formed by an IEEE-1394 serial data bus.

The aforementioned information processing apparatus may further include a combination unit for combining the event ID with a value unique to the information processing. apparatus that has reserved the sub-unit, thereby generating a value unique to the network.

According to a yet further aspect of the present invention, there is provided an information processing method for use in an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function. The information processing method includes a generation step of generating a provisional ID for an event which controls the sub-unit, an extraction step of extracting an event ID of an authenticated event, a comparison step of comparing the provisional ID generated in the generation step with the event ID extracted in the extraction step, and an authentication step of authenticating the provisional ID as the event ID according to a comparison result obtained in the comparison step.

According to a further aspect of the present invention, there is provided a recording medium for recording a program executable by a computer, the program for controlling an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function. The program includes a generation step of generating a provisional ID for an event which controls the sub-unit, an extraction step of extracting an event ID of an authenticated event, a comparison step of comparing the provisional ID generated in the generation step with the event ID extracted in the extraction step, and an authentication step of authenticating the provisional ID as the event ID according to a comparison result obtained in the comparison step.

According to a further aspect of the present invention, there is provided an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function. The information processing apparatus includes a storage unit for storing reservation information concerning a reservation of the sub-unit. A supply unit reads out the reservation information stored in the storage unit and supplies the reservation information to the external information processing apparatus in response to a request from the external information processing apparatus. An addition unit adds identification information to the reservation information of the sub-unit to be stored in the storage unit, the identification information including a value unique to the information processing apparatus that has reserved the sub-unit and a value unique to the reservation of the sub-unit set by the information processing apparatus.

The value unique to the information processing apparatus may be a global unique ID, and the value unique to the reservation may be a record ID.

The aforementioned information processing apparatus may further include an input unit for inputting reservation information concerning the reservation of the sub-unit, a search unit for searching for the identification information corresponding to the reservation information stored in the storage unit, and a setting unit for setting a value which is not stored in the storage unit as a value unique to the reservation information newly input by the input unit and set by the information processing apparatus in accordance with a search result obtained by the search unit.

The aforementioned information processing apparatus may further include a reading unit for reading reservation information stored in a storage unit of the external information processing apparatus when a sub-unit of the external information processing apparatus is reserved, and a writing unit for adding identification information to reservation information of the sub-unit of the external information processing apparatus in accordance with a reading result obtained by the reading unit and for writing the reservation information into the storage unit of the external information processing apparatus, the identification information including a value unique to the information processing apparatus that has reserved the sub-unit of the external information processing apparatus and a value unique to the reservation of the sub-unit of the external information processing apparatus set by the information processing apparatus.

According to a further aspect of the present invention, there is provided an information processing method for use in an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function. The information processing method includes a storage control step of controlling storage of reservation information concerning a reservation of the sub-unit, a supply step of reading out the reservation information stored by processing of the storage control step and of supplying the reservation information to the external information processing apparatus in response to a request from the external information processing apparatus, and an addition step of adding identification information to the reservation information of the sub-unit to be stored by processing of the storage control step, the identification information including a value unique to the information processing apparatus that has reserved the sub-unit and a value unique to the reservation of the sub-unit set by the information processing apparatus.

According to a further aspect of the present invention, there is provided a recording medium for recording an information processing program executable by a computer, the information processing program for use in an information processing apparatus connected to an external information processing apparatus via a network and including at least one sub-unit for executing a predetermined function. The program includes a storage control step of controlling storage of reservation information concerning a reservation of the sub-unit, a supply step of reading out the reservation information stored by processing of the storage control step and of supplying the reservation information to the external information processing apparatus in response to a request from the external information processing apparatus, and an addition step of adding identification information to the reservation information of the sub-unit to be stored by processing of the storage control step, the identification information including a value unique to the information processing apparatus that has reserved the sub-unit and a value unique to the reservation of the sub-unit set by the information processing apparatus.

According to a further aspect of the present invention, there is provided an information processing apparatus connected to via a network an external information processing apparatus including at least one sub-unit for executing a predetermined function. The information processing apparatus includes a reading unit for reading reservation information concerning a reservation of the sub-unit stored in a storage unit of the external information processing apparatus when the sub-unit of the external information processing apparatus is reserved. A writing unit adds identification information to the reservation information of the sub-unit of the external information processing apparatus in accordance with a reading result obtained by the reading unit and writes the reservation information into the external information processing apparatus, the identification information including a value unique to the information processing apparatus that has reserved the sub-unit of the external information processing apparatus and a value unique to the reservation of the sub-unit set by the information processing apparatus.

The value unique to the information processing apparatus may be a global unique ID, and the value unique to the reservation may be a record ID.

According to a further aspect of the present invention, there is provided an information processing method for use in an information processing apparatus connected to via a network an external information processing apparatus including at least one sub-unit for executing a predetermined function. The information processing method includes a reading step of reading reservation information concerning a reservation of the sub-unit stored in a storage unit of the external information processing apparatus when the sub-unit of the external information processing apparatus is reserved, and a writing step of adding identification information to the reservation information of the sub-unit of the external information processing apparatus in accordance with a reading result obtained by processing of the reading step and of writing the reservation information into the external information processing apparatus, the identification information. including a value unique to the information processing apparatus that has reserved the sub-unit of the external information processing apparatus and a value unique to the reservation of the sub-unit set by the information processing apparatus.

According to a further aspect of the present invention, there is provided a recording medium for recording an information processing program executable by a computer, the information processing program for use in an information processing apparatus connected to via a network an external information processing apparatus including at least one sub-unit for executing a predetermined function. The program includes a reading step of reading reservation information concerning a reservation of the sub-unit stored in storage unit of the external information processing apparatus when the sub-unit of the external information processing apparatus is reserved, and a writing step of adding identification information to the reservation information of the sub-unit of the external information processing apparatus in accordance with a reading result obtained by processing of the reading step and of writing the reservation information into the external information processing apparatus, the identification information including a value unique to the information processing apparatus that has reserved the sub-unit of the external information processing apparatus and a value unique to the reservation of the sub-unit set by the information processing apparatus.

FIG. 1 is a block diagram illustrating an example of the configuration of a related network system;

FIG. 2 is a block diagram illustrating the configuration of a network system incorporating an embodiment of the present invention;

FIG. 3 is a block diagram illustrating the configuration of a Bulletin Board Subunit (BBS) 14 shown in FIG. 2;

FIG. 4 is a block diagram illustrating the configuration of a BBS 34 shown in FIG. 2;

FIG. 5 illustrates an example of the operation of the network system shown in FIG. 2;

FIG. 6 illustrates an example of the operation of the network system shown in FIG. 2;

FIG. 7 is a flow chart illustrating the operation of the network system shown in FIG. 5;

FIG. 8 is a flow chart illustrating the operation of the network system shown in FIG. 5;

FIG. 9 is a flow chart illustrating the operation of the network system shown in FIG. 5;

FIG. 10 illustrates the format of a WRITE OPEN command;

FIG. 11 illustrates the format of a READ command;

FIG. 12 illustrates the format of a CREATE command;

FIG. 13 illustrates the subfunction_1 shown in FIG. 12;

FIG. 14 illustrates the details of the subfunction_1 shown in FIG. 13;

FIG. 15 illustrates the values of the fields shown in FIG. 14;

FIG. 16 illustrates the format of a WRITE DESCRIPTOR command;

FIG. 17 illustrates the format of a CLOSE command;

FIG. 18 illustrates another example of the operation of the network system shown in FIG. 2;

FIG. 19 is a block diagram illustrating the configuration of a network system incorporating an embodiment of the present invention;

FIG. 20 is a flow chart illustrating the processing for setting the Object ID;

FIG. 21 is a flow chart illustrating the processing for setting the SA Event ID;

FIG. 22 is a block diagram illustrating the configuration of a network system incorporating another embodiment of the present invention;

FIG. 23 is a flow chart illustrating the operation of the network system shown in FIG. 22;

FIG. 24 illustrates the BBS format;

FIG. 25 illustrates the root_object_list_ID shown in FIG. 24;

FIG. 26 illustrates the RSB format;

FIG. 27 illustrates the format of the Write Enabled list_specific_information shown in FIG. 26;

FIG. 28 illustrates the format of the board_type shown in FIG. 27;

FIG. 29 illustrates the format of the object_entry shown in FIG. 26;

FIG. 30 illustrates the format of the Resource Schedule Entry shown in FIG. 29;

FIG. 31 illustrates the format of the start_time shown in FIG. 30;

FIG. 32 illustrates the format of the Duration shown in FIG. 30;

FIG. 33 illustrates the format of the repeat_type shown in FIG. 34;

FIG. 34 illustrates the format of the repeat_information shown in FIG. 30;

FIG. 35 illustrates the format of the repeat_information shown in FIG. 30;

FIG. 36 illustrates the format of Info blocks shown in FIG. 30;

FIG. 37 illustrates the format of the supported_board_type_specific_information shown in FIG. 24; and

FIG. 38 is a block diagram illustrating an example of the configuration of a computer.

The configuration of a network system incorporating an embodiment of the present invention is described below with reference to FIG. 2. Throughout the specification, the term "system" indicates an entire apparatus formed of a plurality of devices, means, and so on.

This network system is formed of an IRD 1 and a DVCR 3 connected to each other via a bus 2. In addition to the IRD 1 and the DVCR 3, electronic machines provided with an IEEE-1394 terminal, such as personal computers, hard disk drives, compact disc (CD) players, monitors, digital video cameras, and mini disc (MD) (brand name) players, may be connected to the bus 2.

Electronic machines, such as the IRD 1 and the DVCR 3, connected to the bus 2 are referred to as "units". Among the units, it is possible to read and write information from and into the individual units by using a descriptor (Descriptor) defined in the AV/C Digital Interface Command Set General Specification of the AV/C Command Transaction Set (hereinafter referred to as "AV IC General"). The details of AV/C General can be seen in http://cxn02.net.arch.sony.co.jp/Doc/. The functions provided for the units are referred to as the "subunits".

A controller 11 of the IRD 1 controls the entire IRD 1 by receiving a channel-selecting operation or a recording-reservation operation performed by a user. The controller 11 also controls the DVCR 3 by using a predetermined command (AV/C Command Transaction Set). A CS antenna 13 receives digital signals of a digital satellite broadcast transmitted via a communication satellite (not shown) and outputs the digital signals to a tuner sub-unit 12. The tuner sub-unit 12 extracts a predetermined channel signal from the digital signals input from the CS antenna 13 under the control of the controller 11, and outputs the extracted signal to a VCR sub-unit 33 of the DVCR 3 via the bus 2. The controller 11 further searches for information stored in a Bulletin Board Subunit (BBS) 34 of the DVCR 3.

A BBS 14, which serves as a sub-unit of the IRD 1, stores information concerning recording reservations received and determined by the controller 11 (details are discussed below with reference to FIG. 24).

A controller 31 of the DVCR 3 controls the entire DVCR 3 by receiving a reproducing-instruction operation or a recording-reservation operation performed by a user. An analog tuner block 32 extracts a predetermined channel signal from the input analog signals under the control of the controller 31 and outputs the extracted signal to the VCR sub-unit 33.

The VCR sub-unit 33 records on magnetic tape (not shown) a video signal input from the analog tuner block 32 or a video signal input from the tuner sub-unit 12 of the IRD 1 via the bus 2.

The BBS 34 manages information of recording reservations concerning the DVCR 3.

The tuner sub-unit 12 and the BBS 14 are sub-units of the IRD 1, and the VCR sub-unit 33 and the BBS 34 are sub-units of the DVCR 3. The analog tuner block 32 is not a sub-unit because it is not controlled by another unit via the bus 2 though it executes one of the functions of the DVCR 3.

In this network system, when a recording reservation of a digital satellite broadcast is performed, a user inputs the settings of the recording reservation (channel, recording start time, etc.) into the IRD 1. If the input reservation does not cause double-booking, it is accepted, and the reservation information is written into the BBS 14 of the IRD 1.

The BBS 14 is formed of, as shown in FIG. 3, a Resource Schedule Board (RSB) 51 and a Scheduled Action Board (SAB) 52. The SAB 52 stores all the information concerning recording reservations input from the controller 11 of the IRD 1 and from a controller of another unit (for example, the controller 31 of the DVCR 3). That is, the SAB 52 stores all the information for controlling a series of operations of causing the tuner sub-unit 12 of the IRD 1 to receive information at a predetermined time and to record it on the VCR sub-unit 33 of the DVCR 3.

In contrast, the RSB 51 stores only information concerning reservations for the tuner sub-unit 12 of the IRD 1 among all the information concerning recording reservations (including reservations set by other units). Even if the operation of the VCR sub-unit 33 is related to that of the tuner sub-unit 12, the RSB 51 does not store reservation information of the VCR sub-unit 33. The RSB 51 makes the stored information public in response to a request not only from the controller 11 of the same unit, but also from the controller of another unit (for example, the controller 31 of the DVCR 3).

Similarly, the BBS 34 of the DVCR 3 is formed of, as shown in FIG. 4, a RSB 61 and a SAB 62. The SAB 62 stores all the information concerning recording reservations input from the controller 31 of the DVCR 3 and from another controller of another unit (for example, the controller 11 of the IRD 1). In contrast, the RSB 61 stores only information concerning reservations for the VCR sub-unit 33 of the DVCR 3 among all the information concerning recording reservations input into the controller 31 of the DVCR 3 and into the controller 11 of the IRD 1. Even if the operation of the tuner sub-unit 12 is related to that of the VCR sub-unit 33, the RSB 61 does not store reservation information of the tuner sub-unit 12. The RSB 61 makes the stored information public in response to a request not only from the controller 31 of the same unit, but also from the controller of another unit (for example, the controller 11 of the IRD 1).

Details of information stored in the RSBs 51 and 61 and made public will be described in detail later with reference to FIG. 26.

The operation related to both the RSBs 51 and 61 is discussed below with reference to FIG. 5. For example, when a recording reservation (which causes the tuner sub-unit 12 to receive the 48 channel from 20:00 to 21:00 on October 16 and to record the received video signal on the VCR sub-unit 33 of the DVCR 3) is input into the controller 11 of the IRD 1, as shown in FIG. 5, the controller 11 sets an ID (BB Object ID) (in this embodiment, ID_X) unique to the reservation, and stores all the information concerning the recording reservation in the SAB 52. The controller 11 also stores in the RSB 51 the set ID (ID_X), the time and date (from 20:00 to 21:00 on October 16), and information (ID information) for specifying the related sub-unit (in this embodiment, tuner sub-unit 12) of the IRD 1. The controller 11 further stores in the RSB 61 of the DVCR 3 the set ID (ID_X), the time and date (from 20:00 to 21:00 on October 16), and information (ID information) for specifying the related sub-unit (in this embodiment, the VCR sub-unit 33) of the DVCR 3.

Thereafter, when a recording reservation (which causes the analog tuner block 32 to receive the third channel from 20:00 to 21:00 on October 16 and to record the received video image on the VCR sub-unit 33) is input into the controller 31 of the DVCR 3, as shown in FIG. 6, the controller 31 refers to the RSB 61 and determines whether the information of the input recording reservation overlaps with the information of the reservation which has been accepted and made public to the RSB 61. In this case, since the recording time, i.e., from 20:00 to 21:00 on October 16, of the input reservation overlaps with that of the accepted reservation, the input recording reservation is not accepted. If it is determined that the information of one reservation does not coincide with that of the other reservation, the input recording reservation is accepted. All the information is stored in the SAB 62, and the information concerning the VCR sub-unit 33 is stored in the RSB 61.

Details of the above-described reservation processing (contending-unit search processing) are discussed below with reference to the flow charts of FIGS. 7 through 9.

In step S11, a user sets a reservation in the controller 11 of the IRD 1. That is, in the example shown in FIG. 5, a reservation for causing the tuner sub-unit 12 to receive the 48 channel from 20:00 to 21:00 on October 16 and to transfer the received video signal to the VCR sub-unit 33 of the DVCR 3 and record it. Simultaneously, in step S12, the controller 11 controls the RSBs of the units including the target sub-units to be in the WRITE OPEN state. In the example illustrated in FIG. 5, the target sub-units are the tuner sub-unit 12 of the IRD 1 and the VCR sub-unit 33 of the DVCR 3. Accordingly, the controller 11 first selects the tuner sub-unit 12 and outputs a WRITE OPEN command so that the RSB 51 of the IRD 1 including the tuner sub-unit 12 reaches the WRITE OPEN state (the write enable state).

In practice, however, the RSB 51 and the controller 11 are in the same unit, i.e., the RSB 51 and the controller 11 are not connected via the bus 2. Accordingly, the controller 11 controls the RSB 51 as if a WRITE OPEN command were supplied to the RSB 51 via the bus 2.

After the RSB 51 of the IRD 1 including the tuner sub-unit 12 has become the WRITE OPEN state, the controller 11 controls the RSB 61 of the DVCR 3 including the remaining target sub-unit, i.e., the VCR sub-unit 33, to be in the WRITE OPEN state. In this case, the controller 11 outputs a WRITE OPEN command having the format shown in FIG. 10 to the RSB 61 (the controller 31) of the DVCR 3 via the bus 2.

The above WRITE OPEN command is one type of OPEN DESCRIPTOR commands used for making access to a predetermined target address space. As shown in FIG. 10, the value 0816, which represents the OPEN DESCRIPTOR, is set in the opcode. The value 1016, which indicates the Object List Descriptor defined by the list ID, is set in operand 0 as the descriptor_type representing the type of the descriptor. In operand 1 and operand 2, list IDs (in this embodiment, 00 and 01) of the RSBs to be accessed (to be in the WRITE OPEN state) are described.

The value 0316, which indicates that descriptors are to be opened to be read or written, is set in operand 3 as subfunction. The value 00 is set in operand 4 as a reserved value.

Referring back to FIG. 7, in step S13, the controller 11 reads out the descriptor_length and the list_specific_information field (FIG. 26) of the RSB 51 within the BBS 14. The reading operation is performed by using, for example, the READ command shown in FIG. 11. In this case, since the controller 11 and the RSB 51 are not connected via the bus 2, as stated above, the above data is directly read from the controller 11 to the RSB 51. When, however, the controller 11 reads out data from the RSB 61 of the DVCR 3, the READ command shown in FIG. 11 is output to the RSB 61 (the controller 31) via the bus 2.

As illustrated in FIG. 11, the value 0916, representing the read descriptor, is set in the opcode, which is the head of the READ command. In the subsequent operand 0, the descriptor identifier for identifying the descriptor to be read is described. In the reading operation in step S13, the descriptor identifier is set by the list ID. More specifically, 0016 through OD16 of the Address_offset of the write enabled list_specific_information field of the RSB shown in FIG. 27 are set.

When the READ command is transmitted, FF is set in the read_result_status. When the READ command is returned from the target as a response, the read result is set. In the data_length, the number of bytes of data to be read from the target is described. When the data_length is set to be 0, all the lists are read. The address at which the reading is started is set in the address. When 00 is set in the address, the reading commences from the head.

Referring back to FIG. 7, in step S14, the controller 11 extracts for the RSB 51 the maximum length of the list (the object_list_maximum_size shown in FIG. 27), the maximum number of entries of the list (the object_entries_maximum_number shown in FIG. 27), and the maximum byte length of each entry (the object_entry_maximum_size shown in FIG. 27).

The controller 11 then determines in step S15 whether data (reservation information) to be recorded on the RSB 51 causes an excess of the maximum length of the list extracted in step S14. If the outcome of step S15 is no, the process proceeds to step S16 in which the controller 11 determines whether the value obtained by subtracting the current number of entries from the maximum number of entries of the list extracted in step S14 is greater than zero, i.e., whether there is any entry left for writing data. If the result of step S16 is yes, the process proceeds to step S17 in which the controller 11 determines whether the value obtained by subtracting the length of the entry of the reservation information to be written from the maximum length of the entry extracted in step S14 is greater than zero, i.e., whether there is any space left for the entry into which data is written.

If any one of the conditions set in steps S15 through S17 is not satisfied, the process proceeds to step S18 in which the controller 11 indicates a warning, such as "reservations are full" to the user. This enables the user to recognize that no more reservations can be made.

If all the conditions set in steps S15 through S17 are met, the reservation information can be written into the RSB 51, and a determination is further made in steps S19 through S25 of FIG. 8 whether the time of the reservation input by the user overlaps with that of the reservation which has already been accepted, i.e., whether double-booking has occurred.

More specifically, in step S19, a variable i is initialized to zero. It is then determined in step S20 whether the value obtained by subtracting the variable i from the number of entries, i.e., the number_of_entries, recorded on the RSB 51 is greater than zero, i.e., whether all the entries recorded on the RSB 51 have been searched. If the outcome of step S20 is yes, the process proceeds to step S21 in which the controller 11 reads out the object_entry[i] (FIG. 29) (in this case, the object_entry [0]) shown on the RSB 51.

Although the reading operation in step S21 is also performed by using the READ command illustrated in FIG. 11, the descriptor identifier is set by the object position. In the object_entry[i], the time information of the registered reservation (the start_time and the Duration shown in FIG. 30) and the ID information of the target sub-unit (the subunit_type_and_ID[0] shown in FIG. 36) are stored, which will be described later.

Then, the controller 11 determines in step S22 whether the time information (the start_time and the Duration) input by the user in step S11 overlaps with the time information (the start_time and the Duration) read in step S21. If the result of step S22 is yes, the process proceeds to step S23. In step S23, the controller 11 determines whether the sub-unit in which the reservation was set in step S11 (in this case, the tuner sub-unit 12) coincides with the sub-unit read in step S21 (the subunit type_and_ID). If the outcome of step S23 is yes, the time and the sub-unit read in step S21 match those input by the user. Accordingly, the process proceeds to step S25 in which the controller 11 indicates a warning, such as "reservations are overlapping". As a result, the occurrence of double-booking can be prevented.

If it is found in step S22 that the time information input by the user does not overlap with the time information read in step S21, or if it is found in step S23 that the sub-units determined in steps S11 and S21 do not coincide with each other even if time overlapping has occurred in step S22, there is no possibility of generating double-booking. Accordingly, in step S24, the variable i is incremented by one, and the process returns to step S20. Processing similar to the above-described processing is repeated until it is determined in step S20 that the value obtained by subtracting the variable i from the number_of_entries is not greater than zero. That is, all the object_entries[i] stored in the RSB 51 are searched to determine whether there are any overlapping reservations.

If it is found in step S20 that the value obtained by subtracting the variable i from the number_of_entries is not greater than zero, i.e., that all the object_entries[i] have been searched, the process proceeds to step S26. In step S26, the controller 11 outputs a CREATE command to the RSB 51 and creates an object entry in the RSB 51. In this case, the CREATE command is not actually output, and processing is executed as if the CREATE command were output, as stated above. When the object entry is created in the RSB 61, the CREATE command is output.

The above-described steps S15 through S18 may be executed after it is determined in step S20 that the all the entries have not been completely searched.

The above-described CREATE command is described in detail below with reference to FIGS. 12 through 15. FIG. 12 illustrates the format of the AV/C CREATE command. FIG. 13 illustrates the value that can be specified by the subfunction_1 shown in FIG. 12, and in this embodiment, 01 (create a new object and its child list) is used. FIG. 14 illustrates the format of the subfunction_1_specification for subfunction_1=01 shown in FIG. 12. FIG. 15 illustrates the values of the individual fields shown in FIG. 14. If the values 20, 22, and 11 are respectively set, as illustrated in FIG. 15, in the fields, i.e., the descriptor_identifier_where, the descriptor_identifier_what_1, and the descriptor_identifier_what_2, of FIG. 14, the meaning is to create a new object and its child list.

Details of the AV/C CREATE command are indicated in IEEE 1394 (see the Internet homepage http://www.1394 TA.org), and the formats used in this embodiment are extracted from the specifications of the IEEE 1394 standards (Enhancement to the AV/C General Specification 3.0 Version 1.0 FC2 and TA Document 1999005 AV/C Bulletin Board Subunit General Specification 1.0 Draft 0.99:149). The information descriptors forming the board (Information List Descriptor) include writable descriptors and readable descriptors, and the list type is used for differentiating the two types.

To write new information into the AV/C descriptor (AV/C Descriptor) from an external source, the following method may be employed as a typical example. The controller issues the above-described CREATE command to the target, and after the target forms a model for writing information, the controller again controls the writing of specific information. More specifically, when information is first written, the controller designates a desired list and issues the AV/C Descriptor CREATE command. Upon receiving this command, the target forms the object based on the model having the data structure specified by the AV/C General. The model having the data structure designated by the AV/C General has a field of the object ID. In the list using the AV/C Descriptor, the object ID is managed by the target, namely, when the object is created, the target adds an ID unique to the object and possesses the function of managing the ID.

The object ID is an ID number for uniquely specifying the object in the list, and the target is required to have the function of preventing the multiple storing of IDs. The BBS merely provides information, and the object IDs are managed by the controller.

When the CREATE command is issued to a sub-unit, inconsistencies may arise. When an object is created, the object ID, which should be managed by the controller, is under the control of the target. After issuing the CREATE command, the controller has to continue the writing control. In this manner, the processing is divided into a plurality of steps. Accordingly, if the controller is accidentally disconnected from the bus while writing information into the BBS, an imperfect object may be created.

To overcome the above-described situation, there is needed a system for specifying the imperfect object and correctly eliminating it. In this embodiment, the writing of information into the BBS is restricted so as to specify imperfect objects.

In creating an object, the target (in this embodiment, the DVCR 3) first assigns temporarily managing numbers (for example, all 0) to a Global Unique ID (GUID) of the object ID. The object ID consists of the GUID and the record ID. The controller then writes information into the object, and if the writing operation is correctly completed, the controller finally overwrites the GUID.

According to the above procedure, if the writing operation has been correctly completed, the presence of objects having the GUID indicating all 0 is impossible. Accordingly, such objects can be specified as imperfect objects which were accidentally created while the writing operation was being performed.

Consequently, the objects which are being written can be uniquely identified. It is also possible to distinguish correctly written objects from imperfect objects and to easily eliminate the imperfect objects (invalid objects). This further makes it possible to effectively utilize a finite memory provided for an electronic apparatus. According to the above method, the objects which are being written can be simply specified by temporarily assigning 0 to the GUID. Software for eliminating imperfect objects can easily be created accordingly.

In step S26 of FIG. 9, the INSERT command may be used instead of the CREATE command.

Referring back to FIG. 9, the process proceeds to step S27 in which the controller 11 writes the reservation content into the entry_speific_information fields (FIGS. 30 through 36) of the RSB 51. That is, the start_time, the Duration, and the repeat_information, and the target sub-unit (subunit_type_and_ID) are written.

FIG. 16 illustrates the WRITE DESCRIPTOR command output from the controller 11 when step S27 is executed. As stated above, since the controller 11 and the RSB 51 are not connected via the bus 2, the controller 11 directly writes information into the RSB 51 without issuing the WRITE DESCRIPTOR command. Conversely, when the controller 11 writes information into the RSB 61, the WRITE DESCRIPTOR command is issued.

In the opcode, which is the head of the WRITE DESCRIPTOR command, the value OA16, which indicates the WRITE DESCRIPTOR, is set. In operand 0, the descriptor identifier for identifying the descriptor of the information to be written is set by the object position.

Thereafter, the value 5016, which represents the partial_replace, is set as the subfunction, thereby executing partial insert or partial delete. In performing insert, a new descriptor is inserted immediately before the descriptor defined by the operand specified by the descriptor_identifier. In performing delete, the descriptor defined by the descriptor_identifier is deleted.

The group_tag is used for updating the data which cannot be divided when being written into the descriptor. In this embodiment, the value 0016 (immediate), which indicates that the data is immediately written into the descriptor, is set. The replacement_data_length represents the number of bytes of the operand, i.e., the length of data to be written. The address indicates the position at which processing is executed. If the replacement_data_length indicates 0, partial delete is performed, in which case, the operand of the replacement_data does not exist. In this case, the original_data_length is greater than 0, and indicates the number of bytes to be deleted. If the original_data_length is 0, partial insert is executed, in which case, the replacement_data_length is greater than 0, and indicates the number of bytes to be inserted.

Referring back to FIG. 9, the process proceeds to step S28 in which the controller 11 closes the list, i.e., the RSB 51. Simultaneously, the controller 11 outputs the CLOSE command shown in FIG. 17 to the RSB 51. As stated above, the controller 11 directly closes the RSB 51 without issuing the CLOSE command since the controller 11 and the RSB 51 are not connected via the bus 2. When the controller 11 closes the RSB 61 of the DVCR 3, the CLOSE command is output.

The format of the CLOSE command illustrated in FIG. 17 is basically similar to the WRITE OPEN command shown in FIG. 10, except for the following point. The subfunction of the WRITE OPEN command indicates 0316, which represents WRITE OPEN, while the subfunction of the CLOSE command indicates 0016, which indicates CLOSE.

The process then proceeds to step S29 in which the controller 11 determines whether there are any other resources related to the reservation. In this case, although processing for making a reservation in the tuner sub-unit 12 has been completed, another processing for making a reservation in the VCR sub-unit 33 of the DVCR 3 is required. Accordingly, the process returns to step S12 in which processing similar to that performed on the RSB 51 is executed on the RSB 61 of the DVCR 3.

If it is determined in step S29 that there are no other resources related to the reservation, the processing is completed.

As discussed above, a series of record-reservation operations for causing the tuner sub-unit 12 to receive a video signal and to record it on the VCR sub-unit 33 has been made. It is now assumed that reservations are separately made, as shown in FIG. 18, i.e., a receiving reservation is made in the IRD 1 and a recording reservation is made in the DVCR 3. More specifically, a reservation is input into the controller 11 of the IRD 1 to cause the tuner sub-unit 12 to receive a predetermined channel (the 48 channel) during a predetermined period from 20:00 to 21:00 at October 16, and another reservation is input into the controller 31 to cause the VCR sub-unit 33 to start recording during a predetermined period from 20:00 to 21:00 at October 16. It appears to the user that the two reservations are the same reservation. However, it seems to the IRD 1 and the DVCR 3 that the two reservations have been separately made, and different IDs (BB Object ID_Y, and BB Object ID_Z) are respectively set in the IRD 1 and the DVCR 3 and are stored in the corresponding RSB 51 and the RSB 61.

Even when reservations are separately made in the individual units, reservation processing can be executed in a manner similar to that indicated by the flow charts of FIGS. 7 through 9. However, if reservations are separately made even when the sub-units of the different units are used in cooperation with each other, the occurrence of double-booking has to be checked by the user.

The present invention is applicable even when the BBS 14 is not provided for the IRD 1, as shown in FIG. 19. In this case, when a reservation is input from the controller 11 to use the VCR sub-unit 33 of the DVCR 3 from 20:00 to 21:00 at October 16, it is written into the RSB 61 of the BBS 34 of the DVCR 3 via the bus 2.

Processing for setting the Object ID is described below with reference to the flow chart of FIG. 20. After a recording reservation using the DVCR 3 is made on the IRD 1 by the user and is detected by the controller 11, the aforementioned reservation processing (contending-unit search processing) shown in FIGS. 7 through 9 is executed. When the recording reservation is accepted, the above processing for setting the Object ID commences. In this embodiment, the Object ID is employed for identifying the reservation (Event) to be started at a predetermined time for a predetermined period. The Object ID has 72 bits in which the most significant 64 bits are used for the ID unique to the unit possessing all the information concerning the reservation, i.e., for the GUID of the unit, for example, IEEE EUI-64, and the least significant 8 bits are used for the unique value set in the unit, i.e., for the record ID. In this manner, the Object ID for identifying the Event is formed of the GUID and the record ID. Thus, the processing for setting the Object ID can be easily executed, and information for specifying the honor which has written the information can be effectively included.

It is necessary to identify the Object ID among the individual units connected via the bus 2. The reason for this is as follows. The content of the RSB of one unit can be read by the other units, and processing may be simultaneously executed by the sub-units of the different units in cooperation with (relating to) each other. Accordingly, it is necessary for the individual units to check for any processing to be performed in cooperation with each other.

The processing for setting the above-mentioned Object ID is described below with reference to the flow chart of FIG. 20. In step S41, the controller 11 issues a provisional ID for uniquely identifying the reservation information within the IRD 1 as a record ID of the Object ID (which consists of GUID and the record ID).

In step S42, the controller 11 extracts one of the Events registered in the RSB 51, and further extracts the record ID of the Object ID corresponding to the extracted Event. The controller 11 then determines in step S43 whether the provisional ID issued in step S41 coincides with the record ID extracted in step S42. If the outcome of step S43 is yes, the process returns to step S41 in which the provisional ID is changed. The processing of steps S41 through S43 is repeated until the provisional ID does not match the record ID.

If it is found in step S43 that the provisional ID does not coincide with the record ID, the controller 11 determines in step S44 whether all the Events concerning the related sub-unit which have been made public in the RSB 51 have been extracted. If the result of step S44 is no, the process returns to step S42, and the processing of steps S42 through S44 is repeated until it is determined in step S44 that all the Events have been extracted. If the outcome of step S44 is yes, the process proceeds to step S45. In step S45, the controller 11 adds the provisional ID (record ID) generated in step S41 to the unit ID (GUID) of the IRD 1, thereby generating the Object ID. The Object ID is then set in the RSB 51.

As discussed above, the Object ID can be set merely by checking the RSB corresponding to the related sub-unit (without needing to check the RSBs of the units including unrelated sub-units). The reason for this is as follows, as stated above. Since the Object IDs of the RSBs of the other units include the GUIDs unique to the individual units, it is not possible that the Object IDs set by the other units match the Object ID set by the corresponding unit. As a result, the Object ID can be easily set.

Instead of the Object ID, a predetermined unique ID (hereinafter referred to as the "SA Event ID") within the bus 2 may be used. After a recording reservation using the DVCR 3 input into the IRD 1 from the user and detected by the controller 11, reservation (contending-unit searching) processing shown in FIGS. 7 through 9 is executed. Thereafter, the processing shown in FIG. 21 commences.

In step S51, the controller 11 generates a provisional ID for uniquely identifying the reservation information in the bus 2. Then, in step S52, the controller 11 reads out an Event stored in the RSB 51 of one unit (or the unit related to the reservation processing) within the bus 2 and extracts the SA Event ID of the read Event. Subsequently, the controller 11 determines in step S53 whether the provisional ID generated in step S51 matches the SA Event ID extracted in step S52. The processing from step S51 to step S53 is repeated until it is found in step S53 that the two IDs do not coincide with each other.

If the outcome of step S53 is no, the controller 11 determines in step S54 whether all the SA Events of the unit (or the related unit) within the bus 2 have been extracted. The processing from step S52 through step S54 is repeated until the result of step S54 is no. If it is found in step S54 that all the SA Events have been extracted, the process proceeds to step S55 in which the controller 11 records the provisional ID generated in step S51 on the RSB 51 as the SA Event ID.

According to the processing illustrated in FIG. 21, all the RSBs of all the units connected to the bus 2 have to be checked. In contrast, according to the processing shown in FIG. 20, it is necessary to check only the RSBs of the corresponding unit and the related units, thereby achieving fast processing.

The object ID may be stored not only in the RSB, but also in the SAB. This makes it possible to easily detect the occurrence of double-booking. It is now assumed that an IRD 91, as well as the IRD 1 and the DVCR 3, is connected to the bus 2, as illustrated in FIG. 22. The BBS 14 of the IRD 1 is provided with not only the RSB 51 and the SAB 52, but also a Subunit Identifier Descriptor (SID) 100. The SID 100 stores information for identifying which board types (in this case, the RSB 51 and the SAB 52) are supported within the BBS 14 to which the SID 100 belongs.

The BBS 34 of the DVCR 3 is provided with not only the RSB 61, but also a SID 81. The IRD 91 also possesses a controller 92 and a display unit 93.

The operation performed by the system shown in FIG. 22 is discussed in detail below. The user inputs reservation information into the controller 11 of the IRD 1. In the example shown in FIG. 22, a reservation is input to select the X channel from 20:00 to 21:00 on August 12 and record the data of the selected program on the DVCR 3. The controller 11 writes the content of the reservation into a built-in memory and writes the reservation information into the RSB 51 and the SAB 52 of the BBS 14. The controller 11 also writes the schedule for using the DVCR 3 as a target into the RSB 61 of the BBS 34 of the DVCR 3. Simultaneously, the controller 11 sets the Object ID to be stored in the individual entries of the RSB 51, the SAB 52, and the RSB 61 to be the same value.

According to the aforementioned system shown in FIG. 22, a description is given below of the processing executed when the IRD 91 makes a reservation for using the DVCR 3 at the time period overlapping the time of the reservation made by the IRD 1.

In step S61, the controller 92 of the IRD 91 checks the RSB 61 of the target DVCR 3 and determines whether there is any reservation made by another controller in the time period which overlaps with the time of the reservation made by the IRD 1. If the outcome of step S61 is no, the process proceeds to step S65 in which the controller 92 executes reservation processing similar to that described above. That is, the controller 92 writes the time information of the reservation into the RSB 61 of the DVCR 3.

If it is found in step S61 that the VCR sub-unit 33 of the DVCR 3 has been reserved by another controller at the overlapping time, the process proceeds to step S62. In step S62, the controller 92 reads the Object ID of the entry related to the reservation, and determines the node ID of the unit that has written the entry from the upper 8-byte (64 bits) GUID of the Object ID. As stated above, the GUID is inherent in each unit and is not varied every time the bus is reset. Accordingly, the controller 92 checks the GUIDs and the node IDs of the units connected to the bus 2, and then creates a look-up table about the two IDs in correspondence with each other in advance. It is thus possible to determine the node ID from the GUID by referring to the look-up table.

Subsequently, in step S63, the controller 92 designates the same Object ID as the entry of the overlapping reservation from the SAB of the unit determined in step S62 (in this case, the SAB 52 of the IRD 1), and reads the content of the entry. In step S64, the controller 92 outputs the content of the overlapping reservation to the display unit 93 and displays it. This enables the user of the IRD 91 to identify the previously reserved content.

The BBS is discussed in greater detail below. FIG. 24 illustrates the format of the Subunit identifier Descriptor forming the BBS. The descriptor_length represents the length of the Descriptor. The generation_ID indicates which AV/C descriptor format of the BBS is used, and generally, 0016 is set.

The size_of_list_ID designates the number of bytes of the ID. The size_of_object_ID indicates the number of bytes of the Object ID. The size_of_object_position represents the number of bytes of the position of the object in the list. The number_of_root_object_lists indicates the number of root object lists to which the BBS is directly related.

The root_object_list_id_x (x=0, 1, 2, . . . n-1) represents the ID of each of the root object lists to which the BBS is related. The subunit_dependent_information_length designates the length of the subunit_dependent_information, and the information of the format and the contents on which the BBS is dependent is set in the subunit_dependent_information.

The subunit_dependent_information includes the non_info_block_fields_length, the bulletin_board_subunit_version, the number_of_supported_board_type(n), the supported_board_type_specific_of_length[0], the supported_board_type_specific_info[0] through supported_board_type_specific_info[n-1], and the supported_board_type_specific_of_length[0] through supported_board_type_specific_of_length[n-1], which represents the lengths of the supported_board_type_specific_info[0] through supported_board_type_specific_info[n-1].

The BBS further includes the manufacturer_dependent_length, which indicates the length of the manufacturer_dependent_information, and the manufacturer_dependent_information, which represents the information dependent on the manufacturer.

If the value of the root_object_list_id indicates the RSB, a predetermined value 100116 is set, as shown in FIG. 25. In this manner, by fixing the ID representing the RSB (described as Resource Schedule List in FIG. 25) to the predetermined value, the processing for reading the RSB can be facilitated.

FIG. 26 illustrates the format of the RSB. The descriptor_length indicates the length of the RSB. The list_type indicates whether the RSB is Read Only or Write Enabled. The Read Only list represents that only reading is enabled, and the Write Enabled List indicates that writing, as well as reading, is enabled.

The size_of_list_specific_information indicates the length of the list_specific_information, and the content of the list_specific_information varies according to the list_type. The information shown in FIG. 27 is set in the Write Enabled list_specific_information.

The non_info_block_fields_length represents the number of bytes of the non info block fields. If the board_type is the Resource Schedule Board, as shown in FIG. 28, 0116 is set.

The object_list_maximum_size represents the maximum size of the object list. The object_entry_maximum_number indicates the maximum number of object entries in the list. The object_entry_maximum_size indicates the maximum size of each object entry. If there is no limit imposed on the object_list_maximum size, the object_entry_maximum_number, and the object_entry_maximum_size, 000016 is set in each field.

The above three fields are significant for the controller to recognize the capacity of the object list or the object entry.

The board type dependent_information_length designates the length of the board_type_dependent_information, and the information unique to the board type is set in the board_type_dependent_information.

The object_entry is configured specifically as illustrated in FIG. 29. The descriptor_length indicates the length of the descriptor. If the entry_type is Board entry Descriptor, the value 8015, which represents the Board, is set.

The object_ID is formed of the posting_device_GUID and the record_ID. The posting_device indicates the controller that has written (posted) information into the BBS, and accordingly, the posting_device_GUID represents the GUID of the controller. The record_ID designates an ID assigned to the Event within the unit. The size_of_entry_specific_information depicts the size of the entry_specific_information.

FIG. 30 illustrates the format of the entry_specific_information. The non_info_block_length indicates the number of bytes of the non-info block fields before the repeat_information. The start_time represents the second, the minute, the hour, the day, the month, and the year at which the event is started, as illustrated in FIG. 31. The year has 16 bits, the four numbers being each represented by a four-bit binary-coded decimal (BCD). The month has eight bits, the two numbers being each represented by a four-bit BCD. The day has eight bits, the two numbers being each indicated by a four-bit BCD. The hour has eight bits, the two numbers being each indicated by a four-bit BCD. The minute has eight bits, the two numbers being each indicated by a four-bit BCD. The second has eight bits, the two numbers being each represented by a four-bit BCD.

The start_time is easily identified by being indicated as the BCD. The time is represented by local time.

The Duration, which indicates the length of the event, is represented by the hour, the minute, and the second, as illustrated in FIG. 32. The hour has a total of 12 bits, the three numbers being each represented by a four-bit BCD. The minute has a total of eight bits, the two numbers being each indicated by a four-bit BCD. The second has a total of eight bits, the two numbers being each represented by a four-bit BCD.

By adding the Duration to the start_time, the end time of the event can be indicated. The length of the event is thus represented by the Duration without directly indicating the end time. This eliminates the need to modify the end time even when the start_time of the event is changed, thereby simplifying the updating processing.

The repeat_information_length indicates the length of the repeat_information. The repeat_information represents when and how the schedule is repeated. If the Scheduled Action is not repeated, the repeat_information_length indicates 0016.

The content of the repeat_information varies according to the selected repeat type. The repeat type includes the Weekly schedule 0016 and the Interval schedule 1016, as shown in FIG. 33.

If the schedule is repeated every week, the Posting Device indicates the days of the week and the number of events to be repeated, as illustrated in FIG. 34.

The value 0016 shown in FIG. 33 is set in the repeat_type. The number of events is set in the number_of_events. The Weekly flags from Sunday to Saturday indicate the days of the week on which the event to be repeated is started. For example, if an event starting from 13:00 for three hours takes place every Monday and Wednesday, 1 is set in the Weekly flags of Monday and Wednesday, and 0 is set in the other Weekly flags.

The events to be repeated weekly can be recorded, as described above. Accordingly, only a smaller storage capacity is required compared to that required for storing, for example, the absolute time and date every Monday and Wednesday corresponding to the broadcast days.

When the Scheduled Action is repeated with predetermined intervals, the Posting Device describes the event by using the format shown in FIG. 35.

In this example, the value 1016 shown in FIG. 33 is set in the repeat_type. The number of events is set in the number_of_events.

The interval represents the interval from the start_time of a current event to the start_time of the subsequent event. This interval is represented by the hour, the minute, and the second. The hour has a total of 12 bits, the three numbers being each indicated by a four-bit BCD. The minute has a total of eight bits, the two numbers being each designated by a four-bit BCD. The second has a total of eight bits, the four numbers being each indicated by a four-bit BCD.

In this manner, the periodically repeated events can be stored. As a consequence, only a smaller capacity is needed compared to that required for storing the absolute time (time and date) at which each event is started.

The info blocks shown in FIG. 30 are represented by the format illustrated in FIG. 36. The compound_length indicates the byte length of the info block, except for the length field. The info_block_type is set to be 890016. The primary_fields_length indicates the number_of_subunits and the number of bytes of the subunit_type_and_ID field.

The number_of_subunits represents the number of subunits used by the posting Device. The subunit_type_and_ID specifies the subunits to be used by the posting Device.

As discussed above, the start_time and the Duration are represented by the fixed lengths at the fixed address. In contrast, the ID information for identifying the subunit and the Posting Device using the subunit is stored as Info blocks at a predetermined address subsequent to the address of the start_time and the Duration. With this arrangement, the addition of Posting Devices can be easily handled.

The supported_board_type_specific_information field shown in FIG. 24 is indicated by the format illustrated in FIG. 37. The value 0116, which indicates the RSB, shown in FIG. 28, is set in the supported_board_type. The supported_board_type_version represents the version number of the bulletin Board Type Specification. The implementation_profile_ID designates the profile ID version for this board type.

The supported_board_type_dependent_information_length indicates the number of bytes of the supported_board_type_dependent_information. The information inherent in each board type specification is described in the supported_board_type_dependent_information.

The above-described series of operations can be executed by hardware. Alternatively, software may be used, in which case, a software program implementing the above operations may be installed into a computer built into a controller specifically used as hardware. Alternatively, the above software program may be installed into a general-use personal computer that can execute the various functions by installing various programs.

As shown in FIG. 38, a general-use personal computer 101 has, for example, a built-in central processing unit (CPU) 111. An input/output interface 116 is connected to the CPU 111 via a bus 115. In response to an instruction provided by a user from an input unit 118, such as a keyboard, a mouse, etc., via the input/output interface 116, the CPU 111 reads a program implementing the above-described operations from a recording medium, such as a read only memory (ROM) 112 or a hard disk 114, or a recording medium loaded into a drive 120, such as a magnetic disk 131, an optical disc 132, or a magneto-optical disk 133. The CPU 111 then installs the read program into a random access memory (RAM) 113 and executes it. The program installed in the hard disk 114 may be a program stored in a recording medium and distributed to the user, or may be a program transferred through a satellite or a network and received by a communication unit 119, and then installed in the hard disk 14.

After processing the program, the CPU 111 outputs an image signal to a display unit 117, such as a liquid crystal display (LCD) or a cathode ray tube (CRT), via the input/output interface 116.

As is seen from the foregoing description, the information processing apparatus, the information processing method, and the recording medium of the present invention offer the following advantages.

Based on first identification information for identifying a management unit and second identification information for identifying the management information within an area managed by the management unit, third identification information for identifying the management information within the network is generated. Thus, the third identification information can be simply and speedily generated.

A provisional ID is generated for an event for controlling a sub-unit. The provisional ID is compared with an event ID of an extracted event. The provisional ID is then authenticated as the event ID according to the comparison result. Accordingly, the occurrence of double-booking in the network can be prevented.

In response to a request from an external information processing apparatus, the stored reservation information is supplied to the external information processing apparatus. Identification information including a value unique to the information processing apparatus that has reserved the sub-unit and a value unique to the reservation of the sub-unit set by the information processing apparatus is added to the reservation information of the sub-unit. This enables the external information processing apparatus to reliably reserve the sub-unit of the information processing apparatus. The occurrence of double-booking can also be prevented.

When a sub-unit of an external information processing apparatus is reserved, the reservation information concerning the reservation of the sub-unit stored in the external information processing apparatus is read. According to the reading result, identification information including a value unique to the information processing apparatus that has reserved the sub-unit and a value unique to the reservation of the sub-unit set by the information processing apparatus is added to the reservation information of the sub-unit of the external information processing apparatus. Then, the resulting reservation information is written into the external information processing apparatus. Therefore, the occurrence of double-booking can be prevented, and the sub-unit of the external information processing apparatus can be reliably reserved.

Yamamoto, Kazuo, Kawamura, Harumi, Horiguchi, Mari

Patent Priority Assignee Title
11599857, Jan 31 2017 Microsoft Technology Licensing, LLC Categorized time designation on calendars
6647448, Jun 29 2000 Sony Corporation; Sony Electronics Inc. Method and apparatus for managing resource schedules in a peer to peer distributed networking environment
6732282, Oct 20 2000 Sony Corporation; Sony Electronics Inc. System and method of determining the power relationship among devices
6757773, Jun 30 2000 Sony Corporation; Sony Electronics, INC System and method for determining support capability of a device coupled to a bus system
6804734, Feb 21 2000 Sony Corporation Device and method for switching receiving/recording device in a broadcasting connection/point-to-point connection bus enviroment
6810452, Mar 19 1999 Sony Corporation; Sony Electronics, INC Method and system for quarantine during bus topology configuration
6901444, Jun 30 2000 Sony Corporation; Sony Electronics, INC Method of and apparatus for communicating data structures between devices in a networking environment
6944704, Oct 04 2001 Sony Corporation; Sony Electronics Inc. Method and apparatus for utilizing extended AV/C command frames including status inquiry, notify inquiry and control inquiry command types
7003604, Oct 04 2001 Sony Corporation; Sony Electronics Inc. Method of and apparatus for cancelling a pending AV/C notify command
7043542, Jul 18 2000 Sony Corporation Information processing method and system for reserving and information processing apparatus having globally unique identification information
7130315, Sep 10 1999 Sony Corporation; Sony Electronics, INC Method of and apparatus for utilizing extended AV/C command and response frames including transaction label and common result/error code
7389338, Jul 18 2000 Sony Corporation Information processing method and system for reserving an information processing apparatus having globally unique identification information
7417973, Dec 31 2002 Apple Inc Method, apparatus and computer program product for ensuring node participation in a network bus
7565427, Jun 30 2000 Sony Corporation; Sony Electronics, Inc. Method of and apparatus for communicating data structures between devices in a networking environment
8010665, Jun 30 2000 Sony Corporation; Sony Electronics Inc. Method of and apparatus for communicating data structures between devices in a networking environment
8074245, Nov 02 2006 Panasonic Corporation Program reservation system and program reserving method
Patent Priority Assignee Title
6047376, Oct 18 1996 TOSHIBA INFORMATION SYSTEMS JAPAN Client-server system, server access authentication method, memory medium stores server-access authentication programs, and issuance device which issues the memory medium contents
6366964, Oct 22 1998 Sony Corporation; Sony Electronics, INC Method of and apparatus for dynamically enumerating objects representing devices within an IEEE 1394 serial bus networking
WO9728630,
WO9817033,
////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Sep 13 1999Sony Corporation(assignment on the face of the patent)
Nov 02 1999HORIGUCHI, MARISony CorporationASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0104180656 pdf
Nov 02 1999KAWAMURA, HARUMISony CorporationASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0104180656 pdf
Nov 04 1999YAMAMOTO, KAZUOSony CorporationASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0104180656 pdf
Date Maintenance Fee Events
Jul 28 2006M1551: Payment of Maintenance Fee, 4th Year, Large Entity.
Nov 18 2009RMPN: Payer Number De-assigned.
Nov 19 2009ASPN: Payor Number Assigned.
Jul 20 2010M1552: Payment of Maintenance Fee, 8th Year, Large Entity.
Jul 24 2014M1553: Payment of Maintenance Fee, 12th Year, Large Entity.


Date Maintenance Schedule
Jan 28 20064 years fee payment window open
Jul 28 20066 months grace period start (w surcharge)
Jan 28 2007patent expiry (for year 4)
Jan 28 20092 years to revive unintentionally abandoned end. (for year 4)
Jan 28 20108 years fee payment window open
Jul 28 20106 months grace period start (w surcharge)
Jan 28 2011patent expiry (for year 8)
Jan 28 20132 years to revive unintentionally abandoned end. (for year 8)
Jan 28 201412 years fee payment window open
Jul 28 20146 months grace period start (w surcharge)
Jan 28 2015patent expiry (for year 12)
Jan 28 20172 years to revive unintentionally abandoned end. (for year 12)