NOT APPLICABLE
NOT APPLICABLE
NOT APPLICABLE
This invention relates to communication systems. More particularly, and not by way of limitation, the invention is directed to a system and method of multicasting multimedia streams.
Various applications relating to the broadcast of video and audio over the internet, such as IPTV, online radio, etc. are being used with increased regularity. In contrast to true multimedia conferences or streaming video downloads, applications utilizing the internet to broadcast video and audio are similar to conventional television or radio programming in that the content is streamed to a plurality of viewers at a specified time and date.
In existing systems which implement multimedia services over non-multicast, multimedia servers, registered users are able to join a broadcast stream. However, each incoming user connection is treated as a separate point-to-point connection with the multimedia servers transmitting each packet multiple times to each user.
However, problems arise when portable communications devices having low CPU and power requirements, such as a camera phone or personal data assistants (PDAs) attempt to multicast media to a plurality of users. Oftentimes, these communications devices are not capable of originating multiple unicast streams. For example, users may employ mobile devices for various broadcasting applications, such as video-blogging by mobile users or live multicasting of family events using handheld devices. Furthermore, air-bandwidth is also limited when implementing these applications. For such devices utilizing existing multicasting systems, the network provider must support some mechanism to achieve multicast of multimedia content.
To solve the problems associated with multicasting multimedia contents where a server can only generate one steam, specialized multimedia processors are sometimes deployed in the network. These processors can generate multiple streams to multiple destinations in the target network. However, for use with mobile devices, using specialized multimedia processors are costly for a service provider. It requires the processing of the user's content stream. Specifically, it requires the processing at the application layer. To fund this costly solution, service providers must charge the originating user for such a service. This does not scale well for a large number of content originating users, especially if such a service becomes popular and the multimedia content becomes richer.
Other existing implementations to solve these problems include the use of IP multicast protocol supported by an underlying transport network. This existing system allows scalable multicasting. However, with this solution, the service provider's network must have an IP multicast capability. To deploy such a solution requires end-to-end multicast capability and co-operation from the network operators and equipment from the content producer to the final viewing or listening end user. This solution is not seamless enough with respect to the content provider who would like to deliver content to all users, irrespective of the capabilities of the transport network.
Thus, it would be advantageous to have a system and method of multicasting multimedia content using mobile/portable devices which is inexpensive and scalable. The present invention provides such a system and method.
In one aspect, the present invention is directed to a system for multicasting a media stream in a telecommunications network. The system includes a broadcast user broadcasting a media stream. The broadcast user determines the destination addresses of each end user desiring to receive the media stream. The media stream is received by an IP router. Within a classification stage of a data-plane residing in the IP router is a replication filter action which replicates the broadcast media stream. The broadcast media stream is replicated with the exception of the destination address. The replicated media stream is sent to each destination address of the viewing or listening end users, thereby providing a multicast media stream to a plurality of end users without requiring a content server of the broadcast user to send multiple media streams.
In another aspect, the present invention is a method of multicasting a media stream in a telecommunications network. The method begins by broadcasting a media stream by a broadcast user. Next, the broadcast user communicates with a plurality of end users. Each end user has a destination address. Next, an additional media stream is requested for each end user. In response, an IP router then replicates the media stream for each end user. Each end user is then sent a replicated media stream.
In another aspect, the present invention is a method of replicating a broadcast media stream in a telecommunications network. Packets of a broadcast media stream are received by an IP router. Next, the IP router determines a list of a plurality of destination addresses to send the broadcast media stream. The received packets are then matched with a replication filter within the IP router. Next, a replication filter action is conducted by the IP router to replicate the receive packets for each destination address. The replicated packets are then sent to each destination address.
In still another aspect, the present invention is an Internet Protocol (IP) router for replicating media streams in a telecommunications network. The IP router receives a broadcast media stream. The IP router determines a plurality of destination addresses to send the broadcast media stream. Within a data-plane having a packet classification stage of the IP router, a replication filter action is conducted for replicating the broadcast media stream for each destination address. The IP router sends the replicated broadcast media stream to each destination address.
In another aspect, the present invention is a content server for multicasting a media stream to a plurality of end users in a telecommunications network. The content server broadcasts a media stream. The content server includes a signaling function which installs a replication filter action in an Internet Protocol (IP) router. The signaling function is triggered in response to receiving a request for receipt of the broadcast media stream to an end user having a destination address. The signaling function also installs the destination address of the end user in the replication filter action in the IP router.
In the following, the features of the invention will be described in detail by showing preferred embodiments, with reference to the attached figures in which:
The present invention is a system and method of multicasting multimedia content in a telecommunications network.
Typically, multimedia streams are transported over IP using User Datagram Protocol (UDP). The control and session set-up packets are carried over Transmission Control Protocol (TCP). One feature of these transported multimedia UDP packets is that the packets which are broadcast to the plurality of end users are identical with the exception of the end user's IP address information (e.g., Destination Address (DA), Destination Port (DP) and Source Port (SP).
In addition in an IP router data-plane, there may be a classification stage having an ordered set of filters. This classification stage is responsible for matching incoming packets against the various configured filters and performing configured operations on the incoming packets. This operation performed on a filter match is denoted as a “filter action.”
The present invention performs a new type of filter action called a replication that causes packets matching the filter to be replicated, but with some IP/UDP fields changed. This new filter action (i.e., replication), when used to match UDP traffic to a specific destination, can replicate the single UDP traffic stream to form multiple streams, but with different IP destination addresses and ports. In the preferred embodiment of the represent invention, the filter associated with the replication process, is installed in the classification stage of the data-plane of the IP router 30 and configured with the list of destination addresses as end users join to watch the broadcast media. The installation is preferably triggered by a session signaling function found in the multimedia server of the broadcast user.
Referring back to
To perform this additional function to replicate, the broadcast user 12 requests to install replication destinations in the classification stage of the IP router data-plane 70. Within an IP router control/management functionality 76 of the IP router 30, the IP router 30 configures the filter within the IP router data-plane to invoke the replication action within the IP router. The creation of this replication filter and its configuration is trigged by the server 72 as end users join and leave a broadcast program. Thus, the management/control functionality 76 preferably exports an application programming interface (API) to enable the content servers to install and configure these filters on demand. Likewise, when desired by the broadcast user 12, the broadcast user may request deletion of the replication action to the IP router control/management functionality 76 of the IP router 30. In addition, the broadcast user 12 also performs signaling/control operations with the plurality of end users 20, 22, and 24.
In the preferred embodiment of the present invention, the multimedia server 72 is modified. A signaling function within the multimedia server 72 of the broadcast user 12 is preferably modified to trigger a request to the IP router control/management functionality 76 to install a new filter (i.e., replicate) for broadcasting of the multimedia stream 74. In addition, the server 72 is modified to provide a request to the control/management functionality 76 of the IP router 30 to install a new destination (i.e., SA, SP, DA, DP,) tuple in the list of viewing or listening users for the replication filter action. It should be understood that when a viewing or listening user joins the broadcast, a source port for the content stream is allocated to that end user, but does not generate the multimedia stream. Rather, only one multimedia stream is sourced per program to the IP router, which performs the replication.
However, in step 102, if it is determined that the packets (and stream 74) do match the replication filter, the method moves from step 102 to step 106 where the stream 74 is replicated. Specifically, identical and new UDP/RTP payload packets are created, but with new destinations in the UDP/IP header fields. For each destination (e.g., SA, SP, DA, DP) on a list of end users, the replication action is performed.
The method then moves to step 204 where it is determined if a specific end user is to be installed as a new destination or deleted as a destination of the multimedia stream 74 corresponding to the specific end user. From the signaling and control operations, if it is determined in step 204 that an end user no longer wishes to receive the multimedia stream 74 of the broadcast user 12, the method moves to step 206 where the broadcast user requests deletion of the replication action to the IP router control/management functionality 76 of the IP router 30 for a specified end user. Specifically, the broadcast user 12 requests deletion of the destination address corresponding to the end user from the replication action's destination list in the classification stage of the IP router. Next, in step 208, the control/management functionality 76, in response to the request, deletes the destination address utilized in the replication operation for the specified end user. Specifically, the IP router control layer deletes the destination address from the destination list corresponding to the filter rule configured in the classification state of the dataplane. Thus, the IP router will not replicate towards this destination after it is deleted from the destination list of the replication action. Next, the method then moves to step 202 where the broadcast user continues to perform signaling/control operations with the remaining end users.
However, in step 204, if it is determined that an end user wishes to receive the multimedia stream, the method moves from step 204 to step 210 where the broadcast user 12 requests to install a replication destination for a specified end user in the classification stage of the IP router data-plane 70. Specifically, the broadcast user requests the addition of the destination address corresponding to the new end user to the “replication action” in the classifier in the IP router. The method then moves to step 212 wherein the IP router control/management functionality 76 of the IP router 30 configures the filter within the IP router data-plane to invoke the replication action within the IP router. The management/control functionality 76 preferably exports an API to enable the content server 72 to install and configure these filters on demand. Specifically, the control layer of the IP router installs the new destination address to the destination list corresponding to the filter rule configured in the classification stage of the dataplane. Next, in step 214, the IP router performs the replication operation. In the preferred embodiment of the present invention, the IP router dataplane, while forwarding traffic, performs the replication of the UDP/IP multimedia packets to new destinations. Several operations are conducted within the IP router data-plane. Ingress decapsulation, packet classification, route lookup and egress decapsulation are performed on the stream 74. Additionally, this filtering stage includes the new filter action (i.e., replication of the stream). The multimedia stream 74 is thus replicated into a plurality of multimedia streams identical to the stream 74 with the exception of the destination. Specifically, identical and new UDP/RTP packets are created, but with different destinations. For each destination (e.g., DA, DP, SP) on a list of end users, the replication action is performed. Thus, the multimedia stream is multicast to a plurality of end users. The multimedia stream 74 continues to be replicated until a deletion or addition of destinations is requested. Thus, the method then moves from step 214 to step 202 where the broadcast user continues to perform signaling/control operations with the remaining end users.
The present invention provides a simple and innovative method and system of offloading the replication of video/audio UDP streams from low power or low bandwidth multimedia content generation devices, such as mobile phones or other portable communication devices, onto the IP routing data-plane. The IP routing data-plane is designed to handle line rate traffic and includes adequate processing power to perform the replication process. Since the replication of multimedia streams to a plurality of end users is conducted at the networking layer, there is no requirement for the use of expensive hardware (e.g., multimedia processors), located in the service provider's network, to process at the application layer. In addition, the present invention avoids the need for providing true multicast capability in the transport IP network.
Although preferred embodiments of the present invention have been illustrated in the accompanying drawings and described in the foregoing Detailed Description, it is understood that the invention is not limited to the embodiments disclosed, but is capable of numerous rearrangements, modifications, and substitutions without departing from the scope of the invention. The specification contemplates all modifications that fall within the scope of the invention defined by the following claims.