Movatterモバイル変換


[0]ホーム

URL:


US6160796A - Method and system for updating device identification and status information after a local bus reset within a home audio/video network - Google Patents

Method and system for updating device identification and status information after a local bus reset within a home audio/video network
Download PDF

Info

Publication number
US6160796A
US6160796AUS09/003,118US311898AUS6160796AUS 6160796 AUS6160796 AUS 6160796AUS 311898 AUS311898 AUS 311898AUS 6160796 AUS6160796 AUS 6160796A
Authority
US
United States
Prior art keywords
guids
network
devices
local bus
list
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
US09/003,118
Inventor
Feng (Frank) Zou
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sony Corp
Sony Electronics Inc
Original Assignee
Sony Corp
Sony Electronics Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sony Corp, Sony Electronics IncfiledCriticalSony Corp
Priority to US09/003,118priorityCriticalpatent/US6160796A/en
Assigned to SONY ELECTRONICS, INC., SONY CORPORATION OF JAPANreassignmentSONY ELECTRONICS, INC.ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: ZOU, FENG (FRANK)
Priority to JP11001470Aprioritypatent/JPH11317751A/en
Priority to EP99300080Aprioritypatent/EP0929170A3/en
Application grantedgrantedCritical
Publication of US6160796ApublicationCriticalpatent/US6160796A/en
Anticipated expirationlegal-statusCritical
Assigned to SONY CORPORATIONreassignmentSONY CORPORATIONASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: SONY CORPORATION OF JAPAN
Expired - Fee Relatedlegal-statusCriticalCurrent

Links

Images

Classifications

Definitions

Landscapes

Abstract

A method and system for updating device identification and status information in response to a local bus reset within a home audio/video network. Several consumer electronics products, e.g., television, VCR, tuner, set-top box (e.g., intelligent receiver/decoder, IRD), DVTRs, PCs, DVD players (digital video disk), etc., can be coupled within the network to communicate together via a standard bus (e.g., IEEE 1394 serial communication bus). In one embodiment, the communication architecture used is the home audio/visual initiative (HAVI) format. The HAVI network offers unique advantages consumer electronic vendors because the architecture offers for the home network many of the advantages of existing computer system networks. Namely, interconnected devices can share resources and provide open, well defined APIs that allow ease of development for third party developers. The present invention provides a mechanism whereby devices of the network are informed of the current status of the network after a local bus reset caused when a device is inserted into the network or when a device is removed from the network. After a reset, a new GUID list is generated by a driver and passed to a high level program. The high level program then compares the new GUID list with its own copy of an older version and generates a list of devices added to the network after the bus reset and a list of devices removed from the network after the bus reset. This information is then forwarded to all devices on the network that previously specified certain call back information regarding current device status.

Description

BACKGROUND OF THE INVENTION
1. Field of the Invention
The present invention relates to the field of communication systems. More specifically, the present invention relates to equipment for home audio/video electronics.
2. Related Art
A typical home audiovisual equipment complement includes a number of components, e.g., a radio receiver, a CD player, a pair of speakers, a television, a VCR, a tape deck, etc. Components are connected to each other via sets of wires. One component is usually the central component of the home audiovisual system. This is usually the radio receiver, or the tuner/decoder. The control buttons and control switches are usually located on the front of the tuner and in many cases, some or all of these buttons and switches are duplicated on a hand held remote control unit. A user controls the home equipment by manipulating the buttons and switches on the front of the tuner, or alternatively, manipulating buttons on the hand held remote control unit.
As consumer electronic devices have become more capable and more complex, demand for the latest and most capable devices has increased. As new devices emerge and become popular, new devices are purchased by consumers and "plugged" into their home audiovisual systems. The new device is simply plugged into the system alongside the pre-existing, older devices (e.g., cassette tape deck, CD player, and the like). The new device is plugged into an open input on the back of the tuner, or some other device coupled to the tuner. The consumer (e.g., the user) controls the new device via control switches on the new device itself, or via a separate remote control unit for the new device.
As the number of new consumer electronics devices for the home audiovisual system has grown and as the sophistication and capabilities of these devices have increased, a number of problems with the conventional paradigm emerge. One such problem is incompatibility between devices in the home audiovisual system. In addition, where one device is much newer than another device additional incompatibilities may exist For example, a new device might incorporate hardware (e.g., specific inputs and outputs) which enables more sophisticated remote control functions. This hardware may be unusable with older devices within the system. Another problem is the lack of functional support for differing devices within an audiovisual system. For example, even though a television may support advanced sound formats (e.g., surround sound, stereo, etc.), if an older less capable tuner does not support such functionality, the benefits of the advanced sound formats car be lost. Another problem is the proliferation of controls for the new and differing devices within the home audiovisual system. Each new device coupled to the audiovisual system often leads to another dedicated remote control unit for the user to keep track of and learn to operate.
In view of the above, it is desired to provide a communication architecture in which consumer electronics devices can be integrated. In so doing, the consumer electronics devices can offer and be expanded to include advanced communications and control functionality between themselves not heretofore offered. Within such communication architecture integrating consumer electronic devices ("a consumers electronics network"), devices can communicate with each other and control one another. Within a communications network where devices can communicate and control other devices, it is important that devices and associated software objects be aware of the current status of devices in the network to provide effective communication, control and reporting functions. Therefore, what is desired is a system that can efficiently report device status information to other devices and software objects within the communication network while requiring a minimum of high level application effort.
The IEEE 1394 serial communication bus, according to the IEEE 1394 standard, assigns a 6-bit physical identifier value (phy-- id) to each device connected to the bus. The IEEE 1394 serial communication bus uses this physical identifier to communicate with a device coupled thereto. Whenever a new device is inserted onto the bus (or powered on), or an existing device is removed from the bus (or powered down), or both, a bus reset is caused. The bus reset initiates certain well known bus recovery communications and functions in accordance with the IEEE 1394 standard.
The above described bus reset initiates certain well known bus recovery communications and functions in accordance with the IEEE 1394 standard, including the possible renumbering of the physical identifiers of the devices remaining on the IEEE 1394 bus after the bus reset. That is to say, the physical identifiers assigned to devices on the IEEE 1394 bus are not always preserved (e.g., not persistent) following a bus reset.
However, it is also desired within the consumer electronics network that high level applications adopt abstract and persistent identifiers for devices within the network. Since many data structures (e.g., speed map and topology map) and communication channels are maintained and implemented within the IEEE 1394 standard using physical identifiers, a problem exists for high level applications that use a persistent identifier for each device but also need to communicate with the devices of the network and/or need access to speed map and topology data. What is desired is a mechanism and method operable within a consumer electronic network that provides an IEEE 1394 communication framework, but also efficiently provides high level applications with a persistent identifier for devices coupled to the network.
SUMMARY OF THE INVENTION
Accordingly, the present invention provides a method and system that can efficiently report device status information to other devices and software objects within the communication network while requiring a minimum of high level application effort. Further, the present invention provides a mechanism and method operable within a consumer electronic network that provides an IEEE 1394 communication framework, but also efficiently provides high level applications with a persistent identifier for devices coupled to the network.
A method and system are described for updating device identification information in response to a local bus reset within a home audio/video network. Within the network, several consumer electronics products, e.g., television, VCR, tuner, set-top box (e.g., intelligent receiver/decoder, IRD), DVTRs, PCs, DVD players (digital video disk), etc., can be coupled to communicate together via a standard bus (e.g., IEEE 1394 serial communication bus). This allows devices of the network to control one another and obtain information regarding one another. In one embodiment, the communication architecture used is the home audio/visual initiative (HAVI) format. The HAVI network offers unique advantages consumer electronic vendors because the architecture offers for the home network many of the advantages of existing computer system networks, namely, interconnected devices can share resources and provide open, well defined APIs that allow ease of development for third party developers. HAVI offers extended interoperability.
Devices can be removed from or inserted into the network while the network is otherwise operable (e.g., hot modifications are allowed). Therefore, it is important that devices be informed of the current status of other devices on the network following a bus reset. The present invention provides a mechanism whereby devices of the network are informed of the current status of the network after a local bus reset which is caused when a device is inserted into the network (including power on) or when a device is removed from the network (including power down). In accordance with the present invention, after a reset, a new GUID list is generated by a driver program and passed to a high level program. The high level program then compares the new (or "current") GUID list with its own copy of the last GUID list version and generates a list of devices added to the network after the bus reset and a list of devices removed from the network after the bus reset. This information is then forwarded to all devices on the network that previously specified certain call back information regarding current device status.
In one embodiment, the high level program is a communications media manager (CMM) that maintains a copy of the available devices (nodes) in the network in the form of a GUID list. The GUID is a persistent 64-bit device identification number that includes a vendor code and a chip series code and thereby uniquely identifies every device in the network. The device or program that has interest in knowing what devices are new and what devices have been removed from the network provides a call back handler to the CMM. When an IEEE 1394 compatible device (or several devices) is inserted in or removed from the local bus, or any other topology change occurs, a bus reset is generated within the network. A low level driver program, a link driver, catches the bus reset, updates the available devices and passes this information (the new GUID list) to the CMM. The CMM compares its version of the GUID list with the new GUID list and creates new information including the new and removed devices. This status information is passed through the call back handler to each interested object. The present invention thereby provides an efficient mechanism for new and/or removed device notification and removes the burden from high level software of maintaining a list of recently added or removed devices.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1A illustrates a physical port connection topology of an exemplary device configuration of the home audio/visual initiative (HAVI) consumer electronics network in accordance with the present invention.
FIG. 1B illustrates a local bus connection topology of the exemplary device configuration illustrated in FIG. 1A in accordance with the present invention.
FIG. 1C illustrates a communication channel topology with respect to once device coupled to the HAVI network illustrated in FIG. 1A in accordance with the present invention.
FIG. 2 illustrates internal circuitry of an intelligent receiver/decoder device of the HAVI network of FIG. 1A (acting as a full audio/visual, FAV, node) in accordance with the present invention.
FIG. 3 illustrates a complement of, software services made available by a full audio/visual (FAV) node of the HAVI network in accordance with the present invention.
FIG. 4 illustrates communication pathways within the HAVI software architecture in accordance with the present invention.
FIG. 5A illustrates communication flow to the communication media manager (CMM) of the present invention from various software objects.
FIG. 5B illustrates communication flow to various software objects from the communication media manager (CMM) of the present invention.
FIG. 6 illustrates theIEEE 1394 local bus interface (e.g., MPEG/MV Link) with CMM in the HAVI architecture.
FIG. 7A and FIG. 7B illustrates steps performed within the HAVI architecture to implement message communication between devices.
FIG. 8 illustrates communication pathways between an application, a device control module (DCM), the CMM and a link driver in accordance with the present invention.
FIG. 9A is an illustration of a physical identifier indexed topology map data structure used by the present invention.
FIG. 9B and FIG. 9C illustrate, respectively, one dimensional and two dimensional physical identifier indexed speed map data structures as used by the present invention.
FIG. 10A shows a first exemplary crevice network configuration within the HAVI architecture.
FIG. 10B shows a second exemplary device network configuration within the HAVI architecture.
FIG. 11A illustrates a GUID list as constructed by one embodiment of the present invention for the first exemplary device network configuration of FIG. 10A.
FIG. 11B illustrates a GUID list as constructed by one embodiment of the present invention for the second exemplary device network configuration of FIG. 10B.
FIG. 12A illustrates a general GUID update status list constructed by a second embodiment of the present invention in response to the device network configurations of FIG. 10A and FIG. 10B.
FIG. 12B illustrates an "added" GUID update status list constructed by a second embodiment of the present invention in response to the device network configurations of FIG. 10A and FIG. 10B.
FIG. 12C illustrates a "removed" GUID update status list constructed by a second embodiment of the present invention in response to the device network configurations of FIG. 10A and FIG. 10B.
FIG. 13 is a flow diagram illustrating steps performed by the present invention for constructing a GUID list in response to a local bus reset.
FIG. 14 is a flow diagram illustrating steps performed by the present invention for constructing and communicating the GUID update status lists in response to a local bus reset.
FIG. 15A is a flow diagram illustrating the use of the GUID list in accordance with the present invention for sending a message to a device.
FIG. 15B illustrates the use of the GUID list to provide an index in accordance with the present invention for accessing the speed map to determine communication speed information.
FIG. 15C illustrates the use of the GUID list to provide an index in accordance with the present invention for accessing the topology map to determine topology information.
FIG. 15D illustrates the use of the GUID list to provide an index in accordance with the present invention for accessing the speed map to determine communication speed information where the application references the speed map.
FIG. 15E illustrates the use of the GUID list to provide an index in accordance with the present invention for accessing the topology map to determine topology information where the application references the topology map.
DETAILED DESCRIPTION OF THE INVENTION
In the following detailed description of the present invention, a method and system for updating device identification and status information in response to a local bus reset within a home audio/video network, numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be recognized by one skilled in the art that the present invention may be practiced without these specific details or with equivalents thereof. In other instances, well known methods, procedures, components, and circuits have not been described in detail as not to unnecessarily obscure aspects of the present invention.
NOTATION AND NOMENCLATURE
Some portions of the detailed descriptions which follow are presented in terms of procedures, steps, logic blocks, processing, and other symbolic representations of operations on data bits within a computer memory (see FIG. 2). These descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. A procedure, computer executed step, logic block, process, etc., is here, and generally, conceived to be a self-consistent sequence of steps or instructions leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated in a computer system. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussions, it is appreciated that throughout the present invention, discussions utilizing terms such as "processing" or "computing" or "translating" or "calculating" or "determining" or "displaying" or "recognizing" or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
HAVI ARCHITECTURE GENERALLY
Embodiments of the present invention are operable within a consumer electronics network of the home audio/visual initiative (HAVI) architecture. Aspects of the HAVI architecture network (e g., "HAVI architecture") are discussed to provide a general framework in which embodiments of the present invention operate.
HAVI is an architecture for inter-operating consumer electronics equipment devices adapted for the home network. The interoperability aspects define an architectural model that allows devices of any vendor to interwork within the home. A feature of the HAVI architecture is the combination of a base set of generic device controls (a device control software module) with a method to extend the base control protocol as new features and devices are deployed.
The HAVI architecture supports a wide range of devices including intelligent receiver/decoders (IRDs), digital video tape records (DVTRs), video cassette recorders (VCRs), personal computers (PCs), digital video disk players (DVDs), etc., communicating via a common messaging system. FIG. 1A illustrates the physical port-to-port connecting configuration 10a of an exemplary HAVI network. Several consumer electronics devices ("devices") 12-24 are shown connected together withbus segments 30a-30f which couple ("plug into") to ports on the respective devices. In one embodiment of the HAVI architecture, theIEEE 1394 serial communication bus standard is used as a local bus platform to provide the common messaging system. TheIEEE 1394 serial communication bus carries both commands, status information and well as digital audio and digital video signals between devices.
FIG. 1B illustrates alogical bus configuration 10b of the HAVI network of FIG. 1A. As shown in FIG. 1B, all of the devices 12-24 of the HAVI network can be viewed as logically coupled to acommon IEEE 1394serial communication bus 30. Within thisbus configuration 10b, peer-to-peer device communication is supported. For example, as shown in FIG. 1C, any device (having appropriate capabilities), e.g.,device 12, can send or receive communication packets from any other device in the HAVI network. In the example of FIG. 1C, the set-top-box (e.g., an IRD) can receive messages from or generate messages to any of the other devices 14-24 of the exemplary HAVI network.
The interoperability model in the HAVI architecture provides for the following: 1) support for existing devices; 2) a default control model; 2) a means to extend the default control model when new devices or functionality is brought to market; and 4) a common means for device representation (e.g., graphics user interfaces). To achieve the above, the HAVI architecture defines three types of nodes in the home network. A base AV (BAV) node is defined for devices that already exist in the market (e.g.,VCR 22 of FIG. 1A). An intermediate AV (IAV) node is defined for simple devices such as camcorders or DVTRs (e.g., camera 14). A full AV (FAV) node is defined for devices of more resources, such as IRDs or smart televisions (e.g., set-top-box 12). An FAV node (or device) typically contains enough hardware to host control modules and to support application programs locally. The IAV devices and FAV devices communicate by sending messages over the home network using a generic message passing system described more fully below. When new devices join the home network, they are recognized and added to a global name database (registry). The registry holds information about their characteristics and provides a reference to a handler (e.g., communication point) for that device. Other devices and services are able to query the registry to locate a device and then, using the handler, can interact with the device.
When a device is initially added to the home network, the system queries the device to ascertain its characteristics and capabilities. Once a device's characteristics are known, the architecture provides two methods of controlling it. The first method, level one interoperability, uses a predefined message set based onIEEE 1394 AV/C-CTS. All IAV and FAV nodes can use this command set to access and control other devices, however, BAV nodes, because they are deployed before the architecture was defined, are controlled using legacy protocols. The level one interoperability provides a default level of control. The FAV nodes act as control nodes and create a local representation of the IAV node, known as a device control module (DCM), that provides an API used to send control commands to the device.
Level two interoperability within the HAVI architecture goes farther and supports future added functionality and new devices. To achieve this, a particular device can carry within its ROM an override DCM that is uploaded from the IAV device, to the FAV device, and replaces the default DCM for the particular device. This override DCM not only contains the basic level one command set for the particular device but also includes vendor specific commands to control advanced features of the device. This model allows the device to inform another object about its particular functionality. Since the override DCM may be loaded onto any vendor's FAV, the format of the DCM is architecture-neutral.
To allow one device to discover the capabilities of another device and to determine which command set to use with that device, a standard device description structure is provided called the self describing data (SDD) structure. The SDD data structure is extensible. It car be a small number of bytes describing the device type, e.g., TV, or VTR etc. Alternatively, the SDD data structure can be a more complex structure also defining the override DCM and a graphical representation of the device. The graphical representation within the SDD data structure allows an FAV node to present a pictorial representation of the devices in the home network to users.
By defining the graphical representation in a sufficiently generic manner, a device's SDD graphical data can be used in any vendor's product to display (e.g., on a television or monitor within the network a user interface for that device. This provides an enhanced level of vendor interoperability and also allows a vendor to differentiate a product while maintaining within the general look and feel of the display device. The SDD also enables a control device (the FAV node) to present a general control user interface for all devices in the home network, irrespective of the differences in type and vendor. Self describing data (SDD) is described in copending provisional application serial No. 60/054,327, entitled "A Method and Apparatus for Including Self-Describing Information within Devices," filed Jul. 31, 1997 and assigned to the assignee of the present invention. The above referenced provisional patent application is hereby incorporated by reference.
Legacy devices are devices that were built before the HAVI architecture or devices that select not to use the HAVI architecture. The HAVI architecture supports Legacy devices by providing Legacy DCMs to provide protocol conversions for Legacy devices. These Legacy DCMs can contain sufficient knowledge to allow them to support an existing 1 or 2 way control protocol and provide a specific control interface to the devices that conform to the HAVI architecture. A legacy DCM acts as a bridge between the Legacy and HAVI devices. This feature allows the HAVI architecture also to interact with any future device control protocols such as, for example, protocols being used for home energy management or security, etc.
SET-TOP-BOX 12 OF FIG. 2
Any consumer electronics device can be provided with the appropriate hardware to act as an FAV and thereby provide a platform for certain HAVI software (described below). For instance, the set-top-box 12 device of the exemplary HAVI network of FIG. 1A contains special hardware components that provide an operation platform for software components of the HAVI architecture. Another example of an FAV is a digital television having the required hardware resources to support HAVI software. Certain aspects of the present invention, described below, are discussed in terms of steps executed on a computer system (e.g., processes 400, 700, 800, 850, 900a, 950a, 900b and 950b). Although a variety of different computer systems can be used with the present invention, an exemplary general purpose computer system is shown in the set-top-box FAV of FIG. 2.
Set-top-box 12 of FIG. 2, in addition to having a video/audio receiver (decoder)unit 106 andMPEG unit 107 also includes an internal address/data bus 100 for communicating information, one or morecentral processors 101 coupled with thebus 100 for processing information and instructions, a volatile memory 102 (e.g., random access memory RAM) coupled with thebus 100 for storing information and instructions for thecentral processor 101 and a non-volatile memory 103 (e.g., read only memory ROM) coupled with thebus 100 for storing static information and instructions for theprocessor 101. Set-top-box 12 can also optionally include a data storage device 104 ("disk subsystem") such as a magnetic or optical disk and disk drive coupled with thebus 100 for storing information and instructions. Also included n the set-top-box 12 is abus interface unit 108 for interfacing with the local bus 30 (e.g., anIEEE 1394 serial bus). Set-top-box 12 can operate under a variety of different operating systems (e.g., Windows operating system, DOS operating system, Macintosh O/S), but in one embodiment the Aperios operating system is used.
HAVI SOFTWARE ARCHITECTURE
In one embodiment, the software of the HAVI architecture can be broken into three APIs (AVOS, interoperability and application). The AVOS API is a low level system API that abstracts the common operating system services, e.g., threads, communications, and memory. Interoperability APIs are abstractions of common device control models and provide a basic representation model and a means to extend the control model with vendor specific commands. The application API is a high level API for applications including interactive TV applications, and in one embodiment is based on the DAVIC API set including the Motion Hypermedia Expert Group (MHEG) interactive application engine.
FIG. 3 illustrates thesoftware architecture 200 used in the HAVI architecture in more detail. Thearchitecture 200 contains several generic components to provide abstractions of common facilities in the home network. Acommunication media manager 250 is provided and this component abstracts from the underlying transport network. In the case of theIEEE 1394, thecommunication media manager 250 maintains and generates information regarding the speed maps 515 (FIG. 8) aid topology maps 520 which are used by embodiments of the present invention. ADCM Manager 270 is also provided that is responsible for identifying and creatinggeneric DCMs 230 for level one interoperability. TheDCM Manager 270 also hosts override DCMs uploaded from devices or other sites. AGraphics Management unit 220 is provided which supplies generic graphics APIs that applications and DCMs can use to present user interface information.
AStream Manager 335 of FIG. 3 is used to determine the most effective route for AV streams within the home network. A data format manager is included within theStream Manager 335 and is responsible for providing conversion of AV streams to and from various formats as they flow between devices in the home network. These operations are described below with reference to FIG. 7A and FIG. 7B. AMessaging Manager 212 supports a generic messaging mechanism that allows devices to locate and interact with other devices in the home network. A communications media manager (CMM) 250 is a media dependent entity in theHAVI software architecture 200. TheCMM 250 provides abstract services to other HAVI components or application programs in the HAVI network. It also provides media specific transport mechanisms for actual data communication among various devices in the home network. TheCMM 250 is responsible for compiling new GUID status updates upon a local bus reset. It is appreciated that each physical communication media contains its own CMM to serve the above purposes. As one example, theCMM 250 for theIEEE 1394 serial bus is described herein further below.
TheEvent Manager 214, theRegistry 216, theStream Manager 335 and theInitialization Manager 210 of FIG. 3 are described separately further below.
FIG. 4 illustrates a data flow diagram 305a with theHAVI software architecture 200 including an interface with the localbus HAL layer 330 forlocal bus 30. In diagram 305a, the top layer is an application program layer ("application layer") 220 which can communicate with a function control module (FCM)layer 314 having AV/C command. Theapplication layer 220 resides within a FAV and can also communicate with device control modules (DCMs) 230 and with theRegistry 216. Theapplication layer 220 communicates with aStream Manager 335. TheDCMs 230 are controlled by theDCM manager 270 which can communicate with theEvent Manager 214. TheEvent Manager 214 communicates with theCMM 250. TheStream Manager 335 allows communication between the application layer and theCMM 250. TheAV Messenger unit 212 also communicates with theCMM 250. TheCMM 250 provides an interface with thelocal bus interface 330 via alink driver unit 320. Thelink driver unit 320 is responsible for compiling new GUID lists upon a local bus reset. Higher level applications are located withblock 310 and lower level applications withinblock 312. A subset of this communication diagram 305a is illustrated in FIG. 8.
FIG. 5A is a diagram 340a that illustrates communication channels that are available for communicating to theCMM 250. Theapplication layer 220 communicates with theCMM 250 to obtain bus generation information, to obtain the GUID list, to obtain thespeed map 515 and to obtain thetopology map 520. The following APIs are used to perform these functions: getGUIDList(); getBusGeneration(); getSpeedMap(); and getTopologyMap(). The ilink transportation adaptation module, TAM, 212b communicates with theCMM 250 for asynchronous requests and asynchronous responses. The digital I/F controller 335a communicates with theCMM 250 for asynchronous requests, asynchronous responses, channel allocations, channel deallocations, bandwidth allocations and bandwidth deallocations. TheStream Manager 335 utilizes GUID information to establish point to point communications via the digital I/F controller 335a. The digital I/F controller 335a communicates with theCMM 250 using the following APIs: allocatechannel(); deallocatechannel(); allocateBandwidth(); and deallocateBandwidth(). Theisochronous data transceiver 230 is a DCM and communicates with theCMM 250 using the following APIs: isoOpen(); isoClose(); isoAttach(); isoDetach(); and isoControl().
FIG. 5B is a diagram 340b that illustrates communication channels that are available for communicating from theCMM 250 to other objects. TheCMM 250 communicates bus reset indications to theEvent Manager 214. TheCMM 250 also communicates status information regarding the set of current devices on thelocal bus 30 including information as to which devices are added and which devices have been removed from thelocal bus 30 since the last GUID list was constructed. TheCMM 250 also communicates bus reset information to theilink TAM 212b as well as GUID information, asynchronous receive, and isochronous receive. This same information is also communicated from theCMM 250 to the isochronousdata transceiver module 230. Information regarding which devices are coupled to thelocal bus 30 is also communicated from theCMM 250 to the digital I/F controller 335a.
FIG. 6 illustrates anexemplary interface 360 between theCMM 250 and thelocal bus 30 forIEEE 1394 interfacing. A 1394Bus Manager 370 is also shown. TheCMM 250 contains a copy of thespeed map 515 and the topology map 520 (described further below) and andIEEE 1394Bus Manager 370 contains control/status registers (CSRs). The isochronous resource manager 372 contains information regarding the bus master identification and the available channels and bandwidth for communication via isochronous registers (CSRs). Thenode controller 374 contains a configuration ROM as well as node control registers (CSRs).Units 250, 372 and 374 constitute the serialbus management unit 370.Unit 370 communicates with 1394 HAL interface (I/F)layer 330. Thetransaction block 378 processes read/write/lock transactions, tracks pending transactions and controls retry protocol operations with a busy/timeout register. Data transmission takes place within thelink layer 380 and the I/F (CFR)unit 385.
DCM 230 ANDDCM MANAGER 270
A description of theDCM 230 and theDCM manager 270 of FIG. 3, as well as other aspects of theHAVI software architecture 200 are described in copending U.S. patent application Ser. No. 09/003,119, entitled "A Home Audio/Video Network with Two Level Device Control", by R. Lea and A. Ludtke, filed concurrently herewith, attorney docket No. SONY-50L2278, assigned to the assignee of the present invention and hereby incorporated herein by reference.
THECOMMUNICATIONS MEDIA MANAGER 250
The CMM 250 (e.g., for theIEEE 1394 bus) of FIG. 4 provides two levels of APIs. One is the high-level API that interacts with other HAVI components to offer abstract services such astopology map 520 andspeed map 515 as well as generating HAVI related events. The other level of APIs is the low-level API that provides a basic transport mechanism for both asynchronous and isochronous data transfers. Normally, high-level APIs are available to any HAVI entity or applications residing locally on this same node, while the low-level APIs presents the primary interface to theIEEE 1394bus 30 so that specific protocols can be built on top of theCMM 250. To access high-level APIs, the HAVI message system (e.g., AvMessenger 212) is used, whereas access to low-level APIs can be accomplished through direct calls to theCMM 250.
The messaging used to access high-level APIs through HAVI message system is done using a format having a multi-byte selector followed by function dependent parameters. The function selector determines which service to use from theCMM 250, and the parameters section provides all required parameters for the specified function. To invoke low-level APIs, only the parameters section is necessary.
The IEEElocal bus 30 is a dynamically configurable network. After each bus reset, a device can have a complete different physical identifier (phy-- id) than it had before the bus reset. If a HAVI component or an application has been communicating with a device in the HAVI network it generally desires to continue the communication after a bus reset even though the device may have a different physical identifier. To identify a device uniquely regardless of frequent bus resets, the present invention provides the Global Unique ID (GUID) which is used by theCMM 250 and other HAVI entities. A GUID is a multi-bit number (e.g., 64-bits in one implementation) that is composed of 24 bits of node-vendor identification and 40 bits of chip (series) identification. While a device's physical identifier may change constantly, its GUID is permanent within the HAVI architecture. TheCMM 250 of the present invention makes device GUID information available for its clients using a GUID list discussed further below.
TheCMM 250 abstracts the underlying device interconnection mechanism, providing a common set of API's to describes the capabilities of the bus architecture. In one embodiment, the CMM concept is driven by theIEEE 1394 bus model, but is sufficiently abstract to provide a general service for interconnection management. TheCMM 250 provides APIs for 4 four basic concepts. (1) Channel: a channel is a logical data connection that a bus can support. For technology such asIEEE 1394, this maps directly to hardware support for multiple channels. For technology that only supports a single data connection, then this degenerates to a single channel. (2) Bridge: a bridge is a connection between two bus technologies and allows channels to span different bus technologies. (3) Node: a node is a physical endpoint for a channel and corresponds to a unit or subunit in the HAV architecture. (4) Bandwidth: this is a metric of how much data can be carried on a bus at any one time. Bandwidth can be assigned to channels to support the required data rates for whatever data the channel is delivering.
For those bus protocols which do not support these concepts, the results of API calls to their CMMs have limited results For example, if a particular bus technology does not support multiple simultaneous data transfer actions, then it most likely reports only a single "channel," even though it does not really support channels. TheCMM 250 maps transactions to the channel model.
There is oneCMM 250 for each physical interface (e.g. 1394, Control A1, TCP/IP) on a FAV node. Because there can be more than one kind ofCMM 250, and because there can be many of them in existence, eachCMM 250 has a module-- type attribute attached to its entry in theService Registry 216 database. The definition of this attribute can be as follows:
module-- type=busManager
module-- data={1394, Control A1, TCP/IP, etc.} These bus types will have numeric identifiers defined for them.
EachCMM 250 contains the general set of API's for bus management, as well as protocol-specific API's. If a particular bus technology supports features that are above and beyond the general model, then it can subclass the CMM base class and add the new functionality. For example, the 1394CMM 250 allows access to the 1394-specific bus attributes such as the isochronous resource manager. Those clients who are 1394-aware, and need such capabilities, can go through the 1394CMM 250.
One of the advanced features the 1394 bus provides to the HAVI architecture is its support for dynamic device actions such as hot plugging (device insertion or power up) and unplugging (device removal or power down). To fully support this to the user level, high level software clients need to be aware of these environment changes and the present invention provides this information. TheCMM 250 works with theEvent Manager 214 to detect and announce these dynamic bus changes using device status tables (FIG. 12A, FIG. 12B, FIG. 12C). Since any topology change within 1394 bus will cause a bus reset to occur, theCMM 250 is informed of these changes and notifies theEvent Manager 214 of these changes along with the information about devices that have disappeared as well as those that have become available. TheEvent Manager 214 then distributes the related event to all interested HAVI entities or applications that previously established the proper call back handlers.
There are two basic types of events that are generated from theCMM 250 to support dynamic updating of available devices in the network. One is NEW-- DEVICE which indicates a new device, and the other is GONE-- DEVICE, indicating a device has been removed. To increase efficiency, theCMM 250 generates device status tables with this information. Whenever a device is added or removed from the network, a bus reset is generated andCMM 250 finds and passes a status table of new/gone devices o theEvent Manager 214 if theEvent Manager 214 has requested such service. Since NEW-- DEVICE or GONE-- DEVICE also indicates the occurrence of a bus reset, theEvent Manager 214 may also create a BUS-- RESET event based on the above information. It should be noted that all these events are generally "local," which means that theEvent Manager 214 does not generally send/broadcast such events to any other nodes.
TheCMM 250 also provides topology, speed maps, and other environment descriptions to its clients. The topology map 520 (FIG. 9A) depicts the connectivity among physical devices. Within the present invention, it can be used to build a human interface that helps the user understand how devices are connected and how certain features may be used. The speed map 515 (FIG. 9B, FIG. 9C) provides information on the possible maximum speed that can be used for data transmission between any two devices in the network. Speed maps provide information about the connectivity and performance of sections of the HAV network. It can be used to analyze the current connection scheme and give the user helpful suggestions for improving the performance of devices by rearranging the connections. If attributes such as thetopology map 520 cannot be automatically generated, then a dialog with the user may be required. When a topology request is made to a CMM for a protocol that does not support automatic topology detection, the request can trigger such a dialog. After interacting with the user to determine how its devices are connected, the CMM returns the requested information.
Topology map 520 andspeed map 515 may change constantly because their organization (e.g., data order) is based on the physical identifiers of the devices on the network and these values can become reassigned due to the allowed dynamic insertion or removal of devices. To identify the right "version" for these maps, a bus generation number may be used. Newer bus generation values signify the change of bus configuration. It may also be used to check if a pending operation is "stale". Since transactions between devices require the existence of those devices, it is possible that a pending transaction has not yet completed and one or more devices involved have gone away. When this happens, a new bus generation number will be generated and the related process can check against this new generation number to make proper clean up for the stale transaction.
Bus generation number,topology map 520, andspeed map 515 remain unchanged between bus resets. To improve efficiency, theCMM 250 may optionally cache them internally and keep them updated only when bus reset occurs.
Another feature of theIEEE 1394bus 30 is its capability to send timing-critical stream through its isochronous channels. To send data in isochronous mode, channel number and proper bandwidth need to be allocated from the bus. TheCMM 250 provides such services to allocate/deallocate channel numbers and bandwidth for its clients. It is also responsible to restore these resources for its clients right after each bus reset so that any existing isochronous data transaction will not be disrupted because of the unavailability of these resources.
TheCMM 250 also provides a transport mechanism to actually transfer the data, which is part of low-level services. There are two types of data transactions withIEEE 1394bus 30. One is asynchronous, the other isochronous. Typical asynchronous transfer includes quadlet/block write, quadlet/block read, and lock operations. Typical isochronous data transfer normally involves allocating channel/bandwidth, opening isochronous data port, attaching data buffer(s), and activating data transfer. These services provide a fundamental transport mechanism for a 1394 based HAVI system being functional.
The following APIs are provided byIEEE 1394specific CMM 250 within the present invention:
1) CMM::enrollComeNGo()
Status: enrollComeNGo(ObjectID oid, (void *) (*) callback-- handler)
This command is used by theEvent Manager 214 to get a list of new and removed devices when bus reset occurs. TheEvent Manager 214 enrolls such request to theCMM 250 to get the service. The parameter oid is the caller's object identifier and callback-- handler is the callback function provided by the caller. The caller (typically Event Manager 214) enrolls its OID and a callback handler to theCMM 250 so that when bus reset occurs, theCMM 250 invokes the callback function with a list of devices (device status table) that are either new or gone.
2) CMM::getGUIDList()
Status: CMM 250::getGUIDList(GUID *guid)
This command gets the GUID for all active devices in the network. The parameter guid is a pointer to a the GUID list.
3) CMM::getBusGeneration()
Status: CMM::getBusGeneration(uint32 *bus-- en-- number)
This command gets the current local bus generation number from the network. The parameter bus-- en-- number is the current bus generation number.
4) CMM::getSpeedMap()
Status: CMM::getspeedMap(uint32 bus-- en-- number u-- char*spd-- map)
This command gets thespeed map 515 which is associated with the bus generation number specified. The parameter bus-- en-- number is the current bus generation number, spd-- map is a pointer to thespeed map 515
5) CMM::getTopologyMap()
Status: CMM::getTopologyMap(uint32 bus-- en-- number, uint32*top-- map)
This command gets thetopology map 520 that is associated with the bus generation number specified. The parameter bus-- en-- number is the current bus generation number and top-- map is a pointer to an array of integer numbers, each representing a selLID packet from a 1394 node.
6) CMM::allocatechannel()
Status: CMM:: allocateChannel(uint32 chan-- no)
This command allocates a channel specified by chan-- no. If chan-- no is all ones (Ox FFFFffff), any channel available will be allocated and returned. The parameter chan-- no is a channel number to be allocated.
7) CMM::deallocatechannel()
Status: CMM::deallocateChannel(uint32 chan-- no)
This command deallocates a channel specified by chan-- no. The parameter chan-- no is the channel number to be deallocated.
8) CMM::allocateBandwidth()
Status: CMM:: allocateBandwidth(uint32 bandwidth)
This command allocates the bandwidth specified by bandwidth. The parameter bandwidth is the bandwidth to be allocated.
9) CMM::deallocateBandwidth()
Status: CMM::deallocateBandwidth(uint32 bandwidth)
This command deallocates the bandwidth specified by bandwidth. The parameter bandwidth is the bandwidth to be deallocated.
10) CMM::asyncWrite()
Status: CMM::asyncWrite(GUID guid, u-- int64 remote-- offset, u-- char*data, uint32 data size, uint32 pk-- format)
This command sends an asynchronous write request to the remote device, which is identified by guid. The parameter guid is the target device's GUID, remote-- offset is the target device's memory offset, data is a pointer to data to be sent, data-- size is the size of data (in byte) to be sent and pk-- format is the format to use, either quadlet or block for data transfer.
11) CMM::asyncRead()
Status: CMM::asyncRead(GUID guid, u-- int64 remote-- offset, u-- char*data, uint32 data-- size, uint32pk-- format)
This command sends a asynchronous read request to the remote device, and returns the data read back. The parameter guid is the target device's GUID, remote-- offset is the target device's memory offset, data is the pointer to data to be received, data-- size is the size of data (in byte) to readback from remote site, and pk-- format is the format to use, either quadlet or block for data transfer.
12) CMM::asyncLock()
Status: CMM::asynclock(GUID guid, u-- int64 remote-- offset, u-- char*old-- data u-- char*new-- data, uint32 data-- size uint32 exLcode)
This command makes a lock operation on the specified address in the remote device. The parameter old-- data is used for compare and swap operation. The parameter guid is the target device's GUID, remote-- offset is the target device's memory offset, old-- data is the pointer to old data, new-- data is the pointer to the new data, data-- size is the size of data (in byte) to be sent, and ext-- code is the extended code to be used for the lock operation
13) CMM::isoOpen()
Status: CMM::isoOpen(uint32 direction, uint32 bus-- speed, uint32 bandwidth, uint32*port-no)
This command opens an isochronous port or either sending or receiving operation. The actual port opened is returned in port-- no. The parameter direction is the sending or receiving operation, bus-- speed is the requested bus speed, bandwidth is the maximum bandwidth to be used, and porLno is the port number successfully opened
14) CMM::isoClose()
Status: CMM::isoClose(uint32 port-no)
This command closes the port specificed. The parameter port-- no is the port number to be closed Close the port specified.
15) CMM::isoAttach()
Status: CMM::iosAttach(uint32 porLno, u-- char*buffer)
This command attaches a user buffer to the specified port. The parameter porLno is the port number to be used and buffer is the data buffer.
16) CMM::isoDetach()
Status: CMM::iosDetach(uint32 port-no, u-- char*buffer)
This command detaches a user buffer from the specificed port. The parameter port-- no is the port number to be used and buffer is the data buffer.
17) CMM::isoControl()
Status: CMM::isoControl(uint32 chan, uint32 trigger)
This command controls the actual data transfer. It starts immediately or on some synchronization bit. The parameter chan is the channel to be used for the transfer and trigger is the method to use to start the traffic.
In addition to the basic four abstractions discussed above (Node, Channel, Bridge and Bandwidth), the following concepts describe the bus model. Thetopology map 520 is a connected graph which mirrors the physical connections between nodes on the network. ForIEEE 1394, the map is generated automatically. For other protocols, manual assistance from the user may be required. The overall system topology is an amalgamation of individual bus topologies. The generation number provides a way to measure whether a pending operation is "stale." Since transactions between devices depend on being able to access those devices, it is possible that a pending transaction has not yet completed and one or more of the devices involved have gone away. When this happens, any modules that care about the bus generation react accordingly.
The generation value is based on the ability to determine that the bus configuration has changed. For protocols such asIEEE 1394, the generation is critical because of hot plugging support. For others, if hot plugging support can be simulated, then the generation number can be managed as well. If no hot plugging support can be created, then the generation number will always default to "1," meaning that the bus has not changed since the host system was initialized. A bus can allow a certain maximum number of nodes (devices) to be connected and individually addressable at any given time. At any given time, theCMM 250 is informed of how many devices are currently attached and addressable (number of nodes)
As described more fully below, theC MM 250 provides bus reset or change notification for buses that support dynamic connection. After a bus reset is detected, this module assigns new "opaque" ID values to all devices that have just appeared, determines what devices have gone away, invokes theDCM Manager 270 module to create new DCMs, and posts a bus-- change notification event to theEvent Manager 214, which notifies all registered clients about the reset. In accordance with the present invention, it also provides enough information for the clients to determine what devices have disappeared and about any newly discovered devices. TheCMM 250 works with theEvent Manager 214 to detect and announce dynamic bus chances that do not trigger system-wide interrupts or events, thus bringing some of the advantages of 1394 technology to other bus protocols.
TheCMM 250 provides clients with thephysical topology map 520, in a manner that does not require clients to have bus-specific knowledge. Thetopology map 520 can be generated automatically for those control protocols which support it, or can be generated with user interaction and stored for later use for those protocols that do not support automatic generation. Because topologies can be quite diverse, theCMM 250 provides a topology iterator function similar to that of theService Registry 216. This function allows clients to visit each node in a connection-specific manner, with a simple API to move forward or backward through the net. The client can determine simply that this device is connected to that one, which is connected to that one, etc. For clients who simply need to know about all devices in a topology, with no concern for connection patterns, the GUID list is provided. Other API's allow the query to determine if a given moduleID (the identification of a DCM which represents a physical device) is represented in the topology, etc.
TheCMM 250 also provides logical connection information. This is a connection model that specifies data flow sources and sinks. The API allows inquiries such as "given DCM module ID X, tell caller all of the DCMs that are listening to it." Other variations on this inquiry model include the ability to ask for all currently active streams of a particular data type (e.g. MPEG, SD), etc.
EVENT MANAGER 214
TheEvent Manager 214 of FIG. 4 is designed to support a one-to-many model of communication. It is built above thebasic messaging system 212. Objects register interest in events which are then delivered to their event call back entry. For instance, objects interested in device status information register special call back handlers for this information with theEvent Manager 214. Objects can attach event filters to the callback entries that allow them to filter out events that they are not currently interested in. For example an object may register for all events from display devices, but filter out those display devices it is not currently using.
Events are broadcasted by themessaging system 212 and delivered to all objects that have registered an interest in the event. To achieve this, objects register their interest with theirlocal Event Manager 214. The messaging system delivers events to all knownEvent Managers 214 which are then responsible for ensuring that registered objects are informed about events. Filters can be attached toEvent Managers 214 to allow objects to filter out the events as they arrive. This gives an object the flexibility to register interest in an event, but have control over how each event is used. For example a filter could be used to specify that event X is only of interest if it occurs after event Y. TheEvent Manager 214 tracks filters and provides an API that allows applications and DCMs to build sophisticated event filtering chains.
STREAM MANAGER 335
TheStream Manager 335 of FIG. 4 provides an API for configuring end-to-end isochronous ("streaming") connections. Connections may be point-to-point or utilize unbound sources or sinks. The responsibilities of theStream Manager 335 include: configuration of connections; requesting allocation of network resources; maintenance of global connection information; and support of high-level stream operations such as plug type checking, splicing and bridging.
AStream Manager 335 runs on each FAV node. The interface is based on the IEEE 1212 unit directory model and the IEC 6 1883-FDIS plug model (HAVI refers to units and subunits as devices and functional components respectively). Point-to-point connections and broadcast connections are supported. InIEEE 1394, a broadcast connection is one in which either the source or sink is not specified when the connection is requested. Streams do not cross transport boundaries, but bridge devices can be used to feed one stream into another. Streams originate and terminate at functional components (rather than devices). ForIEEE 1394 networks, theStream Manager 335 is responsible for allocating PCRs (plug control registers) and requesting bus bandwidth. A standard naming scheme is used for stream types, transport types and transmission formats. The stream type and transport type naming schemes are specified by HAVI, transmission formats are the FMT/FDF values used in IEC 1883 Common Isochronous Packets.
A stream type identifies a media representation, this can be a data format (for digital media) or signal format (for analog media), e.g. CD audio, NTSC. A transport type identifies a transport system, two examples are IEC 1883 (for connections running over 1394) and "internal" (for connections internal to a device). A transmission format identifies the data transmission protocol used to send a stream type over a transport type. For IEC 1883, the transmission format corresponds to the FMT and FDF fields in the Common Isochronous Packet (CIP) header.
A stream as used by theStream Manager 335 is based on the isochronous data flow model from IEC 1883 with three differences. The first difference is that streams do not restrict the number of sources and so can have multiple sources provided the transport supports this form of connectivity, for example, a UDP "event" stream being fed by many processes. The second difference is that anIEEE 1394 data flow starts at a device output plug and ends at a device input plug, while a stream typically starts at a functional component output plug, goes to a device output plug, then a device input plug, and ends at a functional component input plug. The final difference is that streams are typed, e.g., for each stream there is an associated stream type identifying the data.
The following summarizes the properties of streams: 1) a stream is associated with a globally unique stream identifier; 2) a stream is carried over a single channel; 3) output functional component plugs ("plugs") and input plugs can join a stream (this can also be stated as "connect to the channel"); 4) a channel can be connected to zero or more output plugs and zero or more input plugs; 5) an input plug can join at most one stream; 6) an output plug can join many streams (for example a functional component output plug attached to several device output plugs); 7) a stream can be created with no output plug, but no data will flow over the stream until an output plug has joined; and 8) the upper limit on the number of plugs that can be connected to a channel is transport type dependent.
A stream can be viewed as a set of plugs. The following rules apply to connections within a device. Functional component input plugs can have only one connection (from a functional component output plug or a device input plug). Functional component output plugs can have many connections (to functional component input plugs and/or device output plugs). Device output plugs can have only one connection from a functional component output plug. Device input plugs can have many connections to functional component input plugs.
There are three procedures for adding or removing plugs from this set: 1) point-to-point procedure (Connect, Disconnect); 2) broadcast-out procedure (StartBroadcast, StopBroadcast); and 3) broadcast-in procedure (Tap, Untap). Connect creates a point-to-point connection between two plugs (e.g., a connection from an output plug to the channel and a connection from the channel to the input plug); it adds an output plug and an input plug to the stream (assuming neither are already members). StartBroadcast creates a "broadcast-out" connection (e.g., a connection from an output plug to the channel); it adds an output plug to the stream (assuming it is not already a member). Tap creates a "broadcast-in" connection (e.g., a connection from the channel to an input plug); it adds an input plug to the stream (assuming it is not already a member). Disconnect, StopBroadcast and Untap drop) the connections created by Connect, StartBroadcast, and Tap respectively. They remove plugs (if not used by other connections within the stream).
Streams allow the overlaying of connections as described in IEC-1883, e.g., a plug may have many connections (both point-to-point and broadcast) to the channel used by the stream. Following the connection semantics of IEC-1883, theStream Manager 335 decides when to remove a plug from a stream by examining the plug's point-to-point connection counter and a broadcast flag (which indicates whether or not the plug participates in a broadcast connection). A plug is removed from a stream when the point-to-point connection is 0 and the broadcast flag is false. The underlying network resources used for a stream are allocated when the first plug is added to the stream and released when the last plug is removed. In the case of a channel (connected to several output plugs, the manner in which the resulting data flow is delivered is transport type dependent and theStream Manager 335 does not guarantee that all input plugs will receive data in the same order.
TheStream Manager 335 maintains a map of all stream connections within the home network. This map includes internal connections (those within devices) and external connections (those over transport systems). TheStream Manager 335 builds the Global Connection Map upon initialization, after bus reset, and periodically while running (in case new connections have been added or removed by non-HAVI applications).
An AV network can take on many topological configurations, depending on how the user has made the connections between devices. For example, anIEEE 1394 bus allows any topology except a loop. TheStream manager 335 of FIG. 3 works with theCMM 250 to provide services to assist with routing data from source to destination. This can include many nodes in between. In the event that the source and destination involve different data types, or are separated by a "data type barrier," it will work with a data format manager andService Registry 216 to handle automatic or requested data translation services as well. Some routing can be performed automatically, based on the capabilities provided by the underlying bus architecture. For example, the topology of theIEEE 1394 bus can be precisely determined, and therefore automatic routing between directly-connected 1394 devices can be achieved. However, other connection mechanisms can require interaction with the user, either to assist the user with making well-known connections or to have the user indicate to the controlling software how devices are connected.
One of the most significant attributes of theIEEE 1394 technology is isochronous data flow. Additional services provided by theStream manager 335 for this kind of data include buffer allocation and management. Buffer management includes the provision of a consistent notification mechanism to let the client know when data is available, so that it can be processed. While isochronous data is flowing into a client, various memory buffers will be filled with that data. As each buffer is filled, the client may want to know so that it can handle the data acquisition process from that point forward.
In addition, buffer management can be simplified for clients by having the appropriate service modules partition memory in a manner that is optimized for the data being captured. For example, the client can allocate one large space of memory, then specify that it will be used for capturing a stream of video data. It is possible that the optimum configuration of this memory is to separate it into scan line- or frame-sized segments, so the client can receive one complete line or frame of video on each notification. Raw audio and MIDI data will likely have different optimum segment sizes. Such services require close cooperation between the Route and Data Format Managers, and various service modules.
Refer to FIG. 7A and FIG. 7B where anexample process 400 is shown for setting up a data flow. A client wants to establish a connection between two devices, so atstep 410 it calls to establish in external connection of one of the two DCMs that represent those devices. It passes the moduleID of the other device's DCM as a parameter. Atstep 415, the DCM that was called then calls the Stream Manager (SM) 335 to assist with making the connection. It passes both the source and destination DCM module IDs as parameters. Atstep 420, theSM 335 analyzes the source and destination IDs, finds that they are in different nodes (this step may be carried out by some other entity before invoking the DFM). Atstep 425, theSM 335 asks theCMM 250 of the source node for thetopology map 520 for its network. Atstep 430, theSM 335 analyzes thetopology map 520 to find the destination node.
Atstep 435 of FIG. 7A, if the destination node is on thetopology map 520, then no transport protocol translation is necessary and step 445 is entered directly. If the destination node is not on the map, then at step 475 (FIG. 7B) theSM 335 asks theRegistry 216 for the module with the destinationID, to look at the "transmission-- protocol" attribute, or alternatively, it gets the bus manager ID for that module/node. Atstep 480, theSM 335 then finds a transmission protocol service module, and sets up the conversion process (see separate example for these details). Atstep 485, the above process is repeated if multiple transports need to be bridged.
Atstep 445 of FIG. 7A, theSM 335 analyzes the connection paths to find the best route. If no deterministically optimal path can be determined, then a best guess is accepted. This is done for the entire path from source to destination, including intermediate or cross-network boundaries. All necessary connections are made (in the case of dynamic buses such as 1394). Atstep 450, theSM 335 analyzes the input data formats for source and destination. Atstep 455, if the formats are the same, then no format conversion is necessary. At this point (465) thedata flow route 400 is complete.
If conversion is necessary, then atstep 460, theSM 335 asks theRegistry 216 for the appropriate format converter based on input and output format and sets up the conversion process. Note that several converters can be chained together to achieve the final result from original source to desired destination formats. Thedata flow route 400 is then complete.
SERVICE REGISTRY 216
TheService Registry 216 of FIG. 4 provides a mechanism to locate devices and services that are available in the HAV network. Since all devices and services are represented by objects, theService Registry 216 allows any object to advertise itself. Typically, resident on an FAV, theService Registry 16 contains information on local service objects, remote service objects and local and remote devices. TheService Registry 216 operates by providing an API that allows objects to register their unique identifier, a name, and a set of attributes that define their characteristics including connection point information. Any object wishing to locate a particular service or device object can do so by querying theService Registry 216 for the appropriate DCM.
Attributes associated with an object may be static or dynamic, and can be subsequently changed if desired. Attribute querying is carried out by specifying a set of required attributes which then returns a list of objects that match the required attributes. Identifiers returned as a result of a query are not guaranteed to be valid. This can happen in one of two ways. First, if a device has posted its availability into the registry and then has gone off-line. If the query arrives between the time of going off-line and actually withdrawing the service from the registry, then the identifier will be stale. Second, if a query returns a set of identifiers, the results may be held within an object for an extended period of time. When they are finally used, it may be that the service has been withdrawn from the registry.
TheService Registry 216 is a distributed service. Any object that registers with its local Service Registry will be accessible via any other instances of theService Registry 216 in the HAV network. EachService Registry 216 works with others to ensure that entries are replicated or available when required. However, for both performance and resource reasons, it is often the case that an item registered in one registry will not be visible in another, although the system will try to ensure this. This implies that a simple query to alocal Service Registry 216 may return the local registry's view of the global state. It will always be possible to cause a remote query to be carried out on behalf of the query to ensure that the global state of the system is queried explicitly.
Queries to theService Registry 216 return object identifiers usable as end point for message communication. These identifiers may refer to DCMs, services, or any other entity in the system accessible via the messaging system. The format of the queries allows both sophisticated queries that iterate over the global registry or simple queries that are confined to a local registry.
MESSAGING 212
Themessaging system 212 of FIG. 3 is designed to provide a reliable high level messaging service that supports the transport of 4 different types of messages. (1) Commands: these flow between objects in the system and are used to access functionality. When the target object is a device then these messages are sent by a DCM and contain actual device control messages. (2) Events: events are used as a general purpose asynchronous communication mechanism that allows both devices and service modules to communicate information. Although themessaging system 212 is used to carry these events they are under the control of theEvent Manager 214 which uses a broadcast feature of the communications infrastructure to send events to those who are interested. (3) Errors: errors are similar to events except errors are delivered to the source of the command that caused the error and then broadcast. (4) Status: these messages are designed to be used in response to a query.
Themessage system 212 provides both a synchronous and an asynchronous send allowing services to operate in either mode. Themessaging system 212 defines a minimum capability to allow interoperability at the message level. This includes the format of identifiers, the format of message identifiers and the format of messages.
The following illustrates an exemplary implementation. Local identifiers are 56 bit and are guaranteed to be unique to a particular host. Network identifiers are 128 bits and consists of a 64 bit node identifier, an 8 bit node type and the 56 bit local identifier. The generic format for remote messages is a 4 octet type field followed by a parameter block. This is referred to as the message payload. The mechanism to support local messaging is implementation dependent and what is required is that local identifiers guarantee consistent delivery of the message payload. Remote messaging takes a message payload and encapsulates it in a network message. The network message format is header plus message payload. The network message header is 96 bits and consists of a reserved 6 bit field, a 2 bit packet type, a 56 bit local identifier and a 32 bit message identifier. Depending on the actual transport mechanism, this remote message packet will be encapsulated in a transport specific message, e.g. IP orIEEE 1394.
INITIALIZATION MANAGER 210
TheInitialization Manager 210 of FIG. 3 is used to bring an IAV or FAV node up to initial status. In the case of an IAV node thismanager 210 will initialize themessaging 212,event 214 andregistry 216 service. For the FAV node it will also invoke initialization routines for theDCM manager 270 and any pre-loaded services.
APPLICATION INTERFACE 220
TheApplication Interface 220 of FIG. 4 is a proxy to themessaging system 212 and provides a means for applications to access services and devices in the AV architecture. TheApplication Interface 220 is not necessarily a component of the AV architecture, but rather a means of allowing an arbitrary application to work with the AV architecture The mechanism used to provide the application object depends on the location of the application and the execution environment it uses. Applications can be downloaded from external services provided and made resident (e.g., instantiated) within an intelligent device (FAV) of a HAVI network. An Application so downloaded can query theService Registry 216 to determine connection points for controlling devices of the HAVI network.
There are 3 general cases. The first case is local application running native on the FAV node. These types of applications are designed to make use of the native OS and hardware features of the FAV node. They are created externally to the AV architecture and use the application interface to gain access to the AV architecture services. The exact means to achieve this are system dependent, but a library linked into the application is a typical approach.
The second case is local application running above the FAV interoperability language run-time. In this case, the AV architecture uses an architecture neutral run time to supportlevel 2 interoperability. This run time can also be used to support arbitrary applications written to be hosted on the run time. Such applications are managed by the AV architecture and will typically access the AV services via a run time supplied calling mechanisms.
The third case is remote application. These applications may be running on other devices in the home network such as home personal computers (PCs). These applications need access to the AV architecture and do so by using the basic message passing model of the system. This implies that these applications need a partial implementation of the messaging infrastructure resident on their host node.
GRAPHICS MANAGER 218
TheGraphics Manager 218 of FIG. 3 provides a high level API for the management of the user interface (UI) associated with devices. The role of theGraphics Manager 218 is to support the User Interface model by providing a graphics API that is semantically rich. Low level graphics APIs are generally located close to graphic displays and are used by the high level graphics API to provide and support the UI.
DEVICE IDENTIFICATION PROCESSES OF THE PRESENT INVENTION
FIG. 8 illustrates aportion 305b of the HAVI communication architecture and illustrates anapplication layer 220, adevice control module 230 for aparticular device 20, theCMM 250, thelink driver layer 320, anelectronic device 20 coupled to theIEEE 1394communication bus 30 and thespeed map 515 andtopology map 520 data structures. The location of theCMM 250 and thelink driver layer 320 in the overall architecture of HAVI is shown ininterface 305a of FIG. 4.
As described above, the present invention allows high level software programs (e.g., the application layer 220) to reference devices using a persistent identification scheme. Namely, multi-bit persistent Global Unique Identifier numbers (GUIDs) are assigned to each device and contain a vendor portion and a chip series portion. In one embodiment, a 64-bit number is used as the GUID. FIG. 8 illustrates an exemplary communication path whereby theapplication layer 220 issues a command to causedevice 20 to perform some predefined action (e.g., to start "playing" some media). The initial command from theapplication layer 220 includes an abstract identifier (e.g., "VCR1") of theDCM 230 object and also the action to be done (e.g., "play").
TheDCM 230 of FIG. 8 converts the abstract object name into a GUID that matchesdevice 20 and issues another command including the GUID and the action, "play," to theCMM 250. TheCMM 250 contains aGUID list 510 in accordance with the present invention. TheGUID list 510 is a listing of GUIDs in order of their associated physical identifications (for each respective device). Therefore, theGUID list 510 of the present invention functions as an efficient physical identification to GUID translator and a GUID to physical identification translator. TheGUID list 510 is updated by thelink driver 320 each time a bus reset event is detected.
TheCMM 250, using theGUID list 510, converts the GUID received from theDCM 230 into the corresponding physical identifier fordevice 20. TheCMM 250 then passes a message to thelink driver layer 320 including the action command, "play," and the physical identifier corresponding todevice 20. Thelink driver layer 320 interfaces with thelocal bus 30 using the physical identifier thereby communicating the action command, "play," to thedevice 20. Thespeed map 515 andtopology map 520 are present for other aspects of the present invention described further below.
FIG. 9A, FIG. 9B and FIG. 9C illustrateexemplary speed map 515 andtopology map 520 data structures. The entries of thespeed map 515 andtopology map 520 data structures are organized (e.g., ordered or indexed) based on the physical identifier of the devices. The mechanisms for generating thespeed map 515 and thetopology map 520 data structures are well known within theIEEE 1394 standard.
FIG. 9A illustrates anexemplary topology map 520 data structure used by the present invention. Thisdata structure 520 includes a respective entry (ofentries 522a-522n) for each of the n devices coupled to thelocal bus 30. Thefirst field 524 of each entry corresponds to the device's physical identifier as assigned by thelocal bus layer 330. As shown in FIG. 9A, theentries 522a-522n are ordered according to their physical identifier e.g., physical-- ID0, physical-- ID1, . . . , physical-- IDn. The followingfields 526, 528, 530 for each entry specify port information for each physical port of the device. The port information indicates the physical connection of that port to another port. Using this port information, one can determine the manner in which the n devices of thelocal bus 30 are physically coupled together in the HAVI network.Topology map 520 data structures of the format shown in FIG. 94 are well known in the art and are re-generated upon each local bus reset.
FIG. 9B illustrates an exemplary one-dimensional speedmap data structure 515a used by the present invention. Thisdata structure 515a includes a respective entry (ofentries 531a-531n) for each of the n devices coupled to thelocal bus 30. Thefirst field 532 of each entry corresponds to the device's physical identifier as assigned by thelocal bus layer 330. As shown in FIG. 9B, theentries 531a-531n are ordered according to their physical identifier, e.g., physical-- ID0, physical-- ID1, . . . , physical-- IDn.Field 534 indicates information pertinent to the communication protocol (including communicate rate) available for the device.Speed map 515a data structures of the format shown in FIG. 9B are well known in the art and are re-generated upon each local bus reset.
FIG. 9C illustrates a twodimensional speed map 515b data structure used by the present invention.Speed map 515b is a matrix where eachmatrix entry 546 conveys information regarding the communication speed between referenced devices (e.g., devices referenced by phy-- id n and phy-- id 2). Thespeed map 515b has afirst index 542 and asecond index 544, both being ordered according to their physical identifiers.Speed map 515b data structures of the format shown in FIG. 9C are well Known in the art and are re-generated upon each local bus reset.
FIG. 10A illustrates anexemplary HAVI network 560a having five devices coupled to the local bus.Device 562 has a physical identifier (0) and a GUID(Y);device 564 has a physical identifier (1) and a GUID(Z);device 566 has a physical identifier (2) and a GUID(I);device 568 has a physical identifier (3) and a GUID(J) anddevice 570 has a physical identifier (4) and a GUID(X). Each of the GUID values is unique and persistent. The physical identifier values for the devices of FIG. 10A can become reassigned after a local bus reset.
FIG. 11A illustrates the resultingGUID list 510a compiled by the present invention based on theexemplary HAVI network 560a of FIG. 10A. TheGUID list 510a contains five entries, one for each device of the HAVI network. As shown, the GUID values in theGUID list 510a are ordered, e.g., GUID(Y); GUID(Z); GUID(I); GUID(J); and GUID(X), according to the corresponding physical identification values, 0, 1, 2, 3 and 4, respectively. In one embodiment,GUID list 510a is compiled by thelink driver 320 and stored in computer readable memory.
FIG. 10B illustrates anotherexemplary HAVI network 560b having six devices coupled to the local bus.Network 560b is similar tonetwork 560a exceptdevice 566 is removed anddevices 572 and 574 are added. Innetwork 560b,device 572 has a physical identifier (1) and a GUID(U) anddevice 574 has a physical identifier (5) and a GUID(N). Some of the physical identifier values between FIG. 10A and FIG. 10B have seen reassigned due to a local bus reset. The reassigned physical identifiers for the remaining devices are as follows:device 562 has physical identifier (0),device 564 has physical identifier (3),device 568 has physical identifier (4) anddevice 570 has physical identifier (2). Each of the GUID values is unique and persistent for all devices.
FIG. 11B illustrates the resultingGUID list 510b compiled by the present invention based on theexemplary HAVI network 560b of FIG. 10B. TheGUID list 510b contains six entries, one for each device of theHAVI network 560b. As shown, the GUID values in theGUID list 510b are ordered, e.g., GUID(Y); GUID(U); GUID(X); GUID(Z); GUID(J) and GUID(N), according to the corresponding physical identification values 0, 1, 2, 3, 4 and 5, respectively. In one embodiment, theGUID list 510b is compiled by thelink driver 320 and stored in computer readable memory.
FIG. 12A illustrates a GUID status table 630 generated by theCMM 250 of the present invention each time a local bus reset is generated. The GUID status table 630 includesentries 632a-632g regarding (1) which devices remain connected to thelocal bus 30 since thelast GUID list 510 was compiled, e.g., after a local bus reset, (2) which devices have been just removed and (3) which devices have been just added since thelast GUID list 510 was compiled. Afirst field 632 represents the GUID value of the device and an associatedfield 634 represents the current status of that device. FIG. 12A represents an exemplary table 630 generated byCMM 250 as a result of the exemplary configurations of FIG. 10A and FIG. 10B. As shown in table 630, the devices having GUID(Y), GUID(X), GUID(Z), and GUID(J) remain after the local bus reset. However, the devices having GUID(U), and GUID(N) have been added after the local bus reset and the device having GUID(I) was removed after the local bus reset. In one embodiment, the GUID table 630 is compiled by theCMM 250 and stored in computer readable memory.
FIG. 12B illustrates a subset status table 650 generated by theCMM 250 which containsentries 652a-652b indicating only which devices have been added to thelocal bus 30 since thelast GUID list 510 was compiled. Likewise, FIG. 12C illustrates a subset status table 660 generated by theCMM 250 which contains entries (662a) indicating only which devices have been removed from thelocal bus 30 since thelast GUID list 510 was compiled. In one embodiment, the GUID tables 650-660 are compiled by theCMM 250 and stored in computer readable memory. Device status tables 630, 650 and 660 are forwarded to objects within the HAVI architecture that establish callback handlers within theCMM 250 to receive this information.
FIG. 13 illustrates a flow diagram 700 of the steps performed by thelink driver 320 of the present invention for compiling a current GUID table 510 in response to a local bus reset. After a local bus reset, physical identifiers of devices are reassigned by thelocal bus 30 Atstep 710, if a local bus reset is reported to thelink driver 320, then step 713 is entered. Atstep 715, current GUID list is erased and thelink driver 320 determines the number of devices, n, that are currently coupled to thelocal bus 30. A number of well known mechanisms can be used to implementstep 715. Atstep 720, a counter is set to zero. Atstep 725, thelink layer 320 issues a request to the device coupled to thelocal bus 30 and having the physical identifier corresponding to the counter value. The request is for the GUID value of this device. At this point, thelink layer 320 is unaware which device this is.
Atstep 730, thelink layer 320 receives the return GUID value from the device with the physical identifier of the counter value and places this GUID value into a next entry of the current GUID list 510 (the entry position also corresponds to the counter value). Atstep 735, the counter is incremented by one. Atstep 740, a check is made if the counter is equal to n (the maximum number of devices on the local bus). If not, then step 725 is entered again to continue compiling the current GUID list. If so, then atstep 745, thelink layer 320 forwards the CMM 250 a copy of thecurrent GUID list 510. It is appreciated that physical identifiers are assigned by thelocal bus 30 from 0 to (n-1) values. Afterprocess 700, acurrent GUID list 510 like those shown in FIG. 11A and FIG. 11B is compiled.
FIG. 14 illustrates a flow diagram 800 of the steps performed by theLink layer 320 and theCMM 250 of the present invention for compiling the device status tables 630, 650, 660 in response to a local bus reset. As discussed above,process 700 generates acurrent GUID list 510 in response to a local bus reset and passes the current list to theCMM 250 Atstep 820, the current GUID list is received and the last GUID list received by theCMM 250 is retained and marked as a "previous" GUID list. Atstep 825, theCMM 250 compares the entries of the previous GUID list and thecurrent GUID list 510 and generates GUID table 650 based on the new GUID values that are present in thecurrent GUID list 510 but not in the previous GUID list. Any object w thin the HAVI architecture that previously established a callback handler with theEvent Manager 214 for the information of table 650 is sent a message including the status information of table 650.
Atstep 830, theCMM 250 compares the entries of the previous GUID list and thecurrent GUID list 510 and generates GUID table 660 based on any GUID values that are no longer present in thecurrent GUID list 510 but were present in the previous GUID list. Any object within the HAVI architecture that previously established a callback handler with theEvent Manager 214 for the information of table 660 is sent a message including the status information of table 660. Optionally, atstep 830, the information from tables 660 and 650 can be combined with the GUID values that are common to both the previous and current GUID lists thereby generating table 630. Atstep 835, theCMM 250 erases the previous GUID list and uses only thecurrent GUID list 510. By performingprocess 800, theCMM 250 and thelink layer 320 of the present invention eliminate the burden from higher level application programs of tracking which devices are on the local bus while providing the high level application programs with device status information.
FIG. 15A illustrates a flow diagram 850 of steps performed by the present invention for translating GUID values into physical identifications using theGUID list 510 passed to theCMM 250. Atstep 855, an application program issues a command to control a device(x) and this command is received by the DCM of the device(x). Atstep 860, the DCM issues a command to theCMM 250 including device(x)'s GUID value which is known to the DCM. Atstep 865, theCMM 250 determines the index (e.g., entry order) of the device(x)'s GUID within theGUID list 510. This value is the physical identifier of device(x). Atstep 870, theCMM 250 issues a command to thelink driver layer 320 including device(x)'s physical identifier and an action command Thelink driver layer 320 then commands device(x) using the received physical identifier. Usingprocess 850, high level applications do not need to be aware of a device's physical identifier but can use the constant GUID value.
FIG. 15B illustrates a flow diagram 900a of steps performed by the present invention for accessing speed map information with respect to two devices given their GUIDs. Atstep 910, an application layer issues a command to determine the communication speed supported between device(x) and device(y). The request includes the GUID values for device(x) and device(y). Atstep 915, theCMM 250 receives this command and the GUID values. TheCMM 250 translates the GUID values into two physical identifiers based on the index of the GUIDs within theGUID list 510. Atstep 920, theCMM 250 then accesses (e.g., indexes) a two dimensional speedmap data structure 515b with the obtained two physical identifiers. The speed map thereby returns the proper speed information. Atstep 925, theCMM 250 forwards the determined speed information to the requesting application layer.
FIG. 15C illustrates a flow diagram 950a of steps performed by the present invention for accessing topology map information with respect to a device given its GUID value. Atstep 955, an application layer issues a command to determine the topology of a device(y). The request includes the GUID value for device(y). Atstep 960, theCMM 250 receives this command and the GUID value. TheCMM 250 translates the GUID value into a physical identifier based on the index of the GUID within theGUID list 510. Atstep 965, theCMM 250 then accesses (e.g., indexes) atopology data structure 520 with the obtained physical identifier. The topology map thereby returns the proper topology information for device(y). Atstep 970, theCMM 250 forwards the determined topology information to the requesting application layer.
FIG. 15D illustrates a flow diagram 900b of steps performed by the present invention for accessing speed map information with respect to two devices given their GUIDs. The difference betweenprocess 900b and 900a (FIG. 15A) is that the application program determines the speed information, not theCMM 250. Atstep 980, an application layer issues a command to determine the communication speed between device(x) and device(y). Atstep 982, theCMM 250 receives this command and forwards thecurrent GUID list 510 as well as a copy of thespeed map 515b (or pointers to these data structures) to the application program. Atstep 984, the application program translates the GUID values of the two devices into two physical identifiers based on the index of the GUIDs within theGUID list 510. The application program then accesses (e.g., indexes) the two dimensional speedmap data structure 515b with the obtained two physical identifiers. The speed map thereby returns the proper speed information.
FIG. 15E illustrates a flow diagram 950b of steps performed by the present invention for accessing topology information with respect to a device given its GUID. The difference betweenprocess 950b and 950a (FIG. 15B) is that the application program determines the topology information, not theCMM 250. Atstep 990, an application layer issues a command to determine the topology information of device(y). Atstep 992, theCMM 250 receives this command and forwards thecurrent GUID list 510 as well as a copy of the topology map 520 (or a pointer to this data structure) to the application program. Atstep 994, the application program translates the GUID value of the device(y) into a physical identifier based on the index of the GUID within theGUID list 510. The application program then accesses (e.g., indexes) thetopology data structure 520 with the obtained physical identifier. The topology map thereby returns the proper topology information.
It is appreciated that by providing theGUID list 510, the present invention allows high level applications to utilize persistent device identifiers (GUIDs) to references devices. Upon a bus reset, the high level devices are not burdened with the reassignments of physical identifiers that are done at the local bus level. TheGUID list 510 is particularly efficient by organizing the ordering of GUIDs to conform to the physical identifier value. This reduces memory required to store theGUID list 510 and creates an efficient index mechanism.
The preferred embodiments of the present invention, a method and system for updating device identification and status information in response to a local bus reset within a home audio/video network, are thus described. While the present invention has been described in particular embodiments, it should be appreciated that the present invention should not be construed as limited by such embodiments, but rather construed according to the below claims.

Claims (20)

What is claimed is:
1. A method of providing device status information within a communication network, said method comprising the steps of:
a) constructing a current list of global unique identifiers (GUIDs) by ordering respective GUIDs within said current list of GUIDs according to their associated physical identifier values where n said physical identifier values are assigned by a local bus of said network and each GUID of said current list of GUIDs identifies a unique device coupled within said network;
b) forwarding said current list of GUIDs to a high level software program;
c) said high level software program comparing said current list of GUIDs with a previous list of GUIDs to generate a list of newly added devices to said network and of newly removed devices from said network;
d) forwarding said list to a device within said network that previously established a call back handler with said high level software program for device status information; and
e) repeating steps a)-d) in response to each local bus reset.
2. A method as described in claim 1 wherein each GUID is a persistent multi-bit value comprising a vendor code portion and a chip series code portion.
3. A method as described in claim 1 wherein said network is a network of the home audio/visual initiative (HAVI) architecture and wherein said local bus is of the IEEE 1394 standard.
4. A method as described in claim 1 wherein said step c) further comprises the step of said high level software program replacing said previous list of GUIDs with said current list of GUIDs after said comparing.
5. A method as described in claim 1 further comprising the step of said local bus renumbering physical identifiers of devices of said network that are coupled to said local bus in response to a local bus reset.
6. A method as described in claim 5 wherein said step a) comprises the steps of:
a1) receiving from said local bus an indication of the number of devices of said local bus;
a2) starting with physical identifier zero and incrementing to a last physical identifier corresponding to said number of devices of said local bus, forwarding requests to said devices of said local bus individually requesting their GUIDs;
a3) recording into said current list of GUIDs any GUIDs returned from said devices of said local bus, said GUIDs recorded into positions said current list of GUIDs based on their corresponding physical identifier values; and
a4) storing said current list of GUIDs into a computer readable memory unit.
7. A method of providing device status information within a communication network, said method comprising the steps of:
a) constructing a current list of global unique identifiers (GUIDs) by ordering respective GUIDs within said current list of GUIDs according to their associated physical identifier values, said physical identifier values assigned by a local bus of said network and wherein each GUID of said current list of GUIDs identifies a unique device coupled within said network, said step a) performed by first software;
b) said first software forwarding said current list of GUIDs to second software;
c) said second software comparing said current list of GUIDs with a previous list of GUIDs to generate a first list of newly added devices to said communication network and a second list of newly removed devices from said network;
d) forwarding said first list and said second list to a device within said communication network that previously established a call back handler with said second software for device status information; and
e) repeating steps a)-d) in response to each local bus reset.
8. A method as described in claim 7 wherein each GUID is a persistent multi-bit value comprising a vendor code portion and a chip series code portion.
9. A method as described in claim 7 wherein said network is a network of the home audio/visual initiative (HAVI) architecture and wherein said local bus is of the IEEE 1394 standard.
10. A method as described in claim 7 wherein said step c) further comprises the step of said second software replacing said previous list of GUIDs with said current list of GUIDs after said comparing.
11. A method as described in claim 7 further comprising the step of said local bus renumbering physical identifiers of devices of said network that are coupled to said local bus in response to a local bus reset.
12. A method as described in claim 11 wherein said step a) comprises the steps of:
a1) receiving from said local bus an indication of the number of devices of said local bus;
a2) starting with physical identifier zero and incrementing to a last physical identifier corresponding to said number of devices of said local bus, forwarding requests to said devices of said local bus individually requesting their GUIDs;
a3) recording into said current list of GUIDs any GUIDs returned from said devices of said local bus, said GUIDs recorded into positions said current list of GUIDs based on their corresponding physical identifier values; and
a4) storing said current list of GUIDs into a computer readable memory unit.
13. An electronic system having a processor, a bus and a computer readable memory unit, said system coupled to a local bus, said memory unit having instructions stored therein that implement a method of providing device status information, said method comprising the steps of:
a) constructing a current list of global unique identifiers (GUIDs) by ordering respective GUIDs within said current list of GUIDs according to their associated physical identifier values wherein said physical identifier values are assigned by said local bus and each GUID of said current list of GUIDs identifies a unique device;
b) forwarding said current list of GUIDs to a high level software program;
c) said high level software program comparing said current list of GUIDs with a previous list of GUIDs to generate a list of newly added devices to said network and of newly removed devices from said network;
d) forwarding said list to a device within said network that previously established a call back handler with said high level software program for device status information; and
e) repeating steps a)-d) in response to each local bus reset.
14. An electronic system as described in claim 13 wherein each GUID is a persistent multi-bit value comprising a vendor code portion and a chip series code portion.
15. An electronic system as described in claim 13 wherein said network is a network of the home audio/visual initiative (HAVI) architecture and wherein said local bus is of the IEEE 1394 standard.
16. An electronic system as described in claim 13 wherein said step c) further comprises the step of said high level software program replacing said previous list of GUIDs with said current list of GUIDs after said comparing.
17. An electronic system as described in claim 14 wherein said method further comprises the step of said local bus renumbering physical identifiers of devices of said network that are coupled to said local bus in response to a local bus reset.
18. An electronic system as described in claim 17 wherein said step a) comprises the steps of:
a1) receiving from said local bus an indication of the number of devices of said local bus;
a2) starting with physical identifier zero and incrementing to a last physical identifier corresponding to said number of devices of said local bus, forwarding requests to said devices of said local bus individually requesting their GUIDs;
a3) recording into said current list of GUIDs any GUIDs returned from said devices of said local bus, said GUIDs recorded into positions said current list of GUIDs based on their corresponding physical identifier values; and
a4) storing said current list of GUIDs into a computer readable memory unit.
19. An apparatus for providing device status information within a communication network, said apparatus comprising:
a) means for constructing a current list of global unique identifiers (GUIDs) by ordering respective GUIDs within said current list of GUIDs according to their associated physical identifier values wherein said physical identifier values are assigned by a local bus of said network and each GUID of said current list of GUIDs identifies a unique device coupled within said network;
b) means for forwarding said current list of GUIDs to a high level software program;
c) said high level software program comparing said current list of GUIDs with a previous list of GUIDs to generate a list of newly added devices to said network and of newly removed devices from said network;
d) said high level software program forwarding said list to a device within said network that previously established a call back handler with said high level software program for device status information; and
e) means for repeating steps a)-d) in response to each local bus reset.
20. An apparatus as described in claim 19 wherein said means for constructing comprises:
means for receiving from said local bus an indication of the number of devices of said local bus;
means for starting with physical identifier zero and incrementing to a last physical identifier corresponding to said number of devices of said local bus, forwarding requests to said devices of said local bus individually requesting their GUIDs;
means for recording into said current list of GUIDs any GUIDs returned from said devices of said local bus, said GUIDs recorded into positions said current list of GUIDs based on their corresponding physical identifier values; and
means for storing said current list of GUIDs into a computer readable memory unit.
US09/003,1181998-01-061998-01-06Method and system for updating device identification and status information after a local bus reset within a home audio/video networkExpired - Fee RelatedUS6160796A (en)

Priority Applications (3)

Application NumberPriority DateFiling DateTitle
US09/003,118US6160796A (en)1998-01-061998-01-06Method and system for updating device identification and status information after a local bus reset within a home audio/video network
JP11001470AJPH11317751A (en)1998-01-061999-01-06Method and device for providing identification information
EP99300080AEP0929170A3 (en)1998-01-061999-01-06Methods, systems and apparatus for providing device status information within a communication network

Applications Claiming Priority (1)

Application NumberPriority DateFiling DateTitle
US09/003,118US6160796A (en)1998-01-061998-01-06Method and system for updating device identification and status information after a local bus reset within a home audio/video network

Publications (1)

Publication NumberPublication Date
US6160796Atrue US6160796A (en)2000-12-12

Family

ID=21704260

Family Applications (1)

Application NumberTitlePriority DateFiling Date
US09/003,118Expired - Fee RelatedUS6160796A (en)1998-01-061998-01-06Method and system for updating device identification and status information after a local bus reset within a home audio/video network

Country Status (3)

CountryLink
US (1)US6160796A (en)
EP (1)EP0929170A3 (en)
JP (1)JPH11317751A (en)

Cited By (165)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
WO2001022237A1 (en)*1999-09-212001-03-29Sony Electronics, Inc.A method and system for the simplification of leaf-limited bridges
WO2001059959A1 (en)*2000-02-092001-08-16Sony Electronics Inc.HAVi-VHN BRIDGE SOLUTION
WO2001063389A1 (en)*2000-02-252001-08-30Dreamhouse Software, Inc.Personal server technology
US6286071B1 (en)*1998-07-092001-09-04Sony CorporationCommunication control method, communication system and electronic device used therefor
US20010042141A1 (en)*1999-12-202001-11-15Kosuke MatsunagaData transfer control device, information storage medium and electronic equipment
US20020010824A1 (en)*2000-04-072002-01-24Sumihiro OkawaElectronic equipment and method for processing digital serial data at bus initialization phase in interface unit
US20020066015A1 (en)*2000-11-242002-05-30Matsushita Electric Industrial Co., Ltd.Data transmit/receive device and data transmit/receive method
KR100339359B1 (en)*2000-04-072002-06-03구자홍method for reset processing in home network system
US6405247B1 (en)*1997-05-022002-06-113Com CorporationMethod and apparatus for operating the internet protocol over a high-speed serial bus
US20020083245A1 (en)*2000-08-232002-06-27Dennis Van De MeulenhofCommunication system and device
US20020093977A1 (en)*2001-01-122002-07-18Pioneer CorporationData transmission/ reception system, connection restoring method and information transmission/ reception apparatus
US20020097260A1 (en)*2000-12-132002-07-25Yuji IgataAppliance information transmitting/receiving method and appliance information transmitting/receiving system
US6430629B1 (en)*1999-06-102002-08-06Sony CorporationMethods and apparatus for monitoring a 1394 home network
US20020122068A1 (en)*2001-03-012002-09-05Taizo TsuruokaEntertainment device, menu display method, and information recording medium
US6466549B1 (en)*1999-04-122002-10-15Intel CorporationBroadcast discovery in a network having one or more 1394 buses
US20020161865A1 (en)*2001-04-252002-10-31Gateway, Inc.Automated network configuration of connected device
US20020194596A1 (en)*2001-06-182002-12-19Srivastava Gopal K.Control of multiple AV-devices by a single master controller using infrared transmitted commands and bus transmitted commands
US20030005106A1 (en)*2000-10-312003-01-02Takashi IsodaCommunication control apparatus and method
US20030041195A1 (en)*2000-10-312003-02-27Takashi IsodaCommunication system and communication control apparatus and method
US6529951B1 (en)*1997-11-252003-03-04Kabushiki Kaisha ToshibaApparatus for transmitting connecting status and method of displaying connecting status
US20030048757A1 (en)*2001-08-012003-03-13Jean-Paul AccarieMethod for the processing of remote control signals within a home audiovisual network, corresponding signal, devices and computer program
US20030056045A1 (en)*1998-10-152003-03-20Pioneer CorporationInformation transmitting apparatus and method, information receiving apparatus and method, and information transmitting/receiving apparatus and method
US20030061427A1 (en)*2001-09-212003-03-27O'donnell Ciaran GerardScalable home control platform and architecture
US20030058369A1 (en)*2000-08-182003-03-27Hideaki TakechiControl device, controlled device with passing-through function, controlled device, controlled method, medium and program
US6542474B1 (en)*1999-02-262003-04-01Sony CorporationSystem and method for incrementally updating remote element lists in an electronic network
US20030069960A1 (en)*2001-10-042003-04-10Symons Julie A.Method for describing and comparing data center physical and logical topologies and device configurations
US20030070015A1 (en)*2001-10-042003-04-10Sony CorporationMethod of and apparatus for cancelling a pending AV/C notify command
US20030070028A1 (en)*2001-10-042003-04-10Sony CorporationMethod and apparatus for utilizing extended AV/C command frames including status inquiry, notify inquiry and control inquiry command types
US6581102B1 (en)*1999-05-272003-06-17International Business Machines CorporationSystem and method for integrating arbitrary isochronous processing algorithms in general media processing systems
US6584539B1 (en)*1999-03-192003-06-24Sony CorporationMethod and system for message broadcast flow control on a bus bridge interconnect
US6587904B1 (en)*1999-11-052003-07-01Apple Computer, Inc.Method and apparatus for preventing loops in a full-duplex bus
US20030126220A1 (en)*2001-12-272003-07-03James WanlessQuick reply codes for communication of information between electronic devices
US20030131101A1 (en)*2002-01-092003-07-10Kyoung-Woo LeeMethod for deciding network manager in home network
US6594239B1 (en)*1998-12-282003-07-15Pioneer CorporationTransmission managing apparatus, information processing apparatus and information transmitting system
US20030135859A1 (en)*2001-07-192003-07-17Daniel PuttermanHome media network
US6601086B1 (en)*2000-06-062003-07-29Emware, Inc.Service provider for providing data, applications and services to embedded devices and for facilitating control and monitoring of embedded devices
US6618361B1 (en)*1998-07-042003-09-09Samsung Electronics Co., Ltd.Method of resetting bus for network connected by IEEE 1394 bus
US6618785B1 (en)2000-04-212003-09-09Apple Computer, Inc.Method and apparatus for automatic detection and healing of signal pair crossover on a high performance serial bus
US6628607B1 (en)1999-07-092003-09-30Apple Computer, Inc.Method and apparatus for loop breaking on a serial bus
US6636914B1 (en)1999-11-052003-10-21Apple Computer, Inc.Method and apparatus for arbitration and fairness on a full-duplex bus using dual phases
US6639918B1 (en)2000-01-182003-10-28Apple Computer, Inc.Method and apparatus for border node behavior on a full-duplex bus
US20030208623A1 (en)*2001-02-272003-11-06Masataka MaedaAppliance number setting member for home network system
US6647448B1 (en)2000-06-292003-11-11Sony CorporationMethod and apparatus for managing resource schedules in a peer to peer distributed networking environment
US6658474B2 (en)*1998-11-262003-12-02Samsung Electronics Co., Ltd.Home network system and method of allocating node identification
US6671759B1 (en)*1999-06-182003-12-30Sony CorporationApparatus and method for mapping IEEE 1394 node IDS to unchanging node unique IDS to maintain continuity across bus resets
US20040015272A1 (en)*2000-05-162004-01-22Vasco VollmerMethod for integrating a device into a vehicle communications network
US6694363B1 (en)*1999-06-042004-02-17Kabushiki Kaisha ToshibaNetwork equipment and networking method
US6718497B1 (en)2000-04-212004-04-06Apple Computer, Inc.Method and apparatus for generating jitter test patterns on a high performance serial bus
US6728821B1 (en)1999-11-292004-04-27Sony CorporationMethod and system for adjusting isochronous bandwidths on a bus
US20040088731A1 (en)*2002-11-042004-05-06Daniel PuttermanMethods and apparatus for client aggregation of media in a networked media system
US20040090925A1 (en)*2000-12-152004-05-13Thomas SchoeberlMethod for testing a network, and corresponding network
US6738816B1 (en)*1999-03-092004-05-18Nec CorporationSystem and method for reliable real-time communications among a plurality of nodes having functions conforming to IEEE-1394 serial bus and participating in a session of sharing the maximum bandwidth
US6754184B2 (en)*1998-06-262004-06-22Sony CorporationInformation processing apparatus and method, and distribution medium
US6757773B1 (en)2000-06-302004-06-29Sony CorporationSystem and method for determining support capability of a device coupled to a bus system
US20040131044A1 (en)*2002-09-112004-07-08Mayhew David E.System and method for selecting fabric master
US6768926B2 (en)*2001-02-022004-07-27Hitachi, Ltd.Controller, controlled device, control method, and control system
US6775244B1 (en)*1999-06-212004-08-10Intel CorporationGathering of device discovery information
US6785720B1 (en)*1998-05-232004-08-31Samsung Electronics Co., Ltd.Method for connecting to server devices in browser-based home network apparatus therefor
US20040169662A1 (en)*2001-06-222004-09-02Uwe RiemannArrangement of icons of network components on a screen
US20040174827A1 (en)*2002-04-032004-09-09Makoto SatoSignal processing system, signal receiving device, and communication control method
US20040183756A1 (en)*2003-03-172004-09-23Pedro FreitasMethods and apparatus for rendering user interfaces and display information on remote client devices
US20040183827A1 (en)*2003-03-172004-09-23Daniel PuttermanMethods and apparatus for implementing a remote application over a network
US6810452B1 (en)1999-03-192004-10-26Sony CorporationMethod and system for quarantine during bus topology configuration
US6813663B1 (en)1999-11-022004-11-02Apple Computer, Inc.Method and apparatus for supporting and presenting multiple serial bus nodes using distinct configuration ROM images
US6829225B2 (en)*1998-02-202004-12-07Apple Computer, Inc.Method for computing speed map for IEEE-1394 network
US6831928B1 (en)2000-02-172004-12-14Apple Computer, Inc.Method and apparatus for ensuring compatibility on a high performance serial bus
US20040252231A1 (en)*2003-06-132004-12-16Apple Computer, Inc.Synthesis of vertical blanking signal
US20040255339A1 (en)*2003-06-132004-12-16Apple Computer, IncSynchronized transmission of audio and video data from a computer to a client via an interface
US6839791B2 (en)1999-11-162005-01-04Apple Computer, Inc.Method and apparatus for accelerating detection of serial bus device speed signals
US20050043019A1 (en)*2002-08-292005-02-24Hitoshi NakamuraCommunication device, communication control method, and program
US6865596B1 (en)*1999-06-092005-03-08Amx CorporationMethod and system for operating virtual devices by master controllers in a control system
US6870818B1 (en)*1998-05-262005-03-22Thomson Licensing S.A.Method for identifying devices in a communication network and device for implementing said method
US6874012B1 (en)*2000-11-012005-03-29Sun Microsystems, Inc.System and method for a display device using a priority messaging protocol
US6885631B1 (en)*1999-07-012005-04-26Samsung Electronics Co., Ltd.Connection management method for digital interface
US6901444B1 (en)2000-06-302005-05-31Sony CorporationMethod of and apparatus for communicating data structures between devices in a networking environment
US6910090B1 (en)1999-09-212005-06-21Sony CorporationMaintaining communications in a bus bridge interconnect
US6925513B1 (en)*1999-05-042005-08-02Apple Computer, Inc.USB device notification
US6928503B1 (en)*1997-12-292005-08-09Intel CorporationMethod and apparatus for robust addressing on a dynamically configurable bus
US6931593B1 (en)*2000-05-222005-08-16Gateway Inc.Automatic channel generation for home network systems
US20050207352A1 (en)*2004-03-182005-09-22AlcatelMethod for identifying a control element
US20050210034A1 (en)*2000-06-062005-09-22Emware, Inc.Service provider for embedded devices using a message store
US20050240660A1 (en)*2002-05-202005-10-27Katsutoshi SakaoInformation-processing system, information-processing device, and information-processing method
US20050289558A1 (en)*2004-06-082005-12-29Daniel IllowskyDevice interoperability runtime establishing event serialization and synchronization amongst a plurality of separate processing units and method for coordinating control data and operations
US20060002314A1 (en)*1999-08-312006-01-05Canon Kabushiki KaishaInformation communication system, information communication method, information signal processing device and information signal processing method, and storage medium
US20060031470A1 (en)*2004-06-302006-02-09International Business Machines CorporationMethod to update status on multiple voice and text systems from a single device
US7027411B1 (en)*2000-10-312006-04-11Hewlett-Packard Development Company, L.P.Method and system for identifying and processing changes to a network topology
US7032024B1 (en)*1999-07-292006-04-18Samsung Electronics Co., Ltd.Connection management method for devices connected digital interface and command structure therefor
US7050453B1 (en)2000-02-172006-05-23Apple Computer, Inc.Method and apparatus for ensuring compatibility on a high performance serial bus
US7068822B2 (en)*1999-08-092006-06-27Cross Match Technologies, Inc.System and method for sending a packet with position address and line scan data over an interface cable
US20060209848A1 (en)*2003-04-172006-09-21Helmut BurklinMethod for the tranmission of buss ieee 1394 reinitialization messages and device for carrying out said method
US7130315B1 (en)1999-09-102006-10-31Sony CorporationMethod of and apparatus for utilizing extended AV/C command and response frames including transaction label and common result/error code
US7181511B1 (en)*2002-04-152007-02-20Yazaki North America, Inc.System and method for using software objects to manage devices connected to a network in a vehicle
US7213061B1 (en)1999-04-292007-05-01Amx LlcInternet control system and method
US7224366B2 (en)2002-10-172007-05-29Amx, LlcMethod and system for control system software
CN1322411C (en)*2003-03-312007-06-20微软公司Peripheral equipment driving program maintenance method of network peripheral equipment
US7237135B1 (en)2003-12-292007-06-26Apple Inc.Cyclemaster synchronization in a distributed bridge
US20070150817A1 (en)*2005-12-232007-06-28Ducheneaut Nicolas BUser interface and method for composing services in a ubiquitous computing environment through direction and selection operators
US20070147351A1 (en)*2005-12-272007-06-28Brad DietrichMethods and apparatus for integrating media across a wide area network
US20070160022A1 (en)*2005-06-092007-07-12Whirlpool CorporationSoftware architecture system and method for discovering components within an appliance using fuctionality identifiers
US7257132B1 (en)*1998-02-262007-08-14Hitachi, Ltd.Receiver set, information apparatus and receiving system
US7266617B1 (en)2000-01-182007-09-04Apple Inc.Method and apparatus for border node behavior on a full-duplex bus
US20070210908A1 (en)*2005-01-052007-09-13Daniel PuttermanMethods and apparatus for providing notifications in a media system
US20070214277A1 (en)*2006-03-072007-09-13Ahmed Ali UPeer-to-peer network communications using SATA/SAS technology
US7305680B2 (en)*2002-08-132007-12-04Sharp Laboratories Of America, Inc.Listening module for asynchronous messages sent between electronic devices of a distributed network
US20070283046A1 (en)*2006-06-012007-12-06Bradley DietrichMethods and apparatus for providing media from content providers using a network interface device
US7308517B1 (en)2003-12-292007-12-11Apple Inc.Gap count analysis for a high speed serialized bus
US7353322B1 (en)1999-11-012008-04-01Apple Inc.System and method for providing dynamic configuration ROM using double image buffers
US20080126936A1 (en)*2003-08-212008-05-29Gary WilliamsElectronic/software multimedia library control system and methods of use thereof
US20080162415A1 (en)*2006-12-282008-07-03Sap AgSoftware and method for utilizing a common database layout
US20080183309A1 (en)*2007-01-312008-07-31Beers Ted WDevice control system
US7417973B1 (en)2002-12-312008-08-26Apple Inc.Method, apparatus and computer program product for ensuring node participation in a network bus
US7421507B2 (en)2000-02-162008-09-02Apple Inc.Transmission of AV/C transactions over multiple transports method and apparatus
US7426702B2 (en)1999-06-082008-09-16Amx LlcSystem and method for multimedia display
US20080225827A1 (en)*2007-03-152008-09-18Microsoft CorporationEnabling routing of data on a network based on a portion of data accessed from a non-network enabled device
US20080225869A1 (en)*2007-03-152008-09-18Microsoft CorporationEnabling sharing of devices on a network
US20080225828A1 (en)*2007-03-152008-09-18Microsoft CorporationEnabling routing of data on a network
US20080238653A1 (en)*2007-03-302008-10-02Sony Corporation, A Japanese CorporationMethod and apparatus for identifying an electronic appliance
US7457302B1 (en)2002-12-312008-11-25Apple Inc.Enhancement to loop healing for malconfigured bus prevention
US20090103535A1 (en)*2005-06-092009-04-23Whirlpool CorporationSoftware Architecture System And Method For Communication With, And Management Of, Components Within An Appliance Utilizing Functionality Identifiers
US20090198842A1 (en)*2008-01-312009-08-06Jeevan BasavarajuSystem And Method For Identifying Lost/Stale Hardware In A Computing System
US7574650B1 (en)1999-10-282009-08-11Apple Inc.General purpose data container method and apparatus for implementing AV/C descriptors
US20090274281A1 (en)*2000-10-242009-11-05Eric CheungMethod and system for providing communication control functionality at a remotely located site using a distributed feature architecture
US7680911B1 (en)*1998-04-232010-03-16Thomson LicensingMethod for managing objects in a communication network and implementing device
US20100169533A1 (en)*2001-10-172010-07-01Brocco Lynne MMulti-port system and method for routing a data element within an interconnection fabric
US7788567B1 (en)2003-11-182010-08-31Apple Inc.Symbol encoding for tolerance to single byte errors
US7886324B1 (en)*1998-12-222011-02-08Sony CorporationReceiving system for digital broadcasting and receiving apparatus for digital broadcasting
US20110099178A1 (en)*2004-06-302011-04-28Frank GlaeserMethod for providing a table of station-specific information in a network of distributed stations, and network station for carrying out the method
US20110184965A1 (en)*2010-01-282011-07-28Srikanth KambhatlaIdentifying Devices in a Topology of Devices for Audio/Video Streaming
US7995606B1 (en)2003-12-032011-08-09Apple Inc.Fly-by and ack-accelerated arbitration for broadcast packets
US20110231862A1 (en)*2010-03-192011-09-22At&T Mobility Ii LlcAgnostic execution cluster for an agnostic execution environment
US20110265111A1 (en)*2010-04-262011-10-27Cox Communications, Inc.Broadcast Remote Control
US8051114B2 (en)2005-07-012011-11-01Qnx Software Systems LimitedOptimized startup verification of file system integrity
US8086575B2 (en)2004-09-232011-12-27Rovi Solutions CorporationMethods and apparatus for integrating disparate media formats in a networked media system
US8122178B2 (en)2006-08-252012-02-21Qnx Software Systems LimitedFilesystem having a filename cache
US8275910B1 (en)2003-07-022012-09-25Apple Inc.Source packet bridge
US8412752B2 (en)2005-07-012013-04-02Qnx Software Systems LimitedFile system having transaction record coalescing
US8566503B2 (en)2006-08-252013-10-22Qnx Software Systems LimitedMultimedia filesystem having unified representation of content on diverse multimedia devices
US8584184B2 (en)2000-10-112013-11-12United Video Properties, Inc.Systems and methods for relocating media
US20130311884A1 (en)*2003-08-072013-11-21Samsung Electronics Co., Ltd.Audio/video device, apparatus and method for controlling audio/video device
US8606799B2 (en)2006-12-282013-12-10Sap AgSoftware and method for utilizing a generic database query
US8607287B2 (en)2005-12-292013-12-10United Video Properties, Inc.Interactive media guidance system having multiple devices
US8762446B1 (en)1999-11-022014-06-24Apple Inc.Bridged distributed device control over multiple transports method and apparatus
US8959117B2 (en)2006-12-282015-02-17Sap SeSystem and method utilizing a generic update module with recursive calls
US8959125B2 (en)2005-07-012015-02-17226008 Ontario Inc.File system having inverted hierarchical structure
US9014546B2 (en)2009-09-232015-04-21Rovi Guides, Inc.Systems and methods for automatically detecting users within detection regions of media devices
US9021538B2 (en)1998-07-142015-04-28Rovi Guides, Inc.Client-server based interactive guide with server recording
US9063739B2 (en)2005-09-072015-06-23Open Invention Network, LlcMethod and computer program for device configuration
US9071872B2 (en)2003-01-302015-06-30Rovi Guides, Inc.Interactive television systems with digital video recording and adjustable reminders
US9107140B2 (en)2010-08-132015-08-11At&T Mobility Ii LlcCarrier-driven bearer path selection
US9125169B2 (en)2011-12-232015-09-01Rovi Guides, Inc.Methods and systems for performing actions based on location-based rules
US20150261861A1 (en)*2014-03-122015-09-17Futurewei Technologies, Inc.Framework for Composing Real-Time Media Using a Declarative Mark-Up Language
US9161087B2 (en)2000-09-292015-10-13Rovi Technologies CorporationUser controlled multi-device media-on-demand system
US9311405B2 (en)1998-11-302016-04-12Rovi Guides, Inc.Search engine for video and graphics
US9326016B2 (en)2007-07-112016-04-26Rovi Guides, Inc.Systems and methods for mirroring and transcoding media content
US9414120B2 (en)2008-06-132016-08-09Rovi Guides, Inc.Systems and methods for displaying media content and media guidance information
US9674563B2 (en)2013-11-042017-06-06Rovi Guides, Inc.Systems and methods for recommending content
US9681105B2 (en)2005-12-292017-06-13Rovi Guides, Inc.Interactive media guidance system having multiple devices
US10063934B2 (en)2008-11-252018-08-28Rovi Technologies CorporationReducing unicast session duration with restart TV
US11184236B2 (en)2019-04-302021-11-23Intel CorporationMethods and apparatus to control processing of telemetry data at an edge platform
US11196837B2 (en)2019-03-292021-12-07Intel CorporationTechnologies for multi-tier prefetching in a context-aware edge gateway
US11507545B2 (en)*2020-07-302022-11-22EMC IP Holding Company LLCSystem and method for mirroring a file system journal
US20220407869A1 (en)*2015-12-212022-12-22Nagravision S.A.Secured home network
WO2023010848A1 (en)*2021-08-052023-02-09青岛海信日立空调系统有限公司Central air-conditioning control system
USRE49505E1 (en)*2002-10-242023-04-25Intel CorporationServicing device aggregates
US11669501B2 (en)2020-10-292023-06-06EMC IP Holding Company LLCAddress mirroring of a file system journal

Families Citing this family (16)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US6801507B1 (en)*1999-07-272004-10-05Samsung Electronics Co., Ltd.Device discovery and configuration in a home network
JP2001229114A (en)*1999-12-082001-08-24Sony CorpInformation processing device and method, and program storage medium
US6718424B1 (en)1999-12-102004-04-06Intel CorporationBridge circuit for use in a computing platform
FR2802740B1 (en)*1999-12-152002-08-09Canon Kk METHOD AND DEVICE FOR COMMUNICATION BETWEEN TWO INTERCONNECTION NODES CONNECTED TO TWO COMMUNICATION BUSES
US7111079B2 (en)2000-02-232006-09-19Koninklijke Philips Electronics, N.V.Architecture of a bridge between a non-IP network and the web
JP2002033750A (en)*2000-07-182002-01-31Sony CorpInformation processing unit and method, and medium
JP2002082774A (en)2000-09-082002-03-22Sony CorpInformation processor, its method, information processing system and program storage medium
CN101087412B (en)*2000-09-272010-07-07汤姆森特许公司Method for optimizing audio and video output states for multimedia devices
KR100750735B1 (en)*2001-02-032007-08-22삼성전자주식회사 Device control device and method in home network and home network system using same
DE60140857D1 (en)2001-03-152010-02-04Sony Deutschland Gmbh Control of home networking devices
JP2004523182A (en)*2001-03-222004-07-29ユナイテッド ビデオ プロパティーズ, インコーポレイテッド Personal video recorder system and method
EP1263169B1 (en)*2001-05-222004-12-01Sony International (Europe) GmbHMethod for evaluating information about a plurality of nodes connected to a network
JP3972288B2 (en)2001-10-112007-09-05ソニー株式会社 Signal processing system, signal output device, signal input device, and communication control method
US20040139251A1 (en)*2003-01-142004-07-15Cheng-Chi LiaoBuilding-block system framework for information appliance
KR100587539B1 (en)2003-08-092006-06-08삼성전자주식회사 Method and system for establishing intelligent connection between video device and peripheral device
DE10340156A1 (en)*2003-09-012005-03-24Deutsche Thomson-Brandt Gmbh Method and apparatus for determining electronic information about transmission speeds in a network

Citations (6)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4893199A (en)*1987-09-161990-01-09Sony CorporationDigital signal recording apparatus with a digital subdata converting capability
US5420573A (en)*1991-08-281995-05-30Sony CorporationAudio-visual system with two-way communication between devices
US5537605A (en)*1992-07-141996-07-16Sony CorporationMethod and apparatus for controlling at least one piece of equipment
US5724517A (en)*1994-09-271998-03-03International Business Machines CorporationMethod for generating a topology map for a serial bus
US5764930A (en)*1996-04-011998-06-09Apple Computer, Inc.Method and apparatus for providing reset transparency on a reconfigurable bus
US5815678A (en)*1995-07-141998-09-29Adaptec, Inc.Method and apparatus for implementing an application programming interface for a communications bus

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
JP2001503930A (en)*1996-06-212001-03-21ソニー エレクトロニクス インク Device user interface with topology map

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4893199A (en)*1987-09-161990-01-09Sony CorporationDigital signal recording apparatus with a digital subdata converting capability
US5420573A (en)*1991-08-281995-05-30Sony CorporationAudio-visual system with two-way communication between devices
US5537605A (en)*1992-07-141996-07-16Sony CorporationMethod and apparatus for controlling at least one piece of equipment
US5724517A (en)*1994-09-271998-03-03International Business Machines CorporationMethod for generating a topology map for a serial bus
US5815678A (en)*1995-07-141998-09-29Adaptec, Inc.Method and apparatus for implementing an application programming interface for a communications bus
US5764930A (en)*1996-04-011998-06-09Apple Computer, Inc.Method and apparatus for providing reset transparency on a reconfigurable bus

Cited By (318)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US6405247B1 (en)*1997-05-022002-06-113Com CorporationMethod and apparatus for operating the internet protocol over a high-speed serial bus
US20030140135A1 (en)*1997-11-252003-07-24Kabushiki Kaisha ToshibaApparatus for transmitting connecting status and method of displaying connecting status
US6529951B1 (en)*1997-11-252003-03-04Kabushiki Kaisha ToshibaApparatus for transmitting connecting status and method of displaying connecting status
US7058679B2 (en)1997-11-252006-06-06Kabushiki Kaisha ToshibaApparatus for transmitting connecting status and method of displaying connecting status
US6928503B1 (en)*1997-12-292005-08-09Intel CorporationMethod and apparatus for robust addressing on a dynamically configurable bus
US6829225B2 (en)*1998-02-202004-12-07Apple Computer, Inc.Method for computing speed map for IEEE-1394 network
US20070263662A1 (en)*1998-02-262007-11-15Chiyo AkamatsuReceiver set, information apparatus and receiving system
US8233504B2 (en)1998-02-262012-07-31Hitachi, Ltd.Receiver set, information apparatus and receiving system
US9661363B2 (en)1998-02-262017-05-23Hitachi Maxell, Ltd.Receiver set, information apparatus and receiving system
US8856819B2 (en)1998-02-262014-10-07Hitachi Maxell, Ltd.Receiver set, information apparatus and receiving system
US7257132B1 (en)*1998-02-262007-08-14Hitachi, Ltd.Receiver set, information apparatus and receiving system
US7680911B1 (en)*1998-04-232010-03-16Thomson LicensingMethod for managing objects in a communication network and implementing device
US6785720B1 (en)*1998-05-232004-08-31Samsung Electronics Co., Ltd.Method for connecting to server devices in browser-based home network apparatus therefor
US6870818B1 (en)*1998-05-262005-03-22Thomson Licensing S.A.Method for identifying devices in a communication network and device for implementing said method
US6754184B2 (en)*1998-06-262004-06-22Sony CorporationInformation processing apparatus and method, and distribution medium
US6618361B1 (en)*1998-07-042003-09-09Samsung Electronics Co., Ltd.Method of resetting bus for network connected by IEEE 1394 bus
US6286071B1 (en)*1998-07-092001-09-04Sony CorporationCommunication control method, communication system and electronic device used therefor
US9055319B2 (en)1998-07-142015-06-09Rovi Guides, Inc.Interactive guide with recording
US9118948B2 (en)1998-07-142015-08-25Rovi Guides, Inc.Client-server based interactive guide with server recording
US9154843B2 (en)1998-07-142015-10-06Rovi Guides, Inc.Client-server based interactive guide with server recording
US10075746B2 (en)1998-07-142018-09-11Rovi Guides, Inc.Client-server based interactive television guide with server recording
US9232254B2 (en)1998-07-142016-01-05Rovi Guides, Inc.Client-server based interactive television guide with server recording
US9055318B2 (en)1998-07-142015-06-09Rovi Guides, Inc.Client-server based interactive guide with server storage
US9021538B2 (en)1998-07-142015-04-28Rovi Guides, Inc.Client-server based interactive guide with server recording
US9226006B2 (en)1998-07-142015-12-29Rovi Guides, Inc.Client-server based interactive guide with server recording
US6810453B2 (en)*1998-10-152004-10-26Pioneer CorporationInformation transmitting apparatus and method, information receiving apparatus and method, and information transmitting/receiving apparatus and method
US20030056045A1 (en)*1998-10-152003-03-20Pioneer CorporationInformation transmitting apparatus and method, information receiving apparatus and method, and information transmitting/receiving apparatus and method
US6658474B2 (en)*1998-11-262003-12-02Samsung Electronics Co., Ltd.Home network system and method of allocating node identification
US9311405B2 (en)1998-11-302016-04-12Rovi Guides, Inc.Search engine for video and graphics
US7886324B1 (en)*1998-12-222011-02-08Sony CorporationReceiving system for digital broadcasting and receiving apparatus for digital broadcasting
US6894986B2 (en)*1998-12-282005-05-17Pioneer CorporationTransmission managing apparatus for managing a transmission state of information
US20030206555A1 (en)*1998-12-282003-11-06Makoto MatsumaruTransmission managing apparatus information processing apparatus and information transmitting system
US6594239B1 (en)*1998-12-282003-07-15Pioneer CorporationTransmission managing apparatus, information processing apparatus and information transmitting system
US6542474B1 (en)*1999-02-262003-04-01Sony CorporationSystem and method for incrementally updating remote element lists in an electronic network
US6738816B1 (en)*1999-03-092004-05-18Nec CorporationSystem and method for reliable real-time communications among a plurality of nodes having functions conforming to IEEE-1394 serial bus and participating in a session of sharing the maximum bandwidth
US6584539B1 (en)*1999-03-192003-06-24Sony CorporationMethod and system for message broadcast flow control on a bus bridge interconnect
US6810452B1 (en)1999-03-192004-10-26Sony CorporationMethod and system for quarantine during bus topology configuration
US7336624B2 (en)*1999-04-122008-02-26Intel CorporationBroadcast discovery in a network having one or more 1394 buses
US6466549B1 (en)*1999-04-122002-10-15Intel CorporationBroadcast discovery in a network having one or more 1394 buses
US20060062158A1 (en)*1999-04-122006-03-23Hattig Myron PBroadcast discovery in a network having one or more 1394 buses
US8572224B2 (en)1999-04-292013-10-29Thomas D. HiteInternet control system communication protocol, method and computer program
US7673030B2 (en)1999-04-292010-03-02Amx LlcInternet control system communication protocol, method and computer program
US7213061B1 (en)1999-04-292007-05-01Amx LlcInternet control system and method
US7203778B2 (en)*1999-05-042007-04-10Apple Inc.Method and system for notifying clients of a specific change in a data processing system
US6925513B1 (en)*1999-05-042005-08-02Apple Computer, Inc.USB device notification
US20070150628A1 (en)*1999-05-042007-06-28Clark Thomas CUSB device notification
US7430620B2 (en)1999-05-042008-09-30Apple Inc.Change notification in USB devices
US20090037613A1 (en)*1999-05-042009-02-05Clark Thomas CChange notification in USB devices
US7899952B2 (en)*1999-05-042011-03-01Apple Inc.Change notification in USB devices
US6581102B1 (en)*1999-05-272003-06-17International Business Machines CorporationSystem and method for integrating arbitrary isochronous processing algorithms in general media processing systems
US6694363B1 (en)*1999-06-042004-02-17Kabushiki Kaisha ToshibaNetwork equipment and networking method
US7426702B2 (en)1999-06-082008-09-16Amx LlcSystem and method for multimedia display
US6865596B1 (en)*1999-06-092005-03-08Amx CorporationMethod and system for operating virtual devices by master controllers in a control system
US6430629B1 (en)*1999-06-102002-08-06Sony CorporationMethods and apparatus for monitoring a 1394 home network
US6671759B1 (en)*1999-06-182003-12-30Sony CorporationApparatus and method for mapping IEEE 1394 node IDS to unchanging node unique IDS to maintain continuity across bus resets
US7187661B2 (en)*1999-06-212007-03-06Intel CorporationGathering of device discovery information
US20050102453A1 (en)*1999-06-212005-05-12Intel CorporationGathering of device discovery information
US6775244B1 (en)*1999-06-212004-08-10Intel CorporationGathering of device discovery information
US6885631B1 (en)*1999-07-012005-04-26Samsung Electronics Co., Ltd.Connection management method for digital interface
US6977887B1 (en)1999-07-092005-12-20Apple Computer, Inc.Method and apparatus for loop breaking on a serial bus
US7583656B1 (en)1999-07-092009-09-01Apple Inc.Method and apparatus for loop breaking on a serial bus
US6628607B1 (en)1999-07-092003-09-30Apple Computer, Inc.Method and apparatus for loop breaking on a serial bus
US7032024B1 (en)*1999-07-292006-04-18Samsung Electronics Co., Ltd.Connection management method for devices connected digital interface and command structure therefor
US7068822B2 (en)*1999-08-092006-06-27Cross Match Technologies, Inc.System and method for sending a packet with position address and line scan data over an interface cable
US20060002314A1 (en)*1999-08-312006-01-05Canon Kabushiki KaishaInformation communication system, information communication method, information signal processing device and information signal processing method, and storage medium
US7545822B2 (en)*1999-08-312009-06-09Canon Kabushiki KaishaInformation communication system, information communication method, information signal processing device and information signal processing method, and storage medium
US7130315B1 (en)1999-09-102006-10-31Sony CorporationMethod of and apparatus for utilizing extended AV/C command and response frames including transaction label and common result/error code
WO2001022237A1 (en)*1999-09-212001-03-29Sony Electronics, Inc.A method and system for the simplification of leaf-limited bridges
US6633943B1 (en)1999-09-212003-10-14Sony CorporationMethod and system for the simplification of leaf-limited bridges
US6910090B1 (en)1999-09-212005-06-21Sony CorporationMaintaining communications in a bus bridge interconnect
US8667023B2 (en)1999-10-282014-03-04Apple Inc.General purpose data container method and apparatus for implementing AV/C descriptors
US8250100B2 (en)1999-10-282012-08-21Apple Inc.General purpose data container method and apparatus for implementing AV/C descriptors
US7574650B1 (en)1999-10-282009-08-11Apple Inc.General purpose data container method and apparatus for implementing AV/C descriptors
US7353322B1 (en)1999-11-012008-04-01Apple Inc.System and method for providing dynamic configuration ROM using double image buffers
US8762446B1 (en)1999-11-022014-06-24Apple Inc.Bridged distributed device control over multiple transports method and apparatus
US7191266B1 (en)*1999-11-022007-03-13Apple Computer, Inc.Method and apparatus for supporting and presenting multiple serial bus nodes using distinct configuration ROM images
US7506088B2 (en)1999-11-022009-03-17Apple Inc.Method and apparatus for supporting and presenting multiple serial bus nodes using distinct configuration ROM images
US6813663B1 (en)1999-11-022004-11-02Apple Computer, Inc.Method and apparatus for supporting and presenting multiple serial bus nodes using distinct configuration ROM images
US7389371B2 (en)*1999-11-052008-06-17Apple Inc.Method and apparatus for loop breaking in a data bus
US20050117528A1 (en)*1999-11-052005-06-02Apple Computer, Inc.Method and apparatus for preventing loops in a full-duplex bus
US6636914B1 (en)1999-11-052003-10-21Apple Computer, Inc.Method and apparatus for arbitration and fairness on a full-duplex bus using dual phases
US6587904B1 (en)*1999-11-052003-07-01Apple Computer, Inc.Method and apparatus for preventing loops in a full-duplex bus
US8140729B2 (en)1999-11-052012-03-20Apple Inc.Method and apparatus for arbitration on a full-duplex bus using dual phases
US6985981B1 (en)1999-11-052006-01-10Apple Computer, Inc.Method and apparatus for preventing loops in a full-duplex bus
US7194564B2 (en)1999-11-052007-03-20Apple Computer, Inc.Method and apparatus for preventing loops in a full-duplex bus
US6842805B1 (en)1999-11-052005-01-11Apple Computer, Inc.Method and apparatus for preventing loops in a full-duplex bus
US7650452B2 (en)1999-11-052010-01-19Apple Inc.Method and apparatus for arbitration and fairness on a full-duplex bus using dual phases
US8473660B2 (en)1999-11-052013-06-25Apple Inc.Method and apparatus for arbitration on a data bus
US6865632B1 (en)1999-11-052005-03-08Apple Computer, Inc.Method and apparatus for arbitration and fairness on a full-duplex bus using dual phases
US6839791B2 (en)1999-11-162005-01-04Apple Computer, Inc.Method and apparatus for accelerating detection of serial bus device speed signals
US7096302B2 (en)1999-11-162006-08-22Apple Computer, Inc.Method and apparatus for accelerating detection of serial bus device speed signals
US20050114582A1 (en)*1999-11-162005-05-26Apple Computer, Inc.Method and apparatus for accelerating detection of serial bus device speed signals
US6728821B1 (en)1999-11-292004-04-27Sony CorporationMethod and system for adjusting isochronous bandwidths on a bus
US6904022B2 (en)*1999-12-202005-06-07Seiko Epson CorporationData transfer control device, information storage medium and electronic equipment
US20010042141A1 (en)*1999-12-202001-11-15Kosuke MatsunagaData transfer control device, information storage medium and electronic equipment
US7490174B2 (en)2000-01-182009-02-10Apple Inc.Method and apparatus for border node behavior on a full-duplex bus
US7280490B1 (en)2000-01-182007-10-09Apple Inc.Method and apparatus for border node behavior on a full-duplex bus
US7352708B1 (en)2000-01-182008-04-01Apple Inc.Method and apparatus for border node behavior on a full-duplex bus
US7266617B1 (en)2000-01-182007-09-04Apple Inc.Method and apparatus for border node behavior on a full-duplex bus
US7822898B2 (en)2000-01-182010-10-26Apple Inc.Method and apparatus for border node behavior on a full-duplex bus
US6639918B1 (en)2000-01-182003-10-28Apple Computer, Inc.Method and apparatus for border node behavior on a full-duplex bus
US7317694B1 (en)2000-01-182008-01-08Apple Inc.Method and apparatus for border node behavior on a full-duplex bus
US6891848B2 (en)2000-01-182005-05-10Apple Computer, Inc.Method and apparatus for border node behavior on a full-duplex bus
WO2001059959A1 (en)*2000-02-092001-08-16Sony Electronics Inc.HAVi-VHN BRIDGE SOLUTION
US7421507B2 (en)2000-02-162008-09-02Apple Inc.Transmission of AV/C transactions over multiple transports method and apparatus
US8295302B2 (en)2000-02-172012-10-23Apple Inc.Methods and apparatus for ensuring compatibility on a high performance serial bus
US6831928B1 (en)2000-02-172004-12-14Apple Computer, Inc.Method and apparatus for ensuring compatibility on a high performance serial bus
US7050453B1 (en)2000-02-172006-05-23Apple Computer, Inc.Method and apparatus for ensuring compatibility on a high performance serial bus
US7701966B2 (en)2000-02-172010-04-20Apple IncMethod and apparatus for ensuring compatibility on a high performance serial bus
US9215097B2 (en)2000-02-172015-12-15Apple, Inc.Methods and apparatus for ensuring compatibility on a high performance serial bus
WO2001063389A1 (en)*2000-02-252001-08-30Dreamhouse Software, Inc.Personal server technology
US20020010824A1 (en)*2000-04-072002-01-24Sumihiro OkawaElectronic equipment and method for processing digital serial data at bus initialization phase in interface unit
KR100339359B1 (en)*2000-04-072002-06-03구자홍method for reset processing in home network system
US8407535B2 (en)2000-04-212013-03-26Apple Inc.Method and apparatus for generating jitter test patterns on a high performance serial bus
US6618785B1 (en)2000-04-212003-09-09Apple Computer, Inc.Method and apparatus for automatic detection and healing of signal pair crossover on a high performance serial bus
US7401173B1 (en)2000-04-212008-07-15Apple Inc.Method and apparatus for automatic detection and healing of signal pair crossover on a high performance serial bus
US7861025B2 (en)2000-04-212010-12-28Apple Inc.Method and apparatus for automatic detection and healing of signal pair crossover on a high performance serial bus
US7058872B1 (en)2000-04-212006-06-06Apple Computer, Inc.Method and apparatus for generating jitter test patterns on a high performance serial bus
US9083525B2 (en)2000-04-212015-07-14Apple Inc.Method and apparatus for generating jitter test patterns on a high performance serial bus
US6718497B1 (en)2000-04-212004-04-06Apple Computer, Inc.Method and apparatus for generating jitter test patterns on a high performance serial bus
US6873889B2 (en)*2000-05-162005-03-29Robert Bosch GmbhMethod for integrating a device into a vehicle communications network
US20040015272A1 (en)*2000-05-162004-01-22Vasco VollmerMethod for integrating a device into a vehicle communications network
US6931593B1 (en)*2000-05-222005-08-16Gateway Inc.Automatic channel generation for home network systems
US20050210034A1 (en)*2000-06-062005-09-22Emware, Inc.Service provider for embedded devices using a message store
US8090811B2 (en)2000-06-062012-01-03Panasonic Electric Works Co., Ltd.Service provider for embedded devices using a message store
US20040006620A1 (en)*2000-06-062004-01-08Howard Michael L.Service provider for providing data, applications and services to embedded devices and for facilitating control and monitoring of embedded devices
US6601086B1 (en)*2000-06-062003-07-29Emware, Inc.Service provider for providing data, applications and services to embedded devices and for facilitating control and monitoring of embedded devices
US6647448B1 (en)2000-06-292003-11-11Sony CorporationMethod and apparatus for managing resource schedules in a peer to peer distributed networking environment
US20090259750A1 (en)*2000-06-302009-10-15Sony CorporationMethod of and apparatus for communicating data structures between devices in a networking environment
US7565427B2 (en)2000-06-302009-07-21Sony CorporationMethod of and apparatus for communicating data structures between devices in a networking environment
US6901444B1 (en)2000-06-302005-05-31Sony CorporationMethod of and apparatus for communicating data structures between devices in a networking environment
US20050172023A1 (en)*2000-06-302005-08-04Brelin Jon E.Method of and apparatus for communicating data structures between devices in a networking environment
US6757773B1 (en)2000-06-302004-06-29Sony CorporationSystem and method for determining support capability of a device coupled to a bus system
US8010665B2 (en)2000-06-302011-08-30Sony CorporationMethod of and apparatus for communicating data structures between devices in a networking environment
US20030058369A1 (en)*2000-08-182003-03-27Hideaki TakechiControl device, controlled device with passing-through function, controlled device, controlled method, medium and program
US20020083245A1 (en)*2000-08-232002-06-27Dennis Van De MeulenhofCommunication system and device
US7107372B2 (en)*2000-08-232006-09-12Koninklijke Philips ElectronicsCommunication system and device
US9307291B2 (en)2000-09-292016-04-05Rovi Technologies CorporationUser controlled multi-device media-on-demand system
US9497508B2 (en)2000-09-292016-11-15Rovi Technologies CorporationUser controlled multi-device media-on-demand system
US9161087B2 (en)2000-09-292015-10-13Rovi Technologies CorporationUser controlled multi-device media-on-demand system
US9294799B2 (en)2000-10-112016-03-22Rovi Guides, Inc.Systems and methods for providing storage of data on servers in an on-demand media delivery system
US8584184B2 (en)2000-10-112013-11-12United Video Properties, Inc.Systems and methods for relocating media
US8973069B2 (en)2000-10-112015-03-03Rovi Guides, Inc.Systems and methods for relocating media
US9462317B2 (en)2000-10-112016-10-04Rovi Guides, Inc.Systems and methods for providing storage of data on servers in an on-demand media delivery system
US8295208B2 (en)*2000-10-242012-10-23At&T Intellectual Property Ii, L.P.Method and system for providing communication control functionality at a remotely located site using a distributed feature architecture
US20090274281A1 (en)*2000-10-242009-11-05Eric CheungMethod and system for providing communication control functionality at a remotely located site using a distributed feature architecture
US9565317B2 (en)2000-10-242017-02-07At&T Intellectual Property Ii, L.P.Method and system for providing communication control functionality at a remotely located site using a distributed feature architecture
US9112950B2 (en)2000-10-242015-08-18At&T Intellectual Property Ii, L.P.Method and system for providing communication control functionality at a remotely located site using a distributed feature architecture
US7073000B2 (en)*2000-10-312006-07-04Canon Kabushiki KaishaCommunication system and communication control apparatus and method
US7363405B2 (en)2000-10-312008-04-22Canon Kabushiki KaishaCommunication control apparatus and method
US20030005106A1 (en)*2000-10-312003-01-02Takashi IsodaCommunication control apparatus and method
US7027411B1 (en)*2000-10-312006-04-11Hewlett-Packard Development Company, L.P.Method and system for identifying and processing changes to a network topology
US20030041195A1 (en)*2000-10-312003-02-27Takashi IsodaCommunication system and communication control apparatus and method
US6874012B1 (en)*2000-11-012005-03-29Sun Microsystems, Inc.System and method for a display device using a priority messaging protocol
US20020066015A1 (en)*2000-11-242002-05-30Matsushita Electric Industrial Co., Ltd.Data transmit/receive device and data transmit/receive method
US6988200B2 (en)2000-11-242006-01-17Matsushita Electric Industrial Co., Ltd.Data transmit/receive device and data transmit/receive method
US20020097260A1 (en)*2000-12-132002-07-25Yuji IgataAppliance information transmitting/receiving method and appliance information transmitting/receiving system
US20040090925A1 (en)*2000-12-152004-05-13Thomas SchoeberlMethod for testing a network, and corresponding network
US7602736B2 (en)*2000-12-152009-10-13Robert Bosch GmbhMethod for testing a network, and corresponding network
US20020093977A1 (en)*2001-01-122002-07-18Pioneer CorporationData transmission/ reception system, connection restoring method and information transmission/ reception apparatus
US7227846B2 (en)*2001-01-122007-06-05Pioneer CorporationData transmission/ reception system, connection restoring method and information transmission/ reception apparatus
US6768926B2 (en)*2001-02-022004-07-27Hitachi, Ltd.Controller, controlled device, control method, and control system
US20030208623A1 (en)*2001-02-272003-11-06Masataka MaedaAppliance number setting member for home network system
US20020122068A1 (en)*2001-03-012002-09-05Taizo TsuruokaEntertainment device, menu display method, and information recording medium
US20020161865A1 (en)*2001-04-252002-10-31Gateway, Inc.Automated network configuration of connected device
US20020194596A1 (en)*2001-06-182002-12-19Srivastava Gopal K.Control of multiple AV-devices by a single master controller using infrared transmitted commands and bus transmitted commands
US20040169662A1 (en)*2001-06-222004-09-02Uwe RiemannArrangement of icons of network components on a screen
US20030135859A1 (en)*2001-07-192003-07-17Daniel PuttermanHome media network
US7574723B2 (en)*2001-07-192009-08-11Macrovision CorporationHome media network
US20030048757A1 (en)*2001-08-012003-03-13Jean-Paul AccarieMethod for the processing of remote control signals within a home audiovisual network, corresponding signal, devices and computer program
US7676824B2 (en)*2001-08-012010-03-09Canon Europa NvMethod for the processing of remote control signals within a home audiovisual network, corresponding signal, devices and computer program
US20030061427A1 (en)*2001-09-212003-03-27O'donnell Ciaran GerardScalable home control platform and architecture
US7257661B2 (en)*2001-09-212007-08-14Nxp B.V.Scalable home control platform and architecture
US20030070015A1 (en)*2001-10-042003-04-10Sony CorporationMethod of and apparatus for cancelling a pending AV/C notify command
US6944704B2 (en)2001-10-042005-09-13Sony CorporationMethod and apparatus for utilizing extended AV/C command frames including status inquiry, notify inquiry and control inquiry command types
US20030069960A1 (en)*2001-10-042003-04-10Symons Julie A.Method for describing and comparing data center physical and logical topologies and device configurations
US7003604B2 (en)2001-10-042006-02-21Sony CorporationMethod of and apparatus for cancelling a pending AV/C notify command
US20030070028A1 (en)*2001-10-042003-04-10Sony CorporationMethod and apparatus for utilizing extended AV/C command frames including status inquiry, notify inquiry and control inquiry command types
US8769181B2 (en)2001-10-172014-07-01Jinsalas Solutions, LlcMulti-port system and method for routing a data element within an interconnection fabric
US20100169533A1 (en)*2001-10-172010-07-01Brocco Lynne MMulti-port system and method for routing a data element within an interconnection fabric
US8402197B2 (en)2001-10-172013-03-19Jinsalas Solutions, LlcMulti-port system and method for routing a data element within an interconnection fabric
US8006024B2 (en)2001-10-172011-08-23Jinsalas Solutions, LlcMulti-port system and method for routing a data element within an interconnection fabric
US20030126220A1 (en)*2001-12-272003-07-03James WanlessQuick reply codes for communication of information between electronic devices
US20030131101A1 (en)*2002-01-092003-07-10Kyoung-Woo LeeMethod for deciding network manager in home network
US7568024B2 (en)*2002-01-092009-07-28Lg Electronics Inc.Method for deciding network manager in home network
US20040174827A1 (en)*2002-04-032004-09-09Makoto SatoSignal processing system, signal receiving device, and communication control method
US7372821B2 (en)*2002-04-032008-05-13Sony CorporationSignal processing system, signal receiving device, and communication control method
US7181511B1 (en)*2002-04-152007-02-20Yazaki North America, Inc.System and method for using software objects to manage devices connected to a network in a vehicle
US20050240660A1 (en)*2002-05-202005-10-27Katsutoshi SakaoInformation-processing system, information-processing device, and information-processing method
US8156525B2 (en)*2002-05-202012-04-10Sony CorporationInformation-processing system, information-processing device, and information-processing method
US8561124B2 (en)2002-05-202013-10-15Sony CorporationInformation-processing system, information-processing apparatus, and information-processing method
US7305680B2 (en)*2002-08-132007-12-04Sharp Laboratories Of America, Inc.Listening module for asynchronous messages sent between electronic devices of a distributed network
US20050043019A1 (en)*2002-08-292005-02-24Hitoshi NakamuraCommunication device, communication control method, and program
US7949731B2 (en)*2002-08-292011-05-24Sony CorporationCommunication apparatus, communication control method, and program for reading communication control information for removable storage media
US20040131044A1 (en)*2002-09-112004-07-08Mayhew David E.System and method for selecting fabric master
US7133955B2 (en)*2002-09-112006-11-07Stargen, Inc.System and method for selecting fabric master
US7224366B2 (en)2002-10-172007-05-29Amx, LlcMethod and system for control system software
USRE49505E1 (en)*2002-10-242023-04-25Intel CorporationServicing device aggregates
US20040088731A1 (en)*2002-11-042004-05-06Daniel PuttermanMethods and apparatus for client aggregation of media in a networked media system
US8931010B2 (en)2002-11-042015-01-06Rovi Solutions CorporationMethods and apparatus for client aggregation of media in a networked media system
US7417973B1 (en)2002-12-312008-08-26Apple Inc.Method, apparatus and computer program product for ensuring node participation in a network bus
US7457302B1 (en)2002-12-312008-11-25Apple Inc.Enhancement to loop healing for malconfigured bus prevention
US9369741B2 (en)2003-01-302016-06-14Rovi Guides, Inc.Interactive television systems with digital video recording and adjustable reminders
US9071872B2 (en)2003-01-302015-06-30Rovi Guides, Inc.Interactive television systems with digital video recording and adjustable reminders
US20040183827A1 (en)*2003-03-172004-09-23Daniel PuttermanMethods and apparatus for implementing a remote application over a network
US7213228B2 (en)2003-03-172007-05-01Macrovision CorporationMethods and apparatus for implementing a remote application over a network
US20040183756A1 (en)*2003-03-172004-09-23Pedro FreitasMethods and apparatus for rendering user interfaces and display information on remote client devices
CN1322411C (en)*2003-03-312007-06-20微软公司Peripheral equipment driving program maintenance method of network peripheral equipment
US20060209848A1 (en)*2003-04-172006-09-21Helmut BurklinMethod for the tranmission of buss ieee 1394 reinitialization messages and device for carrying out said method
US20040255339A1 (en)*2003-06-132004-12-16Apple Computer, IncSynchronized transmission of audio and video data from a computer to a client via an interface
US7353284B2 (en)2003-06-132008-04-01Apple Inc.Synchronized transmission of audio and video data from a computer to a client via an interface
US7970926B2 (en)2003-06-132011-06-28Apple Inc.Synchronized transmission of audio and video data from a computer to a client via an interface
US7668099B2 (en)2003-06-132010-02-23Apple Inc.Synthesis of vertical blanking signal
US8838825B2 (en)2003-06-132014-09-16Apple Inc.Synchronized transmission of audio and video data from a computer to a client via an interface
US20040252231A1 (en)*2003-06-132004-12-16Apple Computer, Inc.Synthesis of vertical blanking signal
US8275910B1 (en)2003-07-022012-09-25Apple Inc.Source packet bridge
US9026680B2 (en)2003-07-022015-05-05Apple Inc.Source packet bridge
US20130311884A1 (en)*2003-08-072013-11-21Samsung Electronics Co., Ltd.Audio/video device, apparatus and method for controlling audio/video device
US9342141B2 (en)*2003-08-072016-05-17Samsung Electronics Co., Ltd.Audio/video device, apparatus and method for controlling audio/video device
US20080126936A1 (en)*2003-08-212008-05-29Gary WilliamsElectronic/software multimedia library control system and methods of use thereof
US7975201B2 (en)2003-11-182011-07-05Apple Inc.Symbol encoding for tolerance to single byte error
US7788567B1 (en)2003-11-182010-08-31Apple Inc.Symbol encoding for tolerance to single byte errors
US8321748B2 (en)2003-11-182012-11-27Apple Inc.Symbol encoding for tolerance to single byte errors
US8607117B2 (en)2003-11-182013-12-10Apple Inc.Symbol encoding for tolerance to single byte errors
US7995606B1 (en)2003-12-032011-08-09Apple Inc.Fly-by and ack-accelerated arbitration for broadcast packets
US7237135B1 (en)2003-12-292007-06-26Apple Inc.Cyclemaster synchronization in a distributed bridge
US8392742B2 (en)2003-12-292013-03-05Apple Inc.Cyclemaster synchronization in a distributed bridge
US7987381B2 (en)2003-12-292011-07-26Apple Inc.Cyclemaster synchronization in a distributed bridge
US7308517B1 (en)2003-12-292007-12-11Apple Inc.Gap count analysis for a high speed serialized bus
US7734855B2 (en)2003-12-292010-06-08Apple Inc.Gap count analysis for the P1394a BUS
US20050207352A1 (en)*2004-03-182005-09-22AlcatelMethod for identifying a control element
US7417958B2 (en)*2004-03-182008-08-26AlcatelMethod for identifying a control element
US7712111B2 (en)2004-06-082010-05-04Covia Labs, Inc.Method and system for linear tasking among a plurality of processing units
US20050289558A1 (en)*2004-06-082005-12-29Daniel IllowskyDevice interoperability runtime establishing event serialization and synchronization amongst a plurality of separate processing units and method for coordinating control data and operations
US20060206882A1 (en)*2004-06-082006-09-14Daniel IllowskyMethod and system for linear tasking among a plurality of processing units
CN1965539B (en)*2004-06-302011-07-20汤姆森许可贸易公司Method for providing a table of station-specific information in a network of distributed stations, and network station for carrying out the method
US20110099178A1 (en)*2004-06-302011-04-28Frank GlaeserMethod for providing a table of station-specific information in a network of distributed stations, and network station for carrying out the method
US7631042B2 (en)2004-06-302009-12-08International Business Machines CorporationMethod to update status on multiple voice and text systems from a single device
US20060031470A1 (en)*2004-06-302006-02-09International Business Machines CorporationMethod to update status on multiple voice and text systems from a single device
US20080275986A1 (en)*2004-06-302008-11-06Yen-Fu ChenMethod to Update Status on Multiple Voice and Text Systems from a Single Device
US8233407B2 (en)*2004-06-302012-07-31Thomson LicensingMethod for providing a table of station-specific information in a network of distributed stations, and network station for carrying out the method
US8086575B2 (en)2004-09-232011-12-27Rovi Solutions CorporationMethods and apparatus for integrating disparate media formats in a networked media system
US11288949B2 (en)2005-01-052022-03-29Rovi Guides, Inc.Methods and apparatus for providing notifications in a media system
US7768388B2 (en)2005-01-052010-08-03Rovi Solutions CorporationMethods and apparatus for providing notifications in a media system
US20070210908A1 (en)*2005-01-052007-09-13Daniel PuttermanMethods and apparatus for providing notifications in a media system
US11776384B2 (en)2005-01-052023-10-03Rovi Guides, Inc.Methods and apparatus for providing notifications in a media system
US9747783B2 (en)2005-01-052017-08-29Rovi Guides, Inc.Methods and apparatus for providing notifications in a media system
US10692360B2 (en)2005-01-052020-06-23Rovi Guides, Inc.Methods and apparatus for providing notifications in a media system
US20070160022A1 (en)*2005-06-092007-07-12Whirlpool CorporationSoftware architecture system and method for discovering components within an appliance using fuctionality identifiers
US8155120B2 (en)*2005-06-092012-04-10Whirlpool CorporationSoftware architecture system and method for discovering components within an appliance using fuctionality identifiers
US20090103535A1 (en)*2005-06-092009-04-23Whirlpool CorporationSoftware Architecture System And Method For Communication With, And Management Of, Components Within An Appliance Utilizing Functionality Identifiers
US8345686B2 (en)*2005-06-092013-01-01Whirlpool CorporationSoftware architecture system and method for communication with, and management of, components within an appliance utilizing functionality identifiers
US9264252B2 (en)2005-06-092016-02-16Whirlpool CorporationClient for an appliance network
US20090132070A1 (en)*2005-06-092009-05-21Whirlpool CorporationClient for an appliance network
US8412752B2 (en)2005-07-012013-04-02Qnx Software Systems LimitedFile system having transaction record coalescing
US8051114B2 (en)2005-07-012011-11-01Qnx Software Systems LimitedOptimized startup verification of file system integrity
US8667029B2 (en)2005-07-012014-03-04Qnx Software Systems LimitedOptimized startup verification of file system integrity
US8959125B2 (en)2005-07-012015-02-17226008 Ontario Inc.File system having inverted hierarchical structure
US9063739B2 (en)2005-09-072015-06-23Open Invention Network, LlcMethod and computer program for device configuration
US20070150817A1 (en)*2005-12-232007-06-28Ducheneaut Nicolas BUser interface and method for composing services in a ubiquitous computing environment through direction and selection operators
US20070147351A1 (en)*2005-12-272007-06-28Brad DietrichMethods and apparatus for integrating media across a wide area network
US12363394B2 (en)2005-12-272025-07-15Adeia Solutions LlcMethods and apparatus for integrating media across a wide area network
US9467322B2 (en)2005-12-272016-10-11Rovi Solutions CorporationMethods and apparatus for integrating media across a wide area network
US8607287B2 (en)2005-12-292013-12-10United Video Properties, Inc.Interactive media guidance system having multiple devices
US9681105B2 (en)2005-12-292017-06-13Rovi Guides, Inc.Interactive media guidance system having multiple devices
US20070214277A1 (en)*2006-03-072007-09-13Ahmed Ali UPeer-to-peer network communications using SATA/SAS technology
US20100049896A1 (en)*2006-03-072010-02-25Agere Systems Inc.Peer-to-peer network communications using sata/sas technology
US8046481B2 (en)*2006-03-072011-10-25Agere Systems Inc.Peer-to-peer network communications using SATA/SAS technology
US7929551B2 (en)2006-06-012011-04-19Rovi Solutions CorporationMethods and apparatus for transferring media across a network using a network interface device
US9621605B2 (en)2006-06-012017-04-11Rovi Solutions CorporationMethods and apparatus for providing media from content providers using a network interface device
US20070283046A1 (en)*2006-06-012007-12-06Bradley DietrichMethods and apparatus for providing media from content providers using a network interface device
US20070282969A1 (en)*2006-06-012007-12-06Bradley DietrichMethods and apparatus for transferring media across a network using a network interface device
US8566503B2 (en)2006-08-252013-10-22Qnx Software Systems LimitedMultimedia filesystem having unified representation of content on diverse multimedia devices
US8122178B2 (en)2006-08-252012-02-21Qnx Software Systems LimitedFilesystem having a filename cache
US20080162415A1 (en)*2006-12-282008-07-03Sap AgSoftware and method for utilizing a common database layout
US8959117B2 (en)2006-12-282015-02-17Sap SeSystem and method utilizing a generic update module with recursive calls
US7730056B2 (en)*2006-12-282010-06-01Sap AgSoftware and method for utilizing a common database layout
US8606799B2 (en)2006-12-282013-12-10Sap AgSoftware and method for utilizing a generic database query
US8103363B2 (en)*2007-01-312012-01-24Hewlett-Packard Development Company, L.P.Device control system
US20080183309A1 (en)*2007-01-312008-07-31Beers Ted WDevice control system
US8107469B2 (en)2007-03-152012-01-31Microsoft CorporationEnabling routing of data on a network based on a portion of data accessed from a non-network enabled device
US20080225827A1 (en)*2007-03-152008-09-18Microsoft CorporationEnabling routing of data on a network based on a portion of data accessed from a non-network enabled device
US20080225869A1 (en)*2007-03-152008-09-18Microsoft CorporationEnabling sharing of devices on a network
US20080225828A1 (en)*2007-03-152008-09-18Microsoft CorporationEnabling routing of data on a network
US8971319B2 (en)2007-03-152015-03-03Microsoft CorporationEnabling routing of data on a network based on a portion of data accessed from a non-network enabled device
US8094037B2 (en)2007-03-302012-01-10Sony CorporationMethod and apparatus for identifying an electronic appliance
US20080238653A1 (en)*2007-03-302008-10-02Sony Corporation, A Japanese CorporationMethod and apparatus for identifying an electronic appliance
US9326016B2 (en)2007-07-112016-04-26Rovi Guides, Inc.Systems and methods for mirroring and transcoding media content
US20090198842A1 (en)*2008-01-312009-08-06Jeevan BasavarajuSystem And Method For Identifying Lost/Stale Hardware In A Computing System
US8209443B2 (en)*2008-01-312012-06-26Hewlett-Packard Development Company, L.P.System and method for identifying lost/stale hardware in a computing system
US9414120B2 (en)2008-06-132016-08-09Rovi Guides, Inc.Systems and methods for displaying media content and media guidance information
US10063934B2 (en)2008-11-252018-08-28Rovi Technologies CorporationReducing unicast session duration with restart TV
USRE50355E1 (en)2008-11-252025-03-25Adeia Technologies Inc.Reducing unicast session duration with restart TV
US9014546B2 (en)2009-09-232015-04-21Rovi Guides, Inc.Systems and methods for automatically detecting users within detection regions of media devices
US10631066B2 (en)2009-09-232020-04-21Rovi Guides, Inc.Systems and method for automatically detecting users within detection regions of media devices
US11216235B2 (en)2010-01-282022-01-04Intel CorporationMessage passing framework for audio/video streaming in a topology of devices
US11900003B2 (en)2010-01-282024-02-13Intel CorporationMessage passing framework for audio/video streaming in a topology of devices
US20110184965A1 (en)*2010-01-282011-07-28Srikanth KambhatlaIdentifying Devices in a Topology of Devices for Audio/Video Streaming
US9378172B2 (en)*2010-01-282016-06-28Intel CorporationIdentifying devices in a topology of devices for audio/video streaming
US20110231862A1 (en)*2010-03-192011-09-22At&T Mobility Ii LlcAgnostic execution cluster for an agnostic execution environment
US8732727B2 (en)2010-03-192014-05-20At&T Mobility Ii LlcAgnostic execution cluster for an agnostic execution environment
US8484661B2 (en)*2010-03-192013-07-09At&T Mobility Ii LlcAgnostic execution cluster for an agnostic execution environment
US20110265111A1 (en)*2010-04-262011-10-27Cox Communications, Inc.Broadcast Remote Control
US8826312B2 (en)*2010-04-262014-09-02Cox Communications, Inc.Broadcast remote control
US10153968B2 (en)2010-08-132018-12-11At&T Mobility Ii LlcCarrier-driven bearer path selection
US9107140B2 (en)2010-08-132015-08-11At&T Mobility Ii LlcCarrier-driven bearer path selection
US9125169B2 (en)2011-12-232015-09-01Rovi Guides, Inc.Methods and systems for performing actions based on location-based rules
US9674563B2 (en)2013-11-042017-06-06Rovi Guides, Inc.Systems and methods for recommending content
US20150261861A1 (en)*2014-03-122015-09-17Futurewei Technologies, Inc.Framework for Composing Real-Time Media Using a Declarative Mark-Up Language
US20220407869A1 (en)*2015-12-212022-12-22Nagravision S.A.Secured home network
US11838315B2 (en)*2015-12-212023-12-05Nagravision S.A.Secured home network
US11196837B2 (en)2019-03-292021-12-07Intel CorporationTechnologies for multi-tier prefetching in a context-aware edge gateway
US12132805B2 (en)2019-03-292024-10-29Intel CorporationTechnologies for multi-tier prefetching in a context-aware edge gateway
US12034597B2 (en)2019-04-302024-07-09Intel CorporationMethods and apparatus to control processing of telemetry data at an edge platform
US11184236B2 (en)2019-04-302021-11-23Intel CorporationMethods and apparatus to control processing of telemetry data at an edge platform
US11507545B2 (en)*2020-07-302022-11-22EMC IP Holding Company LLCSystem and method for mirroring a file system journal
US11669501B2 (en)2020-10-292023-06-06EMC IP Holding Company LLCAddress mirroring of a file system journal
WO2023010848A1 (en)*2021-08-052023-02-09青岛海信日立空调系统有限公司Central air-conditioning control system

Also Published As

Publication numberPublication date
EP0929170A3 (en)2003-11-12
EP0929170A2 (en)1999-07-14
JPH11317751A (en)1999-11-16

Similar Documents

PublicationPublication DateTitle
US6160796A (en)Method and system for updating device identification and status information after a local bus reset within a home audio/video network
US6038625A (en)Method and system for providing a device identification mechanism within a consumer audio/video network
US6694349B1 (en)Method and system for message dispatching in a home audio/video network
US6349352B1 (en)Home audio/video network with both generic and parameterized device control
EP1044536B1 (en)A home audio/video network
EP1046259B1 (en)Method and system related to an audio/video network
US6085236A (en)Home audio video network with device control modules for incorporating legacy devices
EP1076961B1 (en)Media manager for controlling autonomous media devices within a network environment
KR100570326B1 (en) Method and system for electronic communication
US6366964B1 (en)Method of and apparatus for dynamically enumerating objects representing devices within an IEEE 1394 serial bus networking
EP1046258A2 (en)An audio/video device
WO2000026876A1 (en)Apparatus and method pertaining to internal connections in an audio/video system
US6684401B1 (en)Method and system for independent incoming and outgoing message dispatching in a home audio/video network
HK1020127A (en)Methods, systems and apparatus for providing device status information within a communication network
HK1020128A (en)Methods, systems and apparatus for providing device identification within a network
US7284259B1 (en)Transmitting method, transmitting system and transmission control device

Legal Events

DateCodeTitleDescription
ASAssignment

Owner name:SONY ELECTRONICS, INC., NEW JERSEY

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ZOU, FENG (FRANK);REEL/FRAME:009134/0539

Effective date:19980408

Owner name:SONY CORPORATION OF JAPAN, JAPAN

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ZOU, FENG (FRANK);REEL/FRAME:009134/0539

Effective date:19980408

FPAYFee payment

Year of fee payment:4

FPAYFee payment

Year of fee payment:8

REMIMaintenance fee reminder mailed
LAPSLapse for failure to pay maintenance fees
LAPSLapse for failure to pay maintenance fees

Free format text:PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCHInformation on status: patent discontinuation

Free format text:PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FPLapsed due to failure to pay maintenance fee

Effective date:20121212

ASAssignment

Owner name:SONY CORPORATION, JAPAN

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SONY CORPORATION OF JAPAN;REEL/FRAME:045208/0908

Effective date:20180131


[8]ページ先頭

©2009-2025 Movatter.jp