A method for transferring content includes requesting the content from a serving peer and sending the content to a requesting peer. requesting the content includes sending a request to a tracker, receiving a request token, a path identifier, and a first peer identifier from the tracker, and sending a request message to a second peer. The first peer identifier includes an identity of a first peer, and the request message includes the request token, the path identifier, and the first peer identifier. Sending the content includes receiving the request token and the path identifier from a third peer, sending a return message to a fourth peer, and transferring the content from the serving peer to the requesting peer through a transfer path. The return message includes the path identifier and a second peer identifier. The second peer identifier includes an identity of a fifth peer. The transfer path includes at least the second, fourth, and fifth peers.
|
20. A computer-readable device comprising instructions, which when loaded and executed by a processor, cause the processor to perform operations, the operations comprising:
receiving a request token, a path identifier, and a landing peer identifier in response to a request from a requesting peer in a first tree of a peer to peer network to contact a serving peer in a second tree of the peer to peer network, wherein the landing peer identifier includes an identity of a landing peer within the second tree other than the serving peer;
sending a request message and a signature message to a first peer in the first tree, wherein the request message includes the request token, the path identifier, and the landing peer identifier, wherein the signature message includes a random number of bits to prevent the first peer from determining an identity of the requesting peer; and
receiving the content from the serving peer through a transfer path, wherein the request token and the path identifier are received from a second peer in the second tree,
wherein a return message is sent to a third peer in the second tree, the return message including the path identifier and a jump point identifier, the jump point identifier including an identity of a fourth peer in the first tree other than the requesting peer; and
wherein the transfer path includes the first peer in the first tree, the third peer in the second tree, and the fourth peer in the first tree.
11. A method for providing content distribution with mutual anonymity, the method comprising:
receiving a request token, a path identifier, and a landing point identifier from a tracker in response to the tracker receiving a request for contacting a serving peer, wherein the landing point identifier includes an identity of a first peer other than the serving peer within a serving peer tree, wherein the serving peer tree includes the serving peer, the first peer, a second peer, and a third peer;
sending, by utilizing instructions from memory that are executed by a processor, a request message and a signature message to a fourth peer within a requesting peer tree, wherein the requesting peer tree includes a requesting peer, the fourth peer, and a fifth peer, wherein the request message includes the request token, the path identifier, and the landing point identifier, wherein the requesting peer tree is different from the serving peer tree, wherein the signature message includes a random number of bits to prevent the fourth peer from determining an identity of the requesting peer;
receiving the request token, the path identifier, and a jumping point identifier from the second peer, wherein the jumping point identifier identifies the fifth peer;
transmitting a return message to the third peer, wherein the return message includes the path identifier and the jumping point identifier; and
transmitting the content to the requesting peer through a transfer path including at least the third peer, the fourth peer, and the fifth peer.
1. A system for providing content distribution with mutual anonymity, the system comprising:
a memory that stores instructions;
a processor that executes the instructions to perform operations, the operations comprising:
receiving a request token, a path identifier, and a landing point identifier from a tracker in response to the tracker receiving a request for contacting a serving peer, wherein the landing point identifier includes an identity of a first peer other than the serving peer within a serving peer tree, wherein the serving peer tree includes the serving peer, the first peer, a second peer, and a third peer;
sending a request message and a signature message to a fourth peer within a requesting peer tree, wherein the requesting peer tree includes a requesting peer, the fourth peer, and a fifth peer, wherein the request message includes the request token, the path identifier, and the landing point identifier, wherein the requesting peer tree is different from the serving peer tree, wherein the signature message includes a random number of bits to prevent the fourth peer from determining an identity of the requesting peer;
receiving the request token, the path identifier, and a jumping point identifier from the second peer, wherein the jumping point identifier identifies the fifth peer;
transmitting a return message to the third peer, wherein the return message includes the path identifier and the jumping point identifier; and
transmitting the content to the requesting peer through a transfer path including at least the third peer, the fourth peer, and the fifth peer.
2. The system of
3. The system of
4. The system of
5. The system of
6. The system of
8. The system of
9. The system of
10. The system of
12. The method of
13. The method of
14. The method of
16. The method of
18. The method of
19. The method of
|
This application is a continuation of U.S. patent application Ser. No. 12/728,910 filed on Mar. 22, 2010, which is hereby incorporated by reference in its entirety.
The present disclosure generally relates to communications networks, and more particularly relates to content distribution with mutual anonymity.
Peer-to-peer (P2P) networks use diverse connectivity between participants in a network and the cumulative bandwidth of network participants, rather than conventional centralized resources where a relatively low number of servers provide a service or application. A pure P2P network does not have traditional clients or servers, but only equal peer nodes that simultaneously function as both “clients” and “servers” to the other nodes on the network.
P2P networks can be useful for sharing content files containing audio, video, or other data in digital format. It is estimated that P2P file sharing, such as BitTorrent, represents greater than 20% of all broadband traffic on the Internet.
It will be appreciated that for simplicity and clarity of illustration, elements illustrated in the Figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements are exaggerated relative to other elements. Embodiments incorporating teachings of the present disclosure are shown and described with respect to the drawings presented herein, in which:
The use of the same reference symbols in different drawings indicates similar or identical items.
The numerous innovative teachings of the present application will be described with particular reference to the presently preferred exemplary embodiments. However, it should be understood that this class of embodiments provides only a few examples of the many advantageous uses of the innovative teachings herein. In general, statements made in the specification of the present application do not necessarily limit any of the various claimed inventions. Moreover, some statements may apply to some inventive features but not to others.
In an embodiment, communications network 100 can also include an originating server 116. Peer system 110 can receive content from originating server 116 or other sources, and make the content available to peer systems 112 and 114 through the P2P network. For example, peer system 112 can request the content from peer system 110, and peer system 110 can provide the content to peer system 112.
In an embodiment, P2P network 200 can be set up by a service provider for distributing content, such as data or video. Participating clients can join the P2P network. When a peer, such as peer 220, requests content from the service provider, the peer can be redirected to one or more of the participating peers by tracker 202. In a particular embodiment, tracker 202 may verify that the requesting peer has the appropriate access rights for the requested content.
In an embodiment, a requesting peer (RP) 220 can contact tracker 202 to identify a path to a peer that can provide a content file. The content file can include a digital audio file such as an MP3, a digital video file, a data file, a software program, a software update, or other type of digital content. Tracker 202 can provide a list of peers 218, 214, and 208 along a path to a serving peer (SP) 204. At least one of the peers identified by tracker 202 can have the serving peer as a neighbor. Peer 204 can have the content file available for sharing with peer 220. Peers 218, 214, and 208 can act as intermediate nodes (INs) for communication between peer 220 and peer 204. In a particular embodiment, tracker 202 may not provide the identity of peer 204 to peer 220.
Peer 220 can send a message along a path comprised of peers 218, 214, and 208 with the expectation that the message can reach a peer able to provide the requested content. Additionally, peers 218, 214, and 208 can broadcast the message to all of their neighbors, so that the message can reach peer 204. Peer 204 can select peer 214 along the path and can establish a return path to peer 214 through peers 206 and 210. Peer 204 can send a return message to peer 214 along the return path. Once the return message reaches peer 214, a communication path (peers 206, 210, 214, and 218) including a portion of the path (peers 218 and 214) and a portion of the return path (206, 210, and 214) can be established between peers 204 and 220. The content file can be transferred from peer 204 to peer 220 through peers 206, 210, 214, 218 without peer 204 and peer 220 knowing the identity of the serving peer and the requesting peer. Additionally, peers 206, 208, 210, 214, and 218 can be unaware of the identity of the source and requesting peers.
In an embodiment, it can be desirable to maintain the anonymity of the peers within the P2P network. Specifically, the P2P network can ensure that no peer including serving peer can know which peer is requesting a particular content and that no peer including the requesting peer can know which peer is providing the content. Additionally, only the serving peer and the requesting peer can know the nature of the content. In this way, a compromised peer or external observer may not be able to identify which peer are requesting a particular content and which peers are making the particular content available to others.
In a particular embodiment, the P2P network can maintain k-anonymity of the source and requesting peer. As used herein, k-anonymity ensures that the source or requesting peer is indistinguishable from k good peers. An attacker can guess the identity of the source or requesting peer and claim that with a probability of 1/k the guess is correct.
In another embodiment, the P2P network can maintain community anonymity of the source and requesting peers. Community anonymity differs from k-anonymity in that the probability of the guess being correct can be unknown to the attacker. As used herein, community anonymity ensures that the source or requesting peer is indistinguishable from a set of x good peers with the precise value of x unknown to an attacker. A guess can be correct with a probability of 1/x. However, since the value of x is unknown to the attacker, the attacker cannot place an upper limit on the value of x. Thus, from the attacker's perspective, the probability of the guess being correct can be infinitely small.
At 310, the requesting peer can create a path including the intermediate nodes. The path can include the intermediate nodes in any order. Optionally, the path can include one or more additional peers selected by the requesting peer. When the path includes additional peers, the additional peers can be placed in the path between the requesting peer and the intermediate nodes provided by the tracker. At 312, the requesting peer can construct a request message. The request message can include information about the path and the path identifier. In an embodiment, the message can encapsulate identifiers for the intermediate nodes using their public keys so that each node can decrypt a portion of the message to identify the two immediate neighbors on the path.
In an example, the path can be RP→A→B→D→C, where RP is the requesting peer and A, B, C, and D are intermediate nodes. The message can include a random number of bits (PADRP) to substantially prevent nodes B and D from knowing that they are communicating with an end node of the path. Additionally, the inclusion of PADRP can substantially prevent node A from knowing RP is the requesting peer. The message can be as follows:
M1=E(PubKeyA, [previous_node=RP, next_node=B, path_ID=Pobj;
E(PubKeyB, [previous_node=A, next_node=D, path_ID=Pobj;
E(PubKeyD, [previous_node=B, next_node=C, path_ID=Pobj;
E(PubKeyC, [previous_node=D, next_node=NULL, path_ID=Pobj;
PADRP])])])])
At 314, the requesting peer can construct an initial signature message. The signature message SigRP can include a random number of bits, such as PADRP. By utilizing a random number of bits as the initial signature message, the intermediate nodes can be prevented from knowing the identity of the requesting peer. At 316, the requesting peer can send the request token, the path message, and the initial signature message to the first peer in the path, for example peer A.
At 318, the intermediate node can decrypt the path message. Decrypting the path message can allow the intermediate node to read the next portion of the path message. The next portion of the path message can include the path identifier and the immediate neighbors to the intermediate node along the path. A remaining portion of the path message can be further encrypted with the public keys of remaining peers along the path and can be unreadable by any of the other intermediate nodes.
At 320, the intermediate node can add the path identifier and a previous portion of the signature message and sign the signature message with its private key. By modifying the signature in this way, the signature can be later used to verify the request did pass through the intermediate node. In an embodiment, the intermediate node can be peer A. Peer A can produce a random sequence of bits of arbitrary length (PADA). Peer A can encrypt its peer identifier, the object identifier, the length of PADA, PADA itself, and the previous portion of the signature message. The inclusion of PADA can substantially prevent other nodes from inferring the path length or their position in the path from the signature message. Additionally, the increasing size of the signature message and the decreasing size of the path message as the messages progress along the path can substantially prevent an observer from determining the number of hops away from the requesting peer. For example, the signature message can be SigA=E(PrivKeyA,[A∥Pobj∥L(PADA)∥PADA∥SigRP])
At 322, the intermediate node can store the route identifier. At 324, the intermediate node can broadcast the route token and path identifier to the neighbors. At least one of the intermediate nodes selected by the tracker can be a neighbor of the serving peer, so that the serving peer can receive the route token and the path identifier as a broadcast from one of the intermediate nodes.
At 326, the intermediate node can determine if it is the last peer along the path. For example, the intermediate node can be the last peer along the path when the next peer identifier in the path message is NULL. At 328, when the intermediate node is the last node along the path, the intermediate node can return the signature message back along the path towards the requesting peer. Each intermediate node along the path can store the signature message and forward the signature message to the previous peer in the path in the request path.
Alternatively, at 330, the intermediate node can determine the next peer along the path. The next peer along the path can be indicated in the route message. At 332, the intermediate node can forward the request token, the path message, and the signature message to the next intermediate node along the path.
At 412, the serving peer can construct a return path message. The return path message can include information about the return path, a return path identifier (PRobj), and the original path identifier (Pobj). In an embodiment, the return path message can encapsulate identifiers for the intermediate nodes of the return path using their public keys. Each node can decrypt a portion of the return path message using its private key. The decrypted portion can identify the previous intermediate node and the next intermediate node along the return path, as well as the original path identifier and the return path identifier.
In an example, the return path can be SP→E→F→D, where SP is the serving peer, E and F are additional peers selected by the serving peer, and D is one of the original intermediate nodes identified by the serving peer. The return path message can include a random number of bits (PADSP) to prevent nodes E and F from knowing that they are communicating with an end node of the path. The message can be as follows:
M1=E(PubKeyE, [previous_node=SP, next_node=F, path_ID=Pobj;
E(PubKeyF, [previous_node=A, next_node=D, path_ID=Pobj;
E(PubKeyD, [previous_node=B, next_node=NULL,
return_path_ID=PRobj, path_ID=Pobj; PADSP])])])
At 414, the serving peer can send the return path message to the first intermediate node along the return path, for example node E. At 416, the return intermediate node can decrypt the return path message. Decrypting the return path message can allow the return intermediate node to read the next portion of the path message. The next portion of the path message can include the return path identifier and the immediate neighbors to the intermediate node along the return path. A remaining portion of the return path message can be further encrypted with the public keys of remaining peers along the path.
At 420, the intermediate node can determine if it is the original intermediate node. For example, the next node identifier in the return path message can be NULL when the peer is the original intermediate node selected by the serving peer. At 422, when the intermediate node is not the original intermediate node selected by the serving peer, the intermediate node can record the return path identifier. At 424, the intermediate node can forward the return path message to the next node on the return path.
Alternatively, when the intermediate node is the original intermediate node, the intermediate node can record completion of a transfer path, as illustrated at 426. The transfer path can include a portion of the return path selected by the serving peer and an initial portion of the original path from the requesting peer to the intermediate node selected by the serving peer. In an embodiment, the intermediate node can compare the original path identifier from the return path message to the path identifier stored previously during creation of the forward path to verify the path.
At 428, the intermediate node can send the signature to the serving peer back along the return path. Each intermediate node can forward the signature message until it reaches the serving peer. At 430, the serving peer can verify that all intermediate nodes selected by the tracker have signed the signature. In an embodiment, the serving peer can know the identities of the intermediate nodes selected by the tracker based on the information included in the request token. The serving peer can decrypt the signature message by systematically trying the public keys for each of the intermediate nodes selected by the tracker. In an example where the path is RP→A→B→D→C, the signature can be as follows:
SigA= E(PrivKeyC,[C||Pobj||L(PADC)||PADC||
E(PrivKeyD,[D||Pobj||L(PADD)||PADD||
E(PrivKeyB,[B||Pobj||L(PADB)||PADB||
E(PrivKeyA,[A||Pobj||L(PADA)||PADA||SigRP])])])])
In the example, the serving peer can systematically try to decrypt the above signature message with the public keys from peers A, B, C, and D. In the first step, the serving peer can try the public keys from peers A, B, and C, successfully decrypting the first part of the message with PubKeyC. Since the public key of peer C successfully decrypted the first part of the message, the serving peer may not try the public key for peer D. In the second step, the serving peer can try the public keys from peers A, B, and D, successfully decrypting the second part of the message with PubKeyD. Since the public key for peer C was utilized to decrypt a previous part of the message, the serving peer may not try to decrypt subsequent parts with the public key for peer C. In the third step, the serving peer can try the public keys from peers A and B, successfully decrypting the third part of other message with PubKeyB. In the final step, the serving peer can decrypt the fourth part of the message with PubKeyA. The serving peer can verify that each of the intermediate nodes identified by the tracker was used in the path since the public key from each intermediate node was used to decrypt the signature.
At 432, the serving peer can send the content to the requesting peer along the transfer path. The serving peer can elect to send the content after verification that all intermediate nodes identified by the tracker were used in the path. In an embodiment, the content can be encrypted with an encryption key provided by the tracker to prevent the intermediate nodes from accessing the content. For example, an encryption key can be provided in the request token for the serving peer and a decryption key can be provided to the requesting peer.
In an embodiment, requesting peer 508 can contact tracker 502 to request a source for a content file. The content file can include a digital audio file such as an MP3 file, a digital video file, a data file, a software program, a software update, or other type of digital content. Tracker 502 can provide a landing point identifier, a request token, and a path identifier. The landing point identifier can include the identity of landing point 516. The request token can be an encrypted message to the serving peer identifying the requested content. The encrypted message may be encrypted with a public key of the serving peer so that only the serving peer can decrypt the message. Requesting peer 508 can forward the request to neighboring peer 510, which can forward the request to another neighbor 512. Neighbor 512 can choose to forward it to another neighbor in the same tree or forward the request to landing point 516. If neighbor 512 forwards the request to landing point 516, neighbor 512 is considered a jumping point. Landing point 516 can forward the request throughout tree 506 by flooding the request to all the nodes including serving peer 518.
In an embodiment, the path can be constructed to avoid congested peers. Congested peers can be peers that are unable to handle the content transfer, such as due to limited bandwidth or other resources. When a first peer, such as neighboring peer 510, forwards the request to a second peer, such as neighboring peer 512, the second peer can determine if the resources are available to handle the request, specifically if the second peer can participate in transferring the content from the serving peer to the requesting peer. If the second peer determines that the resources are not available, the second peer can provide the first peer with a negative acknowledgement. Upon receiving the negative acknowledgement, the first peer can try additional neighboring peers or forward the request to the landing point. In a particular embodiment, when the first peer receives a negative acknowledgement from all of the neighboring peers other than the peer it received the request from, the first peer may send a request to the tracker for an additional peer to join the tree by connecting to the first peer.
Serving peer 518 can decrypt the request token to identify the requested content and forward a response to intermediate node 520, and intermediate node 520 can forward the response to intermediate node 522. Intermediate node 522 can forward the response to jumping point 512, thus enabling the establishment of a connection between serving peer 518 and requesting per 508 via intermediate node 522, jumping point 512, and other nodes. The formation of the path from serving peer 518 to jumping point 512 can be similar to the formation of the path from requesting peer 508 to landing point 516, including techniques for selecting the next neighbor peer and avoiding congestion. The connection can be used to transfer the requested content from serving peer 518 to requesting peer 508. The communication can be encrypted to prevent peers 510, 512, 520, and 522 or an outside observer from viewing the communication and determining the identity of the content.
At 608, the tracker can select an existing peer within the tree. The existing peer within the tree can be randomly chosen from the plurality of peers within the tree. At 610, the tracker can provide information about joining the tree to the joining peer. The information can include a tree identifier, an existing peer identifier, and a joining certificate. At 612, the joining peer can send a request to the existing peer including the tree identifier and the joining certificate. At 614, the existing peer can add the joining peer as a neighbor and acknowledge the request. The existing peer can check the tree identifier and joining certificate to ensure that the existing peer belongs in the tree. Verifying the tree identifier and joining certificate can substantially prevent peers from joining trees without permission from the tracker. Alternatively, the existing peer can contact the tracker to verify the joining peer belongs in the tree. At 616, the joining peer can add the existing peer as a neighbor in the tree.
In an embodiment, each peer can join more than one tree. Joining multiple trees can increase the number of paths for the peer to obtain content. Multiple paths may be necessary for parallel content transfer. Further, by using multiple paths to transfer different parts of the same content, the likelihood of an attacker identifying the content can be decreased.
At 712, the requesting peer can forward the request token, the path identifier, and the landing point identifier to a neighboring peer. The neighboring peer can store the path identifier, as illustrated at 714. Additionally, the neighboring peer can determine if it will forward the request to the landing point, as illustrated at 716. In an embodiment, the neighboring peer can randomly determine to forward the request to the landing point. Alternatively, when no additional peers are available for forwarding the request, the neighboring peer can forward the request to the landing point. For example, the peer may be a leaf node with no additional peers, or the additional peers may refuse to transfer the content, such as when they have insufficient bandwidth for transferring the content. At 718, when the neighboring peer is not going to forward the request to the landing point, the neighboring peer can forward the landing point identifier, the path identifier, and the request token to another peer.
Alternatively, at 720, when the neighboring peer is going to forward the request to the landing point, the neighboring peer, acting as the jumping point, can forward the path identifier and the request token to the landing point. Additionally, the neighboring peer can attach its own identifier as the jumping point (JP) identifier. The landing point can receive the request token, the path identifier, and JP identifier. At 722, the request token, the path identifier, and a jumping point identifier can be flooded to all neighboring peers of the landing point within the tree including the serving peer. The jumping point identifier is the identity of the peer forwarding the request token to the landing point. Specifically, the landing point can forward the request to each neighboring peer within the tree. Each neighboring peer can forward the request to all their neighboring peers except the peer from which they received the request. This process can continue until each peer within the tree has received the request. In an embodiment, peers within the serving peer tree may not store the path identifier received during flooding, unlike forwarding peers in the requesting peer's tree.
At 724, the peer can determine if it is the serving peer. For example, the peer can attempt to decrypt the request token. If the peer is successful at decrypting the request token, the peer is the serving peer. When the peer is not the serving peer, the peer can forward the request token, the jumping point identifier, and the path identifier to all its neighbors within the tree, as illustrated at 722.
Alternatively, when the peer is the serving peer, the serving peer can identify the requested content based on the request token, as illustrated at 726. Additionally, the serving peer can forward the request to its neighboring peers. Continuing to forward the request throughout the rest of the tree can substantially reduce the likelihood of identifying the serving peer.
At 728, the serving peer can forward a response to a neighboring peer. The neighboring peer can be a downstream peer or an upstream peer. A downstream peer can be a peer to whom the flooded request is forwarded, and an upstream peer can be a peer from which the flooded request is received. At 730, the neighboring peer can store the path identifier, and at 732, the neighboring peer can determine if it will forward the response to the jumping point. This can be similar to determining if a neighbor peer will forward the request to the landing point at 716. For example, the peer can forward the response to the jumping point when the peer randomly decides to forward the response to the jumping point, or when no neighboring peers are available for forwarding the response. For example, no neighboring peers may be available when the peer is a leaf node, or when its neighboring peers refuse to participate in the connection, such as when they have insufficient bandwidth. When the peer is not going to forward the response to the jumping point, the peer can forward the response to a neighboring peer as illustrated at 728.
Alternatively, when the peer is going to forward the response to the jumping point, a connection between the serving peer and the requesting peer can be established, as illustrated at 734. At 736, the serving peer can transfer the content to the requesting peer through the connection including neighboring peers in the serving peer tree, the jumping point and neighboring peers in the requesting peer tree. In an embodiment, communication between the serving peer and the requesting peer can be encrypted to prevent an attacker from identifying the content being transferred. Once the connection between the serving peer and the requesting peer has been established without the serving peer and requesting peer knowing the identity of the other, the serving peer and requesting peer can exchange a session key and other information. The session key may be based on a symmetric key pair, so that is it more efficient to encrypt and decrypt the content.
At 806, the tracker can determine if more than one neighbor peer has contacted the tracker regarding the loss of the exiting peer. If only one neighbor peer contacts the tracker, then the exiting peer can be a leaf peer, as illustrated at 808, and the loss can be safely ignored. Alternatively, if more than one neighboring peer contacts the tracker, then the tree may have been divided into multiple subtrees and the multiple subtrees may have to be reconnected. At 810, the tracker selects one of the neighboring peers as the new connection point. The connection point can be selected at random from the neighbor peers contacting the tracker regarding the loss of the exiting peer. At 812, the tracker notifies each of the remaining neighbor peers of the new connection point. The remaining neighbor peers contact the connection point, as illustrated at 814. For example, the neighboring peers can send a request to the connection point to establish a connection. The request can be similar to the request sent when a peer joins the P2P network. At 816, the connection point can add the peers as neighbors and acknowledge the request, and at 818, the neighbor peers can add the connection point as a neighbor.
In a networked deployment, the computer system may operate in the capacity of a server or as a client user computer in a server-client user network environment, or as a peer computer system in a P2P (or distributed) network environment. The computer system 900 can also be implemented as or incorporated into various devices, such as a personal computer (PC), a tablet PC, an STB, a personal digital assistant (PDA), a mobile device, a palmtop computer, a laptop computer, a desktop computer, a communications device, a wireless telephone, a land-line telephone, a control system, a camera, a scanner, a facsimile machine, a printer, a pager, a personal trusted device, a web appliance, a network router, switch or bridge, or any other machine capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that machine. In a particular embodiment, the computer system 900 can be implemented using electronic devices that provide voice, video or data communication. Further, while a single computer system 900 is illustrated, the term “system” shall also be taken to include any collection of systems or sub-systems that individually or jointly execute a set, or multiple sets, of instructions to perform one or more computer functions.
The computer system 900 may include a processor 902, such as a central processing unit (CPU), a graphics processing unit (GPU), or both. Moreover, the computer system 900 can include a main memory 904 and a static memory 906 that can communicate with each other via a bus 908. As shown, the computer system 900 may further include a video display unit 910 such as a liquid crystal display (LCD), an organic light emitting diode (OLED), a flat panel display, a solid-state display, or a cathode ray tube (CRT). Additionally, the computer system 900 may include an input device 912 such as a keyboard, and a cursor control device 914 such as a mouse. Alternatively, input device 912 and cursor control device 914 can be combined in a touchpad or touch sensitive screen. The computer system 900 can also include a disk drive unit 916, a signal generation device 918 such as a speaker or remote control, and a network interface device 920 to communicate with a network 926. In a particular embodiment, the disk drive unit 916 may include a computer-readable medium 922 in which one or more sets of instructions 924, such as software, can be embedded. Further, the instructions 924 may embody one or more of the methods or logic as described herein. In a particular embodiment, the instructions 924 may reside completely, or at least partially, within the main memory 904, the static memory 906, and/or within the processor 902 during execution by the computer system 900. The main memory 904 and the processor 902 also may include computer-readable media.
The illustrations of the embodiments described herein are intended to provide a general understanding of the structure of the various embodiments. The illustrations are not intended to serve as a complete description of all of the elements and features of apparatus and systems that utilize the structures or methods described herein. Many other embodiments may be apparent to those of skill in the art upon reviewing the disclosure. Other embodiments may be utilized and derived from the disclosure, such that structural and logical substitutions and changes may be made without departing from the scope of the disclosure. Additionally, the illustrations are merely representational and may not be drawn to scale. Certain proportions within the illustrations may be exaggerated, while other proportions may be minimized. Accordingly, the disclosure and the FIGs. are to be regarded as illustrative rather than restrictive.
The Abstract of the Disclosure is provided to comply with 37 C.F.R. §1.72(b) and is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description of the Drawings, various features may be grouped together or described in a single embodiment for the purpose of streamlining the disclosure. This disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter may be directed to less than all of the features of any of the disclosed embodiments. Thus, the following claims are incorporated into the Detailed Description of the Drawings, with each claim standing on its own as defining separately claimed subject matter.
The above disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments which fall within the true spirit and scope of the present disclosed subject matter. Thus, to the maximum extent allowed by law, the scope of the present disclosed subject matter is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.
Lee, David, Yu, Fang, Gopalakrishnan, Vijay, Ramankrishnan, Kadangode K.
Patent | Priority | Assignee | Title |
9609056, | Mar 29 2014 | Google Technology Holdings LLC | Methods for obtaining content from a peer device |
9887973, | Jun 03 2015 | Microsoft Technology Licensing, LLC | Private peer-to-peer data transfers |
Patent | Priority | Assignee | Title |
7873690, | Mar 14 2008 | MAGNOLIA LICENSING LLC | Method for managing requests for obtaining peer identifiers to access stored contents in P2P mode, and associated management device and network equipment |
20060023646, | |||
20060218222, | |||
20070143770, | |||
20080072037, | |||
20080120416, | |||
20100153578, | |||
20100161817, | |||
20100250917, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Mar 16 2010 | YU, FANG | AT&T Intellectual Property I, L P | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 030998 | /0603 | |
Mar 19 2010 | RAMAKRISHNAN, KADANGODE K | AT&T Intellectual Property I, L P | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 030998 | /0603 | |
Mar 19 2010 | GOPALAKRISHNAN, VIJAY | AT&T Intellectual Property I, L P | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 030998 | /0603 | |
Aug 13 2013 | AT&T Intellectual Property I, L.P. | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Nov 16 2015 | ASPN: Payor Number Assigned. |
Jan 16 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 11 2023 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Aug 25 2018 | 4 years fee payment window open |
Feb 25 2019 | 6 months grace period start (w surcharge) |
Aug 25 2019 | patent expiry (for year 4) |
Aug 25 2021 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 25 2022 | 8 years fee payment window open |
Feb 25 2023 | 6 months grace period start (w surcharge) |
Aug 25 2023 | patent expiry (for year 8) |
Aug 25 2025 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 25 2026 | 12 years fee payment window open |
Feb 25 2027 | 6 months grace period start (w surcharge) |
Aug 25 2027 | patent expiry (for year 12) |
Aug 25 2029 | 2 years to revive unintentionally abandoned end. (for year 12) |