This application claims the priority benefit of Taiwan application serial no. 96109298, filed Mar. 19, 2007. All disclosure of the Taiwan application is incorporated herein by reference.
1. Field of the Invention
The present invention relates to bus encoding and decoding, and more particularly to encoding and decoding of discontinuous bus data.
2. Description of Related Art
In a computer system, various devices transmit data among each other through buses. The data passes through the bus at an extremely high rate, such that the status of bus lines is rapidly converted between 0 and 1. The bus line transition between 0 and 1 results in charging or discharging of bus wires, and the capacitance value of a system bus is hundreds of times of, even thousands of times of, that of an internal logic circuit. Therefore, the bus is highly power-consuming in the system, and the power consumed during data transmission is substantially in direct proportion to the number of bus line bit-transitions.
For the purpose of power saving, the number of bus line bit-transitions must be reduced, and the most efficient way is bus encoding. As long as a receiver decodes the transmitted data correctly, a transmitter can encode the data into forms that result in fewer bus line bit-transitions. Taking an instruction address bus which transmits instruction addresses for example. Since most program instructions are sequentially executed, consecutive addresses appear on the bus. The encoder may apply Gray Code to make the consecutive addresses differ form each other for only one bit after encoding, thereby greatly reducing the electricity consumed by data transmission.
However, the bus transmits not only consecutive data, but also discontinuous data. For example, branch instructions might cause instruction addresses being discontinuous. Up to the present, various technologies have been developed to encode consecutive bus data to reduce the the number of bus line bit-transitions, such as Gray Code, Zero-Transition (T0), and burst mode. However, we still needs a solution to encode discontinuous bus data to reduce the the number of bus line bit-transitions.
The present invention is directed to a method and an apparatus for bus encoding, which encodes discontinuous bus data to reduce the number of bus line bit-transitions.
The present invention is directed to a method and an apparatus for bus decoding, which decodes discontinuous bus data together with the aforementioned encoding method and apparatus, so as to reduce the number of bus line bit-transitions.
The present invention provides an apparatus for bus encoding, which includes a discontinuous pattern encoder, a consecutive pattern encoder, and a data transmitter. A discontinuous pattern table (DPT), which is built in the discontinuous pattern encoder, stores indices and data in pairs. If a previous data (data transmitted last time) and a current data (data to be transmitted this time) are discontinuous, and the DPT does not contain an index the same as the previous data, the discontinuous pattern encoder pairs the previous data and the current data up and stores them into the DPT by taking the previous data as an index. If the DPT contains the index the same as the previous data, the discontinuous pattern encoder outputs data corresponding to the previous data. The consecutive pattern encoder encodes the current data through the consecutive data encoding method, and outputs an encoding result. The data transmitter is coupled to the discontinuous pattern encoder, the consecutive pattern encoder, a bus, and a control line. If the current data is equal to outputted data of the discontinuous pattern encoder, the data transmitter asserts the control line and freezes the bus (which means that the statuses of all the bus wires are kept the same); otherwise, the control line is de-asserted, and the encoding result of the consecutive pattern encoder is outputted to the bus.
The present invention further provides an apparatus for bus decoding, which includes a discontinuous pattern decoder, a consecutive pattern decoder, and a data receiver. A DPT, which is built in the discontinuous pattern decoder, stores indices and data in pairs. If the DPT contains the index the same as previous data (the data received last time), the discontinuous pattern decoder outputs data corresponding to the previous data. The consecutive pattern decoder is coupled to a bus, so as to decode an input from the bus through the consecutive data decoding method and to output the decoded data. The data receiver is coupled to the discontinuous pattern decoder, the consecutive pattern decoder, the bus, and a control line. If the control line is asserted, the data receiver outputs the output data of the discontinuous pattern decoder and takes it as the current data; otherwise, the data receiver outputs the output data of the consecutive pattern decoder and takes it as the current data. Subsequently, if the previous data and the current data are discontinuous, and the DPT does not contain the index the same as the previous data, the discontinuous pattern decoder pairs the previous data and the current data up and stores them into the DPT by taking the previous data as an index.
The present invention further provides a method for bus encoding, which includes steps as follows. (a) Use a DPT to store indices and data in pairs. (b) If the DPT contains an index the same as the previous data, it outputs data corresponding to the previous data. (c) Consecutive pattern encoder encodes the current data using the consecutive data encoding method, and outputs the encoding result. (d) If the current data is equal to the output data in Step (b), a control line is asserted and the bus is frozen; otherwise, the control line is de-asserted, and the encoding result in Step (c) is outputted to the bus. (e) If the previous data and the current data are discontinuous and the DPT does not contain an index the same as the previous data, the previous data and the current data are paired up and stored in the DPT by taking the previous data as an index.
The present invention further provides a method for bus decoding, which includes the steps as follows. (a) Use a DPT to store indices and data in pairs. (b) If the DPT contains an index the same as the previous data, it outputs data corresponding to the previous data. (c) Consecutive pattern decoder decodes the input from the bus using the consecutive data decoding method, and outputs the decoded data. (d) If a control line is asserted, the output data in Step (b) is outputted as the current data; otherwise, the output data in Step (c) is outputted as the current data. (e) If the previous data and the current data are discontinuous and the DPT does not contain an index the same as the previous data, the previous data and the current data are paired up and stored into the DPT by taking the previous data as an index.
The apparatus and method for bus encoding/decoding provided by the present invention employ the DPT to store discontinuous pattern pairs. Both transmitter and receiver have to keep the synchronization of the discontinuous pattern tables (DPT) at any moment. After transmitting the first data (the index) of a discontinuous pattern pair, the second could be transmitted by merely informing a receiving end through a control line instead of transmitting the second data by the bus. In this manner, not only the power consumption of the bus, but also the wasted heat generated by the system is reduced.
In order to make the aforementioned and other objects, features, and advantages of the present invention comprehensible, preferred embodiments accompanied with figures are described in detail below.
It is to be understood that both the foregoing general description and the following detailed description are exemplary, and are intended to provide further explanation of the invention as claimed.
The accompanying drawings are included to provide a further understanding of the invention, and are incorporated in and constitute a part of this specification. The drawings illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention.
The encoding apparatus, the decoding apparatus, the encoding method, and the decoding method provided by the present invention focus on data transmitted on the bus. For example, the data transmitted on the instruction address bus are instruction addresses. Moreover, the object of encoding and decoding in the present invention is a piece of data that transmitted through the bus in one time.
The data on the bus can be classified into consecutive data and discontinuous data. The so-called consecutive data is arithmetic sequence with a constant difference of a predetermined value among each other. Taking an instruction address bus for example, the addresses of sequentially executed instructions are consecutive data, and the address of the branch instruction and its target address are discontinuous data. Due to the locality of the program execution, it is quite probably that the branch instructions are executed repeatedly, thereby causing the discontinuous data to appear repeatedly. According to the repeatedly-appearing characteristic, the present invention provides a method for encoding and decoding discontinuous data and a corresponding apparatus used for implementing the method.
In this embodiment, the consecutive data is encoded through Zero-Transition (T0), and the discontinuous data is encoded through the DPT provided by the present invention. The DPT which stores discontinuous pattern pairs is as shown in the following Table 1. In Table 1, the first data pair is (0008, 0100), and the second data pair is (0108, 0000). Each data pair includes two data sequentially appeared on the bus. Pi represents the first one; Pi+1 represents the second. When looking up the DPT, Pi+1 in the same pair can be looked up by taking Pi as an index, and thus, Pi+1 is called a data corresponding to Pi.
The functions of the control lines CLD and CLT are shown in Table 2 below. When the control line CLD is asserted (for example, the voltage is at a potential of logic 1), it represents that the bus data is encoded through the DPT. When the control line CLD is de-asserted (for example, the voltage is at a potential of logic 0), and the control line CLT is asserted, it represents that the bus data is encoded through Zero-Transition. When the control lines CLD and CLT are both de-asserted, it represents that the original data without being encoded is transmitted on the bus. Of course, the present invention is not limited to the above definition, but focuses on notifying the receiver end whether the data being transmitted had been encoded or not and which encoding method was adopted. The number of control lines and arrangement of the statuses of control lines may be adjusted upon actual requirements. For example, in other embodiments, the consecutive data encoding methods, other than T0, may be used, and meanwhile, the control lines must be adjusted correspondingly.
Firstly, the first data 0000 does not have a previous data for reference and must be transmitted directly. Next, the data 0004 and 0008 are consecutive data, which can be encoded through Zero-Transition. The receiver end is informed through the control line CLT, instead of transmitting through the bus. i.e., it is not necessary to change the status of the bus. Once being informed that the control line CLD is 0 and the CLT is 1, the receiver end determines that the encoding method is Zero-Transition, and obtains the current data by adding four to the previous data that was transmitted last time.
The next data 0100 is a discontinuous data which appears for the first time and forms a data pair (0008, 0100) with the previous data. So the data 0100 must be transmitted directly. In addition, (0008, 0100) must be inserted into the DPT, as shown by the dashed arrow in
The next data 0104 and 0108 are consecutive data, and also encoded through Zero-Transition, which can be achieved merely by informing the receiver end through the control line CLT.
The next data 0000 is also a discontinuous data which appears for the first time and forms a data pair (0108, 0000) with the previous data. So the data 0000 must be transmitted directly, and (0108, 0000) is inserted into the DPT, as shown by the dashed arrow in
The next data 0004 and 0008 are both consecutive data, and also encoded through Zero-Transition, which can be achieved merely by informing the receiver end through the control line CLT.
The next discontinuous data 0100 forms a data pair (0008, 0100) with the previous data, and the data pair (0008, 0100) has already existed in the DPT, as shown by the solid arrow in
The next data 0104, 0108, and 010C are all consecutive data, and also encoded through the Zero-Transition, which can be achieved by merely informing the receiver end through the control line CLT.
The paradigm in
The bus encoding apparatus 115 will be illustrated in detail with reference to
In the part of the discontinuous data, firstly, a DPT is provided to store indices and data in pairs (Step 405), and the DPT is stored in the table storage 324. Each time when the bus encoding apparatus 115 receives the data 301 to be transmitted currently, the table lookup unit 322 receives the previous data transmitted last time from the data storage 321. And then the table lookup unit 322 looks up the DPT in the table storage 324 by taking the previous data as an index (Step 410). If the DPT contains an index the same as the previous data, the table lookup unit 322 outputs data corresponding to the previous data (Step 420); otherwise, a “not-found” signal is outputted (Step 415).
In another aspect, in the part of the consecutive data, the consecutive pattern encoder 330 encodes the current data 301 through the Zero-Transition and outputs an encoded result (Step 425). Besides the Zero-Transition, the consecutive pattern encoder 330 may use any other consecutive data encoding method, such as Gray Code or burst mode. All encoding methods can be used by the consecutive pattern encoder 330, as long as they are helpful for reducing the number of bus line bit-transitions when the data is being transmitted.
The data transmitter 340 is coupled to the table lookup unit 322, the consecutive pattern encoder 330, the bus 130, and the control lines CLD and CLT. The data transmitter 340 receives the current data 301, the outputs of the table lookup unit 322, and the consecutive pattern encoder 330. And then, determine whether the current data 301 is the same as the corresponding data outputted from the table lookup unit 322 (Step 430). If the current data 301 is the same as the corresponding data, the data transmitter 340 asserts the control line CLD and freezes the bus 130 (Step 440). The “freezing” herein refers that all statuses of the bus lines 130 are maintained to be unchanged, i.e., no bit-transitions. If the current data 301 is not the same as the corresponding data in Step 430, the data transmitter 340 de-asserts the control line CLD and outputs the encoding result of the consecutive pattern encoder 330 to the bus 130 (Step 435). The consecutive pattern encoder 330 in this embodiment uses the bus 130 and the control line CLT to output the encoding result of the Zero-Transition, as shown in the paradigm in
Next, the table updater 323 inspects whether the current data 301 and the previous data from the data storage 321 are consecutive (Step 445). If they are consecutive data, the flow in
Finally, the data storage 321 receives and stores the current data 301 to act as the previous data in the next encoding (Step 465). The bus encoding apparatus 115 has finished the encoding and transmission of the current data 301. And then, the next data may be processed in sequence.
The bus decoding apparatus 125 will be illustrated in detail with reference to
In the part of the consecutive data, the consecutive pattern decoder 530 coupled to the bus 130 decodes the inputs from the bus 130 and the control line CLT through the Zero-Transition, and outputs the decoded data (Step 625). The decoding method used by the consecutive pattern decoder 530 is corresponding to the encoding method used by the consecutive pattern encoder 330. Besides the Zero-Transition, the consecutive pattern decoder 530 may also use other consecutive data decoding methods in accordance with the consecutive pattern encoder 330, for example, Gray Code or burst mode.
The data receiver 540 is coupled to the table lookup unit 322, the consecutive pattern decoder 530, the bus 130, and the control lines CLD and CLT. The data receiver 540 receives the outputs of the table lookup unit 322 and the consecutive pattern decoder 530, and inspects whether the control line CLD is in an asserted status or not (Step 630). If the control line CLD is in the asserted status, the data receiver 540 outputs the corresponding data outputted from the table lookup unit 322 to act as the current data 301 (Step 640); otherwise, the data receiver 540 outputs the output data outputted from the consecutive pattern decoder 530 to act as the current data 301 (Step 635).
Next, the table updater 323 receives the previous data from the data storage 321, receives the current data 301 from the data receiver 540, and then updates the DPT in the table storage 324 by the previous data and the current data 301. Steps 445-460 for updating the DPT are the same as the corresponding steps shown in
Finally, the data storage 321 receives and stores the current data 301 from the data receiver 540 to act as the previous data in the next decoding. Thus, till now, the bus decoding apparatus 125 has finished receiving and decoding the current data, and then processes the next data.
This experiment employs a method for encoding data using the DPT together with the Zero-Transition. The above four test programs are executed. The times of status conversion of the wires of the instruction address bus are calculated. The decreasing ratio relative to the times of bus line bit-transitions without any encoding process is calculated. The average decreasing ratio of the times of status conversion for the above four test programs is also calculated. The experimental result is shown in
The following Table 3 shows the comparative data of the average experimental results for the two encoding methods, i.e., the Zero-Transition and the DPT with the capacity of 4; the Zero-Transition and the DPT with the capacity of 32.
The decreasing ratio of the times of status conversion in
In view of the above, the present invention may encode and decode consecutive data and discontinuous data to make most of data be transmitted without passing through the bus. Therefore the times of bus line bit-transitions are greatly decreased. The benefit includes reducing the power consumption of the bus and the waste heat generated by the system, enhancing the system stability, and elongating the operating time of the system. Besides the instruction address bus, the present invention can also be used in other types of buses, including a common bus connecting a plurality of system devices and a one-to-one special bus. All buses may be applicable for the present invention, as long as they often transmit the consecutive data or the discontinuous data appear repeatedly.
It will be apparent to those skilled in the art that various modifications and variations can be made to the structure of the present invention without departing from the scope or spirit of the invention. In view of the foregoing, it is intended that the present invention cover modifications and variations of this invention provided they fall within the scope of the following claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
96109298 A | Mar 2007 | TW | national |
Number | Name | Date | Kind |
---|---|---|---|
6538584 | Borkar et al. | Mar 2003 | B2 |
6943706 | Pappalardo et al. | Sep 2005 | B2 |
7358868 | Pappalardo et al. | Apr 2008 | B2 |
Number | Date | Country | |
---|---|---|---|
20080235417 A1 | Sep 2008 | US |