System for remote game access

Information

  • Patent Grant
  • 10933314
  • Patent Number
    10,933,314
  • Date Filed
    Tuesday, October 30, 2018
    6 years ago
  • Date Issued
    Tuesday, March 2, 2021
    3 years ago
Abstract
A system for allowing a user to remotely access a game includes: a game console; a remote console client configured to receive a game control signal; and a remote console server. The remote console server includes an audio and video encoder configured to receive an audio output and a video output from the game console and to convert the audio output and the video output to a network packet. The remote console server also includes: a game controller emulation unit and a network interface configured to send and receive the network packet. The game controller emulation unit is configured to receive a game controller signal from the game console and to send the game controller signal to the remote console client and to receive a game controller input from the remote console client and send the game controller input to the game console.
Description
INCORPORATION BY REFERENCE TO ANY PRIORITY APPLICATIONS

Any and all applications for which a foreign or domestic priority claim is identified in the Application Data Sheet as filed with the present application are hereby incorporated by reference under 37 CFR 1.57.


BACKGROUND OF THE INVENTION

Typical game consoles are designed to output audio and video signals to a display such as a television system. Users generally play console games by going physically to the console. A system that allows users to play console games from remote locations over a network would allow users to play a console games without physically going to the location of the game console.


SUMMARY OF THE INVENTION

Embodiments of the present invention enable users to play console games from remote locations in real-time, over a network. Embodiments also provide for a system to allow users to determine which game consoles are available and provide a system to manage the access and accounting for multiple users, thereby creating a virtual arcade.


Embodiments of the present invention bring the game console to the user as opposed to the current static configuration where the user must go to the console. Embodiments of the present invention are configured to allow remote access to various types of game consoles and are not limited to systems that are strictly designed for playing games. Game consoles include standard computers that are capable of performing many other functions in addition to allowing the user to play games. Embodiments comprise a remote console server (RCS), which further comprises a console virtualization engine (CVE). In certain embodiments, the RCS comprises an audio and video encoder that digitizes and compresses the audio and video output of a game console and sends them as TCP/IP network packets to a remote console client (RCC). The RCS may also comprise a game controller emulation (GME) unit that sends game controller signals from the console to the RCC and receives game controller input from the RCC and passes it to the game console. In addition, in certain embodiments the RCS may comprise a memory card emulation (MCE) unit that emulates the memory card of the game console.


The memory card of the game console is used to save user game configuration for games played on the console. By emulating this function, the RCS allows user game settings to be uploaded from the game console for storing in a repository. The emulation unit also allows user game setting information to be downloaded to the RCS so that it can be used by the game console. This allows a user to play games on any virtualized console, as the user's game configurations are enabled to migrate to different units. Thus, the RCS preserves the continuity of game playing experience for the user, enabling the impression of playing from the same game console unit.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a schematic of a remote console server and a game console of one embodiment of the present invention.



FIG. 2 is a schematic of a system in one embodiment of the present invention.



FIG. 3 is a schematic of subsystems used in a remote console client in one embodiment of the present invention.



FIG. 4 is a schematic of a system in one embodiment of the present invention.



FIG. 5 is a schematic of a system in one embodiment of the present invention.



FIG. 6 is a schematic of a system in one embodiment of the present invention.



FIG. 7 is a schematic of a system in one embodiment of the present invention.



FIG. 8 is a schematic of a remote console server and a game console of one embodiment of the present invention.



FIG. 9A is a logic flowchart for a virtual arcade session request in one embodiment of the present invention.



FIG. 9B is a logic flowchart for a virtual arcade session request in one embodiment of the present invention.



FIG. 10 is a logic flowchart for a server virtual arcade game session processing start in one embodiment of the present invention.



FIG. 11 is a flowchart for server game emulation logic in one embodiment of the present invention.



FIG. 12 is a logic flowchart for game removable memory subsystem in one embodiment of the present invention.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT

Referring initially to FIGS. 1-4, an RCS 100 is configured to communicate with a game console 200 and a remote console client (RCC) network 300. The physical connection between the game console 200 and RCS 100 can be wired or wireless. RCS 100 further comprises a console virtualization engine (CVE) 110 and a network interface 120. CVE 110 further comprises an audio and graphics/video encoder 111, a controller emulation unit 112, and a memory card emulation unit 113. Game console 200 generates an audio and graphics output 211 and receives a game controller input 212 and a memory card input 213. Game console 200 further comprises a disk access unit 220 and a network IO unit 230 for accessing a console game network 210. RCC network 300 comprises at least one individual RCC 310. In certain embodiments, the various components of the system are connected to the internet via a local area network (LAN) 411 and router 412.


RCC 310 regenerates the signals received from audio and graphics output 211. RCC 310 also accepts game control signals from the user through a game controller 311, a keyboard 312 or a mouse 313 connected to it. Through a controller translator 314, RCC 310 further encodes and transmits these game control signals in packet 315 (shown in FIG. 3) back to RCS 100 via virtual game play session manager (VGSM) 375. RCS 100 then converts packet 315 to controller input signals 317 in controller emulation unit 112 expected by game controller input 212 of game console 200. In certain embodiments, RCS 100 is configured to receive game controller signals from the game controller input 212 and send them to RCC 310. For example, some game controllers are configured to vibrate or illuminate based on game controller signals received from game controller input 212.


In the embodiment shown in FIG. 3, RCC 310 also includes a microphone input 350 that passes through an audio encoder 351 and is converted to packet 318. Packet 318 is sent to RCC 310 units connected to RCS 100, thereby allowing users to have verbal interactions while playing or viewing a game on game console 200.


Audio and graphics output 211 of game console 200 is sent through the audio and graphics encoder 111 of RCS 100 to VGSM 375 of RCC 310. After VGSM converts output 211 to a packet 316, a low latency audio and video decoder 319 generates a video output 320 and an audio/speaker output 321. In certain embodiments, RCC 310 also comprises a stream packet receiver 322 that communicates with a voice chat/audio out decoder 323 that is sent to speaker output 321. Stream packet receiver 322 and voice chat/audio out decoder 323 allow multiple users to verbally communicate with one another while playing a game.


In certain embodiments, the RCS may adapt the video quality and latency to the available bandwidth by changing encoding parameters to improve users' real-time experience. The video quality and latency may be adjusted by the user or, alternatively, may be adjusted automatically by the system. Further, the RCS may adapt the video quality and latency depending on the type of images being sent to the RCC. For example, in Text Mode, the RCS can send images at slow frame rates but high resolutions. This mode may be useful when the user needs to read game text during game setup or game play. In another embodiment, the Text mode encoding may be implemented as a background process and the data may be transmitted as a sub-channel to the primary game stream. RCC users can dynamically switch between real-time interactive game stream and Text Mode views as necessary. Certain embodiments may also comprise a TV Mode, in which the RCS can send video images using higher compression, higher latency and higher quality video transmission.


In certain embodiments, RCS 100 possesses some or all of the following capabilities:


1. Identifying game controllers plugged into the user's RCC, automatically querying, and retrieving compatible controller configuration from a global server when the user initiates game play;


2. Caching controller configurations for future use;


3. Automatically loading game help information, such as the function of game pad controls in a game;


4. Adjusting to different game console controller types and game save memory emulation system; and


5. Downloading new modes as new console platforms or updates to console platforms become available.


In certain embodiments, RCC 310 possesses some or all of the following capabilities:


1. Sufficient computing power to decode and regenerate audio and video streams from RCS 100 in real-time;


2. TCP/IP network connectivity with sufficient bandwidth to accept the packet stream from RCS 100;


3. An I/O interface to accept a controller adapter that allows a game controller 311 to be connected or other I/O capabilities that are capable of generating signals that can be interpreted as game controller functions; and


4. A microphone interface to allow the user to connect microphone 350 to RCC 310.


There are a wide range of devices that are known to meet these criteria. As shown in FIG. 2 for example, RCC 310 may comprise a desktop computer 315, a laptop (mobile) computer 320, a hand-held device such as a personal digital assistant (PDA) 325, or a television set top box 330. Embodiments of this disclosure are compatible with each of these platforms as well as other similar devices.


Multi-Player Capability


Software running on RCS 100 enables multiple players to share game console 200, such as is currently available in multi-controller, multiplayer games. Each RCS 100 announces its presence to other RCS 100 systems on the local network. Users may then initiate connections to available RCS 100 systems.


Each RCC 310 may be logically connected to at least one input device such as game controller 311, keyboard 312 or mouse 313. Controller inputs from each RCC 310 are forwarded to the designated input on RCS 100. An RCC 310 that can control a port on game console 200 is called “active”. Additionally, RCS 100 may allow more users than the game allows as players to connect in passive or monitor-only sessions. These passive RCCs 310 receive signals from audio and graphics output 211 but no controller input is passed back to RCS 100. Both active and passive users may also communicate verbally through their RCCs. Thus, many users can view a game remotely and virtually experience the feeling of being in the same room. RCS 100 enables an active RCC 310 to hand over control of its controller to a passive RCC 310, thereby making the passive RCC 310 active and causing the active RCC 310 to become passive.


Desired Characteristics


Certain physical network criteria, such as sufficient downstream network bandwidth, are beneficial for providing an optimal remote gaming experience for users. Downstream bandwidth is the network bandwidth needed to send packets from RCS 100 to the RCC network 300. Depending on the RCC unit 310 characteristics (display size, resolution and desired audio quality), bandwidths of between 256 Kb/sec (portable) and 8 Mb/sec (high definition) are needed per user. This is within the capacity of wired and wireless local area networks, such as is typically available in a home or commercial environment. Smaller portable devices generally require less bandwidth because of the smaller display. A wireless network, for example as may exist at a hotspot can sustain many remote play sessions concurrently depending on the network and the specific device characteristics. A 54 Mb/sec wireless network at 50% efficiency could support 50 concurrent remote play users at 384 Kb/sec each. Similarly, the downstream bandwidth of broadband connections (Cable/DSL/Wireless) of 384 Kb/sec and greater is able to support at least one remote play user. RCS 100 is designed to support network bandwidth of 100 Mb/sec and higher and is therefore able to host many users.


Sufficient upstream bandwidth is also desirable to provide an optimal remote gaming experience for users. Upstream bandwidth is the bandwidth needed to transmit controller commands from RCC network 300 to RCS 100. A bandwidth of 2 Kb/sec is typically needed for this function. Additionally, voice grade audio for voice sharing typically needs about 8 Kb/sec. Thus, a total of 10 Kb/sec is generally needed per user. This is within the upstream bandwidth of typical broadband networks which generally have upstream bandwidths of 64 Kb/sec and higher. Local area wired/Wi-Fi networks typically have symmetric bandwidth.


Low network latency is also desirable to provide an optimal remote gaming experience for users. To maintain the experience that users obtain from direct play of console games, the time for packets to travel from RCS 100 to RCC 310 (latency) should be low, of the order of less than 20 milliseconds (ms). On a local area network, latencies are generally significantly lower (<2 ms). Network latencies across the Internet and wide area networks (WAN), however can vary much more significantly. This is generally so when greater geographic distances exist between the communicating parties. Embodiments of the present disclosure will enable an RCC 310 to automatically locate a RCS 100 that is hosting user-desired games that are “closest” to them (lowest latency) and thereby help ensure an optimal game experience.


Video and audio encode/decode latency is also desirable to provide an optimal remote gaming experience for users. Embodiments of the present disclosure provide RCS 100 to RCC 310 encode-decode latencies of less than 100 ms. This is within the bounds that will ensure user perception of direct play experience.


Global Servers


In certain embodiments, remote console play may benefit from the following features:


1. Users may need a unified way of locating RCS 100 and games on the network.


2. Upon locating RCS 100, a method for reserving it for exclusive use may be needed until the session is terminated.


3. An accounting method that allows for the user to access the device without requiring local re-authentication and conducts appropriate time tracking and billing.


Referring now to FIG. 4, embodiments of the present disclosure comprise one or more global servers that provide these functions, enabling the distributed network of RCS 100 to be easily accessed by users and providers. The servers can be owned by a central company that charges a percentage of the fee billed to RCC 310 users who pay to access RCS 100. The central company may also profit from advertisements displayed on RCC 310.


In certain embodiments, the following 3 servers can be used to enable this service to users:


1. Global Registry Server (GRS) 400: For enabling easy discovery of available RCS 100 and games hosted by them.


2. Global Configuration Server (GCS) 420: For persistent storage of user game settings.


3. Global Authentication Server (GAS) 440: For authenticating access to RCS 100 from RCC 310.


GRS 400, GCS 420 and GAS 440 are connected to the internet via a local area network (LAN) 411 and router 412. Software on RCS 100 and RCC 310, with user input, communicates with these servers 400, 420 and 440 to ensure a user-friendly experience accessing remote play network devices and services. While GRS 400, GCS 420 and GAS 440 serve different functions within the system, in certain embodiments, all functions could be performed by one physical global server.


Global Registry Server (GRS)


In certain embodiments, each game console 200 is allowed to play a single game at an instant in time. GRS 400 will allow users to register their RCS 100 and track/monitor its availability. When RCS 100 becomes busy because a game is being played on game console 200, RCS 100 reports this to GRS 400. Similarly, RCS 100 may regularly register with the FRS 400 and report when it becomes available. RCC 310 users search GRS 400 to locate and reserve access to game consoles 200 that are accessible to them. RCS 100 owners register their servers and the games available with GRS 400 and specify who is allowed to access it. Access is defined in the context of a play cell community, subsequently described in more detail below.


Global Configuration Server (GCS)


In certain embodiments, the GCS 440 is a persistent store server that allows users to save and restore their game configuration from GCS 440 to game console 200 via attached RCS 100. When a user connects to RCS 100 to play a game, the option to download a previous game configuration is provided. Thus, as users play a given game on different physical RCC 310 units or RCS 100 units, the perception of continuity in game play is enabled.


Global Authentication Server (GAS)


In certain embodiments, GAS 420 creates and authenticates user accounts. RCC 310 users create accounts by registering on GAS 420. This allows time auditing and authentication to be done for the use of RCS 100 to play games. If a specific RCS 100 used is enabled for billing, the RCC 310 user's account may be charged and the RCS 100 owner's account may be credited. This single system view enables RCC 310 users to locate and use any available RCS 100 and authenticate only once for signing onto the service. The account creation process involves users requesting membership in play cells. An RCS 100 owner creates a play cell for the RCS 100 registered on GRS 400. RCS 100 owners can open access to their RCS 100 to other RCC 310 consumers by adding them to their play cell Community. RCC 310 users can also request access to community by contacting the owner of that play cell community.


In certain embodiments, franchise RCS 100 systems are enabled to communicate with GRS 400, GAS 420 and GCS 440 to participate in creating a single directory view of the registration, configuration and account management to users.


Play Cell Network


Referring now to FIG. 5, through its global servers (GRS 400, GAS 420 and GCS 440) and RCC 310 software, certain embodiments of this disclosure enable the creation of a shared community or network called a play cell 450. Play cell 450 is one or more RCS 100 that only members in that specific play cell 450 can access from their RCC 310. One method for creating play cell 450 comprises the following steps:


1. User creates an account on GAS 420.


2. User registers RCS 100 with GRS 400. This creates play cell 450 with a membership of 1, which is the owner of RCS 100. The owner of RCS 100 has management privileges over who joins/leaves his/her play cell 450. If the user already owns an existing play cell 450, GRS 400 can add RCS 100 to the existing play cell 450, as opposed to creating a new one. In certain embodiments intended for individual users, each RCS 100 is designed to support a relatively small number (for example, two) of game consoles 200 concurrently. In other embodiments intended for commercial or franchise use, RCS 100 may support a greater number (for example, ten or more) of game consoles 200.


3. The owner of play cell 450 invites others to use their RCS-enabled consoles 200 by:

    • i. Adding the names of the user accounts or cells that can access his/her server's play cell 450.
    • ii. Opening the play cell 450 to general use.


In certain embodiments, the RCC 310 has built in instant messaging type functions that enable users to:


1. Monitor the status of RCS 100 to determine its availability and to request access to RCS 100.


2. Notify the user when an RCS 100 become available.


3. Chat with users in their play community.


4. Coordinate the playing of multiplayer games.


5. Manage their contact list and server watch list.


In certain embodiments, users may have access to real-time multimedia streams of live game play through a global web portal system. Game console owners can also expose and manage remote access to their game consoles via this web portal.


Franchise Remote Console Server Systems


Certain embodiments enable businesses to deliver game-on-demand services for console games on their local network or via WAN. The system technology is designed for:


1. Serving a large number of consoles (for example, greater than 10);


2. User authentication and accounting; and


3. System administration and management.


These embodiments enable the creation of game-on-demand services (virtual arcades) in malls, shopping centers, hotels, Wi-Fi hot spots, etc. FIG. 5 depicts this system. Multiple RCS units can be managed and franchised as a common pool through a web portal.


In certain embodiments, messages such as advertisements can be sent to RCC 310 from either RCS 100 or from global servers. Further, users' usage patterns of games played or viewed through either a web portal or franchise location can be collected and used to target advertisements to users.


Referring now to FIGS. 6 and 7, certain embodiments of the present disclosure include highly scalable Enterprise Remote Console Servers (ERCS) 410 and distribution rights from game manufacturers that will enable businesses to provide on-demand game services. ERCS 410 comprises the ability to load games on-demand to the console from a Game Repository Server (GRS) 460 as opposed to a local disk unit. ERCS 410 also interfaces with a console management network 410 to link up to other remote console servers. An audit/service control server 470 controls the access to the on-demand games and provides record-keeping functions. Other embodiments also comprise a disk changer for game console 200. The disk changer is under the control of RCS 100 and enables the user to do remote selection of games from the library available in the disk changer.


Referring now to FIG. 8, an overview and summary of the interaction between game console 200 and remote console server 100 is shown for one embodiment. The individual functions shown in FIG. 8 are described above in the discussion of the various embodiments.


Referring now to FIGS. 9A and 9B, a logic flowchart of the initiation sequence used in certain embodiments is shown. As illustrated, a session request 600 allows a user to enter a game selection 610. A query 630 then evaluates whether game selection 610 is a simultaneous players game. If so, a player selection 640 is performed before a game play session 650 is created. After game play session 650 is created, the user joins a wait queue 660 and waits for a session initiation 670 via a session callback 680. After session initiation 670, a setup connection session 690 is created and the controller emulation 700 is configured. The user then plays game 710 until an expiration or termination signal 720 is generated, at which time the game completion 730 is accomplished.


Referring now to FIG. 10, a logic flowchart for the session processing used in certain embodiments is shown. As illustrated, an initiation 800 of session processing leads to a query 810 of active game users. If there are no active game users, a query 860 is performed to determine if players are waiting in queue. If there are active game users, a query 820 determines if the game play time has expired. If play time has expired, a notification 830 is sent to the users and session resources are freed. If play time has not expired, a query 840 is performed to determine if the user has terminated the session. If the user has not terminated the session and there are players waiting in queue, a scan 870 is performed of the pending session queue. After scan 870, a query 880 is performed to determine if the session is ready. If the session is ready, the session 890 is then initiated.


Referring now to FIG. 11, a logic flowchart for server game emulation logic used in certain embodiments is shown. After a receipt 900 of a game pad packet from a user, a conversion 901 is performed on the game pad packet values. After conversion 901, an activation 902 of the emulation circuits and a reading 903 of outputs from the game client is performed. Finally, a sending 904 of game outputs to the server is conducted for relaying to the user.


Referring to FIG. 12, a logic flowchart for a game removable memory subsystem used in certain embodiments is shown. After installation 905 of a dual interface memory control to the server, a query 906 determines if the game session is starting. If the game session is starting, a query 907 determines if the user has requested a memory download. If so, an acquisition 908 of the memory file is conducted followed by securing single access 909 to the memory unit. This is followed by a clearing 910 of memory and a re-enablement 911 of the game server to access the memory unit. In certain embodiments, the memory transfer between the RCC 310 and the global servers can be accomplished automatically.


If the game session is not starting, a query 912 is performed to determine if the game session is ending. If so, another query 913 determines whether the user has requested a memory upload. If the user has requested a memory upload, an acquisition 914 of the memory file is conducted, followed by a securement 915 of single access to the memory unit. This is in turn followed by a reading 916 of game info from the memory unit and a re-enablement 917 of the game server to access the memory unit.


With the benefit of the present disclosure, those having ordinary skill in the art will comprehend that the embodiments described herein may be modified and applied to a number of additional, different applications, achieving the same or a similar result.

Claims
  • 1. A remote console server comprising: a network interface configured to communicate with remote clients of a plurality of users;a console virtualization engine configured to selectively provide the remote clients of the plurality of users access to a plurality of game consoles, wherein the console virtualization engine is configured to: provide access to a first game console selected from the plurality of game consoles to a user in response to the user requesting a first game session, to enable the user to engage in game play on the first game console, wherein the plurality of game consoles, including the first game console, are remote from the user;receive, using the network interface, packetized control signals from a remote game controller associated with the user;convert the packetized control signals from the remote game controller associated with the user requesting the first game session to a form compatible with the first game console, wherein the first game console is remote from the user;receive audio and video data output from the first game console;encode and packetize the audio and video data output from the first game console;transmit the encoded and packetized audio and video data output from the first game console to a client associated with the user, wherein the client associated with the user is remote from the first game console;store a game configuration, corresponding to the first game session with the first game console;enable the stored game configuration to be accessed during a second game session of the user.
  • 2. The remote console server as defined in claim 1, wherein the stored game configuration is stored remote from the first game console.
  • 3. The remote console server as defined in claim 1, wherein the plurality of game consoles include at least one game console of a first type and at least one game console of a second types.
  • 4. The remote console server as defined in claim 1, wherein the remote console server is configured to cache game controller configurations for future use and to automatically load game-specific controller help information.
  • 5. The remote console server as defined in claim 1, wherein the remote console server is configured to enable multiple users to share the first game console with respect to multi-controller, multiplayer games.
  • 6. The remote console server as defined in claim 1, wherein the remote console server is configured to enable multiple users to have access to real-time multimedia streams of live game play through a web portal system.
  • 7. The remote console server as defined in claim 1, wherein the remote console server is further configured to communicate with a global server, wherein the global server is configured to store a second game configuration from the remote console server and to restore the stored second game configuration to the remote console server, and the remote console server is configured to restore the stored second game configuration to the first game console through a memory emulation unit, the memory emulation unit being configured to emulate a memory device for the first game console, wherein the remote console server is configured to cache game controller configurations for future use and to automatically load game-specific controller help information.
  • 8. The remote console server as defined in claim 1, wherein the remote console server is further configured to communicate with a global server, wherein the global server is configured to keep track of a usage of remote console servers by the clients.
  • 9. The remote console server as defined in claim 1, wherein the remote console server is further configured to communicate to send a network packet that announces a presence of the remote console server to other remote console servers.
  • 10. The remote console server as defined in claim 1, wherein the remote console server is configured to automatically adjust a quality and a latency of a transmitted video depending on an available bandwidth or a type of image being transmitted.
  • 11. The remote console server as defined in claim 1, wherein the remote console server is configured to automatically load game help information corresponding to the remote game controller.
  • 12. The remote console server as defined in claim 1, wherein the remote console server is configured to adjust to a plurality of game console controller types.
  • 13. A method for enabling a user to remotely access a game, the method comprising: providing, by a computer system managing a plurality of game consoles and configured to determine availability of at least one game console in the plurality of game consoles and to manage access for a plurality of users to the plurality of game consoles,access to a first game console, in the plurality of game consoles, determined to be available to the user to enable the user to engage in a game play on the first game console, the user requesting a first game session, wherein the first game console is remote from the user;receiving, at the computer system, packetized control signals from a game controller associated with the user, the game controller remote from the plurality of game consoles;converting, by the computer system, the packetized control signals received from the game controller associated with the user to a form compatible with the first game console;receiving, by the computer system, video data output from the first game console;encoding and packetizing, by the computer system, the video data output from the first game console;transmitting, by the computer system, the encoded and packetized video data to a client associated with the user;storing a game configuration, corresponding to the first game session, the game configuration comprising the game play of the user with the first game console; andenabling, by the computer system, the stored game configuration to be accessed during a second game session of the user.
  • 14. The method as defined in claim 13, the method further comprising enabling multiple users to share the first game console with respect to multi-controller, multiplayer games.
  • 15. The method as defined in claim 13, the method further comprising enabling multiple users to access real-time multimedia streams of live game play through a web portal system.
  • 16. The method as defined in claim 13, the method further comprising automatically adjusting a quality and a latency of a transmitted video depending on an available bandwidth or a type of image being transmitted.
  • 17. The method as defined in claim 13, the method further comprising automatically loading game help information corresponding to the game controller.
  • 18. The method as defined in claim 13, the method further comprising providing a portal that enables franchising of a set of remote console servers, wherein the portal enables management of the set of remote console servers as a common pool.
  • 19. The method as defined in claim 13, the method further comprising enabling an owner of a second game console to expose and manage remote access to the second game console.
  • 20. The method as defined in claim 13, the method further comprising providing the client associated with the user an advertisement for display, the advertisement targeted to the user based at least in part on a usage pattern of games played or viewed by the user.
US Referenced Citations (125)
Number Name Date Kind
5558339 Perlman Sep 1996 A
5586257 Perlman Dec 1996 A
5779548 Asai Jul 1998 A
5779549 Walker et al. Jul 1998 A
5890963 Yen Apr 1999 A
5956485 Perlman Sep 1999 A
6025801 Beitel Feb 2000 A
6026079 Perlman Feb 2000 A
6029046 Khan et al. Feb 2000 A
6224486 Walker et al. May 2001 B1
6315668 Metke et al. Nov 2001 B1
6343990 Rasmussen et al. Feb 2002 B1
6409602 Wiltshire et al. Jun 2002 B1
6425828 Walker et al. Jul 2002 B2
6468160 Eliott Oct 2002 B2
6475090 Roelofs Nov 2002 B2
6557041 Mallart Apr 2003 B2
6665872 Krishnamurthy et al. Dec 2003 B1
6716102 Whitten et al. Apr 2004 B2
6810528 Chatani Oct 2004 B1
6817947 Tanskanen Nov 2004 B2
6878067 Blanco Apr 2005 B2
6884171 Eck et al. Apr 2005 B2
6908389 Puskala Jun 2005 B1
6917984 Tan Jul 2005 B1
6918113 Patel et al. Jul 2005 B2
6959320 Shah et al. Oct 2005 B2
6981918 Blanco Jan 2006 B2
7031473 Morais et al. Apr 2006 B2
7043524 Shah et al. May 2006 B2
7062567 Benitez et al. Jun 2006 B2
7090582 Danieli et al. Aug 2006 B2
7189161 Wiltshire et al. Mar 2007 B1
7209874 Salmonsen Apr 2007 B2
7215660 Perlman May 2007 B2
7218739 Multerer et al. May 2007 B2
7266509 Koenig Sep 2007 B2
7285047 Gelb et al. Oct 2007 B2
7288028 Rodriquez et al. Oct 2007 B2
7297062 Gatto et al. Nov 2007 B2
7311598 Kaminkow et al. Dec 2007 B2
7311608 Danieli et al. Dec 2007 B1
7354345 Bortnik et al. Apr 2008 B2
7458894 Danieli et al. Dec 2008 B2
7471665 Perlman Dec 2008 B2
7493078 Perlman Feb 2009 B2
7500916 Lieberman et al. Mar 2009 B2
7512235 Multerer et al. Mar 2009 B2
7558525 Perlman Jul 2009 B2
7559834 York Jul 2009 B1
7567293 Perlman et al. Jul 2009 B2
7567527 Perlman Jul 2009 B2
7584154 Chen et al. Sep 2009 B1
7590084 Perlman Sep 2009 B2
7593361 Perlman Sep 2009 B2
7605861 LaSalle et al. Oct 2009 B2
7628702 Scallie Dec 2009 B2
7633521 Perlman et al. Dec 2009 B2
7663045 Schmidt et al. Feb 2010 B2
7667767 Perlman Feb 2010 B2
7670220 Chudley et al. Mar 2010 B2
7684752 Perlman Mar 2010 B2
7715336 Perlman May 2010 B2
7736231 Evans et al. Jun 2010 B2
7762885 Kelly et al. Jul 2010 B2
7765401 Multerer et al. Jul 2010 B2
7771280 Yoshino et al. Aug 2010 B2
7785197 Smith Aug 2010 B2
7789757 Gemelos et al. Sep 2010 B2
7794325 Hawkins et al. Sep 2010 B2
7803048 Tilston et al. Sep 2010 B2
7811174 Whitten et al. Oct 2010 B2
7818568 Multerer et al. Oct 2010 B2
7824268 Harvey et al. Nov 2010 B2
7837558 Yoshino et al. Nov 2010 B2
7837560 Wiltshire et al. Nov 2010 B2
7841946 Walker et al. Nov 2010 B2
7846025 Whitten et al. Dec 2010 B2
7849491 Perlman Dec 2010 B2
7878907 Davis et al. Feb 2011 B2
7878908 Sloate et al. Feb 2011 B2
7887418 Kaminagayoshi Feb 2011 B2
7887420 Nguyen et al. Feb 2011 B2
7916147 Clemie et al. Mar 2011 B2
7991890 Schmidt et al. Aug 2011 B2
8002617 Uskela et al. Aug 2011 B1
8038535 Jensen Oct 2011 B2
8118676 Craig et al. Feb 2012 B2
20010016519 Choe Aug 2001 A1
20010035859 Kiser et al. Nov 2001 A1
20020022516 Forden Feb 2002 A1
20020022521 Idaka Feb 2002 A1
20020045484 Eck et al. Apr 2002 A1
20020086730 Nakai Jul 2002 A1
20020151363 Letovsky et al. Oct 2002 A1
20020155891 Okada et al. Oct 2002 A1
20030004882 Holler et al. Jan 2003 A1
20030064808 Hecht et al. Apr 2003 A1
20040038740 Muir Feb 2004 A1
20040109031 Deaton et al. Jun 2004 A1
20040110468 Perlman Jun 2004 A1
20040127272 Park et al. Jul 2004 A1
20040229687 Miyamoto Nov 2004 A1
20040246936 Perlman Dec 2004 A1
20040266529 Chatani Dec 2004 A1
20050021159 Ogawa Jan 2005 A1
20050070359 Rodriguez et al. Mar 2005 A1
20050073968 Perlman Apr 2005 A1
20050176452 Perlman Aug 2005 A1
20050231469 Wittig Oct 2005 A1
20060055699 Perlman et al. Mar 2006 A1
20060055706 Perlman et al. Mar 2006 A1
20060068911 Pirich et al. Mar 2006 A1
20060112176 Liu et al. May 2006 A1
20070021213 Foe et al. Jan 2007 A1
20070091178 Cotter et al. Apr 2007 A1
20070173325 Shaw et al. Jul 2007 A1
20070184903 Liu et al. Aug 2007 A1
20070238528 Harris et al. Oct 2007 A1
20080119290 Lee et al. May 2008 A1
20080125226 Emmerson May 2008 A1
20080178298 Arai et al. Jul 2008 A1
20080267069 Thielman et al. Oct 2008 A1
20120157205 Danieli et al. Jun 2012 A9
20120242590 Baccichet et al. Sep 2012 A1
Non-Patent Literature Citations (10)
Entry
GameSpy—Arcade for the Internet Subscription, 1996-2005.
Henderson, Tristan, “Latency and User Behaviour on a Multiplayer Game Server”, 2001, Springer-Verlag.
Henderson, Tristan, “Observations on game server discovery mechanisms”, Apr. 17, 2002, NetGames 2002.
IGN—The Xbox Live FAQ, http://www.ign.com/articles/2002/08/16/the-xbox-live-faq by Aaron Boulding, Aug. 12, 2002.
IGN—Xbox 360 Launch Guide: Beyond the Launch, http://www.ign.com/articles/2005/12/01/xbox-360-launch-guide-beyond-the-launch by Douglas C. Perry, Nov. 30, 2005.
Product updates regarding Xbox and Xbox Live, http://www.engadget.com/tag/xbox+live+dashboard+update/ (2009).
Steam Subscription Service, 2006 Valve Corporation.
Verizon Open Whole New Virtual World of Online Games, Sep. 13, 2005.
Youtube—“How to get started on Xbox live”, https://www.youtube.com/watch?v=Lz_poqdtVnM, uploaded by videojugtechnology on Apr. 6, 2011.
“Zoo Tycoon”, Nov. 25, 2001, available at <http://web.archive.org/web/20011226173527/www.pibweb.com/review/zooty-coon.html>.
Related Publications (1)
Number Date Country
20190291001 A1 Sep 2019 US
Provisional Applications (1)
Number Date Country
60806233 Jun 2006 US
Continuations (5)
Number Date Country
Parent 15602957 May 2017 US
Child 16174674 US
Parent 14638782 Mar 2015 US
Child 15602957 US
Parent 14049934 Oct 2013 US
Child 14638782 US
Parent 12925651 Oct 2010 US
Child 14049934 US
Parent 11761168 Jun 2007 US
Child 12925651 US