Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
PROCESSING SYSTEM, INFORMATION PROCESSING APPARATUS, CONTROL METHOD, PROGRAM AND STORAGE MEDIUM
Document Type and Number:
WIPO Patent Application WO/2013/191016
Kind Code:
A1
Abstract:
A first device generates, associates with a generated call, and transmits generation information for generating an object corresponding to identification information included in the call. On the other side, in a case where the received call includes unknown identification information, a second device generates and stores an object corresponding to unknown identification information based on generation information associated with the call. Next, the second device associates the unknown identification information with specification information that specifies the stored object in a memory space of the device and register that.

Inventors:
IWASAKI TETSUJI (CA)
Application Number:
PCT/JP2013/065903
Publication Date:
December 27, 2013
Filing Date:
June 04, 2013
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
SQUARE ENIX HOLDINGS CO LTD (JP)
International Classes:
A63F13/12; G06F9/448; A63F13/00; G06F9/46; G06F9/50
Foreign References:
US6678742B12004-01-13
JP2011118867A2011-06-16
JP2004348664A2004-12-09
US20110047255A12011-02-24
US6249822B12001-06-19
Other References:
See also references of EP 2861313A4
Attorney, Agent or Firm:
OHTSUKA, Yasunori et al. (KIOICHO PARK BLDG. 3-6, KIOICHO, CHIYODA-K, Tokyo 94, JP)
Download PDF:
Claims:
CLAIMS

1. A processing system in which a first device generates a call corresponding to a function provided by a second device which is different from the first device, and causes the second device to execute processing corresponding to the function,

wherein the first device comprises:

allocation means for allocating identification information, that is for the processing system, for specification information that specifies an object stored in the first memory;

call transmission means for generating and transmitting to the second device a call including identification information allocated by the allocation means; and

information transmission means for generating, associating with the call and transmitting generation information for generating an object corresponding to identification information included in the call;

and wherein the second device comprises:

a second memory for storing an object;

receiving means for receiving the call or the generation information; and

registration means for, in a case where unknown identification information is included in a call received by the receiving means, generating based on generation information associated with the call, and storing in the second memory, an object corresponding to the unknown identification information, associating with specification information that specifies an object corresponding to the unknown identification information, and registering, the unknown identification information.

2. The processing system according to claim 1, wherein the information transmission means, in a case where an object for which identification information is newly allocated for specification information exists among objects corresponding to identification

information included in the call, generates and

transmits the generation information of the object.

3. The processing system according to either claim 1 or 2, wherein the second device is connected for

communication with a plurality of first devices, and the first device further comprises a sharing means for associating with identification information included in the call, and sharing with another first device

connected for communication to the second device, generation information of an object corresponding to the identification information included in the call.

4. The processing system according to claim 3, wherein the allocation means, in a case where unknown identification information is shared from the other first device by the sharing means, generates, based on generation information associated with the unknown identification information, and stores in the first memory, an object corresponding to the unknown

identification information, and allocates the unknown identification information for specification

information that specifies an object corresponding to the unknown identification information.

5. The processing system according to either claim 1 or 2, wherein the first device is connected for communication to a plurality of third devices, and executes independently processing that includes generation of a call corresponding to a function that the second device provides to each of the plurality of third devices, and the first device further comprises a sharing means for associating with identification information included in the call generated in the independently executed processing, and sharing with other independently executed processing, generation information of an object corresponding to the

identification information.

6. The processing system according to any one of claims 1-5, wherein the second device further comprises processing means for executing processing corresponding to a called function using specification information associated with identification information included in a call received by said receiving means.

7. The processing system according to any one of claims 1-5, wherein specification information is a pointer in the respective memory space for a object stored in the first memory or the second memory, the identification information is a handler allocated for specification information, and the second device further comprises processing means for executing processing corresponding to the called function using a pointer associated with a handler included in the call received by said receiving means .

8. An information processing apparatus that executes processing corresponding to the function in accordance with having received a call for a function that the information processing apparatus provides from another device, the information processing apparatus

comprising :

a memory for storing an object;

receiving means for receiving from the other device a call including identification information allocated for specification information that specifies an object that the other device retains in the other device and generation information for generating an object corresponding to identification information included in the call; and

registration means for, in a case where unknown identification information is included in a call

received by the receiving means, generating based on the generation information, and storing in the memory, an object corresponding to the unknown identification information, and associating with specification

information that specifies an object corresponding to the unknown identification information, and registering, the unknown identification information.

9. A control method of an information processing apparatus that executes processing corresponding to a function that the information processing apparatus provides in accordance with having received a call for the function from another device, the control method comprising :

a receiving step that receiving means of the information processing apparatus receives from the other device a call including identification

information allocated for specification information that specifies an object that the other device retains in the other device and generation information for generating an object corresponding to identification information included in the call; and

a registration step that registration means of the information processing apparatus, in a case where unknown identification information is included in a call received in the receiving step, generates based on the generation information, and stores in the memory, an object corresponding to the unknown identification information, and associates with specification

information that specifies an object corresponding to the unknown identification information, and registers, the unknown identification information.

10. A program for causing a computer to execute each step of the control method of the information

processing apparatus according to claim 9.

11. A computer-readable storage medium storing the program according to claim 10.

Description:
DESCRIPTION

TITLE OF INVENTION PROCESSING SYSTEM, INFORMATION PROCESSING APPARATUS, CONTROL METHOD, PROGRAM AND STORAGE MEDIUM

TECHNICAL FIELD

[0001] The present invention relates to a

processing system, an information processing apparatus, a control method, a program and a storage medium, and particularly to a technique of realizing processing over multiple devices.

BACKGROUND ART

[0002] Client devices such as personal computers

(PCs) capable of network connection have become

widespread. Along with the widespread use of devices, the network population of the Internet is increasing. Various services using the Internet have recently been developed for network users, and entertainment services such as games are also provided.

[0003] One of the services for network users is a multiuser online network game such as MMORPG (Massively Multiplayer Online Role-Playing Game) . In a multiuser online network game, a user connects his/her client device to a server that provides the game, thereby doing match-up play or team play with another user who uses another client device connected to the server. [0004] In a general multiuser online network game, each client device sends/receives data necessary for game rendering to/from the server. The client device performs rendering processing using the received data necessary for rendering and presents the generated game screen to a display device connected to the client device, thereby providing the game screen to the user. Information the user has input by operating an input interface is sent to the server and used for

calculation processing in the server or transmitted to another client device connected to the server.

[0005] However, some network games that cause a client device to perform rendering processing require a user to use a PC having sufficient rendering

performance or a dedicated game device. For this reason, the number of users of a network game (one content) depends on the performance of the client device required by the content. A high-performance device is expensive, as a matter of course, and the number of users who can own the device is limited.

That is, it is difficult to increase the number of users of a game that requires high rendering

performance, for example, a game that provides

beautiful graphics.

[0006] In recent years, however, there are also provided games playable by a user without depending on the processing capability, such as rendering performance, of a client device. In a game such as is described in International Publication No. 2009/138878, a server acquires the information of an operation caused in a client device and provides, to the client device, a game screen obtained by performing rendering processing using the information.

[0007] In a case where a server performs rendering processing such as in the previously described

International Publication No. 2009/138878, for example, an embodiment is considered in which main processing excluding rendering processing is performed on a client device, and processing concerning rendering is caused to be processed by a server. Specifically, the client device can acquire a game screen by using a rendering capability that the server provides as needed in the course of the main processing.

[0008] As one form of achieving this kind of embodiment, a method may be considered in which a function concerning rendering processing that the server provides is used by calling the function in the main processing of the client device. However, a method of providing to a function a handler including a pointer to an object as a callback as with a

conventional callback function could not be used across different devices as in the game system of

International Publication No. 2009/138878. This is because each device uses an independent memory space, and a pointer to an object in one device's memory space cannot be used in the memory space of another device.

SUMMARY OF INVENTION

[0009] The present invention was made in view of such problems in the conventional technique. The present invention provides a processing system, an information processing apparatus, a control method, a program and a storage medium that realize execution of processing due to a call that spans devices.

[0010] The present invention in its first aspect provides a processing system in which a first device generates a call corresponding to a function provided by a second device which is different from the first device, and causes the second device to execute

processing corresponding to the function, wherein the first device comprises: allocation means for allocating identification information, that is for the processing system, for specification information that specifies an object stored in the first memory; call transmission means for generating and transmitting to the second device a call including identification information allocated by the allocation means; and information transmission means for generating, associating with the call and transmitting generation information for generating an object corresponding to identification information included in the call; and wherein the second device comprises: a second memory for storing an object; receiving means for receiving the call or the generation information; and registration means for, in a case where unknown identification information is included in a call received by the receiving means, generating based on generation information associated with the call, and storing in the second memory, an object corresponding to the unknown identification information, associating with specification information that specifies an object corresponding to the unknown identification information, and registering, the unknown identification information.

[0011] The present invention in its second aspect provides an information processing apparatus that executes processing corresponding to the function in accordance with having received a call for a function that the information processing apparatus provides from another device, the information processing apparatus comprising: a memory for storing an object; receiving means for receiving from the other device a call including identification information allocated for specification information that specifies an object that the other device retains in the other device and generation information for generating an object

corresponding to identification information included in the call; and registration means for, in a case where unknown identification information is included in a call received by the receiving means, generating based on the generation information, and storing in the memory, an object corresponding to the unknown

identification information, and associating with

specification information that specifies an object corresponding to the unknown identification information, and registering, the unknown identification information.

[0012] The present invention in its third aspect provides a control method of an information processing apparatus that executes processing corresponding to a function that the information processing apparatus provides in accordance with having received a call for the function from another device, the control method comprising: a receiving step that receiving means of the information processing apparatus receives from the other device a call including identification

information allocated for specification information that specifies an object that the other device retains in the other device and generation information for generating an object corresponding to identification information included in the call; and a registration step that registration means of the information

processing apparatus, in a case where unknown

identification information is included in a call

received in the receiving step, generates based on the generation information, and stores in the memory, an object corresponding to the unknown identification information, and associates with specification

information that specifies an object corresponding to the unknown identification information, and registers, the unknown identification information.

[0013] Further features of the present invention will become apparent from the following description of exemplary embodiments (with reference to the attached drawings ) .

BRIEF DESCRIPTION OF DRAWINGS

[0014] Fig. 1A is view for showing a system configuration of a game system according to a first embodiment of the present invention.

[0015] Fig. IB is view for showing a system configuration of a game system according to a second embodiment of the present invention.

[0016] Fig. 2 is a block diagram for showing a functional configuration of a client terminal 100 according to embodiments of the present invention.

[0017] Fig. 3 is a block diagram for showing a functional configuration of a server 200 according to embodiments of the present invention.

[0018] Fig. 4A and 4B are views for illustrating a handler table of each device according to embodiments of the present invention.

[0019] Fig. 5 is an operation flow illustrating an outline of a handler table updating operation according to embodiments of the present invention.

[0020] Figs. 6A and 6B are views for explaining the handler table updating operation according to embodiments of the present invention.

[0021] Figs. 7A and 7B are other views for

explaining the handler table updating operation

according to embodiments of the present invention.

[0022] Fig. 8 is a flowchart for illustrating client handler table updating operation executed on the client terminal 100 according to the second embodiment of the present invention.

[0023] Fig. 9 is view for showing a system

configuration of a game system according to a second embodiment of the present invention.

DESCRIPTION OF EMBODIMENTS

[0024] [First Embodiment]

Below, for the explanatory embodiments of the present invention, detailed explanation is given referring to the drawings. Note, the first embodiment, which is explained below, is an example of a processing system, and will be explained as an example in which a game system comprising a client terminal 100

functioning as the user operated first device and a server 200 functioning as the game content screen distributing second device is applied to the present invention . [0025]<Game System Configuration>

Fig. 1A is view for showing a system

configuration of a game system according to a first embodiment of the present invention.

[0026] As shown in the drawing, the client

terminal 100 and the server 200 are connected via a network 300. In the game system of the present

embodiment the server 200 receives a processing

instruction concerning screen generation of provided game contents from the client terminal 100 and performs processing corresponding to the instruction. Next the server 200 distributes by streaming the generated screen as encoded video data to the client terminal 100.

[0027] In the present embodiment, explanation is given with the client terminal 100 assumed to be a home-use game console for performing processing other than processing concerning the rendering system, but implementation of the present invention is not limited to this. The client terminal 100 may be any device that can cause the server 200 to perform a function by generating a call to a capability (function) that the server 200 provides such as a PC, a portable game device, and mobile phone, a PDA, a tablet or the like.

[0028] In the present embodiment, the server 200 performs processing concerning the rendering system instead of performance on the client terminal 100. Here the client terminal 100 functions as a master that makes a processing command and the server 200 functions as a slave that provides a game content rendering capability corresponding to the processing command. Note, in the present embodiment, the server 200 is explained as something that provides a rendering capability, but the present invention is not limited to this kind of rendering capability and it should be understood that other application is possible. Also, in the present embodiment, explanation is given with the second device being the server 200, but the second device is not limited to being a server and it may be any device that can receive the call for performance of the provided capability.

[0029] <Client Terminal 100 Configuration>

Fig. 2 is a block diagram for showing a functional configuration of the client terminal 100 according to embodiments of the present invention.

[0030] A control unit 101 is, for example, a CPU.

The control unit 101 controls the operation of each block of the client terminal 100. Specifically, the control unit 101 controls operation of each block by reading out operation programs for each block stored in a ROM 102, loading them into a RAM 103 and executing them.

[0031] The ROM 102 is, for example, a rewriteable non-volatile memory. The ROM 102, in addition to the operation programs of each block of the client terminal 100, also stores information such as parameters

necessary for the operation of the blocks.

[0032] The RAM 103 is a volatile memory. The RAM

103 functions not only as a load area for operation programs of each of the blocks of the client terminal 100, but also as a storage area for such things as intermediate data output in the operation of each block. Also, in the present embodiment, each type of object used in the operation of each block is stored in the RAM 103. The various types of objects may be specific structures that are allocated in a program such as, for example, parameters that show the state of user

operation target characters.

[0033] Also, in the present embodiment, a client handler table that manages handlers that are included in a call of a function (provided function)

corresponding to a capability that the server 200 provides is stored in the RAM 103. Specifically, the client handler table manages a correspondence between handlers included in the calls, and pointers of the various types of objects stored in the RAM 103. For example, in a case where a provided function is defined to be :

InitialisationMethod (Data, &pObjectl, &pObject2, &pObject3) it is necessary to pass three types of instances in addition to data (Data) in order to execute the function. Here, each instance is a pointer that indicates an object in RAM 103, and because the memory spaces are different between the client terminal 100 and the server 200 as described above, in the server 200 the pointer is not correctly interpreted.

Consequently, in the present embodiment, for a pointer included as an instance of a provided function, a handler that uniquely specifies the pointer is

allocated, and this handler is included in a call and transmitted. As shown in Fig. 4A, in the client handler table, a pointer used as a instance and a handler allocated for the pointer are associated and managed .

[0034] A decoding unit 104 decodes encoded video data received from the server 200, and generates screens to provide to a later described display unit 107. Note, in the present embodiment explanation is given having the client terminal 100 be something that receives a game content screen in the form of encoded video data from the server 200, but the received data is obviously not limited to this data form.

[0035] A communication unit 105 is a communication interface of the client terminal 100. The client terminal 100 can connect to the server 200 over the network 300 via the communication unit 105, and can perform data communication according to a defined protocol .

[0036] An operation input unit 106 is a user interface of the client terminal 100 such as, for example, an operation button or a touch panel. When the operation input unit 106 detects operation input from the user, control signals corresponding to the operation input are output to the control unit 101.

[0037 ] The display unit 107 is a display apparatus of the client terminal 100 such as an LCD, for example. A game content screen received from the server 200 is provided to a user by being presented on the display unit 107.

[ 0038 ] <Server 200 Configuration>

Fig. 3 is a block diagram for showing a functional configuration of the server 200 according to embodiments of the present invention.

[ 0039] A server control unit 201 is, for example, a CPU, and it controls the operation of each block of the server 200. Specifically, the server control unit 201 controls the operation of each block stored in a server ROM 202 by reading out an operation program of the block, loading it into a server RAM 203, and executing it.

[0040 ] The server ROM 202 is, for example, a rewritable, non-volatile memory. The server ROM 202, in addition to the operation programs of each block of the server 200, also stores information such as parameters necessary for the operation of the blocks. Also, in the server ROM 202 account information of users of services that the server 200 provides is managed. A user of the client terminal 100 can receive the provision of screens that correspond to progress status on the terminal by performing a service login to the server 200 using the account information when using the game content .

[0041] The server RAM 203 is a volatile memory.

The server RAM 203 functions not only as a load area for operation programs of each of the blocks of the server 200, but also as a storage area for such things as intermediate data output in the operation of each block. Also, in the present embodiment, each type of object used in the operation of each block is stored in the server RAM 203. Some of the various types of objects correspond to objects stored in the RAM 103 of the client terminal 100.

[0042] Also, in the server RAM 203, a server handler table that manages handlers that are included in a call of a provided function. Specifically, the server handler table manages a correspondence between handlers included in the calls, and pointers of objects stored in the server RAM 203 corresponding to these handlers. The server handler table, as shown in Fig. 4B, associates with pointers to corresponding objects in the server RAM 203 and manages handlers allocated in the client terminal 100. Note, there is generally a 1 to 1 correspondence between the server handler table and the client handler table. In other words, on the client terminal 100 and the server 200 for common handlers, pointers to corresponding objects in each memory space are managed using tables.

[0043] A server rendering unit 204 is, for example, a GPU, and it renders game screens for game content of a provided service. For example, in a case where content in which a 3 dimensional scenes are provided as game screens, the server rendering unit 204 receives information of a rendering object included in a

rendering scope from the server control unit 201, and generates game screens rendering to a VRAM (not shown) in order. Note, such things as model data and texture data used in game screen generation are stored in a server storage medium 205.

[0044] A server encoding unit 206 generates encoded video data by encoding game screens generated by the server rendering unit 204. In the present embodiment a game screen provided from the server 200 to the client terminal 100 is transmitted as a frame of encoded video data of a predetermined format.

[0045] A server communication unit 207 is a communication interface of the server 200. The server 200 can connect to servers 200 over the network 300 via the server communication unit 207, and can perform data communication according to a defined protocol. In the present embodiment the server 200 transmits encoded video data generated in the server encoding unit 206 using a streaming format to the client terminal 100.

[0046] <Handler Table Update Operation>

Here an overview of handler table update operation of the previously described client handler table and the server handler table will be explained using the operation flow of Fig. 5. Note, the

processing of this operation flow is performed when the control unit 101, in the processing performed on the client terminal 100, determines to generate a call to a provided function that the server 200 provides.

[ 0047 ] In step S501 the control unit 101 extracts instances included in a call (in other words pointers to objects stored in the RAM 103) .

[ 0048 ] In step S502, the control unit 101

determines, for each pointer extracted in step S501, whether or not a handler has already been allocated referring to the client handler table.

[0049] In step S503, the control unit 101

allocates and registers in the client handler table a new handler for pointers for which a handler was not yet allocated. [0050] In step S504, the control unit 101

generates generation information necessary for

generating the object for an object specified by a pointer for which a new handler was allocated. As with the present embodiment, in order to reference a single object in different memory spaces, it is necessary to generate the same object in each of the memory spaces. In other words, in order to allow reference of an object generated in the client terminal 100 in the server 200, the control unit 101 may transmit

generation information for causing generation in the server 200 of the object, and the server control unit 201 may generate the same object. Note, the generation information may be information to which an allocated handler is associated that generates parameters, processing order and the like necessary for generation of the object, for example.

[0051] In step S505, the control unit 101 packages and transmits to the communication unit 105 the handlers allocated for each pointer extracted in step S501 thereby causing them to be transmitted to the server 200 as a call. Here, in a case where a pointer for which a handler was newly allocated exists amongst the extracted pointers, the control unit 101 includes generation information for the pointer in the call.

[0052] Note, in the present embodiment explanation is made having transmission done including generation information, but so long as association between the generation information and the call can be

distinguished, it should be understood that they can be transmitted separately. Also, in the present

embodiment, explanation is made having handler

information associated with the generation information, but the invention is not limited to this. For example, in a case where only one handler is included in a call, if it is possible to distinguish an association with the generation information, there is no need for the handler information to be associated with the

generation information.

[0053] In step S506, the server control unit 201 receives the call sent from the client terminal 100.

[ 0054] In step S507 the server control unit 201 determines whether or not a handler that does not exist in the server handler table (an unknown handler) is included in the received call.

[0055] In step S508, the server control unit 201 references generation information included in the call, generates an object corresponding to the unknown handler, and stores it in the server RAM 203.

[0056] In step S509, the server control unit 201 associates a pointer to the object generated in step S508 with the unknown handler and registers it to the server handler table.

[0057 ] In step S510, the server control unit 201 executes the provided function that was called. At this point the server control unit 201 references the server handler table, passes as an instance of the provided function a pointer corresponding to the handlers included in the call, and executes.

[0058] With this, it is possible to realize an execution instruction due to a call to a function that another device provides between devices having

different memory spaces. Also, because specification of a pointer by a handler is possible, it is possible to reduce data communication volume for the call.

[0059] <Concrete Example>

Here, explanation of an operation example of the above described operation flow is given. The case in which a call to the provided function:

InitialisationMethod ( Data, SpObjectl, &pObject2, &p0bject3)

is performed in a case where, for example, not a single handler or pointer is registered in the client handler table is considered.

[0060] In this case, because handlers are not yet allocated for pointers pObjectl, p0bject2 or p0bject3, the control unit 101 allocates to each pointer and registers in the client handler table 600 a handler, as shown in Fig. 6A. Next, the control unit 101, as a call 601 to the InitialisationMethod function, packages :

Data (including generation information of Object 1,

Object2- and Object3) ;

a handler "1" allocated for pObjectl;

a handler "2" allocated for pObject2; and

a handler "3" allocated for pObject3,

and transmits them to the server 200 by transferring them to the communication unit 105.

[0061] On the other hand, when on the server 200 the call 601 is received, first the server control unit 201 references the generation information included in the call and generates objects 611, 612 and 613

(Objectl, Object2 and Object3) which correspond to the handlers in the server RAM 203. Next, the server control unit 201 associates the corresponding handlers to the pointers for the generated objects and registers them this in the server handler table 610.

[0062] With this, on top of generating in the server RAM 203 the same objects as Objectl, Object2 and Object3 existing in the RAM 103 of the client terminal 100, handlers that are common between each of the client terminals 100 and the server 200 can be

allocated. Specifically, after being registered in the handler tables, each of the objects can be specified by the handler alone.

[0063] Also, a case in which, in a case where, for example, the client handler table is as in Fig. 6A, a call to a function:

p0bject2->FunctionCall (Data, &pObject4)

that defines an operation corresponding to a particular object is performed in considered.

[0064] In this case, because the handler is not yet allocated for the pointer pObject4, the control unit 101 allocates the handler "4" and registers it in the client handler table 700, as shown in Fig. 7A.

Next, the control unit 101 as a call 701 to the

InitialisationMethod function packages:

Data (including generation information of

Object4) ;

a handler "2" allocated for pObject2; and

a handler "4" allocated for pObject4,

and transmits them to the server 200 by transferring them to the communication unit 105.

[0065] On the other hand, when on the server 200, the call 701 is received, firstly the server control unit 201 references the generation information included in the call and generates an object 711 (Object4) which corresponds to handler "4" in the server RAM 203. Next, the server control unit 201 associates the

corresponding handler "4" to the pointer (p0bject4 on server 200) for the generated object and registers it in the server handler table 710.

[0066] In this way, by updating the data

configuration of a call, even a function that defines operation corresponding to a particular object can be associated .

[0067] As explained above, the processing system of the present embodiment is able to realize the execution of processing due to a call that spans multiple devices. Specifically, in the processing system, the first device allocates identification information, that is for the processing system, for specification information specifying a storage object in the memory space of the device. Next a call to a function which the second device provides which includes the allocated identification information is generated and transmitted. In this case the first device generates generation information in order to generate an object corresponding to the identification information included in the generated call, associates it with the call, and transmits it. Meanwhile, in a case where unknown identification information is included in the received call, the second device generates and stores an object corresponding to unknown identification information based on generation

information associated with the call. Next, the second device associates unknown identification information with specification information that specifies a stored object in the memory space of the device and registers it. [0068] [Second embodiment]

In the above described first embodiment, explanation was given for an example in which a single client terminal 100 is connected to a server 200. In the present embodiment, an example in which, for example, game content that the server 200 provides is an online game of a type in which multiple people can simultaneously participate, and in which multiple client terminals 100 are connected to the server 200 will be explained.

[0069] Note, in the present embodiment,

explanation will be given having the server 200 be something that provides an online game of a type in which multiple people can simultaneously participate, but the present invention is not limited to content in which a plurality of users can simultaneously

participate in a single game space in this way. The invention according to the present can be adopted to a case in which calls made from a plurality of client terminals handlers for common objects are included.

[0070] In a case where, as with an online game of a type in which multiple people can simultaneously participate, game content is provided to a plurality of client terminals, it is possible that common objects are used in rendering processing of such things as screens that are provided to the client terminals, and characters, terrain and the like that are included in screens. In this case, even if the object is the same, a different handler is allocated for each client terminal and managed, in a case where as in the first embodiment a handler table is allocated and managed for each client terminal. In other words, in the memory space of the server 200, the same object will be generated multiple times, and furthermore, a different handler. will be allocated for each instance, and managing handler tables will exist for each. This leads to unnecessary memory space occupation due to multiple occurrences in the memory space of the server 200 for what is in fact only a single object, and so this is undesirable.

[0071] In the present embodiment, in view of this kind of problem, in a system in which execution of processing due to a call over multiple devices being performed, a game system that realizes better memory usage efficiency is provided.

[0072]<Game System Configuration>

Fig. IB shows the system configuration of the game system of the present embodiment. As shown in the drawing, a plurality of client terminals 100 are connected to the server 200 via the network 300. Note, in the game system of the present embodiment, because the functional configuration of the client terminal 100 and the server 200 is common to that of the first embodiment other than the fact that the communication unit 105 of the client terminal 100 performs

communication with other client terminals 100,

explanation is omitted.

[0073] In the client terminal 100 of the present embodiment, in a case where a pointer for which a handler is not yet allocated is included in a call to a function provided by the server 200, the following processing is performed. The control unit 101

transmits, as handler allocation information,

information indicating a newly allocated handler for a pointer for which a handler is not yet allocated and generation information for an object indicating the pointer to not only the server 200 but also to other client terminals 100 that are connected to the server 200. In other words, by transmitting the object for which the handler was newly allocated and information of the handler to the other client terminals 100, it is possible to synchronize the client handler tables between the client terminals.

[0074] In the present embodiment, client handler tables are synchronized between client terminals in this way, and each terminal is made to hold a common handler table. By doing this, because it eliminates the same object being multiply generated in the server RAM 203 of the server 200 and furthermore because it eliminates the necessity of the server 200 having server handler tables for each terminal, it makes for efficient memory usage.

[0075] <Client Handler Table Update Processing>

Here, client handler table update processing executed on the client terminal 100 according to the present embodiment will be explained in detail using the flowchart of Fig. 8. The processing corresponding to this flowchart can be realized by the control unit 101 reading out a corresponding processing program stored in the ROM 102 for example, loading it into the RAM 103 and executing it. Note, explanation will be given with this client handler table update processing being initiated when an application for, for example, game content is executed, and being repeatedly executed in a processing loop corresponding to a single frame in the application.

[0076] In step S801, the control unit 101

determines whether or not the communication unit 105 received handler allocation information indicating that a handler was allocated for a new object from another client terminal 100. In a case where the control unit 101 determined that the communication unit 105 received handler allocation information from another client terminal 100, it moves the processing to step S802, and in a case where it determined that the communication unit 105 did not receive handler allocation information from another client terminal 100, it moves the

processing to step S803.

[0077] In step S802, the control unit 101

generates a new object in the RAM 103 based on

generation information included in the handler

allocation information, associates the handler

specified in the handler allocation information with the pointer to the object, and registers this in the client handler table.

[0078] In step S803, the control unit 101

determines whether or not a pointer for which a handler has yet to be allocated exists in the pointers included in the call transmitted to the server 200 in the processing of the current frame. In a case where the control unit 101 determined that a pointer for which a handler has yet to be allocated exists in the pointers included in the call transmitted to the server, it moves the processing to step S804, and in a case where the control unit 101 determined that a pointer for which a handler has yet to be allocated does not exist in the pointers included in the call transmitted to the server, it terminates this client handler table update processing.

[0079] In step S804, the control unit 101

transmits, as handler allocation information, to other client terminals 100 that are connected to the server 200, by transferring information indicating the handler allocated for the pointer for which a handler was not yet allocated, and generation information of the object that the pointer indicates to the communication unit 105, and terminates this client handler table update processing .

[0080] With this, it is possible to generate a call to a function provided by the server 200 using a handle common to all of the client terminals connected to the server 200. Note, explanation was given having handler information allocated ยท for an object be

something that was shared by all of the client

terminals connected to the server 200, but working of the present invention is not limited to this. For the present invention, handler information may be shared amongst only some client terminals out of the client terminals connected to the server 200 such as, for example, a group of client terminals for which the operation character is located in a specific field in the game, or for a group of client terminals for which the users are performing cooperative play in the game.

[0081] [Third Embodiment]

In the second embodiment described above, an embodiment in which when a plurality of client

terminals 100 are connected to the server 200, client handler tables are synchronized between client

terminals, and used was explained. In the present embodiment, explanation of an embodiment whereby

synchronization of the client handler table between client terminals is unnecessary will be given.

[0082]<Game System Configuration>

Fig. 9 shows the system configuration of the game system of the present embodiment. In the game system of the present embodiment, on the point that a plurality of client terminals 100 are connected to the server 200 via the network 300, this embodiment is the same as the second embodiment. In the present

embodiment, the server 200 is further connected to a rendering server 400. In the example of Fig. 9, the server 200 and the rendering server 400 are shown to be directly connected. However, it should be easy to envision that the server 200 and the rendering server 400 may be connected via a network 300.

[0083] Note, in the game system of the present embodiment, ' the processing that the client terminal 100, the server 200, and the rendering server 400 handle differs from that of the two embodiments described above. In the present embodiment, in contrast to the above described embodiments, the rendering server 400 executes processing concerning the game content

rendering system that is performed in the server 200. Also, the server 200 generates a call to a function provided by the rendering server 400, thereby causing the rendering server 400 to perform the processing. In other words, in the present embodiment, there is no need to perform specific processing of game content such as rendering instructions in the client terminal 100. The client terminal 100 performs playback of encoded video data received from the server 200. Also, the client terminal 100 associates user operation input related to the game content, and transmits this operation input to the server 200.

[0084] In other words, in the game system of the present embodiment, the client terminal 100 only needs an operation input interface with the application that performs playback of the encoded video data provided from the server 200 such as a browser, for example, and does not need to save or execute a particular game program. The specific processing for game content is performed by the server 200 and out of that, for processing concerning the rendering system, the server 200 causes the rendering server 400 to execute the processing by transmitting a call to it. Of course the handler table update operation explained in the

embodiments described above is performed by the server 200 and the rendering server 400, and the server 200 manages a table corresponding to the client handler table, and the rendering server 400 manages a table corresponding to a server handler table.

[0085] In the game system of the present embodiment, the specific processing for each of the plurality of client terminals 100, is executed in the server 200. In this case, the server control unit 201 does not need to manage a table corresponding to the client handler table for processing of each client terminal, but rather only needs to manage a single table and generation information for each object for the plurality of client terminals. In other words, by using a common table in the same memory space for the processing of the plurality of client terminals, it is possible to share handler information allocated for a new object processing of one of them without performing the client handler table update processing described above .

[0086] By doing this, it is possible to generate a call to a function provided by the rendering server 400 using a common handler in the processing for the plurality of client terminals that are connected to the server 200 in the same was as in the second embodiment described above. Note, in this case, because the object that the processing for the plurality of client terminals references exists in the same memory space in the server 200, there is no need to newly generate, based on generation information, or store an object. When the server control unit 201 needs to newly

generate an object, it references generation

information for previously generated objects in the memory space, and in the case where a match exists, the previously generated object may be used without the necessity of generating the object.

[0087] Note, in the first and second embodiments described above, and the in the third embodiment, explanation was given wherein the handler allocated for the pointer was included in the call, but the present invention is not limited to this. The present

invention eliminates not obtaining a desirable result by including an address reference to the object in the call in order that the same object be stored in a different address in a memory space of a different device In other words, the target of allocation of identification information such as the handler, is not limited to a pointer, and may be specifying information that specifies a particular address in a memory space.

[0088] [Other Embodiments]

Also, the processing system according to the present invention can be realized by a program that causes a computer to function as each of the devices in the processing system. This program can be

provided/distributed via an electronic communication circuit by storing it in a computer readable storage medium.

[0089] While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such

modifications and equivalent structures and functions.

[0090] This application claims the benefits of

United States Patent Provisional Application No.

61/661,499, filed June 19, 2012, United States Patent Provisional Application No. 61/664,313, filed June 26, 2012, and Japanese Patent Application No. 2012-183575, filed August 22, 2012, which are hereby incorporated by reference herein in their entirety.