# An Automatic Router for the Pin Grid Array Package* 

Shuenn-Shi Chen ${ }^{1}$, Jong-Jang Chen ${ }^{1}$, Sao-Jie Chen ${ }^{1}$, and Chia-Chun Tsai ${ }^{2}$<br>Department of Electrical Engineering<br>National Taiwan University<br>Taipei, Taiwan, Republic of China<br>${ }^{2}$ Department of Electronic Engineering<br>National Taipei University of Technology<br>Taipei, Taiwan, Republic of China


#### Abstract

A Pin-Grid-Array (PGA) package router is presented in this paper. Given a chip cavity with a number of I/O pads around its boundary and an equivalent number of pins distributed on the substrate, the objective of the router is to complete the planar interconnection of pad-to-pin nets on one or more layers. This router consists of three phases: layer assignment, topological routing, and geometrical routing. Examples tested on a windowsbased environment show that our router is efficient and can complete the routing task with less substrate layers. Compared to the manual routing, this router owns a friendly graphic user interface and can be practically applied to VLSI packaging.


## 1. Introduction

Nowadays, the electronics industry has grown tremendously. The success was attributed to the revolutionary technology breakthrough in the fabrication process and electronic packaging of integrated circuits. Especially, Pin-Grid-Array (PGA) and Ball-Grid-Array (BGA) packages are complex structures with large peripheral I/O counts, multiple routing layers and built-in decoupling capacitors. As a result, developing an industrial-strength CAD tool for package design becomes indispensable. In past years, many studies on high-speed transmission, power dissipation, noise, and crosstalk for package layout, have been presented [1-3].

A typical PGA package structure containing a chip cavity with a number of peripheral I/O pads and a rectangular array of pins was reported by Lewis [4]. Based on this package structure [4], Tsai and Chen proposed a slope method and a rubber-band like method for the PGA package routing, respectively in [5] and [6]. Lately, Ying and Gu [7] proposed a tool for performance-driven PGA package routing on multiple layers ceramic substrates. These routers [5-7] have a common distinguishing feature that they divided the substrate routing area into four separate
zones (namely top, bottom, left, and right zones). But these zones are not independent to each other, for examples, pad-to-pin nets may not belong to the same zone, or pins may be located at the borderline of two adjacent zones. Therefore, these routers cannot complete the routing task under a limited number of available layers when the input netlist becomes more complicated or there are serious crisscrosses among pad-to-pin nets on the routing area.

In this paper, we propose a windows-based routing tool for the PGA package based on the same model [4]. We cluster a set of grid array pins to form multiple rectangular rings on a substrate area. The structure and conceptual routing environment of this PGA package is shown in Figure 1. The objective of the package router is to connect each chip pad to the corresponding pin on the substrate area using less routing layers in the following: layer assignment, topological routing, and geometrical routing phases.

The remainder of this paper is organized as follows. Section 2 presents the problem formulation. Section 3 gives an overview of the package router. Details of the algorithms are discussed in Section 4. The experimental results are reported in Section 5. Finally, Section 6 concludes this paper and discusses some future research problems.


Figure 1. Routing environment of a PGA package.

## 2. Problem Formulation

As shown in Figure 1, a PGA package contains a central chip with a certain number of I/O pads distributed on the chip boundary, and has the same

[^0]number of external pins to form a pin grid array around the chip. In addition, each I/O pad is wired to a pad on a substrate layer. The routing area is viewed like the moat space [8] between the edges of each substrate layer and the chip cavity, and multiple layers are sometimes required for the planar interconnections between the pads and the corresponding pins. All power and ground nets are routed on separated layers. We assume that every pin location is fixed and no pin assignment [9] is allowed because the package may be compatible with the pin locations of an off-the-shelf processor. Routing sequence for pad-to-pin nets is from the inner-most ring toward the outer-most ring and the wires may be routed in the kind of any angle. The routing result must satisfy the design rules constraint.

## 3. Overview of the Package Router

The design flow of our PGA package routing system is shown in Figure 2. The net lists include pad and pin descriptions as the input of the system.


Figure 2. Design flow of the package router.
In the layer assignment phase, it is first to calculate the weights of each nets and then uses a simple comparison procedure to distribute nets onto suitable routing layers. The topological routing determines the topology paths for nets without any crossing and generates a planar sketch. After, the geometrical routing phase transforms the obtained planar sketch into an arbitrary-angle wiring and having the design-rule checking done. The technology file contains a set of design rules that state the parameters on the RLC (resistances, inductances, and capacitances) limits for each signal, the uppercapacity limit of wires passing through spacing between any two adjacent pins, and so on. We use a rip-up and rerouting step to change the routing direction of some segments if design-rule violation or routing cost has to be considered. The above phases will be performed repeatedly until the routing of all unrouted nets has been done.

## 4. Algorithm Descriptions

4.1 Layer Assignment

The layer assignment phase is employed to distribute nets to two or more distinct layers when some existing nets cannot be routed on the current layer after the rip-up and rerouting step. In the topological routing phase, nets are routed from the inner-most ring to the outer-most ring in a multi-ring routing environment. Therefore, we must consider some routing factors like crossing number, detour length, and capacity in the layer assignment phase. For above reasons, let the weight of each net be $\boldsymbol{W}=$ $\alpha V+\beta D+\gamma C$, where $V, D$ and $C$ represent the inversion value, distance and capacity respectively and $\alpha, \beta$ and $\gamma$ are constants.

Using the notation of an inversion-table similar to Knuth [10], we can find two sets of $V, D, C$ values and store them in a Right (R2L) inversion table and a Left (L2R) inversion table, respectively. Here, let ( $a n$, $a_{n-1}, \ldots, a_{1}$ ) be a permutation of sorted data ( $n, n$ $1, \ldots, 1)$, then $(d n, d n-1, \ldots, d 1)$ represent the right (left) inversion values of ( $a n, a n-1, \ldots, a 1$ ), where every $d i$ represents the number of elements located at the right (left) side of ai and greater (less) than ai. For instance, given a permutation ( $3,2,4,1,5$ ), its R2Land L 2 R -inversion values are $(2,2,1,1,0)$ and $(0,0$, $2,0,4)$, respectively. Again, assume pin $i\left(P_{i}\right)$ have an inversion point pin $j\left(P_{j}\right)$ at a ring, where an inversion point of net $i$ in an R2L (a L2R) table is the first element greater (less) than $i$ scanning from right to left (from left to right). The inversion distance of net $i$ is defined as $D_{i}=|m-n|$, where $m$ and $n$ are the pin positions of $P_{i}$ and its inversion point $P_{j}$, respectively. On the other hand, the inversion capacity $C_{i}$ of pin $i$ $\left(P_{i}\right)$ is equal to the number of nets which may pass through between $P_{i}$ and $P_{j}$. That is $C_{i}=\left|P_{i}-P_{j}\right|-1$.

Finally, we assign nets having minimum weights in the L2R table to one layer and nets having minimum weights in the R2L table to another layer. As shown in Figure 3, nets (8, 5, 7, 3) and (6, 4, 2, 1) have to be assigned to layers 1 and 2, respectively.


Figure 3. An example of weight calculation.

### 4.2 Topological Routing

In the direction-constrained topological routing phase, a ring is divided into several independent segments as shown in Figure 4 such that each segment can be chosen a better routing direction (toward left or right) to generate a shorter detour length. Each of independent segments will be transformed into a single row routing problem [11,12] by shifting and rotating the corresponding row of pads surrounding the chip to one side (left or right).

(a) Two segments
(b) Two connected graphs

Figure 4. A ring divided into several segments.
The pin-side and pad-side interval diagram representation and how it corresponds to a single row are shown in Figure 5, where the wiring direction of a pin can be upward or downward while the wiring direction for pads can only be downward (after transformation). We use the term "directionconstrained" to mean that the wiring direction of a pad is only in one direction (while a pin has two directions) and must be away from the chip cavity for our PGA package routing. As a result, by means of shifting and rotating pads back to their original positions, we can obtain an arbitrary-angle planar topology layout, where the relative coordinates of pins and extra nodes (on the reference line) are recorded on each of ring-grid list (RGL). Due to space limitation, detailed discussion of this routing phase is omitted.


Figure 5. A segment routing transformed into a single row routing.

### 4.3 Geometrical Routing

Previous work by Dai [13] transformed a topological routing into a geometrical routing using rubber-band sketch. Our routing phase builds the detailed geometric connections between pads and external pins of a PGA package from a planar sketch obtained in the topological routing. Since the routing region can be partitioned into several sub-regions, we can create some vertical-grid lists to divide each subregion into independent bin-grids, as shown in Figure 6. Whenever the path of any net passes through a vertical grid, insert its net number (as a redundant node) into the vertical grid list. Afterwards, each net in the bin-grid can be routed with a straight line using a river router [14] to connect its two terminals. Finally, the physical wiring paths of all of nets on routing area are made. Additionally, the rip-up and rerouting of a segment is performed only if we have to obey the design rules or to lower routing cost.


Figure 6. Partition a routing sub-region into several bin-grids.

## 5. Experimental Results

The PGA router has been implemented on a PC in Visual C++ language running Windows-98. Due to this type of benchmarks are not commonly available from the literature, some testing examples created by the authors are used to evaluate this router. The data were listed in Table 1 for eleven PGA packages. The wiring layout for a 200-pin PGA package (chip_11) was plotted in Figure 7. As shown, our router can improve the common drawback of existing routers [5-7] that failed to deal with the cases where the pad and pin of the same nets are distributed on distinct routing zones (which causes the borderline problem). And it has provably undisputed advantage over manual designs in terms of routability and productivity.

## 6. Conclusions

We have presented an innovative windows-based routing tool for the PGA package routing on a multilayer substrate. The router includes the following phases: First, the layer assignment phase determines nets to suitable layers. Second, the topological routing phase transforms the initial routing into a direction-constrained single row routing problem to obtain a non-crossing planar sketch. Finally, the
geometrical routing phase partitions the routing region into several independent sub-regions such that we can employ a river router to find an any-angle wiring layout for all nets. In future, we will extend this router to handle the routing problem of Ball-Grid-Array (BGA) package as proposed in [15] and apply it to a Multi-Chip Modules (MCM) environment.

## References

[1] T. Hameenanttila, J. D. Carothers, and D. Li, "Fast coupled noise estimation for crosstalk advoidance in the MCG multichip module autorouter," IEEE Transactions on Very Large Scale Integration (VLSI) Systems, vol. 4, pp. 356-366, 1996.
[2] U. A. Shrivastsva and B. L. Bui, "Inductance calculation and optimal pin assignment for the design of pin-grid-array and chip carrier packages," IEEE Transactions on Components, Hybrids, Manufacturing Technology, vol. 13, pp. 147-153, 1990.
[3] L. L. Moresco, "Electronic system packaging: The search for manufacturing the optimum in a sea of constraints," IEEE Transactions on Components, Hybrids, Manufacturing Technology, vol. 13, pp. 494508, 1990.
[4] E. T. Lewis, "The VLSI package-an analytical review," IEEE Transactions on Components, Hybrids, Manufacturing Technology, vol. CHMT-7, pp. 197201, 1984.
[5] C. C. Tsai and S. J. Chen, "Planar routing on a pin grid array package," in Proc. 3rd International Conf. on CAD \& Computer Graphics, (Beijing, China), pp. 439-445, 1993.
[6] C. C. Tsai, C. M. Wang, and S. J. Chen, "NEWS: A net-even-wiring system for the routing on a multilayer PGA package," IEEE Transactions on ComputerAided Design of Integrated Circuits and Systems, vol. 17, pp. 182-189, 1998.
[7] C. Ying and J. Gu, "Automated pin grid array package routing on multilayer ceramic substrates," IEEE Transactions on Very Large Scale Integration (VLSI) Systems, vol. 1, pp. 571-575, 1993.
[8] C. C. Tsai and S. J. Chen, "Planar moat routing," in Proc. 3rd VLSI/CAD Workshop, pp. 169-178, 1992.
[9] M.-F. Yu and W. W.-M. Dai, "Pin assignment and routing on a single-layer pin grid array," in Proc. IEEE Asia and South Pacific Design Automation Conference, pp. 203-208, 1995.
[10] D. E. Knuth, Sorting and Searching, vol. 3, Reading, MA: Addison-Wesley, 1973.
[11] E. S. Kuh, T. K. Kashiwabara, and T. Fujisawa, "On optimum single row routing," IEEE Transactions on Circuits and Systems, vol. 26, pp. 361-368, 1979.
[12] D. H. C. Du, O. H. Ibarra, and J. F. Naveda, "Singlerow routing with crossover bound," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. CAD-6, pp. 190-201, 1987.
[13] W. W.-M. Dai, R. Kong, and M. Sato, "Routability of a Rubber-Band Sketch," in Proc. 28th Design Automation Conference, pp. 45-48, 1991.
[14] C. P. Hsu, "General river routing algorithm," in Proc. 20th Design Automation Conference, pp. 578-583, 1983.
[15] M.-F. Yu and W. W.-M. Dai, "Single-layer fanout routing and routability analysis for ball grid array," in Proc. International Conference on Computer-Aided Design, pp. 581-586, 1995.


Figure 7. Single-layer routing result of a 200-pin PGA package.

Table 1. Routing results of distinct PGA packages.

| chip name | cavity size (pixels) | \# nets | \# rings | \# routing layers | any-angle length (pixels) |
| :--- | :---: | :---: | :---: | :---: | :---: |
| chip_1 | $104 \times 104$ | 84 | 3 | 1 | 8428 |
| chip_2 | $104 \times 104$ | 84 | 3 | 1 | 9251 |
| chip_3 | $110 \times 110$ | 84 | 3 | 2 | 8361 |
| chip_4 | $110 \times 110$ | 144 | 4 | 1 | 12726 |
| chip_5 | $110 \times 110$ | 144 | 4 | 1 | 14689 |
| chip_6 | $110 \times 110$ | 112 | 4 | 1 | 14396 |
| chip_7 | $110 \times 110$ | 112 | 4 | 1 | 14249 |
| chip_8 | $110 \times 110$ | 200 | 5 | 1 | 28240 |
| chip_9 | $110 \times 110$ | 200 | 5 | 1 | 23450 |
| chip_10 | $110 \times 110$ | 200 | 5 | 1 | 23482 |
| chip_11 | $110 \times 110$ | 200 | 5 | 1 | 23452 |

Note: routing layers do not include power and ground layers.


[^0]:    * This work was supported by the National Science Council, Taipei, Taiwan, R.O.C., under Grants no. NSC 88-2216-E002-017 and NSC 88-2216-E027-003.

