Traditionally, playback of digital media content (e.g., movies, music, pictures, games, etc.) has been constrained to the computing device (e.g., desktop computer, smartphone, tablet, wearable, gaming system, television, etc.) on which the digital media content was stored. However, with the advent of cloud computing related technologies and increased capabilities of computing devices, services such as digital media content transmission services (i.e., streaming, casting, mirroring, etc.) have spurred along the generation, sharing, and consumption of digital media content as consumer devices capable of interacting with such content have become ubiquitous. The desire to share digital media content between consumer interfacing computing devices, especially in a home environment, is increasing in tandem with the increased exposure of consumers to the digital media content and providers of such digital media content.
The introduction of stream-enabled computing devices has enabled digital media content to be streamed, casted, or mirrored from one computing device (e.g., a smartphone, a laptop, etc.) to another compatible computing device (e.g., a smart television, a speaker, etc.) directly, or indirectly, such as via a compatible hub, dongle, etc., connected to the other computing device. In other words, digital media content stored on one computing device can be transmitted to a receiving computing device and received/rendered at the receiving computing device. Present solutions allow manufacturer agnostic wireless streaming of the digital media content using various wireless communication technologies employed by computing devices supporting Wi-Fi®, Digital Living Network Alliance (DLNA), Bluetooth®, etc., via one-way transmission/reception. In other words, present solutions allow for one computing device to be setup as the local processor/transmitter of the content stream, while the other computing device is setup as a receiver device.
The concepts described herein are illustrated by way of example and not by way of limitation in the accompanying figures. For simplicity and clarity of illustration, elements illustrated in the figures are not necessarily drawn to scale. Where considered appropriate, reference labels have been repeated among the figures to indicate corresponding or analogous elements.
While the concepts of the present disclosure are susceptible to various modifications and alternative forms, specific embodiments thereof have been shown by way of example in the drawings and will be described herein in detail. It should be understood, however, that there is no intent to limit the concepts of the present disclosure to the particular forms disclosed, but on the contrary, the intention is to cover all modifications, equivalents, and alternatives consistent with the present disclosure and the appended claims.
References in the specification to “one embodiment,” “an embodiment,” “an illustrative embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may or may not necessarily include that particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described. Additionally, it should be appreciated that items included in a list in the form of “at least one of A, B, and C” can mean (A); (B); (C); (A and B); (A and C); (B and C); or (A, B, and C). Similarly, items listed in the form of “at least one of A, B, or C” can mean (A); (B); (C); (A and B); (A and C); (B and C); or (A, B, and C).
The disclosed embodiments may be implemented, in some cases, in hardware, firmware, software, or any combination thereof. The disclosed embodiments may also be implemented as instructions carried by or stored on one or more transitory or non-transitory machine-readable (e.g., computer-readable) storage media, which may be read and executed by one or more processors. A machine-readable storage medium may be embodied as any storage device, mechanism, or other physical structure for storing or transmitting information in a form readable by a machine (e.g., a volatile or non-volatile memory, a media disc, or other media device).
In the drawings, some structural or method features may be shown in specific arrangements and/or orderings. However, it should be appreciated that such specific arrangements and/or orderings may not be required. Rather, in some embodiments, such features may be arranged in a different manner and/or order than shown in the illustrative figures. Additionally, the inclusion of a structural or method feature in a particular figure is not meant to imply that such feature is required in all embodiments and, in some embodiments, may not be included or may be combined with other features.
Referring now to
Unlike present technologies, in which the source computing device 102 is configured to locally process and transmit digital media content for display on the destination computing device 106, and the destination computing device 106 is configured to receive and display the received digital media content, in the present disclosure, the roles (i.e., transmitter or receiver) may be reversed seamlessly. In other words, if both the source computing device 102 and the destination computing device 106 support role reversal, each is capable of being switched between receiving and transmitting digital media content over the established communication channel 104.
For example, the source computing device 102 may be prompted by a user of the source computing device 102 to stream content locally and cast the streamed content to the destination computing device 106. In use, the source computing device 102 determines whether processing (e.g., downloading, decoding, rendering, display, etc.) of the content stream can be offloaded. In other words, the source computing device 102 determines whether the content stream is local content or off-device content that is to be streamed, such as a video that may be accessed through the Internet via a uniform resource identifier (URI), such as a uniform resource locator (URL), accessible to the destination computing device 106. If so, the source computing device 102 can then determine which of the source computing device 102 and the destination computing device 106 are better suited (e.g., based on capabilities, settings, etc.) to process the content locally.
Upon determining the source computing device 102 is best suited, the content is streamed to and processed by the source computing device 102 and casted to the destination computing device 106 as initially configured. However, upon a determination that the destination computing device 106 is best suited, each of the source computing device 102 and the destination computing device 106 reconfigure their functionality to reverse roles. In other words, the source computing device 102 becomes the receiver and the destination computing device 106 becomes the processor and transmitter of the content stream.
The source computing device 102 may be embodied as any type of computing device that is capable of performing the functions described herein, such as, without limitation, a portable computing device (e.g., smartphone, tablet, laptop, notebook, wearable, etc.) that includes mobile hardware (e.g., processor, memory, storage, wireless communication circuitry, etc.) and software (e.g., an operating system) to support a mobile architecture and portability, a computer, a smart appliance, a smart television, a processor-based system, a multiprocessor system, and/or any other computing/communication device.
As shown in
The processor 110 may be embodied as any type of processor capable of performing the functions described herein. For example, the processor 110 may be embodied as a single or multi-core processor(s), digital signal processor, microcontroller, or other processor or processing/controlling circuit. The memory 114 may be embodied as any type of volatile or non-volatile memory or data storage capable of performing the functions described herein. In operation, the memory 114 may store various data and software used during operation of the source computing device 102, such as operating systems, applications, programs, libraries, and drivers.
The memory 114 is communicatively coupled to the processor 110 via the I/O subsystem 112, which may be embodied as circuitry and/or components to facilitate input/output operations with the processor 110, the memory 114, and other components of the source computing device 102. For example, the I/O subsystem 112 may be embodied as, or otherwise include, memory controller hubs, input/output control hubs, firmware devices, communication links (i.e., point-to-point links, bus links, wires, cables, light guides, printed circuit board traces, etc.) and/or other components and subsystems to facilitate the input/output operations. In some embodiments, the I/O subsystem 112 may form a portion of a system-on-a-chip (SoC) and be incorporated, along with the processor 110, the memory 114, and/or other components of the source computing device 102, on a single integrated circuit chip.
The data storage device 116 may be embodied as any type of device or devices configured for short-term or long-term storage of data, such as memory devices and circuits, memory cards, hard disk drives, solid-state drives, or other data storage devices, for example. It should be appreciated that the data storage device 116 and/or the memory 114 (e.g., the computer-readable storage media) may store various types of data capable of being executed by a processor (e.g., the processor 110) of the source computing device 102, including operating systems, applications, programs, libraries, drivers, instructions, etc.
The communication circuitry 118 may be embodied as any communication circuit, device, or collection thereof, capable of enabling communications between the source computing device 102 and other computing devices (e.g., the destination computing device 106) over a wired or wireless communication channel (e.g., the communication channel 104). For example, the communication circuitry 118 may include a network interface controller (NIC) and/or other devices capable of performing networking-related operations which are not shown for clarity of the description.
The communication circuitry 118 may be configured to use any one or more wired or wireless communication technologies and associated protocols (e.g., Ethernet, Wi-Fi®, Bluetooth®, Bluetooth® Low Energy (BLE), near-field communication (NFC), Worldwide Interoperability for Microwave Access (WiMAX), Digital Living Network Alliance (DLNA), etc.) to affect such communication. The communication circuitry 118 may be additionally configured to use any one or more wireless and/or wired communication technologies and associated protocols to effect communication with other computing devices, such as over a network, for example.
The peripheral devices 120 may include any number of input/output devices, interface devices, and/or other peripheral devices. For example, in some embodiments, the peripheral devices 120 may include a display, a touch screen, graphics circuitry, a keyboard, a mouse, a microphone, a speaker, and/or other input/output devices, interface devices, and/or peripheral devices. The particular devices included in the peripheral devices 120 may depend on, for example, the type and/or intended use of the source computing device 102. The peripheral devices 120 may additionally or alternatively include one or more ports, such as a USB port, for example, for connecting external peripheral devices to the source computing device 102.
Similar to the source computing device 102, the destination computing device 106 may be embodied as any type of computation or computing device capable of performing the functions described herein, including, without limitation, a computer, a portable computing device (e.g., smartphone, tablet, laptop, notebook, wearable, etc.), a smart television, a smart appliance, a projector, a cast hub, a cast dongle, a processor-based system, and/or a multiprocessor system. As shown in
Referring now to
It should be appreciated that, in such embodiments, one or more of the communication management circuit 210, the capability negotiation circuit 220, the streaming content management circuit 230, and the role reversal management circuit 240 may form a portion of one or more of the processor 110, the I/O subsystem 112, and/or other components of the source computing device 102. Additionally, in some embodiments, one or more of the illustrative modules may form a portion of another module and/or one or more of the illustrative modules may be independent of one another. Further, in some embodiments, one or more of the modules of the environment 200 may be embodied as virtualized hardware components or emulated architecture, which may be established and maintained by the processor 110 or other components of the source computing device 102.
In the illustrative environment 200, the source computing device 102 includes role reversal data 202 and streaming content data 204, each of which may be stored in the memory 114 and/or the data storage device 116 of the source computing device 102. Further, each of the role reversal data 202 and the streaming content data 204 may be accessed by the various modules and/or sub-modules of the source computing device 102. It should be appreciated that the source computing device 102 may include additional and/or alternative components, sub-components, modules, sub-modules, and/or devices commonly found in a computing device, which are not illustrated in
The communication management module 210, which may be embodied as hardware, firmware, software, virtualized hardware, emulated architecture, and/or a combination thereof as discussed above, is configured to facilitate inbound and outbound wired and/or wireless network communications (e.g., network traffic, network packets, network flows, etc.) to and from the source computing device 102. To do so, the communication management module 210 is configured to receive and process network packets from other computing devices (e.g., the destination computing device 106 and/or other computing device(s) communicatively coupled to the source computing device 102). Additionally, the communication management module 210 is configured to prepare and transmit network packets to another computing device (e.g., the destination computing device 106 and/or other computing device(s) communicatively coupled to the source computing device 102). The communication management module 210 is further configured to establish a communication channel (e.g., the communication channel 104 of
The capability negotiation module 220, which may be embodied as hardware, firmware, software, virtualized hardware, emulated architecture, and/or a combination thereof as discussed above, is configured to manage capability negotiations between the source computing device 102 and the destination computing device 106. To do so, the capability negotiation module 220 is configured to generate request messages for transmission that indicate supported capabilities, such as supported video codecs, supported resolutions, network port numbers, etc., as well as component capability information, such as processor specifications (e.g., number of processor cores, clock speed, cache size, hyperthreading support, etc.), memory specifications (e.g., total memory size, available memory size, etc.), battery life, and the like. The capability negotiation module 220 is further configured to receive response messages that indicate like or similar capabilities of the computing device to which the request messages were sent.
The illustrative capability negotiation module 220 includes a role reversal capability negotiation module 222 that is configured to negotiate, or exchange, role reversal capabilities. To do so, the role reversal capability negotiation module 222 is configured provide a message (e.g., a real-time streaming protocol (RTSP) message) that includes a role reversal capability indication usable to identify whether the source computing device 102 supports role reversal. For example, in some embodiments, the role reversal capability indication may be a Boolean value, in which a supported value, or value of “1”, may be used to indicate that role reversal is supported, while a not supported value, or value of “0”, may be used to indicate that role reversal is not supported. In some embodiments, the role reversal capability indication, as well as any supported capabilities relevant to the role reversal process may be stored in the role reversal data 202.
The streaming content management module 230, which may be embodied as hardware, firmware, software, virtualized hardware, emulated architecture, and/or a combination thereof as discussed above, is configured to transmit (e.g., cast, stream, mirror, etc.) and/or receive digital media content, as well as to determine whether to transmit (e.g., cast, stream, mirror, etc.) or receive digital media content. To do so, the illustrative streaming content management module 230 includes an offload determination module 232, a content stream transmission module 234, and a content stream reception module 236. In some embodiments, the digital media content to be transmitted or received may be stored in the streaming content data 204.
It should be appreciated that each of the offload determination module 232, the content stream transmission module 234, and the content stream reception module 236 of the streaming content management module 230 may be separately embodied as hardware, firmware, software, virtualized hardware, emulated architecture, and/or a combination thereof. For example, the offload determination module 232 may be embodied as a hardware component, while the content stream transmission module 234 and/or the content stream reception module 236 is embodied as a virtualized hardware component or as some other combination of hardware, firmware, software, virtualized hardware, emulated architecture, and/or a combination thereof.
The offload determination module 232 is configured to determine whether the digital media content to be transmitted is capable of being offloaded to the destination computing device 106. For example, the offload determination module 232 is configured to determine whether the content is local to the source computing device 102 or remote and accessible via a URI. The offload determination module 232 is configured to determine whether to offload the processing of the content to the destination computing device 106 (i.e., whether the processing should be offloaded). To do so, the offload determination module 232 may be configured to determine whether the destination computing device 106 is capable of accessing the remote content (e.g., whether the destination computing device 106 has Internet access), which of the source computing device 102 and the destination computing device 106 has more optimal capabilities to process the particular type of content, such as may be based on the processor specs, memory specs, power source, etc.
The content stream transmission module 234 is configured to locally process and transmit the content to the destination computing device 106. The content stream reception module 236 is configured to receive the content stream from the destination computing device 106. Each of the content stream transmission module 234 and content stream reception module 236 are configured to display (i.e., decode, render, and output) the content stream, whether locally processed (i.e., by the content stream transmission module 234) or received from the destination computing device 106 (i.e., by the content stream reception module 236).
The role reversal management module 240, which may be embodied as hardware, firmware, software, virtualized hardware, emulated architecture, and/or a combination thereof as discussed above, is configured to manage the role reversal process. To do so, the illustrative role reversal management module 240 includes a transmit functionality management module 242 and a receive functionality management module 244. The transmit functionality management module 242 is configured to enable or disable the transmit functionality of the source computing device 102, depending on the role of the source computing device 102. Similarly, the receive functionality management module 244 is configured to enable or disable the receive functionality of the source computing device 102, depending on the role of the source computing device 102. It should be appreciated that the role reversal management module 240 is configured to execute the role reversal over the same communication channel, such that the content transmission/reception is substantially uninterrupted.
Referring now to
It should be appreciated that, similar to the various modules of the illustrative environment 200 of
It should be appreciated that, when the destination computing device 106 is configured as a transmitter (i.e., the roles have been reversed), the offload determination module 332 of the streaming content management module 330 may be additionally configured to determine whether processing of the content should continue to be offloaded (i.e., whether the roles should remain reversed), such as may be determined based on updated characteristics of the source computing device 102 and/or the destination computing device 106, or whether the content to be processed at the destination computing device 106 no longer requires being processed (e.g., a video being processed has ended), etc. Additionally, the streaming content management module 330 is further configured to exit the role reversal (i.e., resume initial receiver functionality) upon a determination by the offload determination module 332 that processing of the content should no longer be performed at the destination computing device 106 (i.e., should no longer be offloaded).
In some embodiments, one or more of the modules of the environment 300 may be embodied as circuitry or a collection of electrical devices (e.g., communication management circuitry 310, capability negotiation circuitry 320, streaming content management circuitry 330, role reversal management module 340, etc.). In the illustrative environment 300, the destination computing device 106 includes role reversal data 302 and streaming content data 304, each of which may be stored in the memory 134 and/or the data storage device 136 of the destination computing device 106. Further, each of the role reversal data 302 and the streaming content data 304 may be accessed by the various modules and/or sub-modules of the destination computing device 106. It should be appreciated that the destination computing device 106 may include additional and/or alternative components, sub-components, modules, sub-modules, and/or devices commonly found in a computing device, which are not illustrated in
Referring now to
The method 400 begins in block 402, in which the source computing device 102 determines whether a communication channel (e.g., the communication channel 104 of
Upon completion of the role reversal capability exchange, the method 400 advances to block 406, in which the source computing device 102 determines whether content is to be transmitted (i.e., streamed, casted, mirrored) to the destination computing device 106, such as may be prompted by an application in response to a user input at the source computing device 102, for example. If the source computing device 102 determines content is to be streamed, the method 400 advances to block 408, in which the source computing device 102 determines whether the content can be offloaded. To do so, the source computing device 102 determines whether the destination computing device 106 supports processing of the offloaded content (i.e., the destination computing device 106 supports role reversal) and whether the content can be accessed by the destination computing device 106 (e.g., has an Internet connection by which to retrieve the remotely located content).
If the source computing device 102 determines the content cannot be offloaded in block 408, the method 400 branches to block 410, in which the source computing device 102 processes the content stream locally. In some embodiments, in block 412, the source computing device 102 may display the content stream local (i.e., in addition to streaming the content). In block 414, the source computing device 102 streams the content to the destination computing device 106 for display at the destination computing device 106.
If the source computing device 102 determines the content can be offloaded in block 408, the method 400 branches to block 416, in which the source computing device 102 determines whether to offload the offloadable content. As described previously, the source computing device 102 may be configured to compare component specifications, settings, supported features, power availability, etc., of the source computing device 102 and the destination computing device 106 to determine whether processing of the offloadable content should be performed by the source computing device 102 or the destination computing device 106.
If the source computing device 102 determines not to offload the content in block 416, the method 400 branches to block 410, in which the source computing device 102 process the content stream locally, as described above. Otherwise, if the source computing device 102 determines to offload the content in block 416, the method 400 branches to block 418, in which the source computing device 102 transmits an offload trigger to the destination computing device 106. The offload trigger may be a message (e.g., an RTSP message) that includes a role reversal indicator that indicates to the receiving device (e.g., the destination computing device 106) whether role reversal is active or not. In other words, the offload trigger is usable by the destination computing device 106 to determine whether the destination computing device 106 should be enable receiver functionality (i.e., roles not reversed) or transmitter functionality (i.e., roles reversed). In some embodiments, in block 420 the source computing device 102 transmits additional data which may include any data usable by the destination computing device 106 to run/launch the content, such as a URI, an identifier/name an application on the destination computing device 106 to launch the URI, a file name corresponding to a file that includes the content which is stored local to the destination computing device 106, etc.
In block 422, the source computing device 102 determines whether a role reversal acknowledgment was received. If so, the method 400 advances to block 424 in
In block 428, the source computing device 102 determines whether a content stream has been received from the destination computing device 106. If so, the method 400 advances to block 430, in which the source computing device 102 displays the received content stream. It should be appreciated that displaying the received content stream may include decoding the content stream, rendering the digital media of the content stream (e.g., at a graphics processing unit (GPU) (not shown) of the source computing device 102), and output the rendered digital media to a display of the source computing device 102.
It should be further appreciated that a user of the source computing device 102 may or may not be made aware of the present role of the source computing device 102 and/or the destination computing device 106. However, it should be further appreciated that any user interaction with the source computing device 102 with regards to the content is to be accepted by the source computing device 102 and an indication of such is to be transmitted to the destination computing device 106. As such, the indication should be formatted such that the destination computing device 106 can achieve the same functionality the input would have provided, had the content been being processed by the source computing device 102. Accordingly, in some embodiments, additional communication channels (e.g., TCP, UDP, etc.) may be established between the source computing device 102 and the destination computing device 106 while in role reversal mode in order to pass additional controls/indications.
In block 432, the source computing device 102 determines whether to exit role reversal. It should be appreciated that various factors may influence whether the source computing device 102 exits role reversal. For example, one or more component characteristics (e.g., available memory, battery life, etc.), settings, and/or dynamic capabilities of the source computing device 102 and/or the destination computing device 106 may be used to determine whether to continue or exit role reversal. If the source computing device 102 determines to exit role reversal, the method 400 advances to block 434; otherwise, the method 400 loops back to block 428, in which the source computing device 102 determines whether the content stream continues to be received. In block 434, the source computing device 102 transmits a role reversal indication via a message to the destination computing device 106. In block 436, the source computing device 102 disables, or otherwise pauses, receive functionality of the source computing device 102. In block 436, the source computing device 102 enables, or otherwise resumes, transmit functionality of the source computing device 102 before the method 400 returns to block 406 to determine whether content is available to be streamed.
Referring now to
The method 600 begins in block 602, in which the destination computing device 106 determines whether a communication channel (e.g., the communication channel 104 of
Upon completion of the role reversal capability exchange, the method 600 advances to block 606, in which the destination computing device 106 determines whether an offload trigger was received. As described previously, the source computing device 102 is configured to transmit the offload trigger to the destination computing device 106. As also described previously, the offload trigger may be a message that includes a role reversal indicator that indicates to the destination computing device 106 whether role reversal is active or not, as well as additional data. As described previously, the additional data may include any data usable by the destination computing device 106 to run/launch the content, such as a URI, an identifier/name an application on the destination computing device 106 to launch the URI, a file name corresponding to a file that includes the content which is stored local to the destination computing device 106, etc.
If the destination computing device 106 determines the offload trigger was not received in block 606, the method 600 advances to block 608, in which the destination computing device 106 determines whether a content stream was received from the source computing device 102. If so, the method 600 advances to block 610, in which the destination computing device 106 displays the content stream received in block 608 before the method 600 returns to block 608 to determine whether the content stream continues to be received; otherwise, the method 600 returns to block 606, in which the destination computing device 106 determines whether the offload trigger was received.
If the destination computing device 106 determines the offload trigger was not received in block 606, the method 600 advances to block 612 in
In block 624, the destination computing device 106 determines whether to exit role reversal. It should be appreciated that various factors may influence whether the destination computing device 106 exits role reversal, such as the content being streamed having ended, one or more component characteristics (e.g., available memory, battery life, etc.), settings, and/or dynamic capabilities of the source computing device 102 and/or the destination computing device 106 having changed, etc. It should be further appreciated that a message may be received from the source computing device 102 that includes an indication indicating to exit role reversal. In other words, the source computing device 102 or the destination computing device 106 may trigger the role reversal exit. In block 626, the destination computing device 106 transmits a role reversal exit indication via a message that includes an indicator indicating the role reversal exit. In block 628, the destination computing device 106 disables, or otherwise pauses, transmit functionality of the destination computing device 106. In block 630, the destination computing device 106 enables, or otherwise resumes, receive functionality of the destination computing device 106.
Illustrative examples of the technologies disclosed herein are provided below. An embodiment of the technologies may include any one or more, and any combination of, the examples described below.
Example 1 includes a source computing device for streaming device role reversal, the source computing device comprising a communication management module to establish a communication channel between the source computing device and a destination computing device; a capability negotiation module to determine whether the source computing device and the destination computing device support role reversal, wherein support of role reversal is indicative that the source computing device and the destination computing device are capable of being switched between receiving and transmitting digital media content over the established communication channel; a role reversal management module to initiate, in response to a determination that both of the source computing device and the destination computing device support role reversal, a role reversal between the source computing device and the destination computing device, wherein to initiate the role reversal comprises to pause transmit functionality of the source computing device and enable the source computing device to receive a content stream from the destination computing device; and a streaming content management module to (i) receive the content stream from the destination computing device and (ii) display the content stream on an output device of the source computing device.
Example 2 includes the subject matter of Example 1, and wherein the streaming content management module is further to (i) determine whether the content is to be transmitted to the destination computing device, (ii) determine, in response to a determination the content is to be transmitted to the destination computing device, whether processing of the content can be offloaded to the destination computing device, and (iii) determine, in response to a determination the processing of the content can be offloaded to the destination computing device, whether to offload the content to the destination computing device, wherein to initiate the role reversal comprises to initiate the role reversal in response to a determination to offload the content to the destination computing device.
Example 3 includes the subject matter of any of Examples 1 and 2, and wherein the streaming content management module is further to transmit an offload trigger to the destination computing device usable by the destination computing device to determine a role reversal has been requested by the source computing device.
Example 4 includes the subject matter of any of Examples 1-3, and wherein the streaming content management module is further to transmit additional data with the offload trigger, wherein the additional data includes at least one of a URI, an identifier of an application on the destination computing device usable by the destination computing device to launch the application, and a file name usable by the destination computing device to open a corresponding file stored on the destination computing device.
Example 5 includes the subject matter of any of Examples 1-4, and, wherein the streaming content management module is further to receive a role reversal acknowledgement from the destination computing device, wherein to initiate the role reversal comprises to initiate the role reversal in response to having received the role reversal acknowledgement.
Example 6 includes the subject matter of any of Examples 1-5, and wherein the role reversal management module is further to (i) receive a role reversal exit indication from the destination computing device and (ii) exit, in response to having received the exit role reversal indication, role reversal.
Example 7 includes the subject matter of any of Examples 1-6, and wherein to exit role reversal comprises to resume transmit functionality of the source computing node and disable the source computing device from receiving the content from the destination computing device.
Example 8 includes the subject matter of any of Examples 1-7, and wherein the role reversal management module is further to (i) determine whether to exit role reversal, (ii) transmit, in response to a determination to exit role reversal, an exit role reversal indication to the destination computing device, and (ii) exit, in response to having transmitted the exit role reversal indication, role reversal.
Example 9 includes the subject matter of any of Examples 1-8, and wherein to determine whether to exit role reversal comprises to compare one or more capabilities of the source computing device, settings of the source computing device, and characteristics of the source computing device against a corresponding one or more capabilities of the destination computing device, settings of the destination computing device, and characteristics of the destination computing device.
Example 10 includes the subject matter of any of Examples 1-9, and wherein to exit role reversal comprises to resume transmit functionality of the source computing node and disable the source computing device from receiving the content from the destination computing device.
Example 11 includes a method for streaming device role reversal, the method comprising establishing, by a source computing device, a communication channel between the source computing device and a destination computing device; determining, by the source computing device, whether the source computing device and the destination computing device support role reversal, wherein support of role reversal is indicative that the source computing device and the destination computing device are capable of switching between receiving and transmitting digital media content over the established communication channel; initiating, by the source computing device and in response to determining that both of the source computing device and the destination computing device support role reversal, a role reversal between the source computing device and the destination computing device, wherein initiating the role reversal comprises to pause transmit functionality and enable the source computing device to receive a content stream from the destination computing device; receiving, by the source computing device, the content stream from the destination computing device; and displaying, by the source computing device, the content stream on an output device of the source computing device.
Example 12 includes the subject matter of Example 11, and further including determining, by the source computing device, whether the content is to be transmitted to the destination computing device; determining, by the source computing device and in response to a determination the content is to be transmitted to the destination computing device, whether processing of the content can be offloaded to the destination computing device; and determining, by the source computing device and in response to a determination the processing of the content can be offloaded to the destination computing device, whether to offload the content to the destination computing device, wherein initiating the role reversal comprises initiating the role reversal in response to a determination to offload the content to the destination computing device.
Example 13 includes the subject matter of any of Examples 11 and 12, and further including transmitting an offload trigger to the destination computing device usable by the destination computing device to determine a role reversal has been requested by the source computing device.
Example 14 includes the subject matter of any of Examples 11-13, and further including transmitting additional data with the offload trigger, wherein the additional data includes at least one of a URI, an identifier of an application on the destination computing device usable to launch the application, and a file name usable by the destination computing device to open a corresponding file stored on the destination computing device.
Example 15 includes the subject matter of any of Examples 11-14, and further including receiving a role reversal acknowledgement from the destination computing device, wherein initiating the role reversal comprises initiating the role reversal in response to having received the role reversal acknowledgement.
Example 16 includes the subject matter of any of Examples 11-15, and further including receiving, by the source computing device, a role reversal exit indication from the destination computing device; and exiting, by the source computing device and in response to having received the exit role reversal indication, role reversal.
Example 17 includes the subject matter of any of Examples 11-16, and wherein exiting role reversal comprises (i) resuming transmit functionality of the source computing node and (ii) disabling the source computing device from receiving the content from the destination computing device.
Example 18 includes the subject matter of any of Examples 11-17, and further including determining, by the source computing device, whether to exit role reversal; transmitting, by the source computing device and in response to a determination to exit role reversal, an exit role reversal indication to the destination computing device; and exiting, by the source computing device and in response to having transmitted the exit role reversal indication, role reversal.
Example 19 includes the subject matter of any of Examples 11-18, and wherein determining whether to exit role reversal comprises comparing one or more capabilities of the source computing device, settings of the source computing device, and characteristics of the source computing device against a corresponding one or more capabilities of the destination computing device, settings of the destination computing device, and characteristics of the destination computing device.
Example 20 includes the subject matter of any of Examples 11-19, and wherein exiting role reversal comprises (i) resuming transmit functionality of the source computing node and (ii) disabling the source computing device from receiving the content from the destination computing device.
Example 21 includes a source computing device comprising a processor; and a memory having stored therein a plurality of instructions that when executed by the processor cause the source computing device to perform the method of any of Examples 11-20.
Example 22 includes one or more machine readable storage media comprising a plurality of instructions stored thereon that in response to being executed result in a source computing device performing the method of any of Examples 11-20.
Example 23 includes a source computing device comprising means for performing the method of any of Examples 11-20.
Example 24 includes a source computing device for streaming device role reversal, the source computing device comprising means for establishing a communication channel between the source computing device and a destination computing device; means for determining whether the source computing device and the destination computing device support role reversal, wherein support of role reversal is indicative that the source computing device and the destination computing device are capable of switching between receiving and transmitting digital media content over the established communication channel; means for initiating, in response to determining that both of the source computing device and the destination computing device support role reversal, a role reversal between the source computing device and the destination computing device, wherein initiating the role reversal comprises to pause transmit functionality and enable the source computing device to receive a content stream from the destination computing device; means for receiving the content stream from the destination computing device; and means for displaying the content stream on an output device of the source computing device.
Example 25 includes the subject matter of Example 24, and further including means for determining whether the content is to be transmitted to the destination computing device; means for determining, in response to a determination the content is to be transmitted to the destination computing device, whether processing of the content can be offloaded to the destination computing device; and means for determining, in response to a determination the processing of the content can be offloaded to the destination computing device, whether to offload the content to the destination computing device, wherein the means for initiating the role reversal comprises means for initiating the role reversal in response to a determination to offload the content to the destination computing device.
Example 26 includes the subject matter of any of Examples 24 and 25, and further including means for transmitting an offload trigger to the destination computing device usable by the destination computing device to determine a role reversal has been requested by the source computing device.
Example 27 includes the subject matter of any of Examples 24-26, and further including means for transmitting additional data with the offload trigger, wherein the additional data includes at least one of a URI, an identifier of an application on the destination computing device usable to launch the application, and a file name usable by the destination computing device to open a corresponding file stored on the destination computing device.
Example 28 includes the subject matter of any of Examples 24-27, and further including means for receiving a role reversal acknowledgement from the destination computing device, wherein initiating the role reversal comprises initiating the role reversal in response to having received the role reversal acknowledgement.
Example 29 includes the subject matter of any of Examples 24-28, and further including means for receiving a role reversal exit indication from the destination computing device; and means for exiting, in response to having received the exit role reversal indication, role reversal.
Example 30 includes the subject matter of any of Examples 24-29, and wherein the means for exiting role reversal comprises means for (i) resuming transmit functionality of the source computing node and (ii) disabling the source computing device from receiving the content from the destination computing device.
Example 31 includes the subject matter of any of Examples 24-30, and further including means for determining whether to exit role reversal; means for transmitting, in response to a determination to exit role reversal, an exit role reversal indication to the destination computing device; and means for exiting, in response to having transmitted the exit role reversal indication, role reversal.
Example 32 includes the subject matter of any of Examples 24-31, and wherein the means for determining whether to exit role reversal comprises means for means for comparing one or more capabilities of the source computing device, settings of the source computing device, and characteristics of the source computing device against a corresponding one or more capabilities of the destination computing device, settings of the destination computing device, and characteristics of the destination computing device.
Example 33 includes the subject matter of any of Examples 24-32, and wherein the means for exiting role reversal comprises means for (i) resuming transmit functionality of the source computing node and (ii) disabling the source computing device from receiving the content from the destination computing device.
The present application is a continuation of U.S. patent application Ser. No. 16/150,264, filed on Oct. 2, 2018 and entitled “TECHNOLOGIES FOR STREAMING DEVICE ROLE REVERSAL,” which is a continuation of U.S. patent application Ser. No. 14/998,311, filed on Dec. 26, 2015 and entitled “TECHNOLOGIES FOR STREAMING DEVICE ROLE REVERSAL.”
Number | Name | Date | Kind |
---|---|---|---|
5706290 | Shaw et al. | Jan 1998 | A |
5815194 | Ueda | Sep 1998 | A |
6912574 | Scifres et al. | Jun 2005 | B2 |
7062570 | Hong et al. | Jun 2006 | B2 |
7113990 | Scifres et al. | Sep 2006 | B2 |
7117521 | Puthiyedath | Oct 2006 | B2 |
7142509 | Rovner et al. | Nov 2006 | B1 |
7177945 | Hong et al. | Feb 2007 | B2 |
7194520 | Beard et al. | Mar 2007 | B1 |
7228350 | Hong et al. | Jun 2007 | B2 |
7237254 | Omoigui | Jun 2007 | B1 |
7274661 | Harrell et al. | Sep 2007 | B2 |
7292571 | Brown | Nov 2007 | B2 |
7336784 | Zuili | Feb 2008 | B2 |
7478432 | Echizen et al. | Jan 2009 | B2 |
7558879 | Nishio et al. | Jul 2009 | B2 |
7647616 | Puthiyedath | Jan 2010 | B2 |
7788394 | Gregotski et al. | Aug 2010 | B2 |
7836223 | Butcher | Nov 2010 | B2 |
7921222 | Courtemanche | Apr 2011 | B2 |
7953883 | Thomas et al. | May 2011 | B2 |
7987490 | Ansari et al. | Jul 2011 | B2 |
8116258 | Perlman | Feb 2012 | B2 |
8117323 | Courtemanche | Feb 2012 | B2 |
8131673 | Chavez et al. | Mar 2012 | B2 |
8132218 | Six et al. | Mar 2012 | B2 |
8156236 | Costanzo et al. | Apr 2012 | B2 |
8191163 | Sun et al. | May 2012 | B1 |
8255552 | Witt et al. | Aug 2012 | B2 |
8266315 | van Oldenborgh et al. | Sep 2012 | B2 |
8370649 | Sherer et al. | Feb 2013 | B2 |
8392594 | Georgis et al. | Mar 2013 | B2 |
8452885 | Sherer et al. | May 2013 | B2 |
8527649 | Wexler et al. | Sep 2013 | B2 |
8543665 | Ansari et al. | Sep 2013 | B2 |
8549573 | Velusamy et al. | Oct 2013 | B2 |
8561115 | Hattori et al. | Oct 2013 | B2 |
8621650 | Cakulev et al. | Dec 2013 | B2 |
8631144 | Lee et al. | Jan 2014 | B2 |
8676882 | Georgis et al. | Mar 2014 | B2 |
8687046 | Yu et al. | Apr 2014 | B2 |
8707375 | Hainline | Apr 2014 | B2 |
8763052 | Theberge | Jun 2014 | B2 |
8799480 | Kovvali et al. | Aug 2014 | B2 |
8825766 | Smith | Sep 2014 | B2 |
8832290 | Li et al. | Sep 2014 | B2 |
8908103 | Kitazato | Dec 2014 | B2 |
8954596 | Ronca et al. | Feb 2015 | B2 |
8959145 | Georgis et al. | Feb 2015 | B2 |
8970662 | Kerger et al. | Mar 2015 | B2 |
8977765 | Patel et al. | Mar 2015 | B1 |
9009337 | Ronca et al. | Apr 2015 | B2 |
9049338 | Witt et al. | Jun 2015 | B2 |
9118814 | Janardhan et al. | Aug 2015 | B2 |
9148478 | Cakulev et al. | Sep 2015 | B2 |
9179277 | Kerger et al. | Nov 2015 | B2 |
9210085 | Harrison | Dec 2015 | B2 |
9210451 | Zhou et al. | Dec 2015 | B2 |
9231786 | Wu et al. | Jan 2016 | B2 |
9276665 | Johnson et al. | Mar 2016 | B1 |
9294580 | Morrison, III et al. | Mar 2016 | B2 |
9374420 | Burba et al. | Jun 2016 | B2 |
9420347 | Khouzam et al. | Aug 2016 | B2 |
9455777 | Johnson et al. | Sep 2016 | B1 |
9479833 | Kitazato | Oct 2016 | B2 |
9563716 | Narvaez | Feb 2017 | B2 |
9596306 | Morrison, III et al. | Mar 2017 | B2 |
9622259 | Johnson et al. | Apr 2017 | B2 |
9667411 | Kumar | May 2017 | B2 |
9699500 | Kafle et al. | Jul 2017 | B2 |
9729627 | Zhang | Aug 2017 | B2 |
9819715 | Scurtu et al. | Nov 2017 | B2 |
9860290 | Oyman | Jan 2018 | B2 |
10764346 | Veeramani et al. | Sep 2020 | B2 |
10909010 | Chandrasekaran | Feb 2021 | B2 |
20020062372 | Hong et al. | May 2002 | A1 |
20030046032 | Puthiyedath | Mar 2003 | A1 |
20030067872 | Harrell et al. | Apr 2003 | A1 |
20030154283 | Brown | Aug 2003 | A1 |
20030225905 | Scifres et al. | Dec 2003 | A1 |
20040123125 | Zuili | Jun 2004 | A1 |
20040143665 | Mace et al. | Jul 2004 | A1 |
20040221163 | Jorgensen et al. | Nov 2004 | A1 |
20050033832 | Hass et al. | Feb 2005 | A1 |
20050041679 | Weinstein et al. | Feb 2005 | A1 |
20050073968 | Perlman | Apr 2005 | A1 |
20050226153 | Scifres et al. | Oct 2005 | A1 |
20050238000 | Pollock et al. | Oct 2005 | A1 |
20050240961 | Jerding et al. | Oct 2005 | A1 |
20060174160 | Kim | Aug 2006 | A1 |
20060174289 | Theberge | Aug 2006 | A1 |
20060235967 | Fritz | Oct 2006 | A1 |
20060288391 | Puthiyedath | Dec 2006 | A1 |
20070101377 | Six et al. | May 2007 | A1 |
20070136488 | Cho et al. | Jun 2007 | A1 |
20070180512 | Chaudhuri | Aug 2007 | A1 |
20070198726 | Marco et al. | Aug 2007 | A1 |
20070222779 | Fastert et al. | Sep 2007 | A1 |
20070234385 | Bopardikar et al. | Oct 2007 | A1 |
20070250880 | Hainline | Oct 2007 | A1 |
20080022006 | van Oldenborgh et al. | Jan 2008 | A1 |
20080059645 | Gregotski et al. | Mar 2008 | A1 |
20080133538 | Chavez et al. | Jun 2008 | A1 |
20080140853 | Harrison | Jun 2008 | A1 |
20080168523 | Ansari et al. | Jul 2008 | A1 |
20080183794 | Georgis et al. | Jul 2008 | A1 |
20080205291 | Li et al. | Aug 2008 | A1 |
20080208985 | Georgis et al. | Aug 2008 | A1 |
20080298370 | Yoshimoto et al. | Dec 2008 | A1 |
20090013095 | Butcher | Jan 2009 | A1 |
20090055461 | Georgis et al. | Feb 2009 | A1 |
20090083810 | Hattori et al. | Mar 2009 | A1 |
20090228897 | Murray et al. | Sep 2009 | A1 |
20090282158 | Courtemanche | Nov 2009 | A1 |
20100023636 | Huang et al. | Jan 2010 | A1 |
20100146569 | Janardhan et al. | Jun 2010 | A1 |
20100146576 | Costanzo et al. | Jun 2010 | A1 |
20100161825 | Ronca et al. | Jun 2010 | A1 |
20100191858 | Thomas et al. | Jul 2010 | A1 |
20100217837 | Ansari et al. | Aug 2010 | A1 |
20100223394 | Sherer et al. | Sep 2010 | A1 |
20100318671 | Lee et al. | Dec 2010 | A1 |
20110004695 | van Oldenborgh et al. | Jan 2011 | A1 |
20110055403 | Balachandran et al. | Mar 2011 | A1 |
20110109725 | Yu et al. | May 2011 | A1 |
20110161509 | Courtemanche | Jun 2011 | A1 |
20110225315 | Wexler et al. | Sep 2011 | A1 |
20120084829 | Kitazato | Apr 2012 | A1 |
20120144415 | Velusamy et al. | Jun 2012 | A1 |
20120176469 | Moore et al. | Jul 2012 | A1 |
20120185574 | Cho et al. | Jul 2012 | A1 |
20120191862 | Kovvali et al. | Jul 2012 | A1 |
20120215851 | Wu et al. | Aug 2012 | A1 |
20120297432 | Zhou et al. | Nov 2012 | A1 |
20120311647 | Sharma et al. | Dec 2012 | A1 |
20120324122 | Miles et al. | Dec 2012 | A1 |
20130033496 | Raveendran et al. | Feb 2013 | A1 |
20130057695 | Huisking | Mar 2013 | A1 |
20130104247 | Cakulev et al. | Apr 2013 | A1 |
20130104249 | Cakulev et al. | Apr 2013 | A1 |
20130117792 | Khouzam et al. | May 2013 | A1 |
20130151723 | Xia | Jun 2013 | A1 |
20130166698 | Georgis et al. | Jun 2013 | A1 |
20130169741 | Witt et al. | Jul 2013 | A1 |
20130179605 | Huang et al. | Jul 2013 | A1 |
20130246638 | Kovvali et al. | Sep 2013 | A1 |
20130290418 | Liu | Oct 2013 | A1 |
20130304729 | Jiang et al. | Nov 2013 | A1 |
20130304874 | Wexler et al. | Nov 2013 | A1 |
20140003322 | Grinshpun et al. | Jan 2014 | A1 |
20140006499 | Ren et al. | Jan 2014 | A1 |
20140025793 | Ramsdell et al. | Jan 2014 | A1 |
20140122570 | Narvaez | May 2014 | A1 |
20140172971 | Akkurt et al. | Jun 2014 | A1 |
20140172972 | Burba et al. | Jun 2014 | A1 |
20140173022 | Morrison, III et al. | Jun 2014 | A1 |
20140189008 | Park | Jul 2014 | A1 |
20140195642 | Georgis et al. | Jul 2014 | A1 |
20140267543 | Kerger et al. | Sep 2014 | A1 |
20140301202 | Bouazizi | Oct 2014 | A1 |
20150095453 | Jain et al. | Apr 2015 | A1 |
20150100997 | Kitazato | Apr 2015 | A1 |
20150126169 | Kerger et al. | May 2015 | A1 |
20150215816 | Abou-Elkheir et al. | Jul 2015 | A1 |
20150222684 | Johansson et al. | Aug 2015 | A1 |
20150263833 | Li et al. | Sep 2015 | A1 |
20150312300 | Mosko | Oct 2015 | A1 |
20150341570 | Jaynes | Nov 2015 | A1 |
20150379617 | Khalsa | Dec 2015 | A1 |
20160050243 | De Vleeschauwer | Feb 2016 | A1 |
20160134704 | Morrison, III et al. | May 2016 | A1 |
20160142327 | Johnson et al. | May 2016 | A1 |
20160150005 | Choi et al. | May 2016 | A1 |
20160285784 | Burba et al. | Sep 2016 | A1 |
20160286270 | Yuen | Sep 2016 | A1 |
20160360547 | Johnson et al. | Dec 2016 | A1 |
20160373251 | Kumar | Dec 2016 | A1 |
20170099522 | Kitazato | Apr 2017 | A1 |
20170104816 | Yan | Apr 2017 | A1 |
20170187763 | Hsu et al. | Jun 2017 | A1 |
20180013979 | Apelqvist et al. | Jan 2018 | A1 |
20180091480 | Brown et al. | Mar 2018 | A1 |
20190340091 | Chandrasekaran | Nov 2019 | A1 |
Number | Date | Country |
---|---|---|
0110125 | Feb 2001 | WO |
Entry |
---|
Nakayama et al., Peer-to-Peer Bidirectional Streaming Using Mobile Edge Computing, Nov. 19, 2017, 2017 Fifth International Symposium on Computing and Networking (CANDAR), DOI: 10.1109/CANDAR.2017.38 (Year: 2017). |
United States Patent and Trademark Office, “Non-Final Office Action,” mailed in connection with U.S. Appl. No. 14/998,311, dated Jul. 14, 2017, 27 pages. |
United States Patent and Trademark Office, “Final Office Action,” mailed in connection with U.S. Appl. No. 14/998,311, dated Jan. 11, 2018, 29 pages. |
United States Patent and Trademark Office, “Notice of Allowance,” mailed in connection with U.S. Appl. No. 14/998,311, dated May 18, 2018, 10 pages. |
United States Patent and Trademark Office, “Non-Final Office Action,” mailed in connection with U.S. Appl. No. 16/150,264, dated Aug. 7, 2019, 23 pages. |
United States Patent and Trademark Office, “Notice of Allowance,” mailed in connection with U.S. Appl. No. 16/150,264, dated Apr. 28, 2020, 9 pages. |
International Search Report and Written Opinion issued by the International Bureau in corresponding International Patent Application No. PCT/US2016/063574 dated Mar. 13, 2017, 10 pages. |
International Preliminary Report on Patentability (IPRP) issued by the International Bureau in corresponding International Patent Application No. PCT/US2016/063574 dated Jun. 16, 2018, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20210021658 A1 | Jan 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16150264 | Oct 2018 | US |
Child | 16944703 | US | |
Parent | 14998311 | Dec 2015 | US |
Child | 16150264 | US |