ISSN 2319 – 2518 www.ijeetc.com Vol. 2, No. 2, April 2013 © 2013 IJEETC. All Rights Reserved

**Research Paper** 

# LOW POWER BUS ENCODING FOR DEEP SUB MICRON VLSI CIRCUITS

K Padmapriya<sup>1</sup>\*

\*Corresponding Author: **K Padmapriya**, 🖂 kesaripadmapriya@yahoo.com

In recent year's low power and power aware has become a driving force in the semiconductor industry. This is due to the growth of portable electronics industry and to the growing cost of the power dissipation on buses. Because, the power dissipation related to the bus is becoming the major part of the total power dissipation in low power VLSI. The power dissipated by DSM bus is directly related to the switching activity of the coupling capacitance that exist between the bus lines and also the switching activity of the self capacitance present between the bus interconnect and the ground. In this paper we develop a new technique to reduce the switching activity of both self and coupling capacitances through encoding the data on buses.

Keywords: DSM, VLSI, Self transitions, Coupling transitions, CODEC

#### INTRODUCTION

In CMOS circuits most power dissipated as dynamic power for charging and discharging of internal node capacitances. Thus, the power dissipated by an IC at these I/O pins is even greater than that dissipated at internal capacitance. In general, four sources of power dissipation can be given by Yan *et al.* (2002).

$$P_{Bus} = P_{Static} + P_{dynamic} + P_{Leakage} + P_{Shortckt}$$
...(1)

The dynamic power dissipated in a bus is expressed as the following equation (Weste and Eshraghian, 1998).

$$P_{Bus} = \Sigma C_{load} V_{dd}^2 f_{clk} \alpha \qquad \dots (2),$$

 $C_{load}$  is the total load capacitance attached to a bus line,  $V_{dd}$  is the voltage swing at operation, and  $\alpha$  is the transition activity factor. Power dissipated by bus can be reduced by reducing either by reducing  $C_{load}$ , or  $V_{dd}$  or  $f_{clk}$ or  $\alpha$ . The transition activity factor  $\alpha$  is given by Sainarayanan *et al.* (2006).

$$\alpha = \alpha_s C_s + \alpha_c C_c \qquad \dots (3)$$

where  $\alpha_s$  is the self transition activity factor which arises from the changes from the changes in a particular bus line,  $C_s$  is the self capacitance, i.e., the capacitance between the bus wire and the ground,  $\alpha_c$  is the coupling

<sup>&</sup>lt;sup>1</sup> ECE Department JNTUKCEV, Vizianagaram, India.

transition activity factor which arises due to the difference in bits carried by adjacent bus lines and  $C_c$  is the coupling capacitance, i.e., the capacitance between two adjacent bus wires.

In DSM technology coupling capacitance is comparable to or exceeds the self and substrate capacitance. Therefore techniques for minimizing switching activity at external buses and data buses, even at the expense of a slight increase in switching activity at internal capacitances, are being investigated for reducing power consumption (Stan and Burleson, 1995; and Sotiriadis and Chandrakasan, 2000). In paper Ravindra et al. (2005), both coupling and self transitions have been considered and a new technique is proposed for reduction of both coupling and self transitions. In this paper a new technique is proposed to reduce coupling and self transitions.

# BACKGROUND

Several techniques exist in literature for reducing power dissipation in VLSI circuits. Some of them aim at reducing data bus transitions (switching activity) during transmission of data. They attempt to reduce the power dissipation by minimizing the bus transitions. Among them, Bus Invert method (BINV) introduced by Stan and Burleson (1995), attempts at reducing the power dissipation by minimizing the number of self transitions. In this paper, encoding was performed to reduce the dynamic power dissipation per cycle of a bus line due to self switching was effective when the coupling capacitance  $C_c$  was negligible compared to line-ground capacitance. It needs one extra line to send the coding information to the decoder.

In deep sub micron technology, coupling transitions also affect the power dissipation predominantly. The fact that power dissipation due to coupling transitions, is appreciably more (75%) than that due to self transitions, (25%) (Bakoglu, 1990), necessitates the need for reducing the number of coupling transitions also. This makes the Bus Invert method incomplete in reducing the power dissipation.

Another similar technique introduced by Natesan and RadhaKrishnan (2004) also suffers with the same limitation. Yan et al. (2002) introduced a new technique which considers reduction of both self and coupling transitions. In this paper, odd and even data items are considered individually for encoding. Another author Ravindra et al. (2005) also aims to reduce the total number of transitions. The technique developed in this paper reduces the total number of transitions more effectively than all the above techniques. We also require two extra lines to send the control information. Another encoding technique was introduced by Naveen et al. (2004) in their paper for coupling transition reduction.

In our paper, we develop a new technique to reduce coupling and self transitions through data encoding on bus. It is presented later with an example followed by simulation results and conclusions.

# ALGORITHM

B = Bus width,

N = Number of data items to be transmitted,

 $C_1C_2(0) = 00$ ; Case0 //direct transmission of data //

 $C_1C_2$  (1) =01; Case1 // shift left the data and transmitted //

| $C_1C_2$ (2) = 10; Case2 //odd lines of the data<br>encoded                         | $D_{\kappa}^{11} = \{b_{1} b_{2} b_{3} b_{4} b_{5} b_{6} b_{7} b_{8} C_{1} C_{2} (2)\}$<br>Bus $\leftarrow D_{\kappa}^{11}$ |
|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| and transmitted //                                                                  | $D_{\kappa} = D_{\kappa} + 1;$                                                                                              |
| $C_1C_2(3) = 11$ ; Case3 // even lines of the data encoded                          | $D_{1} = D_{K}^{11};$                                                                                                       |
| and transmitted //                                                                  | If $K \leq N$ , go to Start;                                                                                                |
| K = 2 to N;                                                                         | end                                                                                                                         |
| $D_1 = First data item \{a_1 a_2 a_3 a_4 a_5 a_6 a_7 a_8 C_1$                       | else<br>begin                                                                                                               |
| $D_{\kappa} = Next  data  item$                                                     | If (ST (D <sub>K</sub> ) > N/2) then                                                                                        |
| $= \{B_1 B_2 B_3 B_4 B_5 B_6 B_7 B_3\}$                                             | <b>Case 1:</b> $D_{K}^{11} = \{B_{2} - B_{1} C_{1} C_{2} (1)\}$                                                             |
| $D_{\kappa}$ = Complement of $D_{\kappa}$ .                                         | $D_{\kappa}^{11} = \{b_{2} b_{3} b_{4} b_{5} b_{6} b_{7} b_{8} b_{1} C_{1} C_{2} (1)\}$                                     |
| $D_{\kappa}^{1} = \{B_{1} B_{3} B_{5} B_{7} B_{2} B_{4} B_{6} B_{9}\} // regrouped$ | else                                                                                                                        |
| data//                                                                              | <b>Case 0:</b> $D_{\kappa}^{11} = D_{\kappa}$                                                                               |
| $D_{\kappa}^{11}$ = Encoded form of data $D_{\kappa}$ .                             | $= \{b_{1} b_{2} b_{3} b_{4} b_{5} b_{6} b_{7} b_{8} C_{1} C_{2} (0)\}$                                                     |
| $OG(D_{\kappa}) = \{B_1 B_3 B_5 B_7\} // odd bit nibble of rearrouped data //$      | $Bus \leftarrow D_{\kappa}^{11}$                                                                                            |
|                                                                                     | $D_{\kappa} = D_{\kappa} + 1;$                                                                                              |
| $OGI(D_{\kappa}) = CI + SI \text{ w.r.t the first four bits of } D_{1}$ .           | $D_{1} = D_{K}^{11};$                                                                                                       |
| $EG(D_{\mu}) = \{B_{\mu}B_{\mu}B_{\mu}B_{\mu}\} // even bit nibble of$              | If $K \le N$ , go to Start;                                                                                                 |
| regrouped data //                                                                   | end.                                                                                                                        |
| $EGT(D_{\kappa}) = CT + ST$ w.r.t the next four bits of data $D_{\tau}$ .           | DECODER HARDWARE                                                                                                            |
| Start: $ f CT(D_{}) > I(B/2) - 1 $                                                  | The decoding hard wars is shown in Figure 1                                                                                 |
| begin                                                                               | It generates the final data received in the                                                                                 |
|                                                                                     | correct form. In the xnor block of Figure 2, the                                                                            |
| <b>Case 3:</b> II EGI $(D_k) \ge 0$ GI $(D_k)$ (IIEII                               | xnor logic will be performed between the                                                                                    |

 $D_{\kappa}^{11} = \{B_{1}B_{3}B_{5}B_{7} \text{ followed by 1 0 1 0xnor } (B_{2}B_{4}B_{6}B_{8}) C_{1}C_{2} (3)\}$ 

$$D_{\kappa}^{11} = \{b_1 \, b_2 \, b_3 \, b_4 \, b_5 \, b_6 \, b_7 \, b_8 \, C_1 C_2 \, (3)\}$$
  
e/se

**Case 2:**  $D_{\kappa}^{11} = \{1 \ 0 \ 1 \ 0 \ \text{xnor} \ B_1 \ B_3 \ B_5 \ B_7$ followed by  $B_2 \ B_4 \ B_6 \ B_8 \ C_1 \ C_2 \ (2)\}$  It generates the final data received in the correct form. In the xnor block of Figure 2, the xnor logic will be performed between the encoded nibble and 1010. The shift left data is decoded by shift right module present in the decoder circuit.

# SIMULATION RESULTS

The algorithm has been simulated for 10<sup>5</sup> random vectors generated in C. The simulation





results are shown in Figure 3 for reduction in CT. The results show clearly a reduction of:

- Coupling transitions by 23.46%,
- Self-transitions by 15%.



### CONCLUSION

Our algorithm results in reducing the coupling transitions better than any other scheme reported so far. In the case of standard one

lakh randomly generated data vectors the percentage of reduction in coupling transitions is found to be higher than the nearest reported value. Various other algorithms using xor, complement and shift right are tried and results are being processed. They will be reported at an appropriate time.

### REFERENCES

- Bakoglu H B (1990), "Circuits, Interconnections and Packaging for VLSI", Addison-Wesley.
- Natesan J and RadhaKrishnan D (2004), "Shift Invert Coding (SINV) for Low Power VLSI", Proceedings of EUROMICRO Systems on Digital System Design (DSD'04), pp. 190-194.
- 3. Naveen K Samala *et al.* (2004), "A Novel Deep Sub-Micron Bus Coding for Low Energy", in Proceedings of the Embedded System and Aplications, June, pp. 25-30.
- Ravindra J V R *et al.* (2005), "A Novel Bus Coding Technique for Low Power Data Transmission", IEEE Symposium VDAT-2005, August, pp. 263-266.

- Sainarayanan K S et al. (2006), "Crosstalk Aware Low Power Bus Coding for VLSI Interconnects", Centre for VLSI and Embeded System Technologies, IIIT, Gachibowli, Hyderabad.
- Sotiriadisand P and Chandrakasan A (2000), "Low Power Coding Techniques Considering Inter Wire Capacitances", in Proc. of IEEE Conferences on Custom Integrated Circuits (CICC'00), pp. 507-510.
- Stan M R and Burelson W P (1995), "Bus Invert Coding for Low Power I/O", *IEEE Transactions VLSI Systems*, pp. 49-58.
- Weste N and Eshraghian K (1998), "Principles of CMOS VLSI Design", A Systems Perspective, Addison-Wesley, Reading, MA.
- Yan Zhang *et al.* (2002), "Odd/Even Bus Invert with Two Phase Transfer for Buses with Coupling", Proceedings of ISPLED'02, August 12-14, pp. 80-83, Monterey, CA, USA.