This application claims priority to Korean Patent Application No. 10-2013-0028336, filed on Mar. 15, 2013, in the Korean Intellectual Property Office, the disclosure of which is incorporated by reference in its entirety herein.
1. Technical Field
The inventive concept relates to a multimedia system and a method of operating the same.
2. Discussion of Related Art
A system-on-chip (SoC) system, which includes an application processor (AP), may be used to process multimedia data to form a multimedia system. The multimedia system may include several modules for performing one or more functions to process the multimedia data. It may be inefficient to control all modules included in the multimedia system with a single special function register (SFR) and one synchronization logic. Further, when the whole system is controlled by the one synchronization logic, it may be difficult to perform high-performance operations.
According to an exemplary embodiment of the inventive concept, a multimedia system includes a main special function register (SFR) configured to store SFR information; a plurality of processing modules each configured to process frames of data, based on the SFR information; and a system control logic configured to control operations of the main SFR and the plurality of processing modules. The plurality of processing modules may process data of different frames at the same time period.
Each of the plurality of processing modules may operate in synchronization with module frame identification (ID) thereof.
The SFR information may include frame synchronization information and non-frame synchronization information, and the plurality of processing modules may process the data using independent clock signals and separate parts of the frame synchronization information.
Each of the plurality of processing modules may include a power/clock manager configured to control clock-gating and power-gating of the processing module.
The multimedia system may further include a starter module configured to set a stream path including stream processing modules for processing the data among the plurality of processing modules. The starter module may set a module frame ID of each of the respective stream processing modules.
Each of the plurality of processing modules may include a frame synchronization manager configured to determine whether processing of a subsequent frame of the data is to be started, a frame SFR configured to receive and store frame synchronization information transmitted from the main SFR, and a data processing logic configured to process the data in units of frames, based on the frame synchronization information stored in the frame SFR.
When the frame synchronization manager determines that the processing of the subsequent frame is to be started, the frame SFR may receive the frame synchronization information corresponding to the subsequent frame from the main SFR, store the frame synchronization information, and maintain the frame synchronization information until the frame synchronization manager determines that the processing of another subsequent frame is to be started.
The main SFR may store an ID of a most recent frame among frames processed by the stream processing modules as recent frame ID, and store the frame synchronization information corresponding to the recent frame ID.
When processing of data corresponding to the module frame ID is completed, the frame synchronization manager may increase the module frame ID and transmit the increased module frame ID to the system control logic. The system control logic may control the frame synchronization manager to start processing of the subsequent frame when the module frame ID and the recent frame ID are the same.
If the module frame ID is greater than the recent frame ID, the system logic may generate an SFR update signal when all the stream processing modules receive the frame synchronization information corresponding to the recent frame ID, and the main SFR may update the frame synchronization information and the recent frame ID according to the SFR update signal.
If the module frame ID is greater than the recent frame ID, the system logic may generate a recent frame ID update signal after a predetermined time period passes when all the stream processing modules receive the frame synchronization information corresponding to the recent frame ID.
When each of the stream processing modules receives and stores the frame synchronization information corresponding to each of the frames, each of the stream processing modules may transmit a module processing signal to the system control logic, and the system control logic may determine whether all the stream processing modules receive the frame synchronization information corresponding to the recent frame ID, according to the module processing signal.
The starter module may receive a stream start signal and initial frame ID from the system control logic, and transmit a stream request and the initial frame ID to the stream processing modules that provide the data to the starter module.
Each of the stream processing modules may receive the stream request and the initial frame ID from the starter module or another stream processing module, transmit the stream request and the initial frame ID to the other stream processing module when the stream processing module receives the data from the other stream processing module, store the initial frame ID as the module frame ID thereof, and receive frame synchronization information corresponding to the module frame ID.
According to an exemplary embodiment of the inventive concept, there is provided a method of operating a multimedia system, which is performed by each of processing modules, the method including receiving and storing frame synchronization information transmitted from a main special function register (SFR), and processing frames of data based on the frame synchronization information.
Each of the processing modules may process different frames of the data at the same point of time, operate in synchronization with module frame identification (ID) thereof, and be independently clock-gated and power-gated.
According to an exemplary embodiment of the inventive concept, a system includes a plurality of processing modules and a main special function register SFR. A first subset of the processing modules process a current frame of data upon being assigned a first frame identifier, and increment the first frame identifier to a second frame identifier after the processing. A second subset of the processing modules process a subsequent frame of data upon being assigned the second frame identifier. The main special function register SFR is configured to transmit information to the first subset of processing modules indicating whether each of the processing modules of the first subset is to operate in synchronization with the second frame identifier. In an exemplary embodiment, the second subset of processing modules sequentially performs operations on the second frame of data, and only the processing modules of the first subset that received information indicating they should operate, perform operations on an output of the sequential operations. In an exemplary embodiment, each of the plurality of processing modules includes a frame synchronization manager configured to determine whether processing of the subsequent frame is to be started, a frame SFR configured to receive and store the information transmitted from the main SFR, and a data processing logic configured to process each of the frames of the data, based on the information stored in the frame SFR. In an exemplary embodiment, the system further includes comprising system control logic configured to control operations of the main SFR and the plurality of processing modules. In an exemplary embodiment, when processing of data corresponding to the first frame identifier has completed, the frame synchronization manager increases the first frame identifier and transmits the increased frame identifier to the system control logic, and the system control logic controls the frame synchronization manager to start processing of the subsequent frame upon receipt of the increased frame identifier.
Exemplary embodiments of the inventive concept will be more clearly understood from the following detailed description taken in conjunction with the accompanying drawings in which:
The inventive concept now will be described more fully hereinafter with reference to the accompanying drawings, in which exemplary embodiments of the invention are shown. The inventive concept may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein. Like numbers refer to like elements throughout. As used herein, the singular forms “a”, “an”, and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise.
Hereinafter, the term “module” may indicate the functional or structural combination between hardware for performing a method according to at least one embodiment of the inventive concept and software for driving the hardware. Accordingly, the module may indicate a logical unit or group of a program code and a hardware resource (e.g., a processor) for performing the program code and does not necessarily indicate physically connected coders or a certain type of hardware.
Referring to
The electronic system 10 includes a system-on-chip (SoC) 100, an input/output (I/O) device 187, a memory device 190, and a display device 195. The SoC 100 includes a central processing unit (CPU) 110, a read only memory (ROM) 120, a random access memory (RAM) 130, a timer 135, an accelerator 140, a clock management unit (CMU) 145, a display controller 150, a memory controller 170, a bus 180, and an I/O interface 185. Although not shown, the SoC 100 may further include other devices, e.g., a television (TV), a processor, etc. The electronic system 10 may further include a power management integrated circuit (PMIC) 160.
The PMIC 160 is disposed outside the SoC 100 in
The CPU 110 that may also be referred to as a processor may process or execute programs and/or data stored in the memory device 190 or an internal memory device such as memories 120 and 130. For example, the CPU 110 may process or execute the programs and/or data according to a clock signal output from a clock signal generator (not shown).
The CPU 110 may be embodied as a multi-core processor. The multi-core processor is one computing component including at least two independent and actual processors (referred to as cores). Each of the at least two processors is capable of reading and performing program instructions. Since the multi-core processor is capable of simultaneously driving a plurality of accelerators, a data processing system including the multi-core processor may perform multi-acceleration.
Programs and/or data stored in the ROM 120, the RAM 130, and the memory device 190 may be loaded to a memory of the CPU 110 if needed.
The ROM 120 may store permanent programs and/or data. The ROM 120 may be embodied as erasable programmable read-only memory (EPROM) or electrically erasable programmable read-only memory (EEPROM).
The RAM 130 may temporarily store programs, data, or instructions. For example, programs and/or data stored in the ROM 120 or the memory device 190 may be temporarily stored in the RAM 130, under control of the CPU 110 or according to a boot code stored in the ROM 120. The RAM 130 may be embodied as dynamic RAM (DRAM) or static RAM (SRAM).
The accelerator 140 may mean a hardware device or a co-processor configured to improve the performance of processing multimedia or multimedia data, e.g., text, audio, still images, animation, video, two-dimensional (2D) data, three-dimensional (3D) data, etc. For example, the accelerator 140 may be a graphic processing unit (GPU).
Although
The CMU 145 generates an operating clock signal. The CMU 145 may include a clock generation device such as a phase-locked loop (PLL), a delayed locked loop (DLL), a crystal, etc.
The operating clock signal may be supplied to the CPU 110. Furthermore, the operating clock signal may be supplied to other elements, e.g., a memory controller, etc.
The voltage controller 161 may control the voltage generator 165. The voltage generator 165 may generate operating voltages for various elements of the SoC 100 and apply the operating voltages to these elements under control of the voltage controller 161.
The memory controller 170 is a block configured to interface with the memory device 190. The memory controller 170 controls overall operations of the memory device 190 and exchange of various data between a host (not shown) and the memory device 190. For example, the memory controller 170 writes data to or reads data from the memory device 190 according to a request from the host.
Here, the host may be a master device such as the CPU 110, the accelerator 140, or the display controller 150.
The I/O interface 185 is a block configured to interface with the I/O device 187. The I/O interface 185 may control exchange of various data between various elements of the SoC 100 and the I/O device 187.
The I/O device 187 may receive an input from a user or output data to the user. The I/O device 187 may be, for example, a touch screen.
The memory device 190 is a storage space for storing data and may store an operating system (OS), various computer programs, and various data (e.g., multimedia data such as images, movies, etc.). The memory device 190 may be DRAM but is not limited thereto. For example, the memory device 190 may be a nonvolatile memory device, e.g., a flash memory, a phase-change RAM (PRAM), a magneto-resistive RAM (MRAM), a resistive RAM (ReRAM), or a ferroelectric RAM (FeRAM). According to an exemplary embodiment of the inventive concept, the memory device 190 is a built-in memory installed in the SoC 100. These elements 110, 120, 130, 140, 150, 170, and 185 may communicate with one another via the system bus 180.
The display controller 150 may control an operation of the display device 195.
The display device 195 may display results provided from a soft accelerator loaded to the CPU 110 or multimedia data accelerated or processed by the accelerator 140, which is a hardware accelerator. As an exemplary embodiment, the display device 195 may be a light-emitting diode (LED), an organic LED (OLED) device, or another type of display device.
Referring to
The multimedia system 150 may include a plurality of processing modules 210, a main special function register (SFR) 220, a system control logic 230, and a starter module 240. The plurality of processing modules 210 process frames of data received from the outside (e.g., a source located external the SoC 100), based on SFR information.
Stream paths Str_path corresponding to the frames in the plurality of processing modules 210 are formed when frames of data are processed. Each of the stream paths Str_path means a sequence of processing modules 210 to which a frame that is to be currently processed by the multimedia system 150 will be moved. Different stream paths Str_path may be used for different frames. Hereinafter, processing modules P1 211-1, . . . , Pn−1 211-(n−1), Pn 211-n included in one of the stream paths Strpath will be referred to as stream processing modules.
The plurality of stream processing modules P1 211-1 to Pn 211-n are capable of sequentially performing a different process on data. For example, the nth stream processing module 211-n may receive data from the outside and perform scaling on the data, and the (n−1)th stream processing module 211-(n−1) may perform blending on the data scaled by the nth processing module 211-n. The first stream processing module 211-1 may finally process data processed sequentially by the nth stream processing module 211-n to the second stream processing module 211-2 and output a processing result to the outside.
The plurality of processing modules 210 may be each assigned different module frame identifications (IDs) and process data of each frame corresponding to the module frame IDs thereof, respectively. Thus, the plurality of processing modules 210 may process data of different frames at the same point of time, respectively.
The main SFR 220 may receive SFR information needed to process the data from the outside and store the SFR information. The SFR information may include frame synchronization information to be synchronized in units of frames, and non-frame synchronization information that does not need to be synchronized in units of frames. Examples of the frame synchronization information may include image size, e.g., 1024×768, a color format, e.g., RGB or YCbCr, etc.
The main SFR 220 may transmit the SFR information to the plurality of processing modules 210.
The system control logic 230 controls operations of the plurality of processing modules 210, the main SFR 220, and the starter module 240. The system control logic 230 may include a table for storing information regarding states of the plurality of processing modules 210.
The starter module 240 may set the stream path Str_path under control of the system control logic 230. The starter module 240 may set the module frame IDs assigned to the respective stream processing modules P1 211-1 to Pn 211-n included in the stream path Strpath.
The elements 211-1 to 211-n, 220, 230, and 240 included in the multimedia system 150 may operate asynchronously or synchronously. For example, the elements 211-1 to 211-n, 220, 230, and 240 may operate in synchronization with clock signals, respectively. The clock signals may be different from one another.
Referring to
The data processing logic 310 processes data in units of frames, based on frame synchronization information stored in the frame SFR 340 and non-frame synchronization information received from the main SFR 220.
The power/clock manager 320 controls clock-gating and power-gating of the processing module 211-k. That is, the power/clock manager 320 may control supply of a clock signal and power to the elements 310, 330, 340 included in the processing module 211-k.
The frame synchronization manager 330 determines whether processing of a subsequent frame of the data is to be started. The frame synchronization manager 330 may store a module frame ID of the corresponding processing module 211-k. The processing modules 211-k may operate in synchronization with the module frame IDs thereof.
In an exemplary embodiment, the frame synchronization manager 330 increases the module frame ID when the data processing logic 310 completes processing of a current frame. When the increased module frame ID is equal to a recent frame ID, the frame synchronization manager 330 controls the frame SFR 340 to receive and store frame synchronization information corresponding to the increased module frame ID. Then, the frame synchronization manager 330 controls the data processing logic 310 to start processing of a frame corresponding to the increased module frame ID. The recent frame ID will be described in detail with reference to
The frame SFR 340 receives the frame synchronization information from the main SFR 220 and stores the frame synchronization information, based on the module frame ID. When the frame synchronization manager 330 determines that processing of the subsequent frame is to be started, the frame SFR 340 receives frame synchronization information corresponding to the subsequent frame from the main SFR 220, stores the frame synchronization information, and maintains the frame synchronization information until the frame synchronization manager 330 determines that processing of another subsequent frame is to be started. Thus, even if the main SFR 220 or the frame SFR 340 of another processing module is updated, the frame SFR 340 may independently operate without being influenced by the updating.
The module frame IDs assigned to the respective processing modules 211-k may be different from one another. Thus, the plurality of processing modules 211-k may process data of different frames at the same point of time. Since the processing modules 211-k include different power/clock managers 320 and different frames SFR 340, the data may be processed using independent clock signals and independent frame synchronization information.
The structure of the starter module 240 may be the same as those of the processing modules 211-k. In other words, similarly, the starter module 240 may include the data processing logic 310, the power/clock manager 320, the frame synchronization manager 330, and the frame SFR 340, and store module frame ID thereof.
Referring to
Although
In the present disclosure, a processing module that operates as a data source in the stream path Str_path will be referred to as a producer and a processing module that consumes data will be referred to as a consumer. For example, when data is supplied in the order of the processing modules 211-n, 211-(n−1), . . . , 211-3, 211-2, and 211-1, a producer of the second processing module 211-2 is the third processing module 211-3 and a consumer of the second processing module 211-2 is the first processing module 211-1. In this case, a final consumer of the stream path Str_path is always the starter module 240.
A process of setting the stream path Str_path using the starter module 240 will now be described.
The main SFR 220 receives a multimedia process request (not shown) from the outside, e.g., a CPU, according to a user input, and transmits this request to the system control logic 230. The system control logic 230 initializes all the processing modules 210 by supplying a reset signal RST thereto according to the multimedia process request.
The system control logic 230 determines that the first processing module 211-1 to the nth processing module 211-n are to be set as stream processing modules among the processing modules 210, according to the multimedia process request. Then, the system control logic 230 transmits an SFR start signal START to the main SFR 220, and module enable signals Module_Enable—1 to Module_Enable_n to the stream processing modules 211-1 to 211-n and the starter module 240.
The system control logic 230 may also transmit the module enable signal Module_Enable to the remaining modules other than the stream processing modules 211-1 to 211-n. In this case, the module enable signal Module_Enable transmitted to the stream processing modules 211-1 to 211-n may be in a first logic level, e.g., a logic high level, and the module enable signal Module_Enable transmitted to the remaining processing modules may be in a second logic level, e.g., a logic low level.
The power/clock manager 320 of each of the stream processing modules 211-1 to 211-n and the starter module 240 starts supply of a clock signal to the frame synchronization manager 330 corresponding thereto according to the module enable signal Module_Enable. It should be hereinafter understood that the stream processing modules 211-n to 211-1 and the starter module 240 are operated by the frame synchronization managers 330 included in the respective stream processing modules 211-n to 211-1 and starter module 240 before the clock signal is supplied to the data processing units 310 of the respective stream processing modules 211-n to 211-1 and the starter module 240, unless otherwise specified.
Then, the system control logic 230 transmits a stream start signal STREAM_START to the starter module 240, and transmits an initial frame ID INIT_FRAMEID to the starter module 240 via the main SFR 220. It is hereinafter assumed that the initial frame ID INIT_FRAMEID is ‘0’.
The main SFR 220 may store a current frame ID CFRMID, and a recent reference frame ID RRFRAMEID.
The current frame ID CFRMID means a module frame ID of the starter module 240 which is located at the back of the multimedia system 150, that is, which is a last consumer. In other words, the current frame ID CFRMID is an ID of an oldest frame among frames that are being processed in the multimedia system 150.
The recent frame ID RRFRAMEID means an ID of a most recent frame that is being processed in the multimedia system 150.
The main SFR 220 may set the current frame ID CFRMID and the recent frame ID RRFRAMEID as initial frame IDs INIT_FRAMEID according to the SFR start signal START. The main SFR 220 may receive frame synchronization information corresponding to the recent frame ID RRFRMID from the outside and store this information whenever the recent frame ID RRFRMID is set or updated.
The starter module 240 sets a module frame ID Module_CFRMID—0 thereof as the initial frame ID INIT_FRAMEID. Then, the starter module 240 receives starter frame synchronization information FRAME_SYNC_INFO—0 corresponding to the module frame ID Module_CFRMID—0 thereof from the main SFR 220, stores this information in the frame SFR 340 thereof, and transmits a starter producer request signal Producer_REQ—0 to the main SFR 220. The frame SFR 340 of the starter module 240 maintains the starter frame synchronization information FRAME_SYNC_INFO—0 until the frame synchronization manager 330 of the starter module 240 determines that processing of a subsequent frame is to be started.
The main SFR 220 determines the P1 211-1 as a producer of the starter module 240 according to the starter producer request signal Producer_REQ—0, and transmits a starter producer signal Producer—0 indicating that the P1 211-1 is the producer to the starter module 240.
The starter module 240 transmits a first stream request STR_REQ—1 to the P1 211-1 according to the starter producer signal Producer—0, sets a first stream frame ID STR_FRAMEID—1 as the module frame ID_ModuleCFRMID—0 thereof, and transmits the first stream frame ID STR_FRAMEID—1 to the P1 211-1.
The P1 211-1 sets a module frame ID Module_CFRMID—1 thereof as the first stream frame ID STR_FRAMEID—1. Then, the P1 211-1 receives first frame synchronization information FRAME_SYNC_INFO—1 corresponding to the module frame ID Module_CFRMID—1 thereof from the main SFR 220, stores this information in the frame SFR 340 thereof, and transmits a first producer request signal Producer_REQ—1 to the main SFR 220. The frame SFR 340 of the P1 211-1 maintains the first frame synchronization information FRAME_SYNC_INFO—1 until the frame synchronization manager 330 of the P1 211-1 determines that processing of a subsequent frame is to be started.
The main SFR 220 determines that the P2 211-2 is a producer of the P1 211-1 and transmits a first producer signal Producer—1 including information indicating that the P2 211-2 is the producer to the P1 211-1, according to the first producer request signal Producer_REQ—1.
The P1 211-1 transmits a second stream request STR_REQ_2 to the P2 211-2, sets a second stream frame ID STR_FRAMEID—2 as the module frame ID Module_CFRMID—1 thereof, and transmits the second stream frame ID STR_FRAMEID—2 to the P2 211-2, according to the first producer signal Producer 1.
The operations of the P2 211-2 to the Pn−1 211-(n−1) may be the same as that of the P1 211-1 described above and is thus not redundantly described here.
The Pn 211-n receives an nth stream request STR_REQ_n and an nth stream frame ID STR_FRAMEID_n. The Pn 211-n sets a module frame ID Module_CFRMID_n thereof as the nth stream frame ID_STR_FRAMEID_n. Then, the Pn 211-n receives nth frame synchronization information FRAME_SYNC_INFO_n corresponding to the module frame ID Module_CFRMID_n thereof from the main SFR 220, stores this information in the frame SFR 340 thereof, and transmits an nth producer request signal Producer_REQ_n to the main SFR 220. The frame SFR 340 of the Pn 211-n maintains the nth frame synchronization information FRAME_SYNC_INFO_n until the frame synchronization manager 330 of the Pn 211-n determines that processing of a subsequent frame is to be started.
The main SFR 220 determines that a producer of the Pn 211-n is not present and transmits an nth producer signal Producer_n including information indicating that a producer of the Pn 211-n is not present to the Pn 211-n, according to the nth producer request signal Producer_REQ_n.
The Pn 211-n receives the nth producer signal Producer_n and determines that a producer of the Pn 211-n is not present. Thus, after the receiving of the nth frame synchronization information FRAME_SYNC_INFO_n ends, the Pn 211-n transmits an nth stream ready signal STR_RDY_n to the Pn−1 211-(n−1), and starts processing of the data. The power/clock manager 320 included in the Pn 211-n starts supply of a clock signal to the data processing logic 310 corresponding thereto according to the nth stream ready signal STR_RDY_n.
The Pn 211-n transmits an nth module processing signal Module_Processing_n to the control logic 230. The nth module processing signal Module_Processing_n may have a first logic level, e.g., a logic high level, while the Pn 211-n processes the data, and may have a second logic level, e.g., a logic low level, while the Pn 211-n does not process the data.
The Pn−1 211-(n−1) may receive the nth stream ready signal STR_RDY_n from the Pn 211-n, transmit an (n−1)th stream ready signal STR_RDY_(n−1) to the Pn−1 211-(n−2) when receiving of an (n−1)th frame synchronization information FRAME_SYNC_INFO_(n−1) ends, and start processing of the data. The power/clock manager 320 included in the Pn 211-(n−1) starts supply of a clock signal to the data processing logic 310 corresponding thereto according to an (n−1)th stream ready signal STR_RDY_(n−1). The Pn−1 211-(n−1) transmits an (n−1)th module processing signal Module_Processing_(n−1) to the control logic 230. The (n−1)th module processing signal Module_Processing_(n−1) may have a first logic level, e.g., a logic high level, while the Pn−1 211-(n−1) processes the data, and may have a second logic level, e.g., a logic low level, while the Pn−1 211-(n−1) does not process the data.
The operations of the P1 211-1 may be the same as that of the Pn−1 211-(n−1) described above and is thus not redundantly described here.
When the starter module 240 receives a first stream ready signal STR_RDY_1 from the P1 211-1, the setting of the stream path Str_path is completed. In this case, all the processing modules 211-1 to 211-n are ready to transmit the data and are assigned the same module frame ID. The process of setting the stream path Str_path described above is referred to as stream building.
Referring to
The first stream path Str_path—1 may be set using the process described above with reference to
After the processing modules P4, P3, P2, and P1 in the first stream path Str_path—1 process the data, the initial module frame ID Module_CFRMID assigned thereto is increased by F. Thus, the module frame ID Module_CFRMID assigned to the processing modules P4, P3, P2, and P1 is changed to ‘2’.
After the module frame ID Module_CFRMID assigned to the processing modules P4, P3, P2, and P1 is increased by ‘1’, the processing modules P4, P3, P2, and P1 receives frame synchronization information FRAME_SYNC_INFO corresponding thereto from the main SFR 230. The frame synchronization information FRAME_SYNC_INFO includes information indicating whether each of the processing modules P4, P3, P2, and P1 corresponding thereto operates in synchronization with the module frame ID Module_CFRMID thereof.
Each of the processing modules P4, P3, P2, and P1 determines whether itself operates in synchronization with the module frame ID Module_CFRMID thereof, based on the frame synchronization information FRAME_SYNC_INFO. At the module frame ID ‘2’, the processing modules P2 to P4 do not operate and only the processing module P1 operates.
Each of the processing modules P1 to P9 transmit data mul_data processed by itself and valid data bits data_valid to a consumer thereof. The processing modules P1 to P9 may set the valid data bits data_valid to be in a first logic level, e.g., a logic high level, when the processing modules P1 to P9 operate in synchronization with module frame IDs thereof, and may set the valid data bits data_valid to be in a second logic level, e.g., a logic low level, when the processing modules P1 to P9 do not operate in synchronization with the module frame IDs thereof.
Thus, since the processing module P4 does operate in synchronization with the frame ID 2, the processing module P4 transmits data that is a logic low to the processing module P3 which is a consumer thereof. Since the processing module P3 does not operate in synchronization with the frame ID 2, the processing module P3 transmits data that is logic low to the processing module P2 which is a consumer thereof. Since the processing module P2 does not operate in synchronization with the frame ID 2, the processing module P2 transmits data that is logic low to the processing module P1 which is a consumer thereof. Then, the power/clock manager 320 of each of the processing modules P4 to P2 may suspend the supply of a clock signal to the data processing logic 310.
Although the processing module P1 operates in synchronization with the frame ID 2, the processing module P1 receives valid data bits data_valid that are logic low from the processing module P2 which is a producer thereof. Since the processing module P1 receives the valid data bits data_valid that are logic low, the processing module P2 does not receive data mul_data and starts stream building at the frame ID 2, starting from the processing module P5 which is a producer of the processing module P1.
That is, the processing module P1 transmits the first producer request signal Producer_REQ—1 to the main SFR 220.
The main SFR 220 determines that the processing module P5 is a producer of the processing module P1 according to the first producer request signal Producer_REQ—1, and transmits a first producer signal Producer—1 including information that the processing module P5 is a producer of the processing module P1, to the processing module P1. The processing module P1 sets module frame ID Module_CFRMID thereof as stream frame ID STR_FRAMEID, and transmits a stream request STR_REQ and the stream frame ID STR_FRAMEID to the processing module P5 according to the first producer signal Producer—1.
The processing module P5 sets the received stream frame ID STR_FRAMEID, e.g., ‘2’, as module frame ID Module_CFRMID thereof, and then operates similar to the processing module P1. Similarly, the processing modules P6 and P7 operate to set the second stream path Str_path—2. Thereafter, the data mul_data may be delivered along the second stream path Str_path—2.
Each of the processing modules P7, P6, P5, and P1 included in the second stream path Str_path—2 processes data and then increases the module frame ID Module_CFRMID thereof by ‘1’. Thus, the module frame IDs Module_CFRMID of the respective processing modules P7, P6, P5, and P1 are ‘3’.
The processing module P6 transmits valid data bits data_valid that are logic high to the processing module P5. However, the processing module P5 transmits valid data bits data_valid that are logic low to the processing module P1, and the processing module P1 transmits valid data bits data_valid that are logic to the starter module 240.
Since the starter module 240 receives the valid data bits data_valid that are logic low, the starter module 240 does not receive data mul_data from the processing module P1 and starts stream building at frame ID 3, starting from the processing module P8 which is a producer of the starter module 240.
A stream building process is as described above. Thus, the third stream path Str_path—3 is set. Then, the data mul_data may be delivered along the third stream path Str_path—3.
Referring to
When the starter module 240 receives the data from the first processing module P1, the starter module 240 increases module frame ID Module_CFRMID—0 thereof from ‘0’ to ‘1’.
The processing modules Pn to P1 and the starter module 240 output the module frame IDs Module_CFRMID_n to Module_CFRMID—0 thereof to the system control logic 230, respectively.
The system control logic 230 may receive and store the module frame IDs Module_CFRMID_n to Module_CFRMID—0 of the respective processing modules Pn to P1 and starter module 240. When the module frame ID Module_CFRMID—0 of the starter module 240 is changed from ‘0’ to ‘1’, the system control logic 230 may transmit a current frame ID update signal CFRMID_update and next frame ID Next_CFRMID to the main SFR 220. The main SFR 220 updates current frame ID CFRMID to the next frame ID Next_CFRMID according to the current frame ID update signal CFRMID_update. Then, the next frame ID Next_CFRMID is increased by ‘1’.
Referring to
The system control logic 230 may receive and store module frame IDs Module_CFRMID from the respective plurality of processing modules 210.
As described above, the system control logic 230 transmits a module enable signal Module_Enable to the plurality of processing modules 210. A module enable signal Module_Enable transmitted to the stream processing modules P4, P3, P2, and P1 has a value that is in a first logic level, e.g., a logic high level, and a module enable signal Module_Enable transmitted to the other processing modules may have a value that is in a second logic level, e.g., a logic low level. The system control logic 230 may store the module enable signal Module_Enable corresponding to a current frame ID CFRMID and transmitted to these processing modules.
The system control logic 230 may store touch values Touch corresponding to respective current frame IDs CFRMID of these processing modules.
The touch values Touch of the respective processing modules may be set to be logic high when all the stream processing modules P4, P3, P2, and P1 receive and store frame synchronization information FRAME_SYNC_INFO corresponding to the current frame IDs CFRMID thereof. For example, the touch values Touch may be set to be logic high when a module processing signal Module_Processing is changed from logic low to logic high while the stream processing modules P1 to P4 have module frame IDs Module_CFRMID that are the same current frame ID CRFMID.
Touch values Touch of processing modules that do not belong to a stream path Str_path are set to be logic high.
The touch values Touch may be set to be logic low when all the stream processing modules P4, P3, P2, and P1 do not store the frame synchronization information FRAME_SYNC_INFO corresponding to the current frame ID CFRMID.
The system control logic 230 receives the current frame ID CFRMID and the recent frame ID RRFRMID from the main SFR 220.
It is assumed that the stream processing module P4 among the stream processing modules P1 to P4 first processes data of the second frame. In this case, the steam processing module P4 updates module frame ID Module_CFRMID—4 to ‘3’ and transmits the updated module frame ID Module_CFRMID—4 and a P4 work-done signal P4_done to the system control logic 230.
The system control logic 230 compares the module frame ID Module_CFRMID—4 and the recent frame ID RRFRMID with each other. When the module frame ID Module_CFRMID—4 and the recent frame ID RRFRMID are the same, the system control logic 230 may control the frame synchronization manager 330 of the steam processing module P4 to determine that processing of data of a third frame is to be started.
However, when the module frame ID Module_CFRMID—4 is greater than the recent frame ID RRFRMID, the main SFR 220 should be updated. That is, in order to allow the stream processing module P4 to process the data of the third frame, first, the frame synchronization information stored in the main SFR 220 should be updated to correspond to the third frame. Since the main SFR 220 stores the recent frame ID RRFRMID, i.e., the frame synchronization information corresponding to the second frame, the system control logic 230 determines that the main SFR 220 should be updated.
The system control logic 230 checks whether each of the stream processing modules P1 to P4 receives and stores the frame synchronization information corresponding to the second frame, before the main SFR 220 is updated. For example, when touch values Touch of respective processing modules are logic high, a pulse may be generated in all touch signals all_touch. The system control logic 230 determines that the respective stream processing modules P1 to P4 receive and store the frame synchronization information corresponding to the second frame based on the pulse, and transmits an SFR update signal SFR_update to the main SFR 220. The main SFR 220 receives SFR update data SFR_update_data from the outside according to the SFR update signal SFR_update. The main SFR 220 stores a next recent frame ID Next_RRFRMID, i.e., the frame synchronization information corresponding to the third frame, which is included in the SFR update data SFR_update_data.
Then, the main SFR 220 receives a recent frame ID update signal RRFRMID_update and a next recent frame ID Next_RRFRMID from the system control logic 230, and updates the recent frame ID RRFRMID to the next RRFRMID Next_RRFRMID according to the recent frame ID update signal RRFRMID_update. Thus, since both the module frame ID Module_CFRMID—4 and the recent frame ID RRFRMID become ‘3’, the stream processing module P4 may receive the frame synchronization information corresponding to the third frame from the main SFR 220, and process the data of the third frame.
By using the starter module 240, module frame IDs of the respective processing modules P4, P3, P2, and P1 are set to ‘0’ and processing of a frame 0 starts.
Each of frames may include a plurality of pixels, e.g., 1920×1080 pixels. In one embodiment, each of the processing modules P4, P3, P2, and P1 may process all the plurality of pixels that form one frame. In another embodiment, each of the processing modules P4, P3, P2, and P1 may process only pixels within a specific window in each of the frames. For example, each of the processing modules P4, P3, P2, and P1 may process less than the entire frame (i.e., a part of a frame).
Each of the processing modules P4, P3, P2, and P1 stores frame synchronization information FRAME_SYNC_INFO corresponding to module frame ID Module_CFRMID. Each of the processing modules P4, P3, P2, and P1 receives data from the outside or data processed by a producer thereof in units of pixels, and processes the data received in units of pixels, based on the frame synchronization information FRAME_SYNC_INFO. Thus, the processing modules P4, P3, P2, and P1 may simultaneously process data of the same frame.
When the processing module P4 completes processing of data of the frame 0 (1), the processing module P4 updates module frame ID Module_CFRMID—4 to ‘1’, and transmits an updating result to the system control logic 230. In this case, the recent frame ID RRFRMID is ‘0’.
The system control logic 230 determines whether all the stream processing modules P4 to P1 receive frame synchronization information FRAME_SYNC_INFO corresponding to the frame 0, since the module frame ID Module_CFRMID—4 is greater than the recent frame ID RRFRMID. The processing module P4 completes the processing of the data of the frame 0, and all the other stream processing modules P3, P2, and P1 process the data of the frame 0 by receiving the frame synchronization information FRAME_SYNC_INFO corresponding to the frame 0.
Thus, the system control logic 230 generates an SFR update signal SFR_update, and the main SFR 220 updates the frame synchronization information FRAME_SYNC_INFO and then increases the recent frame ID RRFRMID to ‘1’ according to the SFR update signal SFR_update. Thus, since module frame ID Module_CFRMID—4 becomes equal to the recent frame ID RRFRMID, the processing module P4 receives frame synchronization information FRAME_SYNC_INFO—4 from the main SFR 220 and starts processing of data of a frame 1 (2).
After the processing module P2 completes the processing of the data of the frame 0 (3), the processing module P2 updates module frame ID Module_CFRMID—2 to ‘1’ and transmits an updating result to the system control logic 230. Since the module frame ID Module_CFRMID—2 becomes equal to the recent frame ID RRFRMID, the processing module P2 receives the frame synchronization information FRAME_SYNC_INFO—2 from the main SFR 220 and starts processing of data of the frame 1 (4).
A case in which the processing module P4 completes processing of the data of the frame 0 to data of a frame 2 (5) will now be described. The processing module P4 updates the module frame ID Module_CFRMID—4 to ‘3’ and transmits an updating result to the system control logic 230. In this case, the recent frame ID RRFRMID is ‘2’.
The system control logic 230 determines whether all the stream processing modules P4 to P1 receive frame synchronization information FRAME_SYNC_INFO corresponding to the frame 2, since the module frame ID Module_CFRMID_4 is greater than the recent frame ID RRFRMID. The processing module P1 is processing the data of the frame 1 and has yet to receive frame synchronization information FRAME_SYNC_INFO—1 corresponding to the frame 2. Thus, the system control logic 230 stands by until the processing module P1 receives the frame synchronization information FRAME_SYNC_INFO—1 corresponding to the frame 2.
When an operation of the processing module P1 starts (6), i.e., when module processing signal Module_Processing—1 transmitted to the system control logic 230 by the processing module P1 changes from logic low to logic high, the system control logic 230 determines that the processing module P1 receives the frame synchronization information FRAME_SYNC_INFO—1 corresponding to the frame 2. Since all the stream processing modules P4, P3, P2, and P1 receive the frame synchronization information FRAME_SYNC_INFO—1 corresponding to the frame 2, the system control logic 230 generates the SFR update signal SFR_update.
The main SFR 220 updates the frame synchronization information FRAME_SYNC_INFO and increases the recent frame ID RRFRMID to ‘3’ according to the SFR update signal SFR update. Thus, since the module frame ID Module_CFRMID—4 becomes equal to the recent frame ID RRFRMID, the processing module P4 receives the frame synchronization information FRAME_SYNC_INFO—4 from the main SFR 220 and starts processing of data of a frame 3 (7).
Referring to
Only after all the stream processing modules P4, P3, P2, and P1 complete processing of data of a frame 0, the main SFR 220 receives frame synchronization information corresponding to a frame 1 and the stream processing modules P4, P3, P2, and P1 start processing of the frame 1.
Thus, it is inefficient that the processing module P4 should stand by until the processing modules P3, P2, and P1 complete the processing of the data of the frame 0, even when the processing module P4 first completes the processing of the data of the frame 0. Also, since all the stream processing modules P4, P3, P2, and P1 start operations thereof at the same time after the main SFR 220 is updated, many data requests are concentrated to an external system (e.g., a bus, a memory, etc.) at once. Thus, the quality of service (QoS) of the whole system is degraded and a large capacity buffer is required to store data received at once.
In at least one embodiment of the inventive concept, the processing modules P4, P3, P2, and P1 individually store frame synchronization information and operate in synchronization with module frame IDs Module_CFRMID thereof, instead of the vertical synchronization signal VSYNC.
Accordingly, the processing modules P4, P3, P2, and P1 may be independently power/clock-gated, and a clock tree for each of the processing modules P4, P3, P2, and P1 thus decreases, thereby reducing power consumed to toggle the clock tree. Also, the system can be efficiently designed in terms of power consumption since the processing modules P4, P3, P2, and P1 may be power/clock-gated regardless of states of the other processing modules, and the system design may be easily modified since the processing modules P4, P3, P2 and P1 are independent from one another.
Also, since the processing module P4 does not stand by and may continuously process data, system inefficiency can be removed. Furthermore, since the stream processing modules P4, P3, P2, and P1 may start processing of a subsequent frame at different points of time after processing of a current frame ends, the amount of data requested to an external system at once decreases, thereby improving the QoS of the whole system. Also, since a large capacity buffer is not needed, an area of a SoC can be reduced.
The non-frame synchronization SFR 410 stores input non-frame synchronization information NFS_data received from the outside. The non-frame synchronization SFR 410 transmits the received input non-frame synchronization information NFS_data as non-frame synchronization information NON_FRAME_SYNC_INFO to the data processing logic 310 of each of the stream processing modules 210.
The frame synchronization SFR 420 includes a shadow register 421 and an operational register 423.
The shadow register 421 may receive input frame synchronization information FS_data corresponding to one frame several times from the outside, and store this information. When an SFR update signal SFR_update is generated, the shadow register 421 may output input frame synchronization information FS_data corresponding to one stored frame as frame synchronization information FRAME_SYNC_INFO to the operational register 423.
The operational register 423 stores the frame synchronization information FRAME_SYNC_INFO corresponding to the one stored frame. The operational register 423 may output the frame synchronization information FRAME_SYNC_INFO to the frame SFRs 340 of the stream processing modules 211, under control of the system control logic 230.
The data processing logic 310 of each of the stream processing modules 211 may process data in units of frames, based on the non-frame synchronization information NON_FRAME_SYNC_INFO received from the non-frame synchronization SFR 410 and the frame synchronization information FRAME_SYNC_INFO received from the operational register 423.
The CFRMID_SFR 430 may store a current frame ID CFRMID. The CFRMID_SFR 430 may receive a next module frame ID Next_CFRMID and a current frame ID update signal CFRMID_update from the system control logic 230. The CFRMID_SFR 430 may update a current frame ID CFRMID to the next module frame ID Next_CFRMID according to the current frame ID update signal CFRMID_update.
The RRFRMID_SFR 440 may store a recent frame ID RRFRMID. The RRFRMID_SFR 440 may receive the next module frame ID Next_RRFRMID and the recent frame ID update signal RRFRMID_update from the system control logic 230. The RRFRMID_SFR 440 may update the recent frame ID RRFRMID to the next module frame ID Next_RRFRMID according to the recent frame ID update signal RRFRMID_update.
If it is assumed that in an embodiment of the inventive concept, an nth processing module 211-n first processes data of a frame 0 and a pulse PS3 occurs in an SFR update signal SFR update, the nth processing module 211-n receives data from the outside and the main SFR 220 receives frame synchronization information in a third section. Then, in a fourth section, the nth processing module 211-n processes data of a frame 1. Since one of the processing modules 211 processes the data of the frame 1 and a pulse PS4 occurs in the SFR update signal SFR_update, the data does not need to be received from the outside within a short time, thereby improving the QoS of the whole system.
It is assumed that an input is received from a user at a point of time t. The user may desire to change the resolution of an output image, for example, from 1024×768 to 768×1024. When the processing modules 211 process data in synchronization with the vertical synchronization signal VSYNC, the frame synchronization information of the main SFR 220 is updated in the first section and the user input may thus be reflected starting from when the frame 1 is processed.
In an embodiment of the inventive concept, the pulse PS3 is generated right after a processing module processes the data of the frame 0, and is thus generated earlier than the pulse PS1 of the vertical synchronization signal VSYNC. In this case, since frame synchronization information corresponding to the frame 1 is updated in the main SFR 220 in the third section, information input from a user at the point of time t is not reflected when the frame 1 is processed and is reflected starting from when a frame 2 is processed. Thus, a user may perceive a slow response rate.
The system logic 230 may generate an SFR delayed update signal SFR_update_delayed obtained by delaying pulses of the SFR update signal SFR_update for a delay time Delay_time to improve the response rate. The delay time Delay_time may be a constant or may be a value that varies according to user settings. The nth processing module 211-n may receive data from the outside in a fifth section and may process the data of the frame 1 in a sixth section, according to the SFR delayed update signal SFR_update_delayed. In this case, the frame synchronization information corresponding to the frame 1 is updated in the main SFR 220 in the fifth section and the user input received at the point of time t may be reflected starting from when the frame 1 is processed.
In at least one embodiment of the inventive concept, the processing modules 210 processes at least two frames at the same time. However, the scope of the inventive concept may be expanded to a case in which the processing modules 210 process more than two frames at the same time.
In this case, the recent frame ID RRFRMID may be (the current frame ID CFRMID+(n−1)). The frame SFRs 340 of the respective processing modules 210 may store frame synchronization information corresponding to (n−1) frames. For example, the frame SFRs 340 of the respective processing modules 210 may store frame synchronization information corresponding to a CFRMID frame to a RRFRMID-1 frame, and update the frame synchronization information corresponding to the CFRMID frame to the frame synchronization information corresponding to the RRFRMID frame when processing of the CFRMID frame is completed.
The system control logic 230 may store module frame IDs Module_CFRMID of the respective processing modules 211, module enable signals Module_Enable corresponding to respective n frames, and touch values Touch corresponding to (n−1) frames, that is, a CFRMID frame to a RRFRMID-1 frame. The system control logic 230 may determine a point of time that values of the CFRMID and RRFRMID frames are to be updated, based on the module frame IDs Module_CFRMID, the module enable signals Module_Enable, and the touch values Touch.
Referring to
Then, each of the processing modules 211-1 to 211-n processes data in units of frames, based on the stored frame synchronization information FRAME_SYNC_INFO (S503).
The SoC 100 may control the operation of at least one of the elements 160, 187, 195, 620 and 630. The power source 160 may supply an operating voltage to at least one of the elements 187, 195, 620 and 630.
The I/O devices 187 may be devices that receive data transmitted to the electronic system 10 or transmit data from the electronic system 10 to an external device, through respective ports.
The expansion card 630 may be implemented as a secure digital (SD) card or a multimedia card (MMC). The expansion card 630 may be a subscriber identity module (SIM) card or a universal SIM (USIM) card.
The network device 620 enables the electronic system 10 to be connected with a wired or wireless network. The display device 195 displays data output from the I/O devices 187, the expansion card 630, or the network device 620.
The camera module 610 converts optical images into electrical images. Accordingly, the electrical images output from the camera module 610 may be stored in the SoC 100 or the expansion card 630. Also, the electrical images output from the camera module 610 may be displayed through the display device 195. The camera module 610 includes an image sensor.
According to at least one exemplary embodiment of the inventive concept, a plurality of pieces of synchronization information that a plurality of modules require, respectively, may be overlapped with respect to the plurality of modules, thereby reducing power consumption in a multimedia system and improving the performance of the multimedia system.
While the inventive concept has been particularly shown and described with reference to exemplary embodiments thereof, it will be understood that various changes in form and details may be made therein without departing from the spirit and scope of the inventive concept.
Number | Date | Country | Kind |
---|---|---|---|
10-2013-0028336 | Mar 2013 | KR | national |