1. Field of the Invention
The present invention relates to a technique for realizing power saving in a data processing apparatus.
2. Description of the Related Art
Heretofore, LSIs used in data processing have been focused on more for their processing speed and other capabilities rather than their power consumption. However, in recent years, following increases in the speed and integration density of LSIs, the importance of techniques for reducing power consumption has been increasing, in order to suppress the power consumption of the overall chip.
One way of realizing reduced power consumption in LSIs that has been proposed involves stopping supply of the clock signal during periods in which processing modules do not need to be operated. For example, a circuit disclosed in Japanese Patent Laid-Open No. 08-054954 (Document 1) detects input of data to a processing circuit, and supplies a clock for a preset period that is long enough for the processing circuit to process the input data. Unnecessary power consumption is then reduced in periods other than when processing is performed by lowering the clock frequency.
However, with the technology set forth in the abovementioned Document 1, there is a problem in that although clock supply can be performed for a stipulated period with respect to input data of a predetermined data length, processing cannot be flexibly performed on input data of variable length.
The present invention provides a data processing apparatus capable of favorably processing variable-length input data.
According to one aspect of the present invention, a data processing apparatus comprises: a receiving unit configured to receive input data including processing-target data from outside; a measuring unit configured to measure a data amount of the processing-target data included in the received input data; a data processing unit configured to perform predetermined processing on the processing-target data, and to output a result of the processing as output data; and a control unit configured to set the data processing unit to an active state by starting supply of a clock to the data processing unit based on reception of the input data by the receiving unit, and when a data amount of the output data reaches a data amount of data obtained by performing the predetermined processing on data of the data amount measured by the measuring unit, to set the data processing unit to a sleep state in which power consumption is less than in the active state by stopping supply of the clock to the data processing unit.
According to another aspect of the present invention, a data processing apparatus comprises: a receiving unit configured to receive input data including processing-target data from outside; a measuring unit configured to measure a data amount of the processing-target data included in the received input data; a data processing unit configured to perform predetermined processing on the processing-target data, and to output a result of the processing as output data; and a control unit configured to set the data processing unit to an active state by supplying a first voltage to the data processing unit based on reception of the input data by the receiving unit, and when a data amount of the output data reaches a data amount of data obtained by performing the predetermined processing on data of the data amount measured by the measuring unit, to set the data processing unit to a sleep state in which power consumption is less than in the active state by supplying a second voltage that is lower than the first voltage to the data processing unit.
Further features of the present invention will become apparent from the following description of exemplary embodiments (with reference to the attached drawings).
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention.
Hereinafter, operations relating to the various functions of the block diagram shown in
The processing circuit 1 can now receive input of input data 206, and an input permission signal 204 is assumed to be in an “H” state. Accordingly, because the input request signal 205 and the input permission signal 204 have both been asserted to “H”, an input detection unit (AND circuit) 14 outputs it's output as an input request detection signal after setting the output to “H” when triggered by the assertion of these signals. Based on this input request detection signal, a latch circuit 12 outputs a latch output signal 202 at “H”.
Following the output of this latch circuit 12, a clock stopping unit 11 lifts a measure stopping the clock of a reference clock signal 201 for supplying to a processing circuit module 16, and resumes clock supply and supplies an operation clock 203 at time t1. A count unit 13, in response to the output of the input detection unit 14 being asserted to “H”, starts counting up at time t1. Counter data is counted up from an initial value 0 to 1, and an Up signal 210 changes to “H”. As a result, a “Zero signal” 213 is de-asserted and reverts to zero, indicating that there is unprocessed data. The latch circuit 12 should of course be configured such that the output signal from the input detection unit 14 is prioritized over the “Zero signal” output from the count unit 13.
Data is input at times t2, t3 and t4, and counter data 212 increases and accumulates by 1 per input. Meanwhile, data processed and output by this processing module is output at a delay from the input by a period that depends on the processing in the processing module. In the example in
In this example, the input request signal 205 informs the input detection unit 14 of the end of input data 206 by changing to “L” at time t4 in order to cancel the input request. The output of the input detection unit 14 changes to “L” as a result of the input request signal 205 changing to “L”. At time t5, the output permission signal 207 changes to “H”, and a Down signal 211 of the count unit 13 changes to “H”, activating counting down.
In
As described above, clock supply to the data processing circuit is started as a result of the input request signal from the pre-processing circuit changing to “H”. The data length (data amount) of input data is then counted up for the duration that the input request signal is “H”, and countdown is activated at the point in time at which the input request signal changes to “L” and the input data ends. Countdown is then performed by 1 from the accumulated value every time data is output after the processing of the data processing circuit has ended, and clock supply is stopped at the point in time at which the count reaches zero.
Controlling clock supply to the data processing circuit in this way produces the effect of activating the processing module for only the period required for data processing on variable-length (variable-amount) input data, and reducing unnecessary power consumption by placing the data processing circuit in a sleep state for the remaining time.
the FIFO 15 was not included in the clock supply/stop control target range, but in another exemplary Embodiment, the clock supply/stop control target range is expanded to include the FIFO.
In this Embodiment, because the clock is not constantly supplied, unlike the FIFO 15, input data cannot be stored until the operation clock is supplied to the data processing circuit 36. Accordingly, with regard to the head data of the input data, it is necessary for the same data to be supplied and the head data to be reliably input until the data processing circuit 36 and the pre-processing circuit are activated by being supplied with the operation clock.
In this Embodiment, the operation clock is thus supplied at the same time to a range including the FIFO and the data processing circuit described in
In
Following the start of clock supply and the assertion of the input request signal 405, an input permission signal 404 is asserted at time t2, and reception of input data 406 starts at time t3. Following this, the count value of the count unit 13 increases, and the Zero signal is de-asserted from t3.
The input request signal 405 is de-asserted to “L” at t6, which is when the required number of data outputs is completed. In response to this de-assertion, the input permission signal 404 is de-asserted to “L” at time t7.
As described above, clock supply to the data processing circuit is started as a result of the head data of input data being continuously transmitted until the input request signal from the pre-processing circuit changes to “H” and the clock is supplied to the buffer upstream of the data processing circuit. The data length of input data is counted up for the duration that the input request signal is “H”, and countdown is activated at the point in time at which the input request signal changes to “L” and input data ends. Countdown is thereby performed per data output after processing by the data processing circuit has ended, and clock supply is stopped at the point in time at which the count reaches zero.
Performing control of clock supply on a circuit range that includes processing upstream of the data processing circuit in this way produces the effect of activating the processing module for only the period required for data processing on the variable-length input data, and reducing unnecessary power consumption.
In another Embodiment, an example will be shown in the case where the present invention is applied to a circuit other than an image processing circuit.
In
A pre-processing circuit for writing data to the input buffer 55 finishes writing the required number of data (in this example, the number of data is 1), and de-asserts the input request signal 605 at t3. Because the input request signal 605 and the input permission signal 604 are both asserted (“H”), the count value of the count unit 13 is counted up from 0 to 1, and the Zero signal is de-asserted (“L”) at the same timing.
Meanwhile, the transmission circuit 56 for serial communication waits without performing output until an output permission signal 607 of the other communication party is asserted (“H”), and starts output from t6 after confirming output permission from the other communication party at t5. In the present embodiment, serial communication is depicted with the start bit and the stop bit both being 1 bit. The transmission circuit 56 outputs transmission data per bit from t8 after outputting the start bit at t6 and t7.
After the last bit output has been performed at tn+2, the transmission circuit 56 starts transmission of the stop bit, and outputs a Down signal indicating the transmission end of one piece of data at tn+3 at the end of the stop bit. In response to this output, the count unit 13 returns the count value from 1 to 0, and the Zero signal is asserted (“H”) as a result. In response to the assertion (“H”) of the Zero signal, the latch output signal is de-asserted (“L”), and the clock stopping unit 11 thereby stops clock supply of the operation clock signal from tn+5.
In this Embodiment, control of clock supply is performed in this way on a circuit range that includes processing upstream of a serial data transmission circuit using start and stop bits. The effect is thus produced of being able to activate the processing module for only the period required for data processing on the variable-length data, and reducing unnecessary power consumption.
In another Embodiment, an example will be described in which the present invention is applied to a processing circuit in which the ratio of the number of input data to the number of output data is uniquely determined to be 1 to N, where N is a positive integer. That is, similarly to the above embodiments, the input data amount can be measured by a counter, and the clock can be stopped when the data amount of output data reaches 1/N after predetermined data processing. The above embodiments were equivalent to the case where N=1.
This example is shown in
In
Following the assertion (“H”) of the latch signal, clock supply of an operation clock signal 803 to the blocks in the range indicated by a clock control range 79 is started at t1. Following the start of clock supply of the operation clock signal 803 and the assertion (“H”) of the input request signal 805, the input permission signal 804 is asserted (“H”) at t2, and reception of eight pieces of data is started at t3. Following this, the count value of a count unit 73 increases, and a Zero signal 813 is de-asserted (“L”) at t3.
Counter data 812 of the count unit 73 is counted up from t3 to t9. Meanwhile, four pieces of output data are output continuously from t9. The counter data 812 of the count unit 73 is thereby counted down from the accumulated value every N (=2) pieces, and returns to 0 at t13, following which the Zero signal is asserted (“H”), and clock supply to the operation clock stop target circuit range 79 is stopped at t14.
An actual count unit is realizable as a result of the count unit 73 and a coefficient unit 78 in
At step S903, it is judged whether the Up signal is L and the Down signal is H. If Yes, the processing proceeds to step S905. If No, the processing proceeds to step S904. At step S904, it is judged whether the Up signal is H and the Down signal is L. If Yes, the processing proceeds to step S906. If No, the processing returns to step S902. At step S905, 2 is subtracted from the count value, and the processing returns to step S902. At step S906, 1 is added to the count value, and the processing returns to step S902. At step S907, 1 is subtracted from the count value, and the processing returns to step S902.
In the present embodiment, an example of a processing circuit was shown in which the coefficient unit is applied on the output side, and the relation of the number of input data to the number of output data is uniquely determined, but the coefficient unit can also be applied on the input side or on both the input and output sides depending on the processing content. That is, the present invention can also be applied to the case where the ratio of input data to output data is 1 to N, where N is a positive integer, and the amount of output data processed is greater than the amount of input data.
The present invention is in this way able to expand the applicable range to an arbitrary processing circuit in which the relation of the number of input data to the number of output data is uniquely determined.
Also, a timing chart example illustrating circuit operations in the present embodiment is shown in
In response to the assertion (“H”) of the control signal from the latch circuit 12 and the voltage control unit 99 returning a supply voltage 1103 of the power saving control target circuit range 98 to the active mode voltage, the clock stopping unit 11 asserts a clock control signal 1105 (t2 in
In response to the assertion (“H”) of the clock control signal 1105, a clock output signal is asserted. The clock output signal 1106 can be configured by receiving the clock control signal 1105 with the latch circuit. The clock output signal 1106 is asserted (“H”), and operation clock supply to the power saving control target circuit range 98 is started (t3). The input buffer 35 asserts (“H”) an input permission signal 1108 at t4 following the clock supply start of the operation clock signal and the assertion (“H”) of an input request signal 1109, and starts import of input data. Following this, the count unit 13 performs count up, counter data 1116 is counted up, and a Zero signal 1117 is de-asserted (“L”) (t5).
Output of output data 1113, which is the processing result output, is started from t8, and following this, the count unit 13 performs countdown, the counter data 1116 of the count unit 13 returns to 0 at t12, and the Zero signal 1117 is de-asserted (“L”). In response to the de-assertion of the Zero signal 1117, the clock stopping unit 11 de-asserts (“L”) the clock control signal 1105, after which an end signal 1104 is asserted (“H”) with respect to a reset input of the latch circuit 12, in order to set the voltage control unit 99 to the sleep voltage. As a result of the assertion (“H”) of the end signal 1104, the latch circuit 12 de-asserts (“L”) a voltage control signal 1102, and the voltage control unit 99 switches the supply voltage 1103 to the power saving control target circuit range 98 to the sleep mode voltage.
The clock stopping unit 11 complying with the timing chart of
Also, in the “sleep state” 1201, the end signal and the clock control signal are both set to 0. When voltage control is asserted, the state moves to “power return standby” 1202. In this state, the value of the timer counter is increased by 1 per clock, while waiting for a preset time to elapse. At the point in time at which the value of the timer counter reaches the set value, the state moves to an “active state” 1203. In this state, clock supply is performed in order to operate the processing circuit, and the clock control signal is asserted from the time of state transition. A condition for moving from the “active state” 1203 to the “sleep state” 1201 is the Zero signal being asserted, at which time the end signal is asserted, and the clock control signal is de-asserted.
Also, the specific configuration for clock stoppage shown in
A specific example of an actual voltage control circuit is realizable with a switch circuit 1401 such as shown in
As described above, by adopting the configuration of this Embodiment, an effect can be produced of enabling unnecessary power consumption to be further reduced by also controlling the supply voltage to the processing module, in addition to the clock control optimized for input of input data and output thereof.
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2009-285742, filed Dec. 16, 2009, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2009-285742 | Dec 2009 | JP | national |