Japanese Patent Application No. 2004-380986, filed on Dec. 28, 2004, is hereby incorporated by reference in its entirety.
The present invention relates to a multimedia processing system and a multimedia processing method.
Moving Picture Experts Group Phase 4 (MPEG-4) has been standardized as a coding method for multimedia information such as video data, still image data, and sound data (MPEG-4 Visual Part (ISO/IEC 14496-2: 1999 (E) )). In recent years, a portable electronic instrument such as a portable telephone is provided with an encoding/decoding function compliant with the MPEG-4 standard. Such an encoding/decoding function enables a portable telephone to encode video data obtained by using a camera (CCD) and transmit the encoded data to another portable telephone (server), or to decode video data received from another portable telephone (server) through an antenna and display the decoded video data in a display (LCD) panel.
When performing multimedia processing such as MPEG-4 encoding/decoding processing, a series of processing may be entirely implemented by using a hardware processing circuit (ASIC) (first method).
However, since the scale of the hardware processing circuit is increased by using the first method, it is difficult to deal with a demand for a reduction in size of the portable electronic instrument and a reduction in power consumption.
A portable electronic instrument such as a portable telephone includes a host central processing unit (CPU) for controlling the entire instrument and realizing a baseband engine (communication processing). Therefore, multimedia processing such as MPEG-4 processing may be implemented by software processing using the host CPU (second method).
However, since the second method increases the processing load imposed on the host CPU, the time necessary for the host CPU to perform processing other than the multimedia processing is limited, whereby the performance of the electronic instrument including the host CPU is decreased. Moreover, since the processing time of the host CPU is increased, power consumption is increased, so that it is difficult to deal with a demand for a reduction in power consumption in order to increase the battery life.
As a third method, multimedia processing may be implemented by using a host CPU and a digital signal processor (DSP). Specifically, the entire multimedia processing program group for encoding and decoding video (MPEG) data, still image (JPEG) data, and sound (audio and voice) data is stored in a built-in memory (nonvolatile memory such as a flash ROM) of the DSP. The host CPU transmits a start command, and the DSP executes a multimedia processing program indicated by the start command.
However, the third method requires that the DSP execute a series of complicated multimedia processing. Therefore, as the number of types of codec is increased or the number of types of additional processing such as stream data multiplexing/separation is increased, the architecture of assigning the entire multimedia processing to the DSP becomes meaningless, so that the performance of the DSP and the system is decreased. Moreover, since the clock frequency of the DSP must be increased in order to deal with the multimedia processing which has become complicated, problems such as an increase in power consumption and generation of heat occur. Furthermore, since the third method requires that the entire multimedia processing program group be stored in the built-in memory (flash ROM) of the DSP, power consumption and product cost are increased due to an increase in the capacity of the memory.
A first aspect of the invention relates to a multimedia processing system for performing multimedia processing which is encoding or decoding processing of video data, still image data, or sound data, the multimedia processing system comprising:
a host memory which stores a multimedia processing program group;
a host processor which performs host processing; and
a display controller controlled by the host processor,
the host processor reading a multimedia processing program from the multimedia processing program group stored in the host memory and transmitting the multimedia processing program to the display controller, and
the display controller including:
a host interface which performs interface processing between the display controller and the host processor;
a memory into which the multimedia processing program transmitted from the host processor is loaded;
a built-in processor which executes a software processing portion of the multimedia processing assigned to software processing, based on the loaded multimedia processing program; and
a first hardware accelerator which executes a hardware processing portion of the multimedia processing assigned to hardware processing.
A second aspect of the invention relates to a multimedia processing method for performing multimedia processing which is encoding or decoding processing of video data, still image data, or sound data, the multimedia processing method comprising:
storing a multimedia processing program group which is executed by a display controller in a host memory accessed by a host processor;
reading a multimedia processing program from the multimedia processing program group stored in the host memory and transmitting the multimedia processing program to the display controller;
loading the transmitted multimedia processing program into a memory of the display controller,
causing a built-in processor of the display controller to execute a software processing portion of the multimedia processing assigned to software processing, the built-in processor operating based on the loaded multimedia processing program; and
causing a first hardware accelerator of the display controller to execute a hardware processing portion of the multimedia processing assigned to hardware processing.
The invention may provide a multimedia processing system and a multimedia processing method which can efficiently execute multimedia processing.
One embodiment of the invention provides a multimedia processing system for performing multimedia processing which is encoding or decoding processing of video data, still image data, or sound data, the multimedia processing system comprising:
a host memory which stores a multimedia processing program group;
a host processor which performs host processing; and
a display controller controlled by the host processor,
the host processor reading a multimedia processing program from the multimedia processing program group stored in the host memory and transmitting the multimedia processing program to the display controller, and
the display controller including:
a host interface which performs interface processing between the display controller and the host processor;
a memory into which the multimedia processing program transmitted from the host processor is loaded;
a built-in processor which executes a software processing portion of the multimedia processing assigned to software processing, based on the loaded multimedia processing program; and
a first hardware accelerator which executes a hardware processing portion of the multimedia processing assigned to hardware processing.
According to one embodiment of the invention, the host processor reads the multimedia processing program selected from the multimedia processing program group from the host memory, and transmits the multimedia processing program to the display controller. The transmitted multimedia processing program is loaded into the memory of the display controller. The built-in processor of the display controller executes the software processing portion of the multimedia processing based on the loaded multimedia processing program, and the first hardware accelerator executes the hardware processing portion of the multimedia processing. This enables efficient execution of the multimedia processing. Moreover, since it is unnecessary to load all the multimedia processing programs into the memory of the display controller, the storage capacity of the memory of the display controller can be saved. Furthermore, it is possible to flexibly deal with complication of the multimedia processing.
With this embodiment, after transmitting the multimedia processing program and causing the multimedia processing program to be loaded into the memory, the host processor may direct reset release to release the built-in processor from a reset state, and may direct the built-in processor to start executing the multimedia processing program after the built-in processor has been released from the reset state.
This enables the built-in processor to be released from the reset state and execute the multimedia processing program as required, whereby power consumption can be reduced.
With this embodiment, after transmitting the multimedia processing program and causing the multimedia processing program to be loaded into the memory, the host processor may perform protection processing of a loading area of the multimedia processing program before the built-in processor is released from the reset state.
This prevents occurrence of a situation in which data is written into the multimedia processing program loading area by the built-in processor, which has been released from the reset state and started to operate, or the host processor so that the multimedia processing program is destroyed.
With this embodiment, the host processor may perform preprocessing including at least one of multiplexing processing, separation processing, and upper-layer header analysis processing of stream data having a layered structure and being a target of the multimedia processing; and
the built-in processor may perform lower-layer header analysis processing of the stream data.
Therefore, the preprocessing (e.g. multiplexing processing, separation processing, or upper-layer header analysis processing), which may be efficiently processed by an upper-layer device, is executed by the host processor. On the other hand, the lower-layer header analysis processing, which may be efficiently processed by a lower-layer device, is executed by the built-in processor. Such a role assignment enables efficient execution of the multimedia processing under control of the host processor.
With this embodiment, the host processor may set information obtained by the preprocessing in a given information area to notify the built-in processor of the information.
This enables the built-in processor to execute appropriate multimedia processing based on the information set in the information area.
With this embodiment,
the multimedia processing program may be an encoding processing program for executing a software processing portion of encoding processing of video data;
the first hardware accelerator may perform discrete cosine transform processing, quantization processing, inverse quantization processing, inverse discrete cosine transform processing, motion compensation processing, and motion estimation processing as the hardware processing portion; and
the built-in processor may perform variable length code encoding processing as the software processing portion.
Therefore, the hardware processing portion, of which the processing load is heavy and which may not be changed, such as the discrete cosine transform processing and the quantization processing, is executed by the first hardware accelerator. On the other hand, the software processing portion, of which the processing load is comparatively low and for which flexible programming is required, is executed by the built-in processor. Such a role assignment enables further efficient execution of the encoding processing of the multimedia processing.
With this embodiment,
the first hardware accelerator may perform scanning processing in the case of interframe coding; and
the built-in processor may perform DC prediction processing and scanning processing in the case of intraframe coding.
This enables execution of the encoding processing of the multimedia processing while suitably assigning the roles corresponding to the type of coding.
With this embodiment,
the multimedia processing program may be an encoding processing program for executing a software processing portion of encoding processing of video data;
when the first hardware accelerator has been directed by the host processor to start executing the encoding processing, the first hardware accelerator may execute a hardware processing portion of the encoding processing for video data written into an encoding data buffer, and may write the resulting video data into a FIFO buffer; and
when the built-in processor has been directed by the host processor to start executing the encoding processing program, the built-in processor may execute a software processing portion of the encoding processing for the video data written into the FIFO buffer based on the encoding processing program, and may write the resulting video data into a host buffer.
The encoding processing of the multimedia processing can be smoothly and efficiently executed under control of the host processor by utilizing the FIFO buffer as described above.
With this embodiment,
the multimedia processing program may be a decoding processing program for executing a software processing portion of decoding processing of video data;
the built-in processor may perform variable length code decoding processing as the software processing portion based on the decoding processing program; and
the first hardware accelerator may perform inverse quantization processing, inverse discrete cosine transform processing, and motion compensation processing as the hardware processing portion.
Therefore, the hardware processing portion, of which the processing load is heavy and which may not be changed, such as the inverse quantization processing and the inverse discrete cosine transform processing, is executed by the first hardware accelerator. On the other hand, the software processing portion, of which the processing load is comparatively low and for which flexible programming is required, is executed by the built-in processor. Such a role assignment enables further efficient execution of the decoding processing of the multimedia processing.
With this embodiment,
the built-in processor may perform inverse scanning processing and inverse DC/AC prediction processing in the case of intraframe coding; and
the first hardware accelerator may perform inverse scanning processing in the case of interframe coding.
This enables execution of the decoding processing of the multimedia processing while suitably assigning the roles corresponding to the type of coding.
With this embodiment,
the multimedia processing program may be a decoding processing program for executing a software processing portion of decoding processing of video data;
when the built-in processor has been directed by the host processor to start executing the decoding processing program, the built-in processor may execute a software processing portion of the decoding processing for the video data written into a host buffer based on the decoding processing program, and may write the resulting video data into the FIFO buffer; and
when the first hardware accelerator has been directed by the host processor to start executing the decoding processing, the first hardware accelerator may execute a hardware processing portion of the decoding processing for video data written into the FIFO buffer, and may write the resulting video data into a decoding data buffer.
The decoding processing of the multimedia processing can be smoothly and efficiently executed under control of the host processor by utilizing the FIFO buffer as described above.
With this embodiment,
the multimedia processing program may be a decoding processing program for executing a software processing portion of decoding processing of video data; and
when an error has occurred during the decoding processing of the built-in processor, the host processor may execute the software processing portion of the decoding processing in place of the built-in processor.
Therefore, even if a decoding error has occurred, the subsequent hardware processing portion can be appropriately executed by recovering from such an error.
With this embodiment, the display controller may include a second hardware accelerator controlled by the built-in processor and assisting a part of the software processing portion of the multimedia processing.
Another embodiment of the invention provides a multimedia processing method for performing multimedia processing which is encoding or decoding processing of video data, still image data, or sound data, the multimedia processing method comprising:
storing a multimedia processing program group which is executed by a display controller in a host memory accessed by a host processor;
reading a multimedia processing program from the multimedia processing program group stored in the host memory and transmitting the multimedia processing program to the display controller;
loading the transmitted multimedia processing program into a memory of the display controller;
causing a built-in processor of the display controller to execute a software processing portion of the multimedia processing assigned to software processing, the built-in processor operating based on the loaded multimedia processing program; and
causing a first hardware accelerator of the display controller to execute a hardware processing portion of the multimedia processing assigned to hardware processing.
Note that the embodiments described hereunder do not in any way limit the scope of the invention defined by the claims laid out herein. Note also that not all of the elements of these embodiments should be taken as essential requirements to the means of the present invention.
1. Configuration
Data (video data or MPEG stream) received from another instrument (portable telephone or server) through the antenna 10 is demodulated by the modulator-demodulator 12 and supplied to the host CPU 30. Data from the host CPU 30 is modulated by the modulator-demodulator 12 and transmitted to another instrument through the antenna 10.
Operation information from the user is input through the operation section 14 (operational button). Data communication processing, data encoding/decoding processing, processing of displaying an image in the display panel 17, imaging processing of the camera 18 (camera module), or the like is performed based on the operation information under control of the host CPU 30.
The display panel 17 is driven by the display driver 16. The display panel 17 includes scan lines, data lines, and pixels. The display driver 17 has a function of a scan driver which drives (selects) the scan lines and a function of a data driver which supplies voltage corresponding to image data (display data) to the data lines. The display controller 50 is connected with the display driver 16, and supplies image data to the display driver 16. A liquid crystal display (LCD) panel may be used as the display panel 17. However, the display panel 17 is not limited to the LCD panel. The display panel 17 may be an electroluminescence display panel, a plasma display panel, or the like.
The camera 18 includes a charge-coupled device (CCD). The camera 18 supplies image data obtained by using the CCD to the display controller 50 in a YUV format.
The host CPU 30 accesses the host memory 40 and performs host processing. In more detail, the host CPU 30 performs processing of controlling the display controller 50, processing of controlling the entire instrument, processing of a baseband engine (communication processing engine), or the like. The host memory 40 stores various programs. The host CPU 30 operates under the program stored in the host memory 40 and realizes software processing. The host memory 40 may be realized by using a nonvolatile memory such as a flash ROM, a RAM, or the like.
The display controller 50 controls the display driver 16. The display controller 50 includes a host interface 60, a built-in CPU 70 (built-in processor in a broad sense), a hardware accelerator 80, and a memory 90. In the specification and the drawings, the terms “interface”, “hardware”, and “software” may be appropriately abbreviated as “I/F”, “H/W”, and “S/W”, respectively.
The display controller 50 (image controller) encodes image data (video data or still image data) from the camera 18, and transmits the encoded image data to the host CPU 30. The host CPU 30 saves the encoded image data as a file, or transmits the encoded image data to another instrument through the modulator-demodulator 12 and the antenna 10.
The display controller 50 decodes image data (encoded data or compressed data) received from the host CPU 30, and supplies the decoded image data to the display driver 16 to allow the display driver 16 to display an image in the display panel 17. The display controller 50 may receive image data obtained by using the camera 18 and supply the image data to the display driver 16 to allow the display driver 16 to display an image in the display panel 17.
The host memory 40 stores a multimedia processing program group. The multimedia processing used herein refers to encoding (compression) or decoding (decompression) processing of video data, still image data, or sound (audio or voice) data. The multimedia processing program used herein refers to a video (MPEG in a narrow sense) encoding program, a video decoding program, a still image (JPEG in a narrow sense) encoding program, a still image decoding program, a sound encoding program, a sound decoding program, or the like. A codec program containing a set of an encoding program and a decoding program may be stored in the host memory 40 as the multimedia processing program.
In one embodiment of the invention, the host CPU 30 (host processor or host in a broad sense) reads the multimedia processing program selected from the multimedia processing program group stored in the host memory 40, and transmits the read program to the display controller 50. The transmitted multimedia processing program is loaded into the memory 90 of the display controller 50.
In more detail, when it is necessary to encode a video, the host CPU 30 reads the encoding processing program for executing the software processing portion of video data encoding processing from the host memory 40, and transmits the read program to the display controller 50. For example, when saving video data (original data) obtained by using the camera 18 as a file or transmitting to the video data to another instrument through the antenna 10, the host CPU 30 reads the video (MPEG) encoding processing program from the host memory 40 and transmits the read program to the display controller 50. The encoding target video data is input to the display controller 50 from the camera 18, for example.
When it is necessary to decode a video, the host CPU 30 reads the decoding processing program for executing the software processing portion of video data decoding processing from the host memory 40, and transmits the read program to the display controller 50. For example, when displaying video data (encoded data or compressed data) received from another instrument through the antenna 10 or video data (encoded data or compressed data) saved as a file in the display panel 17, the host CPU 30 reads the video (MPEG) decoding processing program from the host memory 40 and transmits the read program to the display controller 50. The host CPU 30 transmits the decoding target video data (original data) to the display controller 50.
As described above, according to one embodiment of the invention, a necessary multimedia processing program is selected from the multimedia processing program group by the host CPU 30, and loaded into the memory 90 of the display controller 50. Therefore, since the storage capacity of the memory 90 (RAM) can be saved, the scale of the memory 90 can be reduced, so that cost of the display controller 50 can be reduced. Moreover, since the amount of data loaded at a time can be reduced, a problem in which a long time is required for startup or restart after occurrence of a hang-up can be prevented.
The host I/F 60 included in the display controller 50 performs interface processing between the display controller 50 and the host CPU 30. In more detail, the host I/F 60 performs processing of transmitting or receiving a command, data, or status to or from the host CPU 30 (handshake processing). The host I/F 60 generates an interrupt signal transmitted from the display controller 50 to the host CPU 30. The host I/F 60 may be provided with a data direct memory access (DMA) transfer function.
The built-in CPU 70 (built-in processor in a broad sense) included in the display controller 50 controls the entire display controller 50 and each section of the display controller 50. In one embodiment of the invention, the built-in CPU 70 (RISC processor) executes the software processing portion of the multimedia processing assigned to software processing based on the multimedia processing program loaded into the memory 90. The software processing portion is a portion processed by the built-in CPU 70 which has read the multimedia processing program.
In more detail, the host CPU 30 sets the built-in CPU 70 in a reset state by directing reset of the built-in CPU 70 (by transmitting a reset command). After transmitting the multimedia processing program and causing the multimedia processing program to be loaded into the memory 90, the host CPU 30 directs reset release (transmits a reset release command) to release the built-in CPU 70 from the reset state. After the built-in CPU 70 has been released from the reset state, the host CPU 30 directs the built-in CPU 70 to start executing the multimedia processing program (transmits an execution start command). The built-in CPU 70 is released from the reset state when reset release is directed by the host CPU 30. After the built-in CPU 70 has been released from the reset state, the built-in CPU 70 executes the multimedia processing program loaded into the memory 90.
After the built-in CPU 70 has been released from the reset state, the built-in CPU 70 transitions to a command wait state in which the built-in CPU 70 waits for reception of a command (multimedia processing start command) from the host CPU 30. When the built-in CPU 70 in the command wait state has been directed by the host CPU 30 to start executing the multimedia processing program (when the built-in CPU 70 has received the multimedia processing start command), the built-in CPU 70 executes the multimedia processing program.
After transmitting the multimedia processing program and causing the multimedia processing program to be loaded into the memory 90, the host CPU 30 performs protection (write protection) processing for a multimedia processing program loading area (91 in
The host CPU 30 performs preprocessing including at least one of multiplexing processing (video/audio multiplexing and video/audio packet fragmentation), separation processing (video/audio separation), and upper-layer header analysis processing (analysis of VOS, VO, VOL, and GOV headers) for stream data (MPEG stream) having a layered structure and being the multimedia processing target. The host CPU 30 sets information (data or parameter) obtained by the preprocessing in an information area (99 in
The H/W accelerator 80 (first H/W accelerator) included in the display controller 50 is a circuit (hardware processing circuit) which executes the hardware processing portion of the multimedia processing assigned to hardware processing. The hardware processing portion is a portion processed by a dedicated circuit other than a processor.
The memory 90 included in the display controller 50 functions as a program loading area, a data buffer area, and a work area for the built-in CPU 70. In more detail, the multimedia processing program read from the host memory 40 by the host CPU 30 is loaded into the program loading area of the memory 90. Encoded data or decoded data is buffered in the buffer area (FIFO area) of the memory 90. The built-in CPU 70 expands a table or the like into the work area of the memory 90 and performs processing. The memory 90 may be realized by using a RAM (SRAM or DRAM) or the like.
As shown in
A memory controller 100 controls access (read or write access) to the memory 90. Specifically, the memory controller 100 arbitrates among accesses from the host I/F 60, the built-in CPU 70, the H/W accelerator 80, a driver I/F 110, and a camera I/F 120. The memory controller 100 generates a write address or a read address of the memory 90 to control a write pointer or a read pointer, and reads data or a program from the memory 90 or writes data or a program into the memory 90. For example, the multimedia processing program can be loaded into the program loading area 91 by the memory controller 100.
The driver I/F 110 performs interface processing between the display controller 50 and the display driver 16. In more detail, the driver I/F 110 performs processing of transmitting image data (video data or still image data) to the display driver 16, processing of generating various control signals for the display driver 16, or the like.
The camera I/F 120 performs interface processing between the display controller 50 and the camera 18. For example, the camera 18 outputs image data obtained by imaging in a YUV format, and outputs a synchronization signal (e.g. VSYNC) indicating the end of one frame. The camera I/F 120 takes in the image data from the camera 18 based on the synchronization signal.
In
2. Encoding/Decoding Processing
The MPEG-4 encoding/decoding processing according to one embodiment of the invention is described below with reference to
In the encoding processing shown in
Then, the DCT coefficients are quantized (step S2). Quantization is performed in order to reduce the amount of information by dividing each DCT coefficient in one block by a quantization step value at a corresponding position in a quantization table.
As shown in
In the encoding processing, a feed-back route is necessary in order to perform motion estimation (ME) processing between the current frame and the next frame. As shown in
The decoding processing shown in
Then, inverse quantization processing and inverse DCT processing are performed (steps S25 and S26). Then, motion compensation processing is performed based on the data in the preceding frame and the data after the VLC decoding processing (step S27), and additive processing of the resulting data and the data after the inverse DCT processing is performed.
In one embodiment of the invention, when the multimedia processing program loaded into the memory 90 is the video encoding processing program, the H/W accelerator 80 executes the hardware processing portion including the DCT processing, the quantization processing, the inverse quantization processing, the inverse DCT processing, the motion compensation processing, and the motion estimation processing (steps S1 to S6), as shown in
In one embodiment of the invention, when the multimedia processing program loaded into the memory 90 is the video decoding processing program, the built-in CPU 70 performs the VLC decoding processing (step S21), which is the software processing portion, based on the decoding processing program, as shown in
In one embodiment of the invention, when a decoding error occurs during the decoding processing of the built-in CPU 70, the host CPU 30 executes the software processing portion (steps S21 to S23) of the decoding processing in place of the built-in CPU 70.
In one embodiment of the invention, the software processing portion and the hardware processing portion are realized by assigning the roles as shown in
Specifically, most of the data in each block is zero data as shown in
On the other hand, the DCT processing, the quantization processing, the inverse quantization processing, the inverse DCT processing, the motion compensation processing, and the motion estimation processing in the steps S1 to S6 in
In one embodiment of the invention, the scanning processing for intraframe coding (I picture) is realized by software processing, and the scanning processing for interframe coding (P picture) is realized by hardware processing, as shown in
Specifically, in the case of intraframe coding, since the DC prediction processing in the step S8 is performed by software processing, it is efficient to realize the scanning processing in the step S9 subsequent to the DC prediction processing by software processing. In the case of interframe coding, since the DC prediction processing is unnecessary, the scanning processing in the step S7 may be performed by hardware processing instead of software processing. Moreover, since the scanning processing in the step S7 is relatively simple processing, the scanning processing in the step S7 is suitable for hardware processing. Therefore, in one embodiment of the invention, the scanning processing in the step S7 is realized by hardware processing, and the scanning processing in the step S9 is realized by software processing. In one embodiment of the invention, in the decoding processing shown in
As described above, one embodiment of the invention succeeds in realizing the multimedia processing by using a low-power consumption system, without increasing the clock frequency to a large extent, by assigning the roles to the built-in CPU 70 and the H/W accelerator 80 in a well-balanced manner.
3. FIFO Buffer
In one embodiment of the invention, the encoding processing and the decoding processing are realized by utilizing, as shown in
For example, when the multimedia processing program loaded into the memory 90 is the video encoding processing program, video data (video data for one VOP) obtained by using the camera 18 is written into the encoding data buffer 94 (MPEG-4 encoding buffer), as shown in
When the host CPU 30 directs the built-in CPU 70 to start executing the encoding processing program loaded into the memory 90, the built-in CPU 70 executes the software processing portion of the encoding processing for the video data (video data for one VOP) written into the FIFO buffer 92 based on the encoding processing program. The built-in CPU 70 writes the resulting video data (video data after S/W encoding) into the host buffer 96 (Huffman FIFO).
When the multimedia processing program loaded into the memory 90 is the video decoding processing program, the host CPU 30 writes the decoding target video data (video data for one VOP) into the host buffer 96, as shown in
When the host CPU 30 directs the H/W accelerator 80 to start executing the decoding processing, the H/W accelerator 80 executes the hardware processing portion of the decoding processing for the video data (video data for one VOP) written into the FIFO buffer 92. The H/W accelerator 80 writes the resulting video data (video data after H/W decoding) into the decoding data buffer 93. The video data written into the decoding data buffer 93 is transferred to the display driver 16, and a video is displayed in the display panel 17.
In one embodiment of the invention, the FIFO buffer 92 is interposed between the built-in CPU 70 and the H/W accelerator 80, as shown in
In the encoding processing shown in
The host CPU 30 directs the H/W accelerator 80 to start executing the H/W encoding processing for the subsequent (K+1)th frame ((K+1)th VOP), for example. As a result, the video data in the (K+1)th frame after the H/W encoding processing is written into the FIFO buffer 92, and the built-in CPU 70 executes the S/W encoding processing for the video data in the (K+1)th frame. In this case, the video data in the skipped Kth frame is not written into the FIFO buffer 92. Therefore, processing of disposing of or disregarding the video data in the Kth frame becomes unnecessary, so that smooth processing can be realized.
In one embodiment of the invention, when an error has occurred during the decoding processing of the built-in CPU 70 in the decoding processing shown in FIG. 6B, the built-in CPU 70 notifies the host CPU 30 of occurrence of an error by using a register or the like. When an error has occurred during the decoding processing of the built-in CPU 70, the host CPU 30 executes the software processing portion of the decoding processing in place of the built-in CPU 70. The host CPU 30 writes the video data after the S/W decoding processing into the FIFO buffer 92. This enables the H/W accelerator 80 to execute the H/W decoding processing for the written video data.
When an error has occurred during the decoding processing, it is necessary to analyze the video data (VOP). However, since the video data from the host CPU 30 is stored in the host buffer 96 (FIFO), the built-in CPU 70 cannot analyze an error by accessing the video data at an arbitrary address. On the other hand, since the video data has been transmitted from the host CPU 30, the host CPU 30 can analyze an error by accessing the video data stored in its memory at an arbitrary address. Therefore, even if an error has occurred during the decoding processing of the built-in CPU 70, the decoding processing can be completed by recovering from such an error.
4. Operation During Startup
The operation during startup according to one embodiment of the invention is described below with reference to a sequence diagram of
The host CPU 30 initializes assistance processing of the built-in CPU 70. The host CPU 30 then causes the multimedia processing program to be loaded into the program loading area 91 of the memory 90. Specifically, the host CPU 30 selects a desired multimedia processing program (decoding program or encoding program) from the multimedia processing program group stored in the host memory 40, and causes the selected program to be loaded into the memory 90.
The host CPU 30 then performs protection processing for the program loading area 91 of the memory 90. This enables protection of the multimedia processing program loaded into the program loading area 91. Specifically, if the protection processing is not performed, a situation may occur in which the host CPU 30 or the built-in CPU 70 erroneously writes data or the like into the program loading area 91. If such a situation occurs, the loaded program is destroyed so that a problem such as a hang-up of the system occurs. Occurrence of such a problem can be prevented by protecting the program loading area 91.
The host CPU 30 then transmits an assistance function enable command, a clock enable command, and a reset release command, and transitions to a startup completion status reception wait state.
When the built-in CPU 70 has received the reset release command, the built-in CPU 70 is released from the reset state and performs an initialization setting such as boot processing. The built-in CPU 70 initializes (clears to zero) the work area 97 of the memory 90. When the startup has been completed, the built-in CPU 70 transmits a startup completion status to the host CPU 30 and transitions to an ACK reception wait state. When the built-in CPU 70 has received ACK transmitted from the host CPU 30, the built-in CPU 70 transitions to a decoding/encoding start command wait state.
In one embodiment of the invention, the built-in CPU 70 is set in the reset state until the built-in CPU 70 receives the reset release command from the host CPU 30, as shown in
5. Operation During Encoding Processing
The operation during encoding processing according to one embodiment of the invention is described below with reference to a flowchart of
As shown in
The host CPU 30 then performs rate control processing (step S36). Specifically, the host CPU 30 changes the quantization step of the quantization processing (step S2 in
Then, the host CPU 30 sets a QP value (quantization parameter) to direct start of H/W encoding processing (step S37). This causes the H/W accelerator 80 to execute H/W encoding processing. When the host CPU 30 has determined that the H/W encoding processing has been completed, the host CPU 30 directs the built-in CPU 70 to start S/W encoding processing (steps S38 and S39). The host CPU 30 then determines whether or not an encoding stop has been reached. When the host CPU 30 has determined that an encoding stop has not been reached, the host CPU 30 returns to the step S31. When the host CPU 30 has determined that an encoding stop has been reached (when a specific number of frames have been encoded), the host CPU 30 finishes the processing (step S40).
The sequence diagram of
The host CPU 30 then transmits an S/W encoding processing start command and transitions to an ACK reception wait state. When the built-in CPU 70 has transmitted ACK, the host CPU 30 receives ACK. The built-in CPU 70 then starts S/W encoding processing and writes processed data (video data) into the host buffer 96 (FIFO). When the encoding processing for one VOP (one frame in a broad sense) has been completed, the built-in CPU 70 sets “lastenc” at “1”.
The host CPU 30 reads data from the host buffer 96 (FIFO). Specifically, the host CPU 30 reads data (Huffman data) from the host buffer 96 until “lastenc” becomes “1”. The host CPU 30 performs VOP stuffing for byte alignment. The host CPU 30 creates a skip frame (VOP) for rate control.
6. Operation During Decoding Processing
The operation during decoding processing according to one embodiment of the invention is described below with reference to a flowchart of
As shown in
The host CPU 30 then directs start of S/W decoding processing (step S57). This causes the built-in CPU 70 to perform VOP header analysis processing, VCL decoding processing, inverse scanning processing, and inverse DC/AC prediction processing.
The host CPU 30 determines whether or not the decoding processing for all the frames (VOPs) has been completed (step S58). When the host CPU 30 has determined that the decoding processing for all the frames has been completed, the host CPU 30 finishes the processing. When the host CPU 30 has determined the decoding processing for all the frames has not been completed, the host CPU 30 determines whether or not the decoding processing for one frame has been completed (step S59). When the host CPU 30 has determined the decoding processing for one frame has been completed, the host CPU 30 clears a decoding completion flag (step S60).
The host CPU 30 then acquires an interval value, and determines whether or not the time corresponding to the interval value (time corresponding to the frame rate) has elapsed (steps S61 and S62). When the host CPU 30 has determined that the time corresponding to the interval value has elapsed, the host CPU 30 selects the display area (first or second buffer of the decoding data buffer 93 having a double buffer structure) (step S63), and transfers display data (image data) of the selected display area to the display driver 16 (step S64).
In one embodiment of the invention, the host CPU 30 performs upper-layer header analysis (VOS, VO, VOL, and GOV header analysis) of an MPEG stream (stream data in a broad sense), as indicated by the steps S51 to S56 in
The sequence diagram of
The host CPU 30 then transmits a decoding reset command and transitions to an ACK reception wait state. When the built-in CPU 70 has received the decoding reset command from the host CPU 30 after expanding the assistance table, the built-in CPU 70 sets the operation mode to a decoding mode. The built-in CPU 70 initializes the H/W accelerator and transmits ACK.
When the host CPU 30 has received ACK, the host CPU 30 writes data (Huffman data) into the host buffer 96. Specifically, the host CPU 30 writes data for one VOP into the host buffer 96.
The host CPU 30 then transmits an S/W decoding start command and transitions to an ACK reception wait state. When the built-in CPU 70 has received the decoding start command, the built-in CPU 70 acquires information set in the information area 99 and transmits ACK, and the host CPU 30 receives ACK.
The built-in CPU 70 then starts S/W decoding processing. The built-in CPU 70 writes the processed data into the FIFO buffer 92. When the decoding processing of data for one VOP has been completed, the built-in CPU 70 sets “lastdec” at “1”. When the built-in CPU 70 has detected an error during analysis of Huffman data, the built-in CPU 70 sets “decerr” at “1”.
The host CPU 30 waits until “lastdec” becomes “1”. When “lastdec” has become “1”, the host CPU 30 checks “decerr”. When “decerr=1”, the host CPU 30 clears the FIFO buffer 92 and executes S/W decoding processing in place of the built-in CPU 70.
The host CPU 30 then directs start of H/W decoding processing. After the host CPU 30 has directed start of H/W decoding processing, the host CPU 30 again performs the initialization processing of the host buffer 96.
In one embodiment of the invention, when an error has occurred during the S/W decoding processing, the host CPU 30 executes the S/W decoding processing in place of the built-in CPU 70, as shown in
7. Handshake Communication
In one embodiment of the invention, command and status transfer between the host CPU 30 and the built-in CPU 70 is realized by handshake communication using registers (output register and input register). These registers may be provided in the host I/F 60.
The handshake communication according to one embodiment of the invention is described below with reference to flowcharts shown in
The host CPU 30 starts a timer (step S72), and waits until the output status becomes “0” (step S73). The host CPU 30 finishes the processing when the output status has become “0”. When the output status has not become “0”, the host CPU 30 determines whether or not the timer started in the step S72 has reached a time-out (step S74). When the timer has not reached a time-out, the host CPU 30 returns to the step S73. When the timer has reached a time-out, the host CPU 30 finishes the processing.
The built-in CPU 70 reads data from the output register (bits 15 to 0) (step S75). This read operation causes the output status (bit 8) to be automatically set at “0”.
The built-in CPU 70 then determines whether or not the output status has been set at “1” during reading in the step S75 (step S76). When the output status has not been set at “1”, the built-in CPU 70 returns to the step S75 and again reads data from the output register (bits 15 to 0). When the host CPU 30 has written data into the output register (bits 7 to 0) in the step S71 and the output status has become “1”, the host CPU 30 acquires the data (bits 7 to 0) from the output register (step S77).
The host CPU 30 reads data from the input register (bits 31 to 16) (step S86). This read operation causes the input status (bit 24) to be automatically set at “0”. The host CPU 30 then determines whether or not the input status is “1” (step S87). When the host CPU 30 has determined that the input status is not “1”, the host CPU 30 returns to the step S86 and again reads data from the input register. When the built-in CPU 70 has written data into the input register in the step S81 and the input status has become “1”, the host CPU 30 acquires data (bits 23 to 16) from the input register (step S88).
The present invention is not limited to the above-described embodiments, and various modifications can be made within the scope of the invention. Any term (such as a host CPU, built-in CPU, VOP or portable telephone) cited with a different term having broader or the same meaning (such as a host processor, built-in processor, frame or electronic instrument) at least once in this specification and drawings can be replaced by the different term in any place in this specification and drawings.
The configurations of the electronic instrument, the multimedia processing system, and the display controller according to the invention are not limited to the configurations described with reference to
Although only some embodiments of the present invention have been described in detail above, those skilled in the art will readily appreciate that many modifications are possible in the embodiments without materially departing from the novel teachings and advantages of this invention. Accordingly, all such modifications are intended to be included within scope of this invention.
Number | Date | Country | Kind |
---|---|---|---|
2004-380986 | Dec 2004 | JP | national |