1. Field of the Disclosure
This disclosure pertains in general to data communications, and more specifically to the communication of remote control commands from a remote control to a device in a system of devices.
2. Description of the Related Art
A remote control is used to change the behavior of the device paired with the remote control. However, in systems including a plurality of devices connected to one another, it is difficult to use a remote control to control all of the devices. One solution for controlling multiple devices with a remote includes passing through or tunneling remote control commands from one device to another. However, pass through is not appropriate in a multi-streaming environment when a source device is streaming to multiple sink devices and does not allow for proper decision making on remote control forwarding when many devices are connected to each other.
Embodiments of the present disclosure are related to the handling and communication of remote control commands received by a system of devices. In one embodiment, a first device, such as a sink device, propagates to a second device, such as a source device, via a multimedia link, an address of the first device in association with an indication that the first device is a master for a remote control command type. The indication may indicate that the first device is a master for graphical user interface (GUI) remote control commands, playback control commands, or audio control commands. The second device may store the address of the first device and identify the address to be the address of the master for the remote control command type. The second device responsive to receiving a remote control command from a remote control identifies the remote control command type of the remote control command. Responsive to the command type of the received remote control command being the remote control command type that the first device is the master for, the second device forwards the received remote control command using the address of the first device. The first device upon receiving the remote control command may modify a multimedia output by the first device based on the remote control command received.
In one embodiment, a third device in the system of devices, propagates to the second device an address of the third device in associated with an indication that the third device is the master for another remote control type. The second device may receive another remote control command and upon determining that the command type of the other remote control command is that of the remote control command type that the third device is master for, forwards the other remote control command using the address of the third device. The second device may also propagate to the third device the address of the first device and the indication that the first device is the master for the type of remote control command. The third device upon receiving a remote control command from a remote control determines if the received remote control command is the remote control command type for which the first device is master. On determining that the received remote control command is the remote control command type that the first device is master for, the third device forwards to the second device the received remote control command and the address of the first device.
In one embodiment, a first device includes an interface circuit to communicate with a second device via a multimedia link and a wireless receiver to receive remote control commands from a remote control. The first device may receive from the second device an address of the second device in associated with an indication that the second device is master of a remote control command type. The first device upon receiving a remote control command from the remote control identifies a type of the remote control command. The first device forwards the received remote control command using the address of the second device upon identifying that the type of the received remote control command is the remote control command type for which the second device is master.
The teachings of the embodiments disclosed herein can be readily understood by considering the following detailed description in conjunction with the accompanying drawings.
Figure (
The Figures (FIG.) and the following description relate to various embodiments by way of illustration only. It should be noted that from the following discussion, alternative embodiments of the structures and methods disclosed herein will be readily recognized as viable alternatives that may be employed without departing from the principles discussed herein. Reference will now be made in detail to several embodiments, examples of which are illustrated in the accompanying figures. It is noted that wherever practicable similar or like reference numbers may be used in the figures and may indicate similar or like functionality.
The source device 110 transmits multimedia data streams (e.g., audio/video streams) and control data associated with the multimedia data streams to the intermediate devices 120 and 130, and the sink device 140 through the multimedia communication links 160. The devices in the system 100 together provide audio and visual data to a user of the system 100 in a plurality of forms. For example, source device 110 can be a blu-ray player that outputs multimedia streams, intermediate device 130 is an audio video receiver (AVR) or sound bar that receives audio streams from the source device 110 and converts the audio streams into audio, and sink device 140 is a television that receives video streams from the source device 110 and displays the video streams. Intermediate device 130 can be a repeater.
The devices in the system 100 exchange data using various protocols. In one embodiment, the multimedia communication links 160 represent Mobile High-Definition Link (MHL) cables. The MHL cables support differential signals transmitted via data lines, which form a single logical communication channel for carrying multimedia data streams. In some embodiments of MHL, there may be more than a single pair of differential data lines. In some versions of MHL, embedded common mode clocks are transmitted through the differential data lines. The MHL cables 160 may further include a control bus (CBUS), power, and ground. The CBUS carries data such as discovery data, configuration data and remote control commands.
In one embodiment, the multimedia communication links 160 represent a High Definition Multimedia Interface (HDMI) cable. The HDMI cables 160 supports differential signals transmitted via data lines. Each differential pair of lines forms a logical communication channel that carries multimedia data streams. The HDMI cables 160 may further include differential clock lines; Consumer Electronics Control (CEC) control bus; Display Data Channel (DDC) bus; power, ground; hot plug detect; and four shield lines for the differential signals.
The system 100 also includes remote controls 150a-c. Each remote control 150 transmits remote control commands to a respective one of the devices in the system 100. For example, the remote control 150b transmits an audio command to the sink device 140, which is forwarded to the intermediate device 120 and causes the intermediate device 120 to raise the volume of the audio output to the user. As another example, the remote control 150a may transmit an audio command to the source device 110, which is then forwarded to the intermediate device 120.
The remote control commands may be transmitted wirelessly, via infrared (IR) signals for example, to the devices by the remote control 150. In one embodiment, the remote control 150 includes a control device for processing input commands received from a user and generating one or more remote control commands based on the received input commands. For example, the user may press a button on the remote control 150b corresponding to an input command for incrementally increasing the volume output by the sink device 140. The control device included in the remote control generates a remote control command to be transmitted to the sink device 140b, the remote control command specifying the incremental increase in audio volume.
Embodiments of the present disclosure relate to a system that can support different control masters for different types of remote control commands. The control master is the device of the various devices in the system 100 that is assigned to handle a particular type of remote control command. The other devices on receiving the remote control command transmit the remote control command to the control master via one or more multimedia communication links 160. This provides the ability for each remote control to control all devices along a single logical connection. Also, in a multi-stream environment, one remote control (e.g. control 150c) can be used for control of devices along that logical connection and another remote control (e.g. control 150b) can be used for control of devices along another logical connection.
The user of the system 100 may assign the intermediate device 120 to be the control master for a remote control command type. Remote control commands can generally be divided into different types of commands. Examples of remote control command types include audio control commands (e.g., volume up/down and mute on/off), multimedia playback control commands (e.g., play, pause, rewind), and graphical user interface (GUI) commands (e.g., scroll left, right, up, down, enter and numbers in an on screen display OSD).
In the example of
Similarly, although not shown in
Referring now to
In the example of
Similarly, source device 110 receives a command 230 from the remote control 150a. Source device 110 identifies a type of this command 230, and determines that intermediate device 120 is the master for this command 230. Source device 110 then forwards the command and the address 240 to the intermediate device 120, which modifies its output in accordance with the command.
Examples of the processor 305 include a central processing unit (CPU), a graphics processing unit (GPU), a digital signal processor (DSP), one or more application specific integrated circuits (ASICs), one or more radio-frequency integrated circuits (RFICs), or any combination of these. The processor 305 is configured to communicate with the memory 310, the receiver interface 315, the transmitter interface 320, and the wireless receiver 325 via one or more busses.
In one embodiment, the memory 310 includes a non-transitory machine-readable medium on which is stored modules (e.g. software instructions) that are executed by the processor 305 to perform the methodologies or functions described herein. The modules may also reside, completely or at least partially, within the processor 305 (e.g., within a processor's cache memory) during execution thereof by the sink device 140, the memory 310 and the processor 305 also constituting non-transitory machine-readable media.
In one embodiment, the memory 310 includes a control setup module 330, a control master database 335, a command forwarding module 340, a control cancellation module 345, and a multimedia output module 350. In one embodiment, the control setup module 330 propagates a control setup signal notifying the other devices in the system environment 100 that the device 300 has been assigned as the control master for a remote control command type. The control setup signal may include the address associated with the device 300, an indication that the device 300 is the control master for the remote control command type for which the device 300 has been assigned as the control master. In some examples, the control setup signal also includes an identifier identifying the remote control command type. In one embodiment, the control setup module 330 generates the control setup signal, responsive to being assigned as the control master for the remote control command type by the user.
In one embodiment, the control setup module 330 manages control setup signals received by the device 300. For example, the control setup module 330, responsive to receiving a control setup signal, analyzes the control setup signal to identify the address associated with the other device and the type of remote control command for which the other device is the master. The control setup module 330 may store the address of the other device in the control master database 335 and associate the address with the identified remote control command type, thereby saving for future use the address of the control master for the identified remote control command type.
In the event that the device 300 has not received a control setup signal the control setup module 330 may identify a default device of the various devices in the system environment 100 as a control master for a specific remote control command type. In one embodiment, the control setup module 330 identifies the default device of the various devices in the system environment based on the capabilities of the device. For example, sink device 140 may be a television capable of displaying video data. The intermediate device 120 may be an AVR identifying that sink device 140 is capable of outputting video data and may identify the sink device 140 as the default device and control master for the video remote control command type. In another embodiment, the control setup module 330 may identify the device as the default control master for a remote control command type.
In one embodiment, the control setup module 330 is configured to route or forward control setup signals received from an external device connected to the device 300 to other devices 300 connected to the device. For example, assume device 300 is the intermediate device 130. The control setup module 330 may receive a control setup signal from intermediate device 120 identifying intermediate device 120 as the control master for the audio remote control command type. The control setup module 330 stores the address of intermediate device 120 in the control master database 335 in association with the audio remote control command type, thereby saving for future use the address of the control master associated with the audio remote control command type. The control setup module 330 may then forward or route the control setup signal to sink device 140, thereby notifying sink device 140 of intermediate device 120 being assigned as the control master for the audio remote control command type.
The control master database 335 stores information specifying addresses for the various devices in the system environment 100 that are currently assigned as the control master for various remote control command types. In one embodiment, the control master database 335 includes a table that stores an association between a target address and a remote control command type. The target address is the address of a device in the system environment 100 that is currently assigned as the control master for the remote control command type.
Returning now to the description of
In one embodiment, the command forwarding module 340 manages command forwarding signals received by the device 300. The command forwarding module 340 may receive a command forwarding signal including the address of the control master and the remote control command. The command forwarding module may then forward the command forwarding signal to the address of the control master or to an adjacent device connected to the device 300. In one example, the command forwarding module 340 may determine from analyzing a received command forwarding signal that the device 300 is the control master for the remote control command type. The command forwarding module 340 may then send the received remote control command to the multimedia output module 350 to modify the multimedia output by the device 300 based on the remote control command.
In on embodiment, the control cancellation module 345 propagates a control cancellation signal to the various devices in the system environment 100 notifying the various devices that the device 300 is no longer the control master for a remote control command type. In one example, the control cancellation signal includes the remote control command type and an indication that the device 300 is no longer the control master for the remote control command type.
In one embodiment, the control cancellation module 345 manages control cancellation signals received from other devices. The control cancellation module 345 responsive to receiving a control cancellation signal analyzes the control cancellation signal to identify the indication that an external device is no longer the control master for a remote control command type. The control cancellation module 345 may access the control master database 335 to identify the remote control command type identified in the control cancellation signal and erase the target address associated with the remote control command type, thereby disassociating the previous control master with the remote control command type.
The multimedia output module 350 formats and outputs multimedia to be presented to a user or to be transmitted to another device of the devices in the system environment. For example, the multimedia output module 350 may generate video data to be transmitted to an external device, such that the video data may be displayed to a user by the external device. The multimedia output module 350 modifies the multimedia stream output by the device 300 based on a remote control command received from the remote control 150. For example, the multimedia output module 350 modifies the volume of the audio data output by the device 300 responsive to receiving an audio remote control command. In one embodiment, the multimedia output module 350 receives a remote control command responsive to the command forwarding module 340 determining that the device 300 is the control master for the remote control command type associated with the remote control command.
The receiver interface 315 includes an interface circuit that is communicatively coupled to a multimedia link. The receiver interface 315 receives communications from external devices connected to the device 300 via a multimedia link 160. The multimedia link 160 includes a multimedia channel 360 for carrying a multimedia stream including audio data and video data, and a control channel 365 (e.g., CBUS, DDC) for carrying control codes, radio control commands, and signals associated with the setup and cancellation of a control master, and forwarding of remote control commands. The receiver interface 315 receives multimedia streams via the multimedia channel 360, and transmits or receives control setup signals, command forwarding signals, and control cancellation signals via the control channel 365.
The transmitter interface 320 includes an interface circuit that is communicatively coupled to another multimedia link. The transmitter interface 320 receives communications from devices connected to the device 300 via a multimedia link 160. The multimedia link 160 includes a multimedia channel 370 for carrying a multimedia stream including audio data and video data, and a control channel 375 for carrying control codes, radio control commands, and signals associated with the setup and cancellation of a control master, and forwarding of remote control commands. The transmitter interface 332 transmits multimedia streams via the multimedia channel 370, and transmits or receives control setup signals, command forwarding signals, and control cancellation signals via the control channel 375.
The wireless receiver 325 includes a circuit that receives wireless communications from the remote control 150. The wireless receiver 325 may be configured to receive a variety of wireless signals from the remote control 150, such as infrared (IR) signals or WiFi. The communications received by the wireless receiver 325 often include remote control commands generated by the remote control 150.
During the forward phase 510 the device receives remote control commands from the remote control 150 and forwards the remote control commands to the control master of the remote control command type associated with the received remote control commands. As described in conjunction with
During the cancellation phase 515 the device propagates a cancellation command signal to the other devices in the system environment 100, notifying the other devices that the device is no longer assigned as the control master for a remote control command type. As described in conjunction with
Upon reading this disclosure, those of skill in the art will appreciate still additional alternative designs for assigning a control master for a remote control command type amongst a system of devices. Thus, while particular embodiments and applications of the present disclosure have been illustrated and described, it is to be understood that the embodiments are not limited to the precise construction and components disclosed herein and that various modifications, changes and variations which will be apparent to those skilled in the art may be made in the arrangement, operation and details of the method and apparatus of the present disclosure disclosed herein without departing from the spirit and scope of the disclosure as defined in the appended claims.
This application claims priority from U.S. Provisional Patent Application No. 61/989,417, titled “Control Target Selection” filed on May 6, 2014, the contents of which are incorporated by reference herein in their entirety.
Number | Date | Country | |
---|---|---|---|
61989417 | May 2014 | US |