US8943488B2 - Video game forward compatibility including software patching - Google Patents

Video game forward compatibility including software patching Download PDF

Info

Publication number
US8943488B2
US8943488B2 US11/967,969 US96796907A US8943488B2 US 8943488 B2 US8943488 B2 US 8943488B2 US 96796907 A US96796907 A US 96796907A US 8943488 B2 US8943488 B2 US 8943488B2
Authority
US
United States
Prior art keywords
handheld
information
handheld device
game
video game
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US11/967,969
Other versions
US20090172659A1 (en
Inventor
Gregory Keith OBERG
Jesse Nathaniel Booth
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Activision Publishing Inc
Original Assignee
Activision Publishing Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Activision Publishing Inc filed Critical Activision Publishing Inc
Priority to US11/967,969 priority Critical patent/US8943488B2/en
Assigned to ACTIVISION PUBLISHING, INC. reassignment ACTIVISION PUBLISHING, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BOOTH, JESSE NATHANIEL, OBERG, GREGORY KEITH
Publication of US20090172659A1 publication Critical patent/US20090172659A1/en
Assigned to BANK OF AMERICA, N.A. reassignment BANK OF AMERICA, N.A. SECURITY AGREEMENT Assignors: ACTIVISION BLIZZARD, INC.
Application granted granted Critical
Publication of US8943488B2 publication Critical patent/US8943488B2/en
Assigned to BLIZZARD ENTERTAINMENT, INC., ACTIVISION PUBLISHING, INC., ACTIVISION BLIZZARD INC., ACTIVISION ENTERTAINMENT HOLDINGS, INC. reassignment BLIZZARD ENTERTAINMENT, INC. RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: BANK OF AMERICA, N.A.
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/70Game security or game management aspects
    • A63F13/77Game security or game management aspects involving data related to game devices or game servers, e.g. configuration data, software version or amount of memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/30Interconnection arrangements between game servers and game devices; Interconnection arrangements between game devices; Interconnection arrangements between game servers
    • A63F13/31Communication aspects specific to video games, e.g. between several handheld game devices at close range
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/90Constructional details or arrangements of video game devices not provided for in groups A63F13/20 or A63F13/25, e.g. housing, wiring, connections or cabinets
    • A63F13/92Video game devices specially adapted to be hand-held while playing
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F2300/00Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
    • A63F2300/20Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of the game platform
    • A63F2300/204Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of the game platform the platform being a handheld device
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F2300/00Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
    • A63F2300/20Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of the game platform
    • A63F2300/209Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of the game platform characterized by low level software layer, relating to hardware management, e.g. Operating System, Application Programming Interface
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F2300/00Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
    • A63F2300/40Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of platform network
    • A63F2300/404Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of platform network characterized by a local network connection
    • A63F2300/405Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of platform network characterized by a local network connection being a wireless ad hoc network, e.g. Bluetooth, Wi-Fi, Pico net

Definitions

  • the present invention relates generally to handheld video game devices and more particularly to provision of video game information from one handheld game device to another handheld game device over a wireless connection.
  • Video games allow users to enjoy interactive displays, engage in competitive interaction, and engage in scenarios and simulated activities which they would not otherwise be able to experience. Video games are a source of enjoyment for millions of users across the world.
  • Handheld video game devices are at times the video game platform of choice due to their mobility and convenience. Handheld video game devices provide a relatively small platform on which to enjoy video game play, allowing for easy transport and ease of play in many environments unsuitable for video game play on more traditional video game consoles or arcade machines.
  • Specific video game programs for handheld video game devices are generally provided on a removable memory source.
  • the video game device processes video game program instructions stored on the removable memory source to provide video game play.
  • the wireless communication capabilities may be utilized, for example, to quickly and conveniently communicate game play information between two or more handheld video game devices for competitive game play, allowing for multiplayer game play.
  • the wireless communication capabilities may also be convenient for providing video game data or other video game information from one handheld video game device to another. Indeed, programs instructions for an entire video game may be wirelessly connected from one handheld device to another handheld device. For a variety of reasons, however, it may be preferable for each handheld device to have a video game program resident on a removable memory source.
  • the same or substantially same video game may be available in different versions, with different handheld devices potentially having different versions of a video game. Compatibility issues between the different versions may result in difficulties in multiplayer game play, whether by not providing full use of features of a game or by being unable to provide multiplayer game play at all.
  • the invention provides for sending video game updates over a wireless connection for, for example, handheld video game devices.
  • a method of updating handheld device video game software comprising determining a version of a game on a handheld device, determining information to update the version of the game on the handheld device, and commanding the handheld device to write the information to memory of the handheld device so as to modify the game on the handheld device.
  • a handheld game device configured to perform software patching of video game software of another handheld device, comprising a processor, wireless communication circuitry, memory including program instructions to configure the processor to determine information to provide to another handheld game device in order to modify video game software of the other handheld device.
  • FIG. 1 illustrates an embodiment of a multiplayer handheld video game configuration.
  • FIG. 2 is a block diagram of a handheld game device.
  • FIG. 3 is a sequence diagram showing data transfer interactions between handheld devices in accordance with aspects of the invention.
  • FIG. 4 is a flow diagram of a process of providing software patches in accordance with aspects of the invention.
  • FIG. 5 is a flow diagram of a process of receiving software patches in accordance with aspects of the invention.
  • FIG. 1 illustrates an embodiment of a multiplayer handheld video game configuration.
  • the configuration includes a first handheld video game device 101 and a second handheld video game device 103 .
  • Each handheld video game device includes at least one display 111 (with two displays per device shown in FIG. 1 ), at least one user input device 113 , and, as illustrated, at least one speaker 115 .
  • Each device includes circuitry generally associated with video game devices, such as circuitry for reading a removable memory, processing circuitry for executing game instructions stored in the removable memory, circuitry for driving the display, circuitry for driving the speaker, and circuitry for receiving user inputs.
  • each device includes circuitry for wireless communication 117 between the devices.
  • the handheld devices are Nintendo DS handheld video game devices or Nintendo DS Lite handheld video game devices, both widely available in consumer electronics retail stores.
  • the first handheld device 101 and the second handheld device 103 are both provided with a removable memory, such as provided by a game cartridge.
  • the removable memory will include, for example, video game instructions and other data related to running the game on the handheld device, such as display or audio information for use as part of or in conjunction with the video game.
  • the first handheld device 101 , and the second handheld device 103 are in wireless communication 117 .
  • the devices may be in wireless communication during multiplayer game play.
  • video game information used for multiplayer interaction for example, synchronization information, user input information, and score or statistical information, may be transmitted wirelessly between the two handheld devices to create an interactive multiplayer game environment.
  • these wireless transmissions may occur between a plurality of other handheld devices.
  • the interactive multiplayer game play may be between more than two handheld devices.
  • the removable memory, such as a video game cartridge, in the first handheld device 101 may differ slightly from the removable memory in the second handheld device 103 .
  • the differences may be such that the two handheld devices are incapable of providing multiplayer game environment, or incapable of providing an intended or desired multiplayer game environment.
  • the removable memory in the first handheld device may contain an older version of a video game than the removable memory in the second handheld device, may be for a newer generation, for example a sequel, of the video game in the removable memory in the second handheld device.
  • the video game in the removable memory in the second handheld device may contain a bug not present in the memory of the first handheld device. In such and other cases, inconsistencies in data or program instructions may cause one of the handheld devices to be unable to fully or partially process game information.
  • variations in versions, iterations, or generations of the same video game may result in inconsistencies in data or data formats, resulting in improper game operation.
  • bugs or problems in software of a particular version of a video game data may hinder multiplayer interactivity as well.
  • the inconsistencies between the video game information may be with respect to, for example, character animations and models, venue animation and models, textures, and game play data such as user instruction information, such as music note data in music games, and animation tracks.
  • the first handheld device wirelessly communicates 117 software patches to the second handheld device 103 , as seen in FIG. 1 .
  • the software patches may be program instructions or data to be operated on by program instructions.
  • the software patches include information to replace or supplement program instructions or data already resident in memory of the second handheld device.
  • the second handheld device provides an indication of software version to the first handheld device.
  • the first handheld device determines software patches to provide to the second handheld device based on the version information.
  • the first handheld device retrieves appropriate information from its own removable memory or on board memory, and provides, via wireless transmission, software patches to the second handheld device.
  • a removable memory in the second handheld device 103 has an older generation of video game software
  • a removable memory in the first handheld device 101 has a newer generation of video game software, for example. a sequel of the older generation video game software.
  • the second handheld device may communicate version information to the first handheld device over, for example, a wireless connection 117 as seen in FIG. 1 .
  • the first handheld device may determine, for example using a look-up table, software code, components, or data to be patched or replaced in the second handheld device to properly enable multiplayer game play.
  • the first handheld device retrieves replacement information from memory, for example from a game cartridge containing a video game program, and patches or replaces the identified software components in the removable memory of the first handheld device by wirelessly transmitting the patches or replacement software components to the first handheld device, preferably along with instruction information as to storage locations for the replacement information.
  • the patched or updated video game information is maintained in the second handheld device memory, or stored in the removable game cartridge of the second handheld device. This may be preferable, for example, if the removable memory in the second handheld device holds video game information that is later discovered to include a bug or inconsistency in the video game software which could use a software upgrade to function correctly.
  • the patched or updated video game information on the removable memory in the first handheld device is deleted or overwritten after the multiplayer connection 117 is terminated.
  • each new version or generation of a video game will include information as to what to replace or fix for prior versions or generations to enable forward compatibility for, for example, multiplayer game play.
  • Each new version or generation of a video game preferably includes information to determine whether patches or updates sent to the older version or generation video game software should be a permanent write to the older version or generation video game software or merely a temporary write used during an instance of multiplayer game play. These tasks may be accomplished by, for example, identification of version or generation information of a recipient video game cartridge, and determining which bytes of the recipient video game software should be patched or updated and whether the patches or updates should be made permanent based on the version or generation of the recipient video game cartridge.
  • FIG. 2 is an example of a block diagram of, for example, a handheld device in accordance with one embodiment of the invention.
  • the handheld game device includes a bus 201 coupled to a processor 203 , a main memory 205 , an audio driver 207 , a video driver 209 , a video memory 211 , a removable memory interface 213 , a user input/output (I/O) interface 215 , and a wireless communication interface 217 .
  • I/O user input/output
  • wireless communication interface 217 a wireless communication interface 217 .
  • the video driver is coupled directly to the video memory via a dedicated bus 219 .
  • the removable memory interface 213 is configured to communicate with a removable memory, for example, a video game cartridge providing specific video game instructions, and storage and memory commands related to the operation of that specific video game.
  • the processor 203 is configured to communicate with the removable memory through the removable memory interface, and execute the video game instructions from the removable memory by communicating with each component coupled to the bus 201 , including the removable memory.
  • the main memory 205 stores information from the other components as needed.
  • the main memory can store information such as, for example, video game play instructions, audio information, video information, and configuration information from the removable memory, and user inputs from the user I/O interface 215 .
  • the video game instructions stored from the removable memory are also instructions on how to interpret user inputs from the user I/O interface in relation to the specific video game.
  • the processor adjusts the video game's audio and video properties according to the user inputs based on these instructions.
  • the audio driver 207 is configured to receive audio information from the bus and to translate that information into audio signals to be provided to audio output devices such as speakers.
  • the video driver 209 is configured to receive video information and to translate that information into video signals to be provided to video output devices such as one or more video screens or monitors.
  • the video driver is configured to receive this video information from either a component connected to it through the main bus, or from a video memory 211 which is dedicated to store video information for the specific game.
  • the handheld device may also communicate wirelessly with other handheld devices or other computing devices through the wireless communication interface 217 .
  • the wireless communication interface will be controlled by commands from the processor based on instructions read from either the removable memory or the main memory.
  • FIG. 3 is a sequence diagram representing the interaction between a first handheld device 301 and a second handheld device 303 in accordance with embodiments of the invention.
  • the interaction may be, for example, the multiplayer interaction discussed with respect to FIG. 1 , where the video game on the removable memory in a second handheld device is an older version or generation than the video game on the removable memory in a first handheld device.
  • the first handheld device requests the version or generation of the video game on the removable memory in the second handheld device. This version request is indicated by communication 311 .
  • the second handheld device provides the version or generation information of the video game on the removable memory in the second handheld device to the first handheld device during communication 313 .
  • the first handheld device compares the version or generation of the video game used by the second handheld device with the version or generation of its own video game. It should be noted that generally both devices will inquire about version information from the other device, but for ease of discussion only one such inquiry is specifically shown in FIG. 3 .
  • the first handheld device may be considered a providing device, for example with the video game information on the removable memory in the first handheld device being a newer version or generation than the video game information on the removable memory in the second handheld device.
  • the second handheld device may be considered a receiving device.
  • the providing device assesses version information, for example, from the receiving device and, based on that information and information from the removable memory of the providing device, the providing device provides update information to the receiving device. This may be the case where, for example, the update information will generally be specific to the version or generation of the video game software used by the receiving device.
  • the size of the bytes of data to write to the receiving device will match the size of the bytes of data to be replaced on the receiving device. In such embodiments, allocation of extra space for data may not be necessary. In other embodiments, the size of the bytes of data to write to the video game software of the receiving device may not match the size of the bytes of data to be replaced on the video game software of the receiving device. In such embodiments, the providing device will send an allocate memory request communication 315 to the receiving device to request allocation of memory to store the update information onto the receiving device.
  • the receiving device determines where on the receiving device to allocate memory for the update information.
  • the receiving device allocates memory in device memory for receipt of the update information from the providing device.
  • device memory of the receiving device may include flash memory, and the allocated memory may be in flash memory. Allocation of device memory, for example instead of in removable memory inserted into the device, may be appropriate when, for example, the write information is not to be kept permanent, and the newly allocated memory will be freed on disconnect from multiplayer interaction.
  • the receiving device allocates memory in the removable memory holding the video game software. This may be appropriate when, for example, the video game software used by the receiving device was initially programmed with allocated memory for forward compatibility purposes, or for example, the update information is to be a permanent patch or upgrade for the video game software used by the receiving device.
  • the receiving device sends an address representing the location of allocated memory to the providing device via communication 317 .
  • the receiving device may send a plurality of allocated memory addresses to the providing device.
  • the providing device may have more than one memory location on the receiving device available to which to write information.
  • the providing device uses a patch memory command 319 to send the update information to the receiving device.
  • the patch memory command includes instructions for the number of bytes to allocate for the information, the memory address location to write the patched or updated data, the data, and a flag indicator.
  • the flag indicator indicates whether to permanently apply the patch or update to the video game software of the receiving device, or to remove the patch or update upon disconnect of multiplayer interaction.
  • the providing device may send a plurality of patch memory commands to the receiving device. Such embodiments would be appropriate, for example, where more than one section of the video game software of the receiving device is patched or updated by the providing device.
  • the providing device uses the patch memory command without first making use of the request for memory allocation or receiving an allocated memory address.
  • the providing device may already have sufficient information to be able to specify a memory address.
  • the providing device and the receiving device wirelessly communicate with each other for multiplayer game play using communications 321 .
  • the receiving device utilizes the flag indicators of each patch command to determine whether to make the software patch or update associated with each patch command permanent, or whether to remove the patch or update and revert the video game software back to the state prior to initiating the multiplayer connection.
  • FIG. 4 is a flow diagram of a process of sending forward compatibility information from a providing handheld device in accordance with aspects of the invention.
  • the process may be performed, for example, by the first handheld device of FIG. 1 or the providing device of FIG. 3 .
  • the process determines the version or generation of the video game software being used by the receiving device. In many embodiments, this determination is performed by receiving game version information from the receiving device.
  • game version information is received from the receiving handheld after the process requests game version information from the receiving device.
  • the receiving device automatically provides game version information, for example as part of establishing communications between handheld devices.
  • the process determines update information to provide to the receiving device.
  • the update information may, for example, be used to modify video game software of the receiving device so as to provide for compatibility of video game software.
  • the process determines update information by referencing a table, for example stored in memory of the providing device, for changes appropriate for the particular version or generation of the video game software of the receiving device.
  • the table may include, for example, information indicating bytes to be written over specific memory in the video game software of the receiving device.
  • the table may also include, for example, information on the amount of allocated memory to be utilized on the other handheld device, and the bytes to be written to the allocated memory.
  • the process requests allocatable addresses of memory on the receiving device.
  • the allocatable addresses are for the purpose of allowing the process to command writes of information to appropriate address space of the receiving device where the software patches or upgrades required for forward compatibility may be stored.
  • separate allocations may be requested for each separate patch or update.
  • a request for an allocation sufficient to store all the patches together may be sent from the providing device to the receiving device.
  • the process generally receives allocated addresses from the receiving device.
  • patch information represents information to be written to specific memory of the video game software on the receiving device, overwriting video game instructions and bytes which are to be replaced preferably to provide increased function or interoperability for multiplayer game play.
  • patch information represents information redirecting a processor of the receiving device to process bytes of information, program instructions and/or data in various embodiments, at one or more of the allocated addresses.
  • allocated information represents bytes of software information meant to replace older versions of the same software information, to achieve forward compatibility for example, where the space required to hold the new software information exceeds the space available at the memory location where the old software information was held.
  • allocated information represents bytes of information including a flag indicating the removal of the bytes of information after the wireless connection for multiplayer game play is terminated.
  • allocated information represents specific instructions to which associated patch information redirects the processor of the other handheld device, to achieve forward compatibility for example. Allocated information can be transmitted, for example, before or after patch information.
  • FIG. 5 is a flow diagram of a process of receiving information, for example forward compatibility information, in accordance with aspects of the invention.
  • the process may be performed, for example, by the wireless communications system of FIG. 1 , and more particularly by a receiving device of the system of FIG. 3 .
  • the process initially includes providing version information of video game software.
  • the process receives a memory allocation request from another handheld device, such as the providing handheld device of FIG. 3 .
  • the request may ask for the byte size allocation of addresses with preexisting bytes of information to be overwritten in the video game software used by the receiving device.
  • the requests may ask for allocations of free space available on the receiving device.
  • the requests may contain both overwrite requests and free space allocation requests.
  • the process allocates memory.
  • the memory is allocated for writing of information as requested by the providing device.
  • allocating memory includes determining free space available on memory of a handheld device performing the process.
  • allocating memory includes determining free space available on removable memory used by the handheld device performing the process. If there is not enough space on the removable memory, or if, for example, the request from the providing device indicates a temporary change which will be removed after multiplayer game play is complete, the required memory space may alternatively be allocated on the main memory of the receiving device.
  • the receiving device may back up the bytes of information to be overwritten at another location before allocating the requested memory address. Thus, if reversion is appropriate after multiplayer game play is complete, the original bytes of information can be easily restored onto the memory of the handheld device.
  • the process provides memory address locations on either the main memory or the removable memory for the allocated memory, and transmits the addresses to the other handheld device in block 515 .
  • the information provided and transmitted by the handheld device may only include starting addresses and byte size information.
  • the addresses of the allocated memory may be paired with information on the specific patch or update to be stored in that particular allocated memory.
  • the process receives patch information from the providing device.
  • this patch information overwrites original bytes of information in the video game software used by the handheld device. These bytes of information may have been identified by the providing device as information which should be patched or updated to enable multiplayer game play.
  • patch information received redirects the processor of the receiving device to process bytes of information at one or more of the allocated addresses holding new video game instructions. This may be done, for example, where the byte size of the patch or update exceeds the byte size available at the memory location where the old software information to be replaced was held.
  • Allocated information may represent, for example, bytes of information including a flag indicating the removal of the bytes of information after the wireless connection for multiplayer game play is terminated. Allocated information may also represent, for example, specific video game software instructions to which associated patch information redirects the processor to achieve forward compatibility. Such information may be stored in separate allocated memory rather than overwrite specific memory because, for example, the size of the replacement information is too large to store in the memory address of the information to be replaced. In another embodiment, information may be stored in allocated memory rather than over write original video game software when the changes are not meant to be permanent, and will be deleted upon completion of multiplayer game play.
  • Some portions of the allocated information received may be stored in the removable memory used by the receiving device, while other portions of the allocated information received may be stored, possibly simultaneously, in the main memory of the receiving device.
  • Allocated information can be received from the providing device, for example, before, after, or simultaneously with patch information.
  • the process engages in multiplayer game play.
  • multiplayer game play ends the process returns.
  • any flags indicating portions of video game software information to be reverted to the original version of software will be honored, and the video game will be able to function for standalone game play.
  • the forward compatibility process may be reinitiated.
  • aspects of the invention provide for software patching and forward compatibility of video game software of handheld game devices.

Abstract

Methods for updating video game software or handheld game devices, and systems for performing the methods. In some embodiments a first handheld game device with a later version of a game update software of a second handheld game device with an earlier version of the game.

Description

BACKGROUND OF THE INVENTION
The present invention relates generally to handheld video game devices and more particularly to provision of video game information from one handheld game device to another handheld game device over a wireless connection.
Video games allow users to enjoy interactive displays, engage in competitive interaction, and engage in scenarios and simulated activities which they would not otherwise be able to experience. Video games are a source of enjoyment for millions of users across the world.
Handheld video game devices are at times the video game platform of choice due to their mobility and convenience. Handheld video game devices provide a relatively small platform on which to enjoy video game play, allowing for easy transport and ease of play in many environments unsuitable for video game play on more traditional video game consoles or arcade machines.
Specific video game programs for handheld video game devices are generally provided on a removable memory source. The video game device processes video game program instructions stored on the removable memory source to provide video game play.
Many handheld video game devices have wireless communication capabilities. The wireless communication capabilities may be utilized, for example, to quickly and conveniently communicate game play information between two or more handheld video game devices for competitive game play, allowing for multiplayer game play. The wireless communication capabilities may also be convenient for providing video game data or other video game information from one handheld video game device to another. Indeed, programs instructions for an entire video game may be wirelessly connected from one handheld device to another handheld device. For a variety of reasons, however, it may be preferable for each handheld device to have a video game program resident on a removable memory source.
Often, however, the same or substantially same video game may be available in different versions, with different handheld devices potentially having different versions of a video game. Compatibility issues between the different versions may result in difficulties in multiplayer game play, whether by not providing full use of features of a game or by being unable to provide multiplayer game play at all.
SUMMARY OF THE INVENTION
The invention provides for sending video game updates over a wireless connection for, for example, handheld video game devices. In one aspect, a method of updating handheld device video game software, comprising determining a version of a game on a handheld device, determining information to update the version of the game on the handheld device, and commanding the handheld device to write the information to memory of the handheld device so as to modify the game on the handheld device.
In another aspect a handheld game device configured to perform software patching of video game software of another handheld device, comprising a processor, wireless communication circuitry, memory including program instructions to configure the processor to determine information to provide to another handheld game device in order to modify video game software of the other handheld device.
These and other aspects of the invention are more fully comprehended upon review of this disclosure.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 illustrates an embodiment of a multiplayer handheld video game configuration.
FIG. 2 is a block diagram of a handheld game device.
FIG. 3 is a sequence diagram showing data transfer interactions between handheld devices in accordance with aspects of the invention.
FIG. 4 is a flow diagram of a process of providing software patches in accordance with aspects of the invention.
FIG. 5 is a flow diagram of a process of receiving software patches in accordance with aspects of the invention.
DETAILED DESCRIPTION
FIG. 1 illustrates an embodiment of a multiplayer handheld video game configuration. The configuration includes a first handheld video game device 101 and a second handheld video game device 103. Each handheld video game device includes at least one display 111 (with two displays per device shown in FIG. 1), at least one user input device 113, and, as illustrated, at least one speaker 115. Each device includes circuitry generally associated with video game devices, such as circuitry for reading a removable memory, processing circuitry for executing game instructions stored in the removable memory, circuitry for driving the display, circuitry for driving the speaker, and circuitry for receiving user inputs. In addition, each device includes circuitry for wireless communication 117 between the devices. In some embodiments, the handheld devices are Nintendo DS handheld video game devices or Nintendo DS Lite handheld video game devices, both widely available in consumer electronics retail stores.
Generally, for standalone game play, the first handheld device 101 and the second handheld device 103 are both provided with a removable memory, such as provided by a game cartridge. The removable memory will include, for example, video game instructions and other data related to running the game on the handheld device, such as display or audio information for use as part of or in conjunction with the video game.
As shown in FIG. 1, the first handheld device 101, and the second handheld device 103 are in wireless communication 117. The devices may be in wireless communication during multiplayer game play. For example, video game information used for multiplayer interaction, for example, synchronization information, user input information, and score or statistical information, may be transmitted wirelessly between the two handheld devices to create an interactive multiplayer game environment. In various embodiments, these wireless transmissions may occur between a plurality of other handheld devices. Thus, in such embodiments, the interactive multiplayer game play may be between more than two handheld devices.
In some instances, the removable memory, such as a video game cartridge, in the first handheld device 101 may differ slightly from the removable memory in the second handheld device 103. The differences may be such that the two handheld devices are incapable of providing multiplayer game environment, or incapable of providing an intended or desired multiplayer game environment. For example, the removable memory in the first handheld device may contain an older version of a video game than the removable memory in the second handheld device, may be for a newer generation, for example a sequel, of the video game in the removable memory in the second handheld device. Alternatively, the video game in the removable memory in the second handheld device may contain a bug not present in the memory of the first handheld device. In such and other cases, inconsistencies in data or program instructions may cause one of the handheld devices to be unable to fully or partially process game information.
For example, variations in versions, iterations, or generations of the same video game may result in inconsistencies in data or data formats, resulting in improper game operation. Likewise, bugs or problems in software of a particular version of a video game data may hinder multiplayer interactivity as well. The inconsistencies between the video game information may be with respect to, for example, character animations and models, venue animation and models, textures, and game play data such as user instruction information, such as music note data in music games, and animation tracks.
In some embodiments, the first handheld device wirelessly communicates 117 software patches to the second handheld device 103, as seen in FIG. 1. The software patches may be program instructions or data to be operated on by program instructions. In most embodiments the software patches include information to replace or supplement program instructions or data already resident in memory of the second handheld device. For example, in some embodiments the second handheld device provides an indication of software version to the first handheld device. The first handheld device determines software patches to provide to the second handheld device based on the version information. The first handheld device retrieves appropriate information from its own removable memory or on board memory, and provides, via wireless transmission, software patches to the second handheld device.
Thus, for example, a removable memory in the second handheld device 103 has an older generation of video game software, and a removable memory in the first handheld device 101 has a newer generation of video game software, for example. a sequel of the older generation video game software. The second handheld device may communicate version information to the first handheld device over, for example, a wireless connection 117 as seen in FIG. 1. The first handheld device may determine, for example using a look-up table, software code, components, or data to be patched or replaced in the second handheld device to properly enable multiplayer game play. The first handheld device retrieves replacement information from memory, for example from a game cartridge containing a video game program, and patches or replaces the identified software components in the removable memory of the first handheld device by wirelessly transmitting the patches or replacement software components to the first handheld device, preferably along with instruction information as to storage locations for the replacement information.
After multiplayer game play is complete, in some embodiments, or upon some other predefined occurrence, the patched or updated video game information is maintained in the second handheld device memory, or stored in the removable game cartridge of the second handheld device. This may be preferable, for example, if the removable memory in the second handheld device holds video game information that is later discovered to include a bug or inconsistency in the video game software which could use a software upgrade to function correctly. In other embodiments, the patched or updated video game information on the removable memory in the first handheld device is deleted or overwritten after the multiplayer connection 117 is terminated.
Preferably, each new version or generation of a video game will include information as to what to replace or fix for prior versions or generations to enable forward compatibility for, for example, multiplayer game play. Each new version or generation of a video game preferably includes information to determine whether patches or updates sent to the older version or generation video game software should be a permanent write to the older version or generation video game software or merely a temporary write used during an instance of multiplayer game play. These tasks may be accomplished by, for example, identification of version or generation information of a recipient video game cartridge, and determining which bytes of the recipient video game software should be patched or updated and whether the patches or updates should be made permanent based on the version or generation of the recipient video game cartridge.
FIG. 2 is an example of a block diagram of, for example, a handheld device in accordance with one embodiment of the invention. The handheld game device includes a bus 201 coupled to a processor 203, a main memory 205, an audio driver 207, a video driver 209, a video memory 211, a removable memory interface 213, a user input/output (I/O) interface 215, and a wireless communication interface 217. In some embodiments, there may be multiple processors, with each processor having separate data buses. In this embodiment, the video driver is coupled directly to the video memory via a dedicated bus 219.
The removable memory interface 213 is configured to communicate with a removable memory, for example, a video game cartridge providing specific video game instructions, and storage and memory commands related to the operation of that specific video game. The processor 203 is configured to communicate with the removable memory through the removable memory interface, and execute the video game instructions from the removable memory by communicating with each component coupled to the bus 201, including the removable memory. The main memory 205 stores information from the other components as needed. The main memory can store information such as, for example, video game play instructions, audio information, video information, and configuration information from the removable memory, and user inputs from the user I/O interface 215. Among the video game instructions stored from the removable memory are also instructions on how to interpret user inputs from the user I/O interface in relation to the specific video game. The processor adjusts the video game's audio and video properties according to the user inputs based on these instructions. The audio driver 207 is configured to receive audio information from the bus and to translate that information into audio signals to be provided to audio output devices such as speakers. The video driver 209 is configured to receive video information and to translate that information into video signals to be provided to video output devices such as one or more video screens or monitors. The video driver is configured to receive this video information from either a component connected to it through the main bus, or from a video memory 211 which is dedicated to store video information for the specific game. The handheld device may also communicate wirelessly with other handheld devices or other computing devices through the wireless communication interface 217. The wireless communication interface will be controlled by commands from the processor based on instructions read from either the removable memory or the main memory.
FIG. 3 is a sequence diagram representing the interaction between a first handheld device 301 and a second handheld device 303 in accordance with embodiments of the invention. The interaction may be, for example, the multiplayer interaction discussed with respect to FIG. 1, where the video game on the removable memory in a second handheld device is an older version or generation than the video game on the removable memory in a first handheld device. After a wireless connection is made and before multiplayer game play begins, the first handheld device requests the version or generation of the video game on the removable memory in the second handheld device. This version request is indicated by communication 311. The second handheld device provides the version or generation information of the video game on the removable memory in the second handheld device to the first handheld device during communication 313. The first handheld device compares the version or generation of the video game used by the second handheld device with the version or generation of its own video game. It should be noted that generally both devices will inquire about version information from the other device, but for ease of discussion only one such inquiry is specifically shown in FIG. 3.
The first handheld device may be considered a providing device, for example with the video game information on the removable memory in the first handheld device being a newer version or generation than the video game information on the removable memory in the second handheld device. In such an instance, for example, the second handheld device may be considered a receiving device. The providing device assesses version information, for example, from the receiving device and, based on that information and information from the removable memory of the providing device, the providing device provides update information to the receiving device. This may be the case where, for example, the update information will generally be specific to the version or generation of the video game software used by the receiving device.
In some embodiments, the size of the bytes of data to write to the receiving device will match the size of the bytes of data to be replaced on the receiving device. In such embodiments, allocation of extra space for data may not be necessary. In other embodiments, the size of the bytes of data to write to the video game software of the receiving device may not match the size of the bytes of data to be replaced on the video game software of the receiving device. In such embodiments, the providing device will send an allocate memory request communication 315 to the receiving device to request allocation of memory to store the update information onto the receiving device.
After receiving an allocate memory request 315, the receiving device determines where on the receiving device to allocate memory for the update information. In some embodiments, the receiving device allocates memory in device memory for receipt of the update information from the providing device. In some embodiments device memory of the receiving device may include flash memory, and the allocated memory may be in flash memory. Allocation of device memory, for example instead of in removable memory inserted into the device, may be appropriate when, for example, the write information is not to be kept permanent, and the newly allocated memory will be freed on disconnect from multiplayer interaction. In other embodiments, the receiving device allocates memory in the removable memory holding the video game software. This may be appropriate when, for example, the video game software used by the receiving device was initially programmed with allocated memory for forward compatibility purposes, or for example, the update information is to be a permanent patch or upgrade for the video game software used by the receiving device.
The receiving device sends an address representing the location of allocated memory to the providing device via communication 317. In one embodiment, the receiving device may send a plurality of allocated memory addresses to the providing device. Thus, in some embodiments, the providing device may have more than one memory location on the receiving device available to which to write information.
The providing device uses a patch memory command 319 to send the update information to the receiving device. In some embodiments, the patch memory command includes instructions for the number of bytes to allocate for the information, the memory address location to write the patched or updated data, the data, and a flag indicator. The flag indicator indicates whether to permanently apply the patch or update to the video game software of the receiving device, or to remove the patch or update upon disconnect of multiplayer interaction. In various embodiments, the providing device may send a plurality of patch memory commands to the receiving device. Such embodiments would be appropriate, for example, where more than one section of the video game software of the receiving device is patched or updated by the providing device.
It should also be noted that in some embodiments the providing device uses the patch memory command without first making use of the request for memory allocation or receiving an allocated memory address. For example, the providing device may already have sufficient information to be able to specify a memory address.
Once the patch memory commands 319 have been executed, and the video game software of the receiving device is successfully patched or updated to be forward compatible with the video game software of the providing device, the providing device and the receiving device wirelessly communicate with each other for multiplayer game play using communications 321. Once multiplayer game play ends, and the multiplayer wireless connection between the providing device and receiving device is terminated, the receiving device utilizes the flag indicators of each patch command to determine whether to make the software patch or update associated with each patch command permanent, or whether to remove the patch or update and revert the video game software back to the state prior to initiating the multiplayer connection.
FIG. 4 is a flow diagram of a process of sending forward compatibility information from a providing handheld device in accordance with aspects of the invention. In some embodiments, the process may be performed, for example, by the first handheld device of FIG. 1 or the providing device of FIG. 3. In block 411, the process determines the version or generation of the video game software being used by the receiving device. In many embodiments, this determination is performed by receiving game version information from the receiving device. In some embodiments game version information is received from the receiving handheld after the process requests game version information from the receiving device. In other embodiments the receiving device automatically provides game version information, for example as part of establishing communications between handheld devices.
In block 413, the process determines update information to provide to the receiving device. The update information may, for example, be used to modify video game software of the receiving device so as to provide for compatibility of video game software. In some embodiments, the process determines update information by referencing a table, for example stored in memory of the providing device, for changes appropriate for the particular version or generation of the video game software of the receiving device. The table may include, for example, information indicating bytes to be written over specific memory in the video game software of the receiving device. The table may also include, for example, information on the amount of allocated memory to be utilized on the other handheld device, and the bytes to be written to the allocated memory.
In block 415, the process requests allocatable addresses of memory on the receiving device. Generally, the allocatable addresses are for the purpose of allowing the process to command writes of information to appropriate address space of the receiving device where the software patches or upgrades required for forward compatibility may be stored. In some embodiments, separate allocations may be requested for each separate patch or update. In other embodiments, a request for an allocation sufficient to store all the patches together may be sent from the providing device to the receiving device. Although not shown as a separate block, the process generally receives allocated addresses from the receiving device.
In block 417, the process transmits patch information to the receiving device. In some embodiments, patch information represents information to be written to specific memory of the video game software on the receiving device, overwriting video game instructions and bytes which are to be replaced preferably to provide increased function or interoperability for multiplayer game play. In other embodiments, patch information represents information redirecting a processor of the receiving device to process bytes of information, program instructions and/or data in various embodiments, at one or more of the allocated addresses.
In block 419, the process transmits allocated information to the receiving device. In some embodiments, allocated information represents bytes of software information meant to replace older versions of the same software information, to achieve forward compatibility for example, where the space required to hold the new software information exceeds the space available at the memory location where the old software information was held. In other embodiments, allocated information represents bytes of information including a flag indicating the removal of the bytes of information after the wireless connection for multiplayer game play is terminated. In various embodiments, allocated information represents specific instructions to which associated patch information redirects the processor of the other handheld device, to achieve forward compatibility for example. Allocated information can be transmitted, for example, before or after patch information.
In block 421 the process engages in multiplayer game play. When multiplayer game play ends, the process returns.
FIG. 5 is a flow diagram of a process of receiving information, for example forward compatibility information, in accordance with aspects of the invention. In some embodiments, the process may be performed, for example, by the wireless communications system of FIG. 1, and more particularly by a receiving device of the system of FIG. 3. In many embodiments, the process initially includes providing version information of video game software. In block 511, the process receives a memory allocation request from another handheld device, such as the providing handheld device of FIG. 3. In some embodiments, the request may ask for the byte size allocation of addresses with preexisting bytes of information to be overwritten in the video game software used by the receiving device. In other embodiments, the requests may ask for allocations of free space available on the receiving device. In yet other embodiments, the requests may contain both overwrite requests and free space allocation requests.
In block 513, the process allocates memory. The memory is allocated for writing of information as requested by the providing device. In some embodiments, allocating memory includes determining free space available on memory of a handheld device performing the process. In some embodiments allocating memory includes determining free space available on removable memory used by the handheld device performing the process. If there is not enough space on the removable memory, or if, for example, the request from the providing device indicates a temporary change which will be removed after multiplayer game play is complete, the required memory space may alternatively be allocated on the main memory of the receiving device. In some embodiments the receiving device may back up the bytes of information to be overwritten at another location before allocating the requested memory address. Thus, if reversion is appropriate after multiplayer game play is complete, the original bytes of information can be easily restored onto the memory of the handheld device.
The process provides memory address locations on either the main memory or the removable memory for the allocated memory, and transmits the addresses to the other handheld device in block 515. In some embodiments, the information provided and transmitted by the handheld device may only include starting addresses and byte size information. In some embodiments, the addresses of the allocated memory may be paired with information on the specific patch or update to be stored in that particular allocated memory.
In block 517, the process receives patch information from the providing device. In some embodiments, this patch information overwrites original bytes of information in the video game software used by the handheld device. These bytes of information may have been identified by the providing device as information which should be patched or updated to enable multiplayer game play. In other embodiments, patch information received redirects the processor of the receiving device to process bytes of information at one or more of the allocated addresses holding new video game instructions. This may be done, for example, where the byte size of the patch or update exceeds the byte size available at the memory location where the old software information to be replaced was held.
In block 519, the process receives allocated information from the providing device. Allocated information may represent, for example, bytes of information including a flag indicating the removal of the bytes of information after the wireless connection for multiplayer game play is terminated. Allocated information may also represent, for example, specific video game software instructions to which associated patch information redirects the processor to achieve forward compatibility. Such information may be stored in separate allocated memory rather than overwrite specific memory because, for example, the size of the replacement information is too large to store in the memory address of the information to be replaced. In another embodiment, information may be stored in allocated memory rather than over write original video game software when the changes are not meant to be permanent, and will be deleted upon completion of multiplayer game play. Some portions of the allocated information received may be stored in the removable memory used by the receiving device, while other portions of the allocated information received may be stored, possibly simultaneously, in the main memory of the receiving device. Allocated information can be received from the providing device, for example, before, after, or simultaneously with patch information.
In block 521 the process engages in multiplayer game play. When multiplayer game play ends the process returns. In most embodiments any flags indicating portions of video game software information to be reverted to the original version of software will be honored, and the video game will be able to function for standalone game play. Upon another multiplayer connection attempt, the forward compatibility process may be reinitiated.
Accordingly, aspects of the invention provide for software patching and forward compatibility of video game software of handheld game devices. Although the invention has been discussed with respect to certain embodiments, it should be recognized that the invention may be practiced other than as specifically described, the invention comprising the claims and their insubstantial variations supported by this disclosure.

Claims (15)

What is claimed is:
1. A method of updating handheld device video game software, comprising:
determining, by a second handheld device, a version of video game software stored on a first handheld device;
determining, by the second handheld device, information to update portions of the video game software version of the game on the first handheld device to make the video game software on the first handheld device forward compatible with a version of the video game software on the second handheld device to allow for multiplayer game play between the first and second handheld devices, based at least on a version of video game software of a game stored on the second handheld device;
transmitting the information to update the video game software version of the game from the second handheld device to the first handheld device along with instructions as to where in memory of the first handheld device to store the information, the instructions including at least one memory address for storage of the information in the first handheld device and at least one flag indicating removal of the information after termination of multiplayer game play;
commanding the first handheld device to write the information to memory of the first handheld device in accordance with the received instructions, so as to modify the video game software on the first handheld device; and
communicating, by the second handheld device, with the first handheld device for multiplayer game play.
2. The method of claim 1 further comprising deleting the information from the first handheld device after termination of multiplayer game play in accordance with the at least one flag.
3. The method of claim 1 further comprising requesting a memory allocation from the first handheld device, receiving at least one memory address of allocated memory from the first handheld device, and wherein the at least one memory address for storage of the information includes the at least one memory address of allocated memory.
4. The method of claim 1 wherein the information to update the video game software version of the game comprises program instructions for use in execution of the game by the first handheld device.
5. The method of claim 1 wherein the information comprises data for use by program instructions.
6. A handheld game device configured to perform software patching of video game software of another handheld device, having a different version of the video game software, in wireless communication with the handheld game device, comprising:
a processor;
wireless communication circuitry;
memory including program instructions to configure the processor to determine information to provide to another handheld game device in order to modify a portion of video game software of the other handheld device based on a version of video game software of the handheld game device so as to make the older version of the video game software of the other handheld device forward compatible for multiplayer game play with video game software stored on the handheld device to allow for multiplayer game play between the handheld device and the other handheld device, wherein the other handheld device has an older version of the same video game software stored thereon as compared to the video game software stored on the handheld device;
wherein the memory further includes program instructions to provide the information to the other handheld game device using the wireless communication circuitry; and
wherein the program instructions to provide the information to the other handheld game device using the wireless communication circuitry includes program instructions to provide the information and to provide at least one memory address of memory of the other handheld game device to which the other handheld game device should write the information and at least one flag indicating removal of the information after termination of multiplayer game play.
7. The handheld game device of claim 6 wherein the program instructions to provide the information to the other handheld game device using the wireless communication circuitry includes program instructions to provide a retention flag as to retention of the information in memory to the other handheld game device.
8. The handheld game device of claim 6 wherein the memory further includes program instructions to request an allocation of memory from the other handheld game device.
9. The handheld game device of claim 6 wherein the information includes program instructions.
10. The handheld game device of claim 6 wherein the information includes program instructions to replace program instructions of the video game software of the other handheld game device.
11. The handheld game device of claim 10 wherein the program instructions are to replace some but not all of the program instructions of the video game software of the other handheld game device.
12. A method including updating handheld device video game software, comprising:
determining, by a first handheld device, a version of video game software stored on a second handheld device;
determining, by the first handheld device, information to update portions of the video game software version of the game on the second handheld device to make the video game software version of the game on the second handheld device forward compatible with video game software stored on the first handheld device to allow for multiplayer game play between the handheld devices, based at least on a version of video game software of a game stored on the first handheld device, the information including program instructions;
transmitting, from the first handheld device to the second handheld device, at least one memory address identifying a location in memory of the second handheld device for storage of at least some of the information;
transmitting the information, including the program instructions, to update the video game software version of the game from the first handheld device to the second handheld device along with at least one flag indicating removal of information after termination of multiplayer game play;
engaging, by the first and second handheld devices, in multiplayer game play; and
deleting at least some of the information from the second handheld device in accordance with the at least one flag after completion of multiplayer game play.
13. The method of claim 12, wherein the at least one memory address is a memory address provided to the first handheld device from the second handheld device.
14. The method of claim 12, wherein the program instructions include program instructions which replace program instructions resident in memory of the second handheld device.
15. The method of claim 12, wherein the program instructions include program instructions which supplement program instructions resident in memory of the second handheld device.
US11/967,969 2007-12-31 2007-12-31 Video game forward compatibility including software patching Active 2031-06-01 US8943488B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/967,969 US8943488B2 (en) 2007-12-31 2007-12-31 Video game forward compatibility including software patching

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US11/967,969 US8943488B2 (en) 2007-12-31 2007-12-31 Video game forward compatibility including software patching

Publications (2)

Publication Number Publication Date
US20090172659A1 US20090172659A1 (en) 2009-07-02
US8943488B2 true US8943488B2 (en) 2015-01-27

Family

ID=40800293

Family Applications (1)

Application Number Title Priority Date Filing Date
US11/967,969 Active 2031-06-01 US8943488B2 (en) 2007-12-31 2007-12-31 Video game forward compatibility including software patching

Country Status (1)

Country Link
US (1) US8943488B2 (en)

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2009054645A (en) * 2007-08-23 2009-03-12 Rohm Co Ltd Semiconductor device
KR20110000162A (en) * 2009-06-26 2011-01-03 주식회사 넥슨 System and method for providing online game using storage media
JP5675373B2 (en) * 2011-01-06 2015-02-25 任天堂株式会社 Communication system, information processing apparatus, communication program, and communication method
JP5688297B2 (en) * 2011-01-06 2015-03-25 任天堂株式会社 Communication system, information processing apparatus, communication program, and communication method
US9999832B2 (en) * 2012-04-19 2018-06-19 Nintendo Co., Ltd. Game system, computer-readable non-transitory storage medium, game processing method and game apparatus
JP6152289B2 (en) * 2012-11-15 2017-06-21 任天堂株式会社 Information processing apparatus, terminal system, information processing program, and application update data acquisition method
US11600263B1 (en) * 2020-06-29 2023-03-07 Amazon Technologies, Inc. Natural language configuration and operation for tangible games
US11645947B1 (en) 2020-06-29 2023-05-09 Amazon Technologies, Inc. Natural language configuration and operation for tangible games

Citations (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5806849A (en) 1994-02-17 1998-09-15 Electronic Arts, Inc. Electronic game system with wireless controller
US6198946B1 (en) 1997-11-20 2001-03-06 Samsung Electronics Co., Ltd. Firmware upgrade method for wireless communications device, and method for supporting firmware upgrade by base station
US6334815B2 (en) * 1997-11-20 2002-01-01 Nintendo Co., Ltd. Game system operable with backup data on different kinds of game machines
US6353174B1 (en) 1999-12-10 2002-03-05 Harmonix Music Systems, Inc. Method and apparatus for facilitating group musical interaction over a network
US20020169014A1 (en) 2001-05-14 2002-11-14 Eran Egozy Method and apparatus for facilitating group musical interaction over a network
US6544126B2 (en) * 2000-04-25 2003-04-08 Nintendo Co., Ltd. Portable game machine with download capability
US20040093592A1 (en) * 2002-11-13 2004-05-13 Rao Bindu Rama Firmware update in electronic devices employing SIM card for saving metadata information
US20040120001A1 (en) * 2002-12-20 2004-06-24 Boldon John L. Temporary printer firmware upgrade
US6757517B2 (en) 2001-05-10 2004-06-29 Chin-Chi Chang Apparatus and method for coordinated music playback in wireless ad-hoc networks
US20040127254A1 (en) * 2002-12-12 2004-07-01 Chang William Ho Device for wireless communication between computing devices
US6779004B1 (en) 1999-06-11 2004-08-17 Microsoft Corporation Auto-configuring of peripheral on host/peripheral computing platform with peer networking-to-host/peripheral adapter for peer networking connectivity
US6996817B2 (en) 2001-12-12 2006-02-07 Valve Corporation Method and system for upgrading and rolling back versions
US7069452B1 (en) 2000-07-12 2006-06-27 International Business Machines Corporation Methods, systems and computer program products for secure firmware updates
US7143939B2 (en) 2000-12-19 2006-12-05 Intel Corporation Wireless music device and method therefor
US20070136297A1 (en) * 2005-12-08 2007-06-14 Microsoft Corporation Peer-to-peer remediation
US7251812B1 (en) 2001-10-31 2007-07-31 Microsoft Corporation Dynamic software update
US7275994B2 (en) 1999-10-07 2007-10-02 Nintendo Co., Ltd. Game machine having wireless communication capability
US20070243915A1 (en) 2006-04-14 2007-10-18 Eran Egozy A Method and Apparatus For Providing A Simulated Band Experience Including Online Interaction and Downloaded Content
US20070245881A1 (en) 2006-04-04 2007-10-25 Eran Egozy Method and apparatus for providing a simulated band experience including online interaction
US7293201B2 (en) 2003-01-17 2007-11-06 Microsoft Corporation System and method for active diagnosis and self healing of software systems
US7305672B2 (en) 2004-01-06 2007-12-04 International Business Machines Corporation Dynamic software update system, method and program product
US20080133650A1 (en) * 2006-12-05 2008-06-05 Anssi Saarimaki Software distribution via peer-to-peer networks
US20080141018A1 (en) * 2006-11-09 2008-06-12 Shinichi Tanaka Game apparatus and information processing apparatus

Patent Citations (25)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5806849A (en) 1994-02-17 1998-09-15 Electronic Arts, Inc. Electronic game system with wireless controller
US6198946B1 (en) 1997-11-20 2001-03-06 Samsung Electronics Co., Ltd. Firmware upgrade method for wireless communications device, and method for supporting firmware upgrade by base station
US6334815B2 (en) * 1997-11-20 2002-01-01 Nintendo Co., Ltd. Game system operable with backup data on different kinds of game machines
US6779004B1 (en) 1999-06-11 2004-08-17 Microsoft Corporation Auto-configuring of peripheral on host/peripheral computing platform with peer networking-to-host/peripheral adapter for peer networking connectivity
US7275994B2 (en) 1999-10-07 2007-10-02 Nintendo Co., Ltd. Game machine having wireless communication capability
US6353174B1 (en) 1999-12-10 2002-03-05 Harmonix Music Systems, Inc. Method and apparatus for facilitating group musical interaction over a network
US6544126B2 (en) * 2000-04-25 2003-04-08 Nintendo Co., Ltd. Portable game machine with download capability
US7069452B1 (en) 2000-07-12 2006-06-27 International Business Machines Corporation Methods, systems and computer program products for secure firmware updates
US7143939B2 (en) 2000-12-19 2006-12-05 Intel Corporation Wireless music device and method therefor
US7236739B2 (en) 2001-05-10 2007-06-26 Chin-Chi Chang Apparatus and method for coordinated music playback in wireless ad-hoc networks
US6757517B2 (en) 2001-05-10 2004-06-29 Chin-Chi Chang Apparatus and method for coordinated music playback in wireless ad-hoc networks
US6482087B1 (en) 2001-05-14 2002-11-19 Harmonix Music Systems, Inc. Method and apparatus for facilitating group musical interaction over a network
US20020169014A1 (en) 2001-05-14 2002-11-14 Eran Egozy Method and apparatus for facilitating group musical interaction over a network
US7251812B1 (en) 2001-10-31 2007-07-31 Microsoft Corporation Dynamic software update
US6996817B2 (en) 2001-12-12 2006-02-07 Valve Corporation Method and system for upgrading and rolling back versions
US20040093592A1 (en) * 2002-11-13 2004-05-13 Rao Bindu Rama Firmware update in electronic devices employing SIM card for saving metadata information
US20040127254A1 (en) * 2002-12-12 2004-07-01 Chang William Ho Device for wireless communication between computing devices
US20040120001A1 (en) * 2002-12-20 2004-06-24 Boldon John L. Temporary printer firmware upgrade
US7293201B2 (en) 2003-01-17 2007-11-06 Microsoft Corporation System and method for active diagnosis and self healing of software systems
US7305672B2 (en) 2004-01-06 2007-12-04 International Business Machines Corporation Dynamic software update system, method and program product
US20070136297A1 (en) * 2005-12-08 2007-06-14 Microsoft Corporation Peer-to-peer remediation
US20070245881A1 (en) 2006-04-04 2007-10-25 Eran Egozy Method and apparatus for providing a simulated band experience including online interaction
US20070243915A1 (en) 2006-04-14 2007-10-18 Eran Egozy A Method and Apparatus For Providing A Simulated Band Experience Including Online Interaction and Downloaded Content
US20080141018A1 (en) * 2006-11-09 2008-06-12 Shinichi Tanaka Game apparatus and information processing apparatus
US20080133650A1 (en) * 2006-12-05 2008-06-05 Anssi Saarimaki Software distribution via peer-to-peer networks

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
"Game Boy Advance Wireless Adapter" 1 page, Jan. 29, 2005.
"Nintendo DS Lite", Instruction Booklet, Nintendo of America Inc., 2006, 15 pages.

Also Published As

Publication number Publication date
US20090172659A1 (en) 2009-07-02

Similar Documents

Publication Publication Date Title
US8943488B2 (en) Video game forward compatibility including software patching
CN109460245B (en) Remote upgrading method for embedded system
WO2022007656A1 (en) Bootloader software updating method and apparatus, embedded controller, and storage medium
US8856810B2 (en) Information processing system configured to emulate software during an emulation mode
KR20060113043A (en) Apparatus and method of firmware updating for movable storage apparatus
US8949205B2 (en) Information processing apparatus for processing application software and a patch file
MXPA04002527A (en) Software update method, apparatus and system.
JP5039986B2 (en) Apparatus, method, data carrier and computer program for synchronizing controller firmware downloads
CN107402776A (en) A kind of mobile phone wireless upgrading stm32 singlechip controller firmware methods based on bluetooth 4
CN110543318A (en) control device program updating method and device, storage medium and control device
US8176307B2 (en) Method and system for post-build modification of firmware binaries to support different hardware configurations
CN110597542A (en) Automatic OTA (over the air) software upgrading method and device and electronic equipment
WO2016062146A1 (en) Serial number information update method, device and terminal
CN109002320A (en) For the update method of software development kit, system, electronic equipment and storage medium
CN114691178B (en) Firmware upgrading method and device based on EtherCAT communication driver
RU2220446C2 (en) Portable electronic device and entertainment system
JP3985737B2 (en) Software update system, electronic device, and software update method
JP2002207599A (en) Communication terminal and software update system thereof
CN113051071A (en) Command submitting method and device, command reading method and device, and electronic equipment
WO2017173924A1 (en) Method and device for switching between file systems
CN114461158B (en) Application screen projection method and device, vehicle-mounted terminal and readable storage medium
CN104580398B (en) A kind of Web content method for pushing, device and Web content displaying client
CN113315831B (en) Cloud game playing method, device, equipment and storage medium
JP3688424B2 (en) Information processing apparatus and method, and recording medium
CN112540800A (en) Method for realizing compatibility of EMMCs with different sizes through newly added partitions based on high-pass platform

Legal Events

Date Code Title Description
AS Assignment

Owner name: ACTIVISION PUBLISHING, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:OBERG, GREGORY KEITH;BOOTH, JESSE NATHANIEL;REEL/FRAME:020548/0725

Effective date: 20080214

AS Assignment

Owner name: BANK OF AMERICA, N.A., WASHINGTON

Free format text: SECURITY AGREEMENT;ASSIGNOR:ACTIVISION BLIZZARD, INC.;REEL/FRAME:031435/0138

Effective date: 20131011

STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: ACTIVISION ENTERTAINMENT HOLDINGS, INC., CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:BANK OF AMERICA, N.A.;REEL/FRAME:040381/0487

Effective date: 20161014

Owner name: ACTIVISION BLIZZARD INC., CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:BANK OF AMERICA, N.A.;REEL/FRAME:040381/0487

Effective date: 20161014

Owner name: BLIZZARD ENTERTAINMENT, INC., CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:BANK OF AMERICA, N.A.;REEL/FRAME:040381/0487

Effective date: 20161014

Owner name: ACTIVISION PUBLISHING, INC., CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:BANK OF AMERICA, N.A.;REEL/FRAME:040381/0487

Effective date: 20161014

Owner name: ACTIVISION ENTERTAINMENT HOLDINGS, INC., CALIFORNI

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:BANK OF AMERICA, N.A.;REEL/FRAME:040381/0487

Effective date: 20161014

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551)

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8