WO2006008961A1 - 情報処理システム及び情報処理方法、並びにコンピュータプログラム - Google Patents
情報処理システム及び情報処理方法、並びにコンピュータプログラム Download PDFInfo
- Publication number
- WO2006008961A1 WO2006008961A1 PCT/JP2005/012422 JP2005012422W WO2006008961A1 WO 2006008961 A1 WO2006008961 A1 WO 2006008961A1 JP 2005012422 W JP2005012422 W JP 2005012422W WO 2006008961 A1 WO2006008961 A1 WO 2006008961A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- information processing
- processor
- sub
- image data
- information
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0862—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches with prefetch
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
- G06F15/177—Initialisation or configuration control
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/42—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
- H04N19/423—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation characterised by memory arrangements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/42—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
- H04N19/43—Hardware specially adapted for motion estimation or compensation
- H04N19/433—Hardware specially adapted for motion estimation or compensation characterised by techniques for memory access
Definitions
- the present invention relates to an information processing system, an information processing method, and a computer program that link operations between two or more devices, and in particular, a plurality of devices perform virtual processing by cooperative operation, thereby enabling virtual processing.
- the present invention relates to an information processing system, an information processing method, and a computer program that operate as a single device.
- the present invention relates to information in which each processor suitably operates in an information processing apparatus having a multiprocessor configuration having a main processor power that commands execution of a program to one or more subprocessors and each subprocessor.
- the information processing system relates to a processing system, an information processing method, and a computer program, and in particular, an information processing system in which each sub-processor executes processing assigned from a main processor with high performance and without reducing the performance of the entire system. And an information processing method, and a computer program.
- a plurality of information processing devices on a network perform coordinated operations to perform distributed processing, and from a user, the information processing devices can operate virtually as one information processing device. it can.
- Each information processing apparatus that realizes grid computing is configured as, for example, a multiprocessor system.
- the information processing apparatus is equipped with one or more sub processors capable of executing a program developed on its own local storage, and a main processor that instructs the sub processor to execute the program.
- the main processor is not included in each sub-processor.
- resources such as surplus processing capacity
- multiple functions can be executed in parallel.
- additional processing related to recorded content such as recording reservations for TV programs, playback of recorded content, scene recognition, and re-encoding 'image quality improvement' can be distributed using sub-processors.
- FIG. 24 schematically shows a configuration example of an information processing system that realizes grid computing.
- the illustrated system has a multiprocessor configuration including a main processor and one or more sub-processors, and each processor can execute a program developed on its own local storage.
- the main processor can load a subprocessor program for processing on the local storage of the subprocessor and instruct the subprocessor to execute the program.
- the illustrated stem is provided with a main memory shared by each processor via a system bus.
- the main processor can distribute a plurality of processes and execute them in parallel by assigning the processing of each data developed on the main memory to each sub processor.
- the sub-processor uses data transferred from the main memory to its own local storage for calculation.
- the arithmetic unit in the sub processor accesses only its own low-power storage during the operation, and does not directly access the main memory.
- the operation result stored in the local storage is written back to the main memory. That is, the sub-processor does not access the main memory sequentially, but uses its own local storage as a cache memory.
- the main processor can assign the decoding processing of the compressed image to one sub processor.
- other processing on the decoded image data such as image quality improvement that edits the image data to the user's preferred quality, and re-encoding that re-encodes to another encoding method, etc. Can be operated as a whole system.
- the overall code generation amount is controlled by controlling the DCT coefficient quantization scale.
- inter-frame coding is performed to compress difference information between a compression target frame and a reference frame.
- MPEG uses “predictive coding” that expresses the signal value of a pixel as a difference from the signal value of a pixel at another time. This is realized by combining “forward prediction between frames” based on prediction and “bidirectional prediction between frames” that predicts the current screen using both the past and future playback screens.
- the image types handled in MPEG are I-pictures (Intra-Pictures) that can be used only for intra-coded (intra-frame prediction) screens, P-pictures (Predictive-Pictures) generated by inter-frame forward prediction, and inter-frame predictions.
- B pictures Bidirectionally Predictive Picture
- the size of the frame memory is about 3 Mbytes to 6 Mbytes per frame in an HD (High Definition) size image. For this reason, image coding and decoding In systems that handle image frames, DRAM with a low unit price per bit is used. And since DRAM is slow, ordinary processors often take a system with a cache. As a general cache operation, data in an area continuous to the memory address accessed by the processor is stored in the cache memory.
- the bus connecting the main memory and the local storage is commonly used by multiple modules, and the main memory often uses low-speed DRAM. It becomes a factor that degrades the overall performance.
- One possible solution to this problem is to implement a cache.
- a cache By implementing a cache, the number of accesses to the main memory can be reduced, and as a result, the performance of the entire decryption process can be prevented from being degraded.
- each sub-processor uses its own local storage as a cache.
- the compressed stream data is sequentially processed along the time axis, so that it is continuous with the memory address accessed by the sub processor.
- the data in the area is cached, it is easy to always place valid data in the cache by normal cache operation.
- the predicted image data in (2) varies depending on the characteristics of the image, that is, the moving direction and speed of the image between frames, so that the probability of missing the cache varies. That is, if the data in the area continuous to the memory address accessed by the sub-processor is cached, a sufficient cache hit rate cannot be obtained in normal cache operation.
- This cache miss causes data transfer waiting, delays the decoding process in the sub-processor, and causes an increase in system bus traffic, resulting in a decrease in overall system performance.
- Patent Document 1 Japanese Patent Application Laid-Open No. 2002-342165
- Patent Document 2 JP 2002-351850 A
- Patent Document 3 Japanese Patent Laid-Open No. 2002-358289
- Patent Document 4 Japanese Patent Laid-Open No. 2002-366533
- Patent Document 5 Japanese Patent Laid-Open No. 2002-366534
- An object of the present invention is to enable each processor to suitably operate in cooperation in an information processing apparatus having a multiprocessor configuration that also has one or more sub-processors and a main processor that instructs each sub-processor to execute a program.
- An information processing system, an information processing method, and a computer program are provided.
- a further object of the present invention is to provide an excellent information processing system in which each sub-processor can execute processing assigned main processor power with high performance and without reducing the performance of the entire system. And an information processing method and a computer program.
- a further object of the present invention is to assign processing of each data on the memory shared by the entire system to each sub processor, and execute processing to which each sub processor is assigned without degrading the performance of the entire system. Excellent information processing system and information A processing method and a computer program are provided.
- a further object of the present invention is that the sub-processor can execute the decoding process of the compressed image on the memory shared by the entire system with high performance and without reducing the performance of the entire system.
- An object is to provide an excellent information processing system, information processing method, and computer program.
- the present invention has been made in consideration of the above-mentioned problems.
- the first aspect of the present invention is that one or more sub-processors capable of executing a program developed on its own mouthless storage,
- This is an information processing system characterized by adaptively determining the cache area in the main memory to be cached next in the local storage based on the characteristics of the data being stored.
- system refers to a logical collection of a plurality of devices (or function modules that realize specific functions), and each device or function module is a single unit. It does not matter whether the force is in the housing.
- an information processing system having a multiprocessor configuration, which includes one or more sub-processors capable of executing a program developed on its own local storage, and a main processor that instructs the sub-processor to execute the program.
- a single processor can distribute and implement high-load processing, or two or more related data processes can be synchronized and executed in a coordinated manner. Can provide value service.
- each sub-processor uses its own local storage as a so-called cache memory when processing data in the main memory, thereby competing for access to the main memory and system-nos traffic. Increase can be suppressed. However, if the cache hit rate is not high enough, the effect cannot be fully demonstrated.
- the present invention based on data currently cached! /, The following key is used. Since the cache area is determined adaptively, the probability of hitting the cache on the local storage in the subsequent data processing increases, and the data processing performance of the sub processor itself is improved. In addition, cache hits can reduce system bus traffic associated with access to main memory, improving overall system performance.
- the sub processor when the compressed image data on the main memory shared by the entire system is decoded using a certain sub processor, the sub processor indicates the characteristics of the image data currently cached on the local storage. Based on the parameters, the cache area on the main memory to be cached next in the low power storage is adaptively determined.
- the compressed image data is subjected to an inter-frame encoding process for compressing difference information between a compression target frame and a reference frame. Therefore, the sub processor obtains the reference position used to generate the difference information in the reference frame based on the parameters indicating the characteristics of the image data, and sets the image data around the reference position as a cache area. do it.
- the motion information of the image block encoded together with the image data can be used as the parameter indicating the feature of the image data referred to here. Then, based on the motion information of the encoded image block, the movement direction and speed of the image block can be calculated to predict the operation of the image block, and the cache area can be obtained.
- the motion information for several past image blocks is stored, and the motion information used in the next image block is obtained by extrapolation from the moving speeds in the X and Y coordinate directions. Good.
- the operation of the image block may always be predicted, and the cache prefetching process may be executed speculatively.
- a motion vector is always predicted regardless of the presence or absence of a cache miss.
- Execute cache prefetch processing In this case, motion vector prediction processing is required every time, but if the overhead of the prediction processing is less than the data transfer waiting processing at the time of a cache miss, the performance of the entire system is improved. be able to.
- the data transfer between the main memory and the local storage, which occurs due to speculative cache processing, is shorter and takes less time than image decoding processing performed in units of macroblocks. Therefore, it is possible to efficiently perform cache processing of reference image data without degrading the overall performance of the decoding system.
- one or more sub-processors capable of executing a program developed on its own local storage, a main processor instructing the sub-processor to execute the program,
- Main memory power Page of Tagawa which transfers data to be processed to the local storage of the sub processor
- a cache processor that adaptively determines the cache area on the main memory to be cached in the local storage next based on the data processing procedure in which the sub processor processes the data on the local storage and the characteristics of the data processed on the local storage. Rear determination procedure,
- the computer program according to the second aspect of the present invention defines a computer program described in a computer-readable format so as to realize predetermined processing on a computer system.
- the computer program according to the second aspect of the present invention is installed on the computer system so as to be executed on the computer system. Has a cooperative action and can obtain the same operational effects as the information processing system according to the first aspect of the present invention.
- each sub-processor allocates main processor power. It is possible to provide an excellent information processing system, information processing method, and computer program capable of executing the processed processing without degrading the performance of the entire system.
- the processing of each data on the memory shared by the entire system is allocated to each sub processor, and the processing to which each sub processor is allocated is executed without degrading the performance of the entire system.
- cache control is performed according to the characteristics of the reference image using the motion direction and motion speed of the motion vector.
- the present invention data is stored in the cache with a high possibility of hit. Therefore, the cache size can be reduced if the same performance as the conventional system is maintained. As a result, it is possible to reduce the amount of transfer between memories, which improves power efficiency.
- FIG. 1 is a diagram showing a configuration of a network system according to an embodiment of the present invention. is there.
- FIG. 2 is a diagram for explaining an access procedure from the sub processor 23 to the main memory 24.
- FIG. 3 is a diagram showing a configuration example of a software cell.
- FIG. 4 is a diagram showing the data area of the software cell when the DMA command is a status return command.
- FIG. 5 is a diagram showing a state in which a plurality of information processing devices operate as a single virtual information processing device.
- FIG. 6 is a diagram illustrating an example of a software configuration of the information processing controller.
- FIG. 7 is a diagram showing a state in which four information processing apparatuses operate as one virtual information processing apparatus.
- FIG. 8 is a diagram showing an example of distributed processing in the system shown in FIG.
- FIG. 9 is a diagram illustrating a specific example of each information processing apparatus and system.
- FIG. 10 is a diagram showing a hardware configuration of the hard disk recorder in FIG.
- FIG. 11 is a diagram showing a software configuration of the hard disk recorder in FIG.
- FIG. 12 is a diagram showing a hardware configuration of the PDA in FIG.
- FIG. 13 is a diagram showing the software configuration of the PDA in FIG.
- FIG. 14 is a diagram showing a hardware configuration of the portable CD player in FIG.
- FIG. 15 is a diagram showing a software configuration of the portable CD player in FIG.
- FIG. 16 is a diagram schematically showing a functional configuration of a multiprocessor configuration system when one sub-processor performs image decoding processing.
- FIG. 17 is a flowchart showing a basic operation procedure when decoding a compressed image signal.
- FIG. 18 shows the position of the image data used for prediction in the reference frame (cache area). It is the flowchart which showed the process sequence for acquiring a).
- FIG. 19 is a flowchart showing a processing procedure for obtaining the position (cache area) of image data used for prediction in a reference frame.
- FIG. 20 is a diagram for explaining a processing procedure for predicting a motion vector decoded in the next macro block based on the current macro block and surrounding motion vectors.
- FIG. 21 is a diagram for explaining a processing procedure for obtaining a frame area to be cached based on a motion vector.
- FIG. 22 is a diagram for explaining a cache area calculation method.
- FIG. 23 is a flowchart showing a processing procedure for acquiring a position (cache area) of image data used for prediction in a reference frame.
- FIG. 24 is a diagram schematically showing a configuration example of an information processing system for realizing grid computing.
- the present invention provides a recording reservation operation in each device set in different locations by suitably linking operations between two or more information processing devices via a home network. Is simple and efficient. In order to link devices on the network, grid computing technology is used to achieve high computing performance through cooperative operation of devices.
- FIG. 1 schematically shows a configuration of a network system configured by applying grid computing.
- the network includes the Internet and other wide area networks, and private networks such as a local area network (LAN) and a home network connected to the wide area network via a gateway.
- the home network can be physically configured with standard network interfaces such as lOBaseT, 100BaseTX, and Giga eather.
- Upnp Universal Plug and Play
- XML extended Markup Language
- a plurality of information processing apparatuses are connected on the network.
- Examples of information processing devices include AV equipment equipped with recording media and a recording reservation function such as a DVD recorder or HD recorder, or a playback-only AV equipment that has a recording function such as a compact disc, etc.
- Information processing apparatus is a computer processing system such as a PDA or a personal computer. In the example shown in FIG. 1, a plurality of information processing apparatuses 1, 2, 3, 4 are connected via a network 9.
- the information processing apparatuses 1, 2, 3, and 4 are, for example, various AV (Audio and Visual) devices and portable devices (described later).
- the information processing apparatus 1 includes an information processing controller 11 as a computer function unit.
- the information processing controller 11 includes a main processor 21-1 and a sub processor 23— 1, 23-2, 23-3, DMAC (Direct Memory Access Controller) 25-1, and DC (Disk Controller) 27-1.
- the information processing controller 11 is preferably configured as a one-chip IC (integrated circuit).
- the main processor 21-1 is responsible for program execution (data processing) schedule management by the sub-processors 23-1, 1, 23-2, 23-3, and general management of the information processing controller 11 (information processing apparatus 1). And do. However, a program other than the program for managing in the main processor 21-1 can be configured to operate. In this case, the main processor 21-1 also functions as a sub processor.
- the main processor 21 — 1 is equipped with LS (local storage) 22 — 1!
- the number of sub-processors provided in one information processing apparatus may be one, but is preferably plural. In the illustrated example, there are a plurality of cases.
- Each sub-processor 23-1, 23-2, 23-3 executes a program and processes data in parallel and independently under the control of the main processor 21-1. Further, in some cases, the program in the main processor 21-1 can operate in cooperation with the program in the sub-processors 23-1, 23-2, 23-3.
- Each sub-processor 23-1, 1, 23-2, 23-3 also has LS (local storage) 24-1, 24-2, 24-3, respectively.
- the DMAC (direct memory access controller) 25-1 is stored in the main memory 26-1 including DRAM (dynamic RAM) connected to the information processing controller 11!
- DRAM dynamic RAM
- the program and data are accessed without the intervention of the processor.
- a DC (disk controller) 27-1 controls access operations to the external recording units 281, 28-2 connected to the information processing controller 11.
- the external recording units 28-1, 28-2 may be either a fixed disk (node disk) or a removable disk.
- various recording media such as MO (magnetic disk), CD ⁇ RW, DVD player RW and other optical disks, memory disks, SRAM (static RAM), and ROM can be used as removable disks.
- DC27-1 which is called a disk controller, is an external recording unit controller. As shown in FIG. 1, the information processing controller 11 can be configured so that a plurality of external recording units 28 can be connected.
- the main processor 21-1, each of the sub processors 23-1, 23-2, 23-3, DMAC25-1, and DC27-1 are interconnected by a bus 29-1.
- An identifier that can uniquely identify the information processing device 1 in which the information processing controller 11 is mounted throughout the entire network is assigned to the information processing controller 11 as an information processing device ID.
- the main processor 21-1 and the sub-processors 23-1, 2 3-2, and 23-3 are also assigned as identifier power main processor ID and sub-processor ID that can identify each.
- each sub-processor 23 in one information processing controller independently executes a program and processes data, but different sub-processors simultaneously read or write to the same area in the main memory 26. If this is done, data inconsistencies may occur. Therefore, the access from the sub processor 23 to the main memory 26 is performed according to the following procedure.
- FIG. 2A shows a location in the main memory 26.
- the main memory 26 is composed of memory locations that can specify a plurality of addresses, and an additional segment for storing information indicating the state of data is allocated to each memory location.
- the additional segment shall include the FZE bit, sub-processor ID and LS address (single-calor 'storage address). Each memory location is also assigned an access key, described below.
- the FZE bit is defined as follows:
- FZE bit 0 indicates that data can be written to the corresponding memory location, and is set to 1 after writing.
- FZE bit 1
- the data in the memory location is read by sub-processor 23. It indicates that the latest data is not processed and is not processed.
- the data at this memory location is readable and is set to 0 after being read by sub-processor 23.
- the sub processor 23 When a read reservation is made for a memory location of 0, the sub processor 23 writes the sub processor ID and LS address of the sub processor 23 as read reservation information in an additional segment of the memory location where the read reservation is made.
- the sub-processor 23 that performs the process of the previous stage has already been processed by controlling the reading and writing of data in each memory location in this way. Immediately after the data is written to a predetermined address on the main memory 26, another sub-processor 23 that performs the subsequent process can read the pre-processed data.
- FIG. 2 (B) shows memory locations in the LS 24 in each sub processor 23.
- the LS 24 in each sub-processor 23 is also configured by a memory location where a plurality of addresses can be specified.
- an additional segment is allocated as well.
- the additional segment shall include a busy bit.
- the sub-processor 23 When the sub-processor 23 reads the data in the main memory 26 to the memory location of its own LS24, it sets the corresponding busy bit to 1 and reserves it. No other data can be stored in the memory location where the busy bit is 1. After reading to the memory location of the LS24, the busy bit is set to 0 and can be used for any purpose.
- the main memory 26 connected to each information processing controller further includes a plurality of sandboxes that define areas in the main memory 26.
- the main memory 26 is also a force sandbox that consists of multiple memory location forces.
- a sandbox is a collection of these memory locations.
- Each sandbox is assigned to each sub-processor 23 and can be used exclusively by the corresponding sub-processor. In other words, each sub-processor 23 can use the sandbox assigned to it, and cannot access data beyond this area.
- a key management table as shown in FIG. 2C is used.
- the key management table is stored in a relatively high-speed memory such as a SRAM in the information processing controller, and is associated with the DMAC 25.
- Each entry in the key management table contains a sub-processor ID, sub-processor 'key, and key mask.
- a process when the sub processor 23 uses the main memory 26 is as follows.
- the sub processor 23 outputs a read or write command to the DMAC 25.
- This command includes its own sub-processor ID and the address of the main memory 26 that is the use request destination.
- the DMAC 25 refers to the key management table before executing this command, and checks the sub processor key of the sub processor of the use request source. Next, the DMAC 25 compares the checked sub-processor key of the use request source with the access key allocated to the memory location shown in FIG. 2A in the main memory 26 that is the use request destination, and Execute the above command only when the two keys match.
- the key mask on the key management table shown in FIG. 2 (C) is set to the corresponding bit force SO or 1 of the sub-processor key associated with the key mask when its arbitrary bit becomes 1. Can be.
- this subprocessor key is 1010. Normally, this subprocessor key only allows access to sandboxes with 1010 access keys. However, if the key mask associated with this subprocessor key is set to 0001 !, only the digits with the keymask bit set to 1 will receive the subprocessor key.
- This sub-processor key 1010 enables access to a sandbox having an access key whose access key is either 1010 or 1011.
- the sandbox exclusivity of the main memory 26 is realized.
- only the sub-processor that performs the process in the previous stage and the sub-processor that performs the process in the subsequent stage can be used. It becomes possible to access a predetermined address in the memory 26 and protect the data.
- Such exclusive memory control can be used as follows, for example. First, the key mask values are all zero immediately after starting the information processing device. It is assumed that the program in the main processor is executed and works in conjunction with the program in the sub processor. When processing result data output by the first sub-processor is stored in the main memory and input to the second sub-processor, the corresponding main memory area is naturally accessible from either sub-processor. There is a need. In such a case, the program in the main processor can change the value of the key mask appropriately and provide a main memory area that can be accessed by multiple sub-processors, enabling multi-stage processing by the sub-processor. To do.
- Sub-processor key of first sub-processor 0100
- Sub-processor of the second sub-processor 'key 0101
- software cells are transmitted between the information processing apparatuses 1, 2, 3, and 4 for distributed processing between the information processing apparatuses 1, 2, 3, and 4. That is, the main processor 21 included in the information processing controller in a certain information processing device generates a software cell including a command, a program, and data, and transmits it to another information processing device via the network 9. Processing can be distributed.
- FIG. 3 shows an example of the configuration of the software cell.
- the illustrated software cell includes a transmission source ID, a transmission destination ID, a response destination ID, a cell interface, a DMA command, a program, and data.
- the transmission source ID includes the network address of the information processing device that is the transmission source of the software cell, the information processing device ID of the information processing controller in the information processing device, and information in the information processing device.
- the identifiers (main processor ID and sub processor ID) of the main processor 21 and each sub processor 23 included in the processing controller are included.
- the transmission destination ID and the response destination ID include the same information about the information processing apparatus that is the transmission destination of the software cell and the information processing apparatus that is the response destination of the execution result of the software cell, respectively.
- the cell interface is information necessary for using the software cell, and includes a global ID, necessary sub-processor information, a sandbox size, and a previous software cell ID.
- the global ID uniquely identifies the software cell throughout the network, and is created based on the transmission source ID and the date and time (date and time) of creation or transmission of the software cell.
- the number of sub-processors necessary for executing the software cell is set.
- the amount of memory in the main memory 26 and the LS 24 of the sub processor 23 required for execution of the software cell is set.
- the previous software cell ID is an identifier of the previous software cell in one group of software cells that require sequential execution of streaming data or the like.
- the execution section of the software cell consists of DMA commands, programs, and data.
- the DMA command includes a series of DMA commands necessary for program startup.
- the program includes a sub processor program executed by the sub processor 23.
- the data here is data processed by a program including the sub processor program.
- the DMA command includes a load command, a kick command, a function program execution command, a status request command, and a status return command.
- the load command is a command for loading information in the main memory 26 into the LS 24 in the sub processor 23, and includes a main memory address, a sub processor ID, and an LS address in addition to the load command itself.
- the main memory address indicates an address of a predetermined area in the main memory 26 from which information is loaded.
- the sub processor ID and LS address indicate the identifier of the sub processor 23 to which the information is loaded and the address of the LS 24.
- the kick command is a command for starting execution of a program, and includes a sub processor ID and a program counter in addition to the kick command itself.
- the sub-processor ID identifies the sub-processor 23 to be kicked, and the program counter gives an address for the program execution program counter.
- the function program execution command is a command in which a certain information processing device requests execution of a function program from another information processing device (described later).
- the information processing controller in the information processing apparatus that has received the function program execution command identifies the function program to be activated by the function program ID (described later).
- the status request command is a command for requesting transmission of device information related to the current operation state (situation) of the information processing device indicated by the transmission destination ID to the information processing device indicated by the response destination ID.
- the function program is a program that is powerfully classified into the function program in the software configuration diagram stored in the main memory 26 of the information processing controller shown in FIG. The function program is loaded into the main memory 26 and executed by the main processor 21.
- the status reply command is a command in which the information processing device that has received the status request command responds to the information processing device indicated by the response destination ID included in the status request command with respect to its own device information.
- the status return command stores device information in the data area of the execution section.
- FIG. 4 shows the structure of the data area of the software cell when the DMA command is a status return command.
- the information processing apparatus ID is an identifier for identifying the information processing apparatus including the information processing controller, and indicates the ID of the information processing apparatus that transmits the status reply command.
- the information processing device ID is sent to the information processing controller in the information processing device by the main processor 21 included in the information processing device. It is generated based on the number of sub-processors 23 included.
- the information processing apparatus type ID includes a value representing the characteristics of the information processing apparatus.
- the features of the information processing apparatus mentioned here include, for example, a hard disk recorder (described later), a PDA (Personal Digital Assistants), a portable CD (Compact Disc) player, and the like.
- the information processing device type ID may represent a function of the information processing device, such as video / audio recording or video / audio playback.
- the values representing the features and functions of the information processing device are determined in advance. It is possible to grasp the features and functions of the information processing device by calling the information processing device type ID.
- the MS (master Z slave) status indicates whether the information processing apparatus is operating as a master apparatus or a slave apparatus, as will be described later, and if this is set to 0, the master apparatus If it is set to 1, it indicates that it is operating as a slave device.
- the main processor operating frequency represents the operating frequency of the main processor 21 in the information processing controller.
- the main processor usage rate represents the usage rate in the main processor 21 for all programs currently running on the main processor 21.
- the main processor usage rate is the ratio of the processing capacity in use to the total processing capacity of the target main processor.
- MIPS Manufacturing ion Instructions Per Second
- MIPS is a unit for evaluating processor processing capacity, is used as the unit. Or calculated based on processor usage time per unit time. The same applies to the sub processor usage rate described later.
- the number of sub-processors is the number of sub-processors 23 included in the information processing controller. Represents.
- the sub processor ID is an identifier for identifying each sub processor 23 in the information processing controller.
- the sub-processor status represents the state of each sub-processor 23, and there are states such as "unused”, "reserved", and "busy". unused indicates that the sub-processor is not reserved for use as it is currently used. reserved indicates a state that is not used at present but is reserved. busy indicates that it is currently in use.
- the sub processor usage rate represents the usage rate of the sub processor for a program currently being executed by the sub processor or reserved for execution by the sub processor. That is, the sub-processor usage rate indicates the current usage rate when the sub-processor status is 3 ⁇ 4usy, and indicates the estimated usage rate scheduled to be used later when the sub-processor status is reserved.
- One set of sub processor ID, sub processor status, and sub processor usage rate is set for one sub processor 23, and the number of sets corresponding to the sub processor 23 in one information processing controller is set.
- the main memory total capacity and the main memory usage represent the total capacity of the main memory 26 connected to the information processing controller and the capacity currently in use, respectively.
- the number of external recording units represents the number of external recording units 28 connected to the information processing controller.
- the external recording unit ID is information for uniquely identifying the external recording unit 28 connected to the information processing controller.
- the external recording unit type ID indicates the type of the external recording unit (for example, hard disk, CD ⁇ RW, DVD player RW, memory disk, SRAM, ROM, etc.).
- the external recording unit total capacity and the external recording unit usage amount represent the total capacity and the currently used capacity of the external recording unit 28 identified by the external recording unit ID, respectively.
- the external recording unit ID, the external recording unit type ID, the total external recording unit capacity, and the external recording unit usage amount are set for one external recording unit 28. Only the number of sets of external recording units 28 connected to the controller is set. That is, when multiple external recording units are connected to one information processing controller !, different external recording unit IDs are assigned to the respective external recording units, and the external recording unit type ID and external recording unit are assigned. The total capacity and the external recording unit usage are also managed separately.
- the main processor 21 included in the information processing controller in one information processing apparatus generates a software cell having the above-described configuration, and transmits it to another information processing apparatus and the information processing controller in the apparatus via the network 9. Send.
- the source information processing device, the destination information processing device, the response destination information processing device, and the information processing controller in each device are respectively the above-mentioned source ID, transmission destination ID, and response destination ID. Identified by.
- the main processor 21 included in the information processing controller in the information processing apparatus that has received the software cell stores the software cell in the main memory 26. Further, the transmission destination main processor 21 reads the software cell and processes the DMA command included therein.
- the transmission destination main processor 21 first executes a load command. As a result, information is loaded from the main memory address specified by the load command to a predetermined area of the LS24 in the subprocessor specified by the subprocessor ID and LS address included in the load command.
- the information loaded here is the sub-processor program or data included in the received software cell, or other indicated data.
- the main processor 21 outputs the kick command to the sub processor indicated by the sub processor ID included therein, together with the program counter included in the kick command.
- the instructed subprocessor executes the subprocessor program according to the kick command and the program counter. After the execution result is stored in the main memory 26, the main processor 21 is notified that the execution has been completed.
- the processor that executes the software cell in the information processing controller in the information processing apparatus of the transmission destination is not limited to the sub processor 23.
- the main processor 21 is a main memory such as a function program included in the software cell. It is also possible to specify to execute the program.
- the transmission source information processing apparatus sends the sub-address to the transmission destination information processing apparatus.
- the main memory program and the data processed by the main memory program are included, and the DMA command is transmitted as a load command software cell, and the main memory 26 and the main memory program are transmitted to the main memory 26.
- the data to be processed is stored.
- the transmission source information processing apparatus addresses the transmission destination information processing apparatus to the main processor ID, main memory 'address, main memory program for the information processing controller in the transmission destination information processing apparatus.
- a software cell that includes an identifier such as a function program ID (to be described later) for identifying the program and a program counter and whose DMA command is a kick command or a function program execution command is transmitted to the main processor 21. Is executed.
- the transmission source information processing apparatus transmits the sub processor program or the main memory program to the transmission destination information processing apparatus using the software cell.
- the sub processor program is loaded into the sub processor 23 included in the information processing controller in the transmission destination information processing apparatus, and the transmission destination information processing apparatus is caused to execute the sub processor program or the main memory program. Can do.
- the information processing controller in the information processing apparatus of the transmission destination loads the subprocessor program to the designated subprocessor. Then, the sub processor program or the main memory program included in the software cell is executed.
- the sub processor program or the main memory program can be automatically executed by the information processing controller in the transmission destination information processing apparatus. Can do.
- the information processing apparatus has a main memory program such as a sub-processor program or a function program in the information processing controller in its own apparatus. In this case, other information connected to the network may be used. Processor power can get them.
- data is transferred between each sub-processor using the DMA method, and by using the sandbox described above, data can be stored in multiple stages within one information processing controller. Even if it is necessary to process to the floor, it can be executed at high speed and with high security.
- Figure 5 shows how multiple information processing devices are operating as one virtual information processing device.
- a plurality of information processing devices 1, 2, 3, and 4 connected to the network 9 are virtually connected as shown in the lower part of the figure. It operates as a single information processing device 7.
- the following processing needs to be executed with the following configuration.
- FIG. 6 shows a software configuration stored in the main memory 26 of each information processing controller. These software (programs) are recorded in the external recording unit 28 connected to the information processing controller before the information processing apparatus is turned on. Each program is classified into a control program, a function program, and a device driver according to function or feature.
- the control program is the same for each information processing controller, and is executed by the main processor 21 of each information processing controller, and includes an MS (master Z slave) manager and a capability exchange program described later. .
- the function program is executed by the main processor 21, and for each information processing controller, a program suitable for the information processing device, such as recording, reproduction, and material search, is provided.
- the device driver is used for input / output (transmission / reception) of the information processing controller (information processing device), such as broadcast reception, monitor output, bit stream input / output, and network input / output. Is provided.
- the main processor 21 of the information processing controller of the information processing apparatus loads each program belonging to the control program and each program belonging to the device driver into the main memory 26.
- the main processor 21 first reads a program from the external recording unit 28 by causing the DC 27 to execute a read instruction, and then causes the DMA C25 to execute a write instruction. The program is written into the main memory 26.
- each program belonging to the function program it may be configured to load only the necessary program into the memory when necessary, or just like the programs belonging to other categories, immediately after the main power is turned on. It can be configured to load each program.
- Each program belonging to the function program does not necessarily need to be recorded in the external recording unit 28 of all information processing devices connected to the network.
- the external recording unit 28 of one information processing device 28 Can be loaded from another information processing device by the method described above. As a result, as shown in the lower part of FIG. 5, it functions as a single virtual information processing device 7.
- the program can be executed.
- the function program processed by the main processor 21 may operate in cooperation with the sub processor program processed by the sub processor 23. Therefore, when there is a sub processor program that operates in cooperation with the target functional program when the main processor 21 reads the functional program from the external recording unit 28 and writes it to the main memory 26, the sub processor program is also included. It shall be written to the same main memory 26. In this case, there may be one or more sub-processor programs that operate in cooperation with each other. If there are a plurality of sub-processor programs, all the sub-processor programs that operate in cooperation are written in the main memory 26. The sub processor program written in the main memory 26 is then written in the LS 24 in the sub processor 23 and operates in cooperation with the function program processed by the main processor 21.
- a sub processor program ID is also assigned to the sub processor program, whereby the sub processor program can be uniquely identified.
- the sub processor program ID to be assigned is an identifier related to the function program ID of the function program with which the cooperative operation is performed, for example, the function program ID as a parent number and a branch number added at the end. It is possible that the function It may be an identifier that is not related to the program's functional program ID. If the function program and sub-processor program operate in cooperation with each other even if they are different from each other, it is necessary to store the program ID, which is the other's identifier, in the own program. Even when a function program operates in cooperation with a plurality of sub-processor programs, the function program stores the sub-processor program IDs of all the plurality of sub-processor programs.
- an identifier that can uniquely identify a program for each program is assigned to the function program as a function program ID.
- the function program ID is determined from the creation date and time, information processing device ID, and the like at the stage of creating the function program.
- the main processor 21 secures an area in the main memory 26 for storing device information (information on the operation state) of the information processing device on which it operates, and stores this information in the device information table of the own device. Record as.
- the device information referred to here is information below the information processing device ID in the data area of the status reply command shown in FIG.
- the main processor 21 of the information processing controller of the information processing device loads a master Z slave manager (hereinafter referred to as MS manager) into the main memory 26, Execute.
- MS manager master Z slave manager
- connection means that the information processing apparatus is not only physically connected to the network 9 but also electrically and functionally connected to the network 9 as described above. Indicates.
- an information processing apparatus on which it operates is referred to as an own apparatus, and another information processing apparatus is referred to as an other apparatus.
- the apparatus also indicates the information processing apparatus.
- the MS manager indicates that the DMA command is a status request command, A software cell whose response destination ID is the information processing apparatus and does not specify the transmission destination ID is generated, transmitted to the network to which the information processing apparatus is connected, and a timer for network connection confirmation is set.
- the timer timeout is, for example, 10 minutes.
- the other apparatus When another information processing apparatus is connected to the network system, the other apparatus receives the status request command software cell and issues a status request command specified by the response destination ID.
- the DMA command is a status reply command and the software cell containing the device information of itself (other device) is transmitted as data to the information processing device.
- the software cell of this status reply command includes at least information for identifying the other device (information processing device ID, information on the main processor, information on the sub processor, etc.) and the MS status of the other device.
- the MS manager of the information processing device that has issued the status request command does not receive the software cell of the status return command sent from another device on the network until the timer for network connection confirmation times out. Monitor.
- the MS status in the device information table of its own device is set to 1. This makes the device a slave device.
- the apparatus when no information processing apparatus is connected to the network 9 in a state where no apparatus is connected to the network 9 or a master apparatus does not exist on the network 9, the apparatus It is automatically set as a master device. On the other hand, when a new information processing apparatus is connected to the network 9 in a state where the master apparatus already exists on the network 9, the apparatus is automatically set as a slave apparatus.
- the MS manager For both the master and slave devices, the MS manager periodically sends status request commands to other devices on the network 9 to query status information. By doing so, the status of other devices is monitored. As a result, the main power source of the information processing apparatus connected to the network 9 is cut off or the information processing apparatus is disconnected from the network 9, so that the information processing apparatus can be switched from a specific other apparatus within a predetermined period set in advance for determination. If there is a change in the connection status of the network 9, such as when a response command is not sent back or when a new information processing device is connected to the network 9, the information is exchanged as described below. Notify the program.
- the main processor 21 executes the capability exchange program.
- the self-device is the master device
- the capability exchange program is connected to the network 9 !, and all other information processing devices, that is, the device information of each slave device. Get information.
- the device information of the other device is acquired by generating a software cell in which the DMA command is a status request command and transmitting it to the other device, and then the DMA command is a status return command. It is possible by receiving a software cell including device information of another device as data.
- the capability exchange program stores the device information of all other devices (each slave device) connected to the network 9 in the same manner as the device information table of its own device which is the master device. Is reserved in the main memory 26 of its own device, and these pieces of information are recorded as a device information table of another device (slave device). That is, the device information of all information processing devices connected to the network 9 including the device itself is recorded in the main memory 26 of the master device as a device information table.
- the capability exchange program is a self-device power S slave device
- the information processing device ID and the MS status included in the device information are recorded in the main memory 26 of the own device.
- the main device 26 of the slave device stores the device information of its own device in the device information table.
- the information processing device ID and the MS status are recorded as a separate device information table by the master device and each slave device connected to the network 9 other than its own device.
- the capability exchange program when notified from the MS manager that the information processing device is newly connected to the network 9, as described above, The device information of the device is acquired and recorded in the main memory 26 as described above.
- MS manager and the capability exchange program are not limited to being executed by the main processor 21, but may be executed by any of the sub processors 23.
- the MS manager and the capability exchange program are resident programs that always operate while the main power supply of the information processing apparatus is turned on.
- the capacity exchange program shuts off the main power supply of the information processing device connected to the network 9 or disconnects the information processing device from the network 9 from the MS manager.
- the device information table of the information processing device is deleted from the main memory 26 of the own device.
- a new master apparatus is determined by the following method.
- each of the information processing devices that are not disconnected from the network 9 replaces the information processing device IDs of the own device and other devices with numerical values, and replaces the information processing device ID of the own device with the information processing device of the other device If the information processing device ID of its own device is the smallest among the information processing devices that are not disconnected from the network 9, the slave device moves to the master device, sets the MS status to 0, As described above, device information is acquired from all other information processing devices (each slave device) connected to the network 9 as a master device and recorded in the main memory 26.
- FIG. 7 shows a state where four information processing apparatuses operate as one virtual information processing apparatus 7.
- the information processing apparatus 1 is operating as a master apparatus and the information processing apparatuses 2, 3, and 4 are operating as slave apparatuses A, B, and C, respectively.
- the operation information is directly grasped by the master apparatus 1. If the slave device is an operation target force slave device, the operation information is transmitted to the master device 1 from the operated slave device. That is, regardless of whether the user's operation target is a difference between the master device 1 and the slave device, the operation information is always grasped by the master device 1.
- the operation information is transmitted, for example, by a software cell whose DMA command is an operation information transmission command.
- the main processor 21-1 included in the information processing controller 11 in the master device 1 selects a function program to be executed according to the operation information.
- the main processor 2 1 1 included in the information processing controller 11 in the master device 1 can connect the external memory 28-1 and 28-2 of the device itself to the main memory 2 6- The ability to load a function program into 1
- Another information processing device may send a function program to the master device 1.
- the main processor 21-1 included in the information processing controller 11 in the master device 1 reads out the above-mentioned required specifications necessary for each function program. Also, the device information table of each information processing device is read out by referring to the device information table recorded in the main memory 26-1 by the capability exchange program in advance.
- the device information here is information related to the information processor ID shown in FIG. 4 and below, and is information related to the main processor, sub processor, main memory, and external recording unit.
- the main processor 21-1 included in the information processing controller 11 in the master device 1 The device information of each information processing device connected on the network 9 is sequentially compared with the required specifications necessary for executing the function program.
- the function program requires a recording function
- only the information processing apparatus having the recording function is specified and extracted based on the information processing apparatus type ID.
- a slave device that can secure the conditions regarding the processing capability of the main processor or sub processor, the amount of main memory used, and the external recording unit necessary for executing the function program is specified as an execution request candidate device.
- one execution request candidate device is specified and selected from the candidate devices.
- the main processor 21-1 included in the information processing controller 11 in the master device 1 determines whether or not the slave device in the own device has the identified slave device. Recorded in the main memory 26-1 included in the information processing controller 11, the device information table of the slave device is updated.
- the slave device requested to execute the function program executes the function program and updates the device information table of the own device.
- the main processor 21 included in the information processing controller in the slave device may store the function program and the function program in the main memory 26 from the external recording unit 28 of the own device by the above method. Load the sub-processor program that operates in cooperation.
- the required function program or the sub processor program that operates in cooperation with the function program is recorded in the external recording unit 28 of the slave device that is requested to execute the function program.
- the system may be configured so that the processing device transmits the function program or sub-processor program to the function program execution request destination slave device.
- the main processor 21 included in the information processing controller in the slave device that has executed the function program sends an end notification to the main processor 21 included in the information processing controller 11 in the master device 1. At the same time, it updates the device information table of its own device.
- the main processor 21-1 included in the information processing controller 11 in the master device 1 receives the end notification and updates the device information table of the slave device that has executed the function program.
- the main processor 21-1 included in the information processing controller 11 in the master device 1 is an information processing device that can execute the function program based on the reference result of the device information table of the own device and the other device. , You may choose yourself. In that case, the master device 1 executes the function program.
- slave device A when the user operates slave device A, distributed processing of the entire network system including slave device A starts.
- slave device A transmits the operation information to master device 1.
- master device 1 To (step 81).
- the master device 1 receives the operation information (step 72), and is recorded in the main memory 26-1 of the own device and stored in the device information tables of the own device and other devices.
- the operating state is checked, and an information processing apparatus that can execute the function program corresponding to the received operation information is selected (step 73). In the example shown in the figure, the case where the slave device B is selected is shown.
- master device 1 requests execution of the function program from the selected slave device B (step 74).
- Slave device B receives the execution request (step 95), and further executes the function program requested to be executed (step 96).
- the information processing devices 1, 2, 3, and 4 connected to each other via the network 9 are basically any ones that can process information by the information processing controllers 11, 12, 13, and 14 as described above. Such a configuration may be used.
- FIG. 9 shows a configuration example of the information processing apparatus.
- An example of the information processing apparatus 1 including the information processing controller 11 is a hard disk recorder. 10 and 11 show the hardware configuration and software configuration of the hard disk recorder shown in FIG. As the hardware configuration of the hard disk recorder, a hard disk is built in as the external recording unit 28-1 shown in FIG. 1, and the DVD player RZRW, CD player RZRW, Bluray— Disc (external recording unit 28-2 shown in FIG.
- bus 31-1 connected to the bus 29-1 of the information processing controller 11 is connected to the broadcast receiver 32-1, video input unit 331, The audio input unit 34-1, video output unit 35-1, audio output unit 36-1, operation panel unit 37-1, remote control light receiving unit 38-1 and network connection unit 39-1 are connected.
- the broadcast receiving unit 32-1, the video input unit 33-1 and the audio input unit 34-1 receive a broadcast signal or input a video signal and an audio signal from the outside of the information processing apparatus 1, respectively.
- the data is converted to digital data in the specified format and sent to the bus 31-1 for processing by the information processing controller 11.
- the video output unit 35-1 and audio output unit 36-1 process the video data and audio data sent from the information processing controller 11 to the bus 31-1, and convert them into digital data or analog signals.
- the remote control light receiving unit 38-1 receives the remote control (remote operation) infrared signal from the remote control transmitter 43-1.
- a monitor display device 41 and a speaker device 42 are connected to the video output unit 35-1 and the audio output unit 36-1 of the information processing device (hard disk recorder) 1.
- the information processing device hard disk recorder
- the information processing apparatus 2 including the information processing controller 12 illustrated in FIG. 9 is also a hard disk recorder, and is configured in the same manner as the information processing apparatus 1 as indicated by reference numerals in parentheses in FIG. . However, as shown in FIG. 2) A monitor display device and a speaker device are not connected to 2.
- the software configuration of the information processing devices (node disk recorders) 1 and 2, that is, the information processing controllers 11 and 12, as shown in Fig. 11, includes an MS manager and a capability exchange program as a control program, Function programs include programs for video / audio recording, video / audio playback, material search and program recording reservation, and device drivers for broadcast reception, video output, audio output, external recording unit input / output and network input / output The program is provided.
- FIG. 12 shows the hardware configuration of the information processing apparatus 3 configured as a PDA.
- the external recording unit 28-5 shown in FIG. 1 is configured so that a memory card disk can be mounted, and a liquid crystal display is provided on the bus 51 connected to the bus 29-3 of the information processing controller 13.
- the unit 52, the audio output unit 53, the camera unit 54, the audio input unit 55, the keyboard unit 56, and the network connection unit 57 are connected.
- the information processing controller 13 that is not shown in FIG. 1 includes a main processor 21-3, sub-processors 23-7, 23-8, 23-9, DMAC (direct memory access controller) 25-3, It has DC (disk controller) 27-3 and bus 29-3, and its main processor 21-3 has LS (local 'storage) 22-3, and each sub-processor 23-7, 23-8, 23 — 9 ⁇ , LS (low-power storage) 24—7, 24—8, 24—9!
- FIG. 13 shows a software configuration of the information processing apparatus (PDA) 3, that is, the information processing controller 13.
- the control program includes MS manager and capability exchange program
- the function program includes video / audio recording, video / audio playback, phone book, word processor, spreadsheet program, and Web browser.
- device drivers programs for video output, audio output, camera video input, microphone audio input, and network input / output are provided.
- FIG. 14 shows the hardware configuration of the portable CD player.
- the portable CD player is configured so that a CD (Compact Disc) can be mounted as the external recording unit 28-6 shown in FIG.
- the liquid crystal display unit 62, the audio output unit 63, the operation button unit 64, and the network connection unit 65 are connected to the node 61 connected to the bus 29-4 of 4.
- the information processing controller 14 whose interior is omitted is the main processor 21-4, subprocessor 23-10, 23-11, 23-12, DMAC25-4, DC27-4, and bus 29-4.
- the main processor 21-4 has LS22-4, and each of the sub processors 23-10, 23-11, 23-12 has LS24-10, 24-11, 24-12.
- FIG. 15 shows a software configuration of the information processing apparatus (portable CD player) 4, that is, the information processing controller 14.
- the control program includes an MS manager and an ability exchange program
- the function program includes a program for music playback
- the device driver includes a program for audio output, CD control, and network input / output.
- the information processing device 2 when the information processing device 2 is newly connected to the network 9, it is executed by the main processor 2 1 2 included in the information processing controller 12 in the information processing device 2 by the method described above.
- the information processing device 1 set as the master device collects device information of each device including the newly added information processing device 2 and updates the device information table in the main memory 26-1. .
- the information processing device (PDA) 3 which is a slave device, makes a recording reservation including information such as recording start time, recording end time, recording target broadcast channel, and recording quality from the user.
- the information input is received, a software cell including the recording reservation information and a recording reservation command as a DMA command is generated, and transmitted to the information processing apparatus 1 which is a master apparatus.
- the main processor 21-1 included in the information processing controller 11 in the information processing apparatus 1 that has received the software cell in which the DMA command is a recording reservation command reads out the recording reservation command and stores it in the main memory 26-1 Information processing apparatus that can execute the recording reservation command is specified.
- the main processor 21-1 can read the information processing device type IDs of the information processing devices 1, 2, 3, and 4 included in the device information table and execute the function program corresponding to the recording reservation command. A simple information processing apparatus is extracted.
- the information processing devices 1 and 2 having the information processing device type ID indicating the recording function are specified as candidate devices, and the information processing devices 3 and 4 are excluded from the candidate devices.
- the main processor 21-1 included in the information processing controller 11 in the information processing apparatus 1 which is the master apparatus refers to the apparatus information table, and the main processor or sub processor of the information processing apparatuses 1 and 2 Reads information about the processor, such as the processor's processing capacity and information about the main memory, and determines whether the information processing devices 1 and 2 meet the required specifications required to execute the function program corresponding to the recording reservation command. To do.
- the information processing apparatuses 1 and 2 satisfy the required specifications necessary for executing the function program corresponding to the recording reservation command.
- the main processor 21-1 refers to the device information table, reads information related to the external recording units of the information processing devices 1 and 2, and the free space of the external recording unit is used to execute the recording reservation command. Judgment is made on whether or not the required capacity is satisfied. Since the information processing apparatuses 1 and 2 are hard disk recorders, the difference between the total capacity and the used capacity of the node disks 28-1 and 28-3 corresponds to the respective free capacity.
- the free space capacity of the hard disk 28-1 of the information processing device 1 is 10 minutes in terms of recording time, and the free space capacity of the hard disk 28-3 of the information processing device 2 is converted to 20 hours. Suppose it is time.
- the main processor 21-1 identifies the information processing device that can secure the free space for two hours necessary for executing the recording reservation command as the execution request destination slave device.
- the main processor 21-1 included in the information processing controller 11 in the information processing device 1 which is the master device is operated by the user.
- the recording reservation command including the recording reservation information transmitted from the information processing apparatus 3 is transmitted to the information processing apparatus 2 to request execution of recording reservation for the broadcast program for the above two hours.
- the main processor 2 1 2 included in the information processing controller 12 in the information processing device 2 analyzes the recording reservation command, and stores a function program necessary for recording in the hard disk 28- that is an external recording unit. 3 is loaded into the main memory 26-2, and recording is performed according to the recording reservation information. As a result, the video / audio data of the 2-hour broadcast program reserved for recording is recorded on the hard disk 28-3 of the information processing device 2.
- the information processing system includes one or more sub-processors that can execute a program developed on its own local storage, and a main processor that instructs the sub-processor to execute the program.
- Multiprocessor configuration According to such an information processing system with a multi-processor configuration, each processor can be linked to achieve high-load processing in a single processor, or two or more related data processing can be synchronized. Since it can be executed in a coordinated manner, it can provide high-function, high-value-added services to users.
- Each processor shares the main memory via the system bus, and the processing data of the system is expanded on the main memory.
- the main processor assigns data processing on the main memory to each sub processor and instructs execution of the processing.
- the sub-processor loads a sub-processor program for executing data processing and sends it from the main processor.
- the program is started by the instruction, and the data on the main memory is executed.
- DRAM having a relatively large capacity and a low unit price per storage amount is used. For this reason, there are problems such as high latency between the sub processor and the main memory, and contention of access to the main memory between the sub processor.
- each sub-processor has its own local storage, and when processing data on the main memory, the local storage is used as a so-called cache memory.
- the cache memory By using it, it is possible to suppress contention on access to the main memory and increase in system bus traffic.
- the cache hit rate is not high enough, the effect cannot be fully demonstrated.
- adaptive control of the cache area to improve the probability of hitting the cache on the local storage in subsequent data processing improves the data processing performance of the sub processor and the overall system performance. It is considered necessary for this.
- the main processor can assign the decoding processing of the compressed image to one sub-processor.
- other processing on the decoded image data such as image quality improvement for editing the image data to the user's preferred quality and re-encoding for re-encoding to another encoding method, is performed.
- image quality improvement for editing the image data to the user's preferred quality
- re-encoding for re-encoding to another encoding method
- FIG. 16 schematically shows a functional configuration of the multiprocessor configuration system when one sub-processor performs image decoding processing.
- the system shown has the following characteristics.
- Each sub-processor has a dedicated local storage.
- the main memory uses a relatively low-speed memory device such as DRAM.
- the sub-processor has a mechanism that caches a part of the main memory area in the local storage as needed.
- signal processing is performed by dividing the entire frame into small areas called macroblocks.
- macroblocks For example, the basic compression algorithm in MPEG, one of the standard image compression standards, is as follows. That is,
- the overall code generation amount is controlled by controlling the DCT coefficient quantization scale.
- FIG. 17 shows a basic operation procedure in the form of a flowchart when decoding a compressed image signal.
- the compressed image decoding process flow includes compressed stream input (step S1), stream decoding (step S2), reference frame input (step S3), image decompression process (step S4), A series of processes of decoding result output (step S5) is performed for each frame by determining the number of blocks (step S6).
- steps Sl, S3, and S5 data transfer occurs between the main memory and the local storage. Data transfer between memories is performed via a system node that is shared by multiple modules. As already mentioned, in order to prevent the performance of the entire decoding system from being degraded due to the deterioration of the transfer performance of the node, the subprocessor must implement a cache to improve the performance of memory-to-memory transfers.
- step S1 In the transfer for stream input in step S1, the stream is continuously arranged in the memory and processed sequentially, so that the cache can be controlled easily. There is no cache miss.
- step S5 In addition, in the output of the decoding result in step S5, a plurality of macroblocks do not write the output result to the same address, and the output result is not changed until the entire frame is decoded. It is not read by macroblock processing. Therefore, the decoding result can be transferred to the main memory asynchronously with the decoding processing of the succeeding macroblock, which can suppress the performance degradation. Excluded.
- inter-frame coding is performed to transmit only the difference information between the frame to be compressed and the reference frame to improve the compression efficiency (described above). In this case, it is necessary to acquire the reference image data used to generate the difference information in the decoding process.
- the position of the image data used for prediction in the reference frame can be obtained by using a motion vector encoded in the stream.
- the procedure is realized by the processing procedure shown in the flow chart format in Fig. 18.
- the reference position in the reference frame is calculated based on the motion vector (step Sl l).
- step S12 it is determined whether or not the image data at the calculated reference position is cached in the local storage (step S12).
- the cache area is transferred from the main memory (steps S13 and S14).
- the cache area is adaptively changed according to the moving direction and moving speed of the motion vector from the motion vectors used for the peripheral macroblock processing.
- FIG. 19 shows the procedure of the reference image acquisition process in this case in the form of a flowchart.
- the reference position in the reference frame is calculated based on the motion vector (step S21).
- the image data of the calculated reference position is cached in the local storage! (Step S22).
- step S23 the motion vector decoded in the next macroblock is predicted based on the current macroblock and surrounding motion vectors.
- a frame area to be cached that is, a cache area is calculated (step S24). Then, the calculated cache area is transferred from the main memory to the local storage of the sub processor (steps S25 and S26).
- FIG. 20 illustrates an example of a processing procedure for predicting a motion vector decoded in the next macroblock based on the current macroblock and surrounding motion vectors in step S23.
- the motion vector of the macroblock due to the outer fence is predicted.
- the motion vectors of the past several macroblocks (2 macroblocks in the example shown in the figure) are always saved, and the next macroblock is determined from the movement speed in the X and Y coordinate directions. Calculate the motion vector used in.
- FIG. 21 illustrates a processing procedure for obtaining a frame area to be cached, that is, a cache area, based on the motion vector in step S24.
- the motion vector of the next block calculated in the preceding step S23 is input to the cache processing block, and the area to be cached is determined.
- Fig. 21 (a) shows an operation example in the case where power is taken into consideration in consideration of the motion vector prediction result.
- the area centering on the reference data used this time is cached.
- Fig. 21 (b) shows a state where the cache area is calculated in consideration of the motion vector prediction result. In this case, there is a high possibility that the data used in the next macroblock processing is cached, so it is expected to increase the performance of the decoding processing system.
- FIG. 22 illustrates an example of a cache area calculation method.
- the size of the cache memory an area that is three times larger than the macro block in both the vertical and horizontal directions can be stored.
- the coordinates of the image referenced by the macroblock being decoded are (X, Y) and
- next macroblock is Let the coordinates of the image predicted to be referenced be (X, Y). When transferring the reference image, next next next
- Determining which area of the frame memory is to be transferred from the main memory to the cache is equivalent to obtaining the parameters h and w in the figure, and this is expressed as (X, Y), (X, Y
- weightH and weightW are mobility weighting factors, and optimal values are selected depending on the implementation.
- ⁇ is ⁇ '
- ⁇ is ⁇ ' saturated in the range of 1 to 1, respectively.
- FIG. 23 shows an application example of the reference image acquisition processing procedure shown in FIG. 19 in the form of a flowchart.
- the reference position in the reference frame is calculated based on the motion vector (step S31).
- step S32 The motion vector decoded in the next macroblock is predicted (step S32). Based on the calculated motion vector, a frame area to be cached, that is, a cache area is calculated (step S33).
- step S34 the transfer of the calculated cache area from the main memory to the local storage of the sub processor is started (step S34).
- the cache area is transferred from the main memory to the low power storage of the sub processor (step S36).
- the motion vector prediction (step S23) and cache area calculation (step S24) processes are activated only when a cache miss occurs.
- the cache area is limited. Processing performance deteriorates due to the overhead of waiting for transfer due to a cache miss.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Software Systems (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
Description
Claims
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/632,655 US20080253673A1 (en) | 2004-07-16 | 2005-07-05 | Information Processing System, Information Processing Method, and Computer Program |
EP20050765473 EP1775962A1 (en) | 2004-07-16 | 2005-07-05 | Information processing system, information processing method, and computer program |
KR20077000928A KR20070035037A (ko) | 2004-07-16 | 2005-07-05 | 정보 처리 시스템 및 정보 처리 방법과 컴퓨터 프로그램 |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2004210761A JP2006031480A (ja) | 2004-07-16 | 2004-07-16 | 情報処理システム及び情報処理方法、並びにコンピュータプログラム |
JP2004-210761 | 2004-07-16 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2006008961A1 true WO2006008961A1 (ja) | 2006-01-26 |
Family
ID=35785081
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2005/012422 WO2006008961A1 (ja) | 2004-07-16 | 2005-07-05 | 情報処理システム及び情報処理方法、並びにコンピュータプログラム |
Country Status (6)
Country | Link |
---|---|
US (1) | US20080253673A1 (ja) |
EP (1) | EP1775962A1 (ja) |
JP (1) | JP2006031480A (ja) |
KR (1) | KR20070035037A (ja) |
CN (1) | CN101036393A (ja) |
WO (1) | WO2006008961A1 (ja) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2006140558A (ja) * | 2004-11-10 | 2006-06-01 | Casio Comput Co Ltd | 画像処理装置及び画像処理方法 |
JP2011234383A (ja) * | 2011-06-02 | 2011-11-17 | Casio Comput Co Ltd | 画像処理装置及び画像処理方法 |
US8593469B2 (en) | 2006-03-29 | 2013-11-26 | Nvidia Corporation | Method and circuit for efficient caching of reference video data |
US8599841B1 (en) | 2006-03-28 | 2013-12-03 | Nvidia Corporation | Multi-format bitstream decoding engine |
JP2015207123A (ja) * | 2014-04-18 | 2015-11-19 | 富士通株式会社 | ストレージ装置、ストレージ制御方法およびストレージ制御プログラム |
Families Citing this family (26)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090245580A1 (en) * | 2006-07-21 | 2009-10-01 | Darryl Greig | Modifying parameters of an object detector based on detection information |
JP4910576B2 (ja) | 2006-09-04 | 2012-04-04 | 富士通株式会社 | 動画像処理装置 |
JP4983160B2 (ja) * | 2006-09-04 | 2012-07-25 | 富士通株式会社 | 動画像処理装置 |
JP4862566B2 (ja) | 2006-09-04 | 2012-01-25 | 富士通株式会社 | 動画像処理装置及びプリフェッチ制御方法 |
JP4535047B2 (ja) | 2006-09-06 | 2010-09-01 | ソニー株式会社 | 画像データ処理方法、画像データ処理方法のプログラム、画像データ処理方法のプログラムを記録した記録媒体及び画像データ処理装置 |
US20090225867A1 (en) * | 2008-03-06 | 2009-09-10 | Lee Kun-Bin | Methods and apparatus for picture access |
FR2930059B1 (fr) * | 2008-04-09 | 2010-04-09 | Ateme Sa | Traitement d'une sequence video dans une memoire cache |
US8577165B2 (en) * | 2008-06-30 | 2013-11-05 | Samsung Electronics Co., Ltd. | Method and apparatus for bandwidth-reduced image encoding and decoding |
US20090327609A1 (en) * | 2008-06-30 | 2009-12-31 | Bruce Fleming | Performance based cache management |
US8700862B2 (en) * | 2008-12-03 | 2014-04-15 | Nvidia Corporation | Compression status bit cache and backing store |
US9253496B2 (en) | 2008-12-12 | 2016-02-02 | Qualcomm Incorporated | Intelligent decoded picture buffering |
JP5469433B2 (ja) * | 2009-10-30 | 2014-04-16 | 株式会社キーエンス | 画像処理装置及び画像処理方法 |
KR101279507B1 (ko) * | 2009-12-15 | 2013-06-28 | 한국전자통신연구원 | 병렬 처리 기반 파이프라인 복호화 장치 및 방법 |
JP5020391B2 (ja) * | 2010-02-22 | 2012-09-05 | パナソニック株式会社 | 復号化装置及び復号化方法 |
JP5378298B2 (ja) * | 2010-05-18 | 2013-12-25 | 日立コンシューマエレクトロニクス株式会社 | 機器間情報交換機能を有するストレージ |
CN102360273A (zh) * | 2011-09-26 | 2012-02-22 | 北京邦诺存储科技有限公司 | 控制存储器与非易失性缓存装置协同存储的设备和方法 |
KR101611289B1 (ko) * | 2011-12-16 | 2016-04-12 | 엘지전자 주식회사 | 전기자동차 및 그 제어방법 |
US20140184630A1 (en) * | 2012-12-27 | 2014-07-03 | Scott A. Krig | Optimizing image memory access |
US9667706B2 (en) * | 2013-08-16 | 2017-05-30 | Pearson Education, Inc. | Distributed processing systems |
US10148589B2 (en) * | 2014-09-29 | 2018-12-04 | Pearson Education, Inc. | Resource allocation in distributed processing systems |
US10051294B2 (en) * | 2015-03-31 | 2018-08-14 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Compressed video buffering |
CN106157230B (zh) * | 2016-05-25 | 2019-08-16 | 华中科技大学 | 海量脑组织三维图像数据快速调用方法 |
CN107562686B (zh) * | 2017-08-18 | 2019-12-10 | 清华大学 | 信息处理方法和装置 |
TWI714003B (zh) * | 2018-10-11 | 2020-12-21 | 力晶積成電子製造股份有限公司 | 可執行人工智慧運算的記憶體晶片及其操作方法 |
US11436046B2 (en) | 2018-10-11 | 2022-09-06 | Powerchip Semiconductor Manufacturing Corporation | Electronic device with memory processor-based multiprocessing architecture and operation method thereof |
JP7259537B2 (ja) * | 2019-05-16 | 2023-04-18 | オムロン株式会社 | 情報処理装置 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH11215509A (ja) * | 1998-01-28 | 1999-08-06 | Nec Corp | 動き補償処理方法及びシステム並びにその処理プログラムを記録した記録媒体 |
JP2000030047A (ja) * | 1998-07-15 | 2000-01-28 | Sony Corp | 符号化装置とその方法および復号化装置とその方法 |
JP2000278693A (ja) * | 1999-03-19 | 2000-10-06 | Nec Corp | 動画像伸長方法及びそれを実行するプログラムを記録した記録媒体 |
Family Cites Families (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6088391A (en) * | 1996-05-28 | 2000-07-11 | Lsi Logic Corporation | Method and apparatus for segmenting memory to reduce the memory required for bidirectionally predictive-coded frames |
US5929850A (en) * | 1996-07-01 | 1999-07-27 | Thomson Consumer Electronices, Inc. | Interactive television system and method having on-demand web-like navigational capabilities for displaying requested hyperlinked web-like still images associated with television content |
US6526491B2 (en) * | 2001-03-22 | 2003-02-25 | Sony Corporation Entertainment Inc. | Memory protection system and method for computer architecture for broadband networks |
US6809734B2 (en) * | 2001-03-22 | 2004-10-26 | Sony Computer Entertainment Inc. | Resource dedication system and method for a computer architecture for broadband networks |
US7233998B2 (en) * | 2001-03-22 | 2007-06-19 | Sony Computer Entertainment Inc. | Computer architecture and software cells for broadband networks |
US6826662B2 (en) * | 2001-03-22 | 2004-11-30 | Sony Computer Entertainment Inc. | System and method for data synchronization for a computer architecture for broadband networks |
US7093104B2 (en) * | 2001-03-22 | 2006-08-15 | Sony Computer Entertainment Inc. | Processing modules for computer architecture for broadband networks |
JP4335516B2 (ja) * | 2001-12-04 | 2009-09-30 | パナソニック株式会社 | 複数のプロセッサを用いた動画像符号化装置およびその方法 |
US7088872B1 (en) * | 2002-02-14 | 2006-08-08 | Cogent Systems, Inc. | Method and apparatus for two dimensional image processing |
US7304646B2 (en) * | 2004-08-19 | 2007-12-04 | Sony Computer Entertainment Inc. | Image data structure for direct memory access |
US7924914B2 (en) * | 2005-09-20 | 2011-04-12 | Intel Corporation | Dynamically configuring a video decoder cache for motion compensation |
-
2004
- 2004-07-16 JP JP2004210761A patent/JP2006031480A/ja not_active Abandoned
-
2005
- 2005-07-05 US US11/632,655 patent/US20080253673A1/en not_active Abandoned
- 2005-07-05 KR KR20077000928A patent/KR20070035037A/ko not_active Application Discontinuation
- 2005-07-05 CN CNA200580031284XA patent/CN101036393A/zh active Pending
- 2005-07-05 WO PCT/JP2005/012422 patent/WO2006008961A1/ja active Application Filing
- 2005-07-05 EP EP20050765473 patent/EP1775962A1/en not_active Withdrawn
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH11215509A (ja) * | 1998-01-28 | 1999-08-06 | Nec Corp | 動き補償処理方法及びシステム並びにその処理プログラムを記録した記録媒体 |
JP2000030047A (ja) * | 1998-07-15 | 2000-01-28 | Sony Corp | 符号化装置とその方法および復号化装置とその方法 |
JP2000278693A (ja) * | 1999-03-19 | 2000-10-06 | Nec Corp | 動画像伸長方法及びそれを実行するプログラムを記録した記録媒体 |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2006140558A (ja) * | 2004-11-10 | 2006-06-01 | Casio Comput Co Ltd | 画像処理装置及び画像処理方法 |
US8599841B1 (en) | 2006-03-28 | 2013-12-03 | Nvidia Corporation | Multi-format bitstream decoding engine |
US8593469B2 (en) | 2006-03-29 | 2013-11-26 | Nvidia Corporation | Method and circuit for efficient caching of reference video data |
TWI471011B (zh) * | 2006-03-29 | 2015-01-21 | Nvidia Corp | 視訊處理方法及系統 |
JP2011234383A (ja) * | 2011-06-02 | 2011-11-17 | Casio Comput Co Ltd | 画像処理装置及び画像処理方法 |
JP2015207123A (ja) * | 2014-04-18 | 2015-11-19 | 富士通株式会社 | ストレージ装置、ストレージ制御方法およびストレージ制御プログラム |
Also Published As
Publication number | Publication date |
---|---|
EP1775962A1 (en) | 2007-04-18 |
CN101036393A (zh) | 2007-09-12 |
KR20070035037A (ko) | 2007-03-29 |
JP2006031480A (ja) | 2006-02-02 |
US20080253673A1 (en) | 2008-10-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2006008961A1 (ja) | 情報処理システム及び情報処理方法、並びにコンピュータプログラム | |
KR20060043201A (ko) | 정보 처리 시스템 및 정보 처리 방법과, 컴퓨터 프로그램 | |
JP4772375B2 (ja) | 電子機器およびコンテンツ管理方法 | |
Lin et al. | A framework for scalable cloud video recorder system in surveillance environment | |
JP5548671B2 (ja) | 画像処理システム、画像提供サーバ、情報処理装置、および画像処理方法 | |
US20080205389A1 (en) | Selection of transrate and transcode processes by host computer | |
JP2005235019A (ja) | ネットワークシステム、分散処理方法、情報処理装置 | |
US20120229638A1 (en) | Video Monitoring System and Control Method Thereof | |
JP4599923B2 (ja) | 情報処理システム及び情報処理方法、並びにコンピュータプログラム | |
JP2003204556A (ja) | マルチメディア信号処理のための映像復元プロセッサ | |
KR20060053894A (ko) | 정보 처리 시스템, 정보 처리 방법, 및 그와 함께 사용되는컴퓨터 프로그램 | |
JP2008234668A (ja) | メモリ管理装置、メモリ管理方法、メモリ管理プログラム及び該プログラムを記録したコンピュータ読み取り可能な記録媒体 | |
JP4329647B2 (ja) | 情報処理システム及び情報処理方法、並びにコンピュータプログラム | |
JP2004507957A (ja) | アルゴリズムを実行する方法と、拡張性のあるプログラマブル処理装置 | |
JP2005252402A (ja) | コンテンツ記録システム及びコンテンツ記録方法、並びにコンピュータ・プログラム | |
US20140099039A1 (en) | Image processing device, image processing method, and image processing system | |
JP5506250B2 (ja) | ストリーム復号装置及びストリーム復号方法 | |
JP2006033396A (ja) | 送信装置、受信装置、通信システム、送信方法、受信方法、送信プログラム、受信プログラム及びサーバ装置 | |
JP2006020147A (ja) | 情報処理装置および方法、記録媒体、並びにプログラム | |
JP4542308B2 (ja) | 信号処理用デバイス及び情報処理機器 | |
CN112492350A (zh) | 一种视频转码方法、装置、设备和介质 | |
CN107251000A (zh) | 片上系统中的动态存储器利用 | |
JP2005352909A (ja) | 情報処理装置および方法、記録媒体、並びに予約処理プログラム | |
JP2005311479A (ja) | ネットワークシステム、番組録画予約方法および情報処理装置 | |
Yan et al. | Hw-sw framework for multimedia applications on mpsoc: practice and experience |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AK | Designated states |
Kind code of ref document: A1 Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS KE KG KM KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NG NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SM SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW |
|
AL | Designated countries for regional patents |
Kind code of ref document: A1 Designated state(s): GM KE LS MW MZ NA SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IS IT LT LU LV MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG |
|
121 | Ep: the epo has been informed by wipo that ep was designated in this application | ||
WWE | Wipo information: entry into national phase |
Ref document number: 2005765473 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 1020077000928 Country of ref document: KR |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
WWE | Wipo information: entry into national phase |
Ref document number: 200580031284.X Country of ref document: CN |
|
WWP | Wipo information: published in national office |
Ref document number: 1020077000928 Country of ref document: KR |
|
WWP | Wipo information: published in national office |
Ref document number: 2005765473 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 11632655 Country of ref document: US |