The multiple-supply voltage (MSV) design style has been extensively applied to mitigate dynamic-power consumption. The MSV design paradigm, however, brings many crucial challenges, especially in the power-ring synthesis. Unlike the previous works that form the power rings as the enclosing bounding boxes of voltage islands, we enable power rings alignment to the outer boundaries of voltage islands. With this new formulation, the power-ring estimation becomes more accurate during floorplanning, and the power-ring synthesis is more practical after floorplanning. In this paper, we first propose a linear-time voltage-island power-ring search algorithm to identify the power rings of voltage islands and then present a linear-time optimal power-ring corner-patching algorithm to minimize the number of corners in the power rings by using post-floorplanning whitespaces. Experimental results first demonstrate that reducing corners in power rings significantly mitigates IR drop, and then show that the proposed algorithm can reduce the number of corners by 33% on average for the GSRC floorplan benchmarks. In particular, the total running time for the 16 GSRC benchmarks is less than one second on an AMD-64 machine with a 2.2 GHz CPU and 8 GB memory.
INTRODUCTION
Performance-constrained low-power design has been studied extensively in the literature. Among existing techniques, the * This work was supported in part by TSMC and NSC of Taiwan under Grant No's. NSC 96-2752-E-002-008-PAE, NSC 96-2628-E-002-248-MY3, NSC 96-2628-E-002-249-MY3, and NSC 96-2221-E-002-245.
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. To copy otherwise, to republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. multiple-supply voltage (MSV) design style [13] provides an effective way for dynamic-power reduction. Generally, dynamic-power consumption can be computed by
where k is the circuit switching rate, C load is the loading capacitance, V dd is the supply voltage, and f is the clock frequency. The dynamic-power consumption is proportional to the square of V dd , implying that lowering supply voltages can effectively reduce dynamic-power consumption.
While dynamic-power consumption is mitigated by the MSV technique, the MSV design style induces several crucial challenges for power-ring synthesis. In this work, to make the MSV designs more flexible and more practical, we allow one or several blocks to form a voltage island; in other words, each supply voltage may have several physical independent voltage islands whose power rings are naturally independent. As a result, this method provides much higher flexibility, but dramatically increases the complexity of the power-ring synthesis.
To reduce the complexity of the power-ring synthesis, previous works defined the power rings as consisting of the bounding boxes of the voltage islands. However, treating the problem this way is perhaps over simplistic; an example is shown in Section 2. Therefore, a more practical methodology for MSV power-ring synthesis is desired. In this paper, we propose a power-ring synthesis methodology that first identifies the power rings that align to the outer boundaries of voltage islands and then adjusts the power rings for fewer corners while fixing the positions of the blocks (at the floorplanning packing or post-floorplanning stages). Furthermore, the proposed methodology is proven to take linear time when employing a hash-table based algorithm. Due to its efficiency, our methodology can be applied to post-floorplan MSV design as well as MSV-aware floorplan synthesis.
MSV systems have been applied at various design stages such as the floorplanning stage [3, 4, 5, 7, 10] , the post-floorplanning stage [9] , the placement stage [8] , or the post-placement stage [1, 14, 15] . Most of these works do not consider power-network synthesis or consider it by rough models, e.g., the boundingbox power-ring formulation. However, such an approach might be over simplistic for power-ring estimation during floorplanning and could be impractical for power-ring synthesis at the postfloorplanning stage. In contrast, our outer-boundary formulation is amenable to being employed in the floorplanning and postfloorplanning stages because of its accuracy and practicality. Section 2 gives an example to compare the two power-ring formulations, the traditional bounding-box formulation and our outerboundary one.
In addition to the aforementioned novel methodology of power rings for voltage islands, we summarize our major contributions as follows:
• To the best of our knowledge, this is the first work proposing power-ring alignment to the outer boundaries of voltage islands. Compared with previous works that approximate power rings by the bounding boxes of voltage islands, our methodology is more realistic.
• A linear-time voltage-island power-ring (contour) search algorithm is presented. When using a hash-table approach, the proposed algorithm takes only linear time on average to search for a power ring.
• A linear-time optimal power-ring corner-patching algorithm is presented. While power rings are aligned to the outer boundaries of voltage islands, there may be multiple corners for each power ring. This implies that a significant number of vias would be introduced in the power rings, which is definitely not desirable. Therefore, it is important to minimize the number of corners in the power rings by patching the whitespaces in the given floorplan into the circuit blocks and make power rings more regular. We empirically validate this undesired effect of the corners on IR drops.
• Experimental results demonstrate that reducing corners in power rings significantly mitigates IR drop, and show that the proposed algorithm can reduce the number of corners by 33% on average for the GSRC floorplan benchmarks.
The total running time for the 16 GSRC circuits is less than one second on an AMD-64 machine with a 2.2 GHz CPU and 8 GB memory.
• Since the proposed algorithms are computationally efficient, they are amenable to being embedded into MSV floorplanners to achieve better MSV floorplans. In addition, they can also be applied for synthesizing the power rings during the post-floorplanning stage.
The remainder of this paper is organized as follows. Section 2 discusses the advantages of the outer-boundary formulation for MSV designs. Section 3 formulates the power-ring synthesis and adjusting problem for MSV designs. Section 4 describes our proposed methodology for the addressed problem. Section 5 shows the experimental results, and Section 6 concludes this paper.
COMPARISONS OF POWER-RING FORMULATIONS
We first introduce the bounding-box formulation and our outerboundary one. Take Figure 1 for example, in which the given floorplan contains five circuit blocks operating at two specific supply voltages, three blocks in the left voltage island and two in the right one, and the interconnection wires among the blocks are shown. Figures 1(a) and (b) employ the bounding-box formulation for power-ring estimation while Figures 1(c) and (d) adopt our outer-boundary formulation. The bounding-box formulation estimates and forms power rings as enclosing bounding boxes of voltage islands, as shown in Figures 1(a) and (b); our outer-boundary formulation, in contrast, searches power rings by aligning the outer boundaries of voltage islands and then makes the power rings more regular by patching whitespace into voltage islands, e.g., w 1 and w 2 as shown in Figure 1 (c).
Compared with our outer-boundary formulation, the boundingbox one might underestimate the complexity of the power-ring synthesis during floorplanning and/or post-floorplanning, and thus might mislead MSV-aware floorplanning and/or post-floorplanning optimization. The floorplan in Figure 1 (b) is more preferable than that in Figure 1(a) if the bounding-box formulation is employed, because they both have the same cost of the power-ring synthesis, but the floorplan in Figure 1 (b) has shorter wirelength. As a matter of fact, however, the cost/complexity of the power-ring synthesis for the floorplan in Figure 1 (b) is underestimated due to the overlap between the two voltage islands. The overlap between two voltage islands implies that the power lines for different supply voltages need to be interleaved in the overlapped region, widening the power-line pitch and thus increasing IR drop. In contrast, our outer-boundary formulation can capture the cost of the power-ring synthesis more accurately, as shown in Figures 1(c) and (d) . Although the floorplan in Figure 1 (d) has shorter wirelength, its power cost (e.g., IR drop) and power-ring complexity could be higher due to the larger number of corners in the power rings. Note that to reduce the number of corners and thus make the power rings more regular, our outer-boundary formulation patches whitespaces into voltage islands, as shown in Figure 1 (c), which might lead to a better MSV floorplan solution.
In addition, the power meshes for voltage islands in industrial designs are usually not regarded as the enclosing bounding boxes of the voltage islands if there are overlapping regions in the bounding boxes. To avoid widening the power-line pitch and save more power-network resource, the power ring for a voltage island is typically aligned to the outline of the voltage island. Hence, our outer-boundary formulation is more realistic and more suitable for MSV designs than the bounding-box one.
PROBLEM FORMULATION
To achieve better power-ring synthesis for MSV designs, our objective is to identify the power rings and then reduce the number of corners for each power ring, while keeping all circuits blocks fixed (during the floorplanning packing or the post-floorplanning stages). In this problem, an MSV floorplan is given, in which circuit blocks occupy specified physical spaces and operate at specified supply voltages, as shown in Figure 2 (a).
We formally define a voltage island, a power ring, and a corner as follows, and also illustrate them by the examples shown in Figure 2 
Definition 2. (Power Ring of a Voltage Island) A power ring for a voltage island is the contour (outer boundary) of the voltage island.
Since the input is a floorplan consisting of rectangular blocks, a power ring of a voltage island is composed of a set of vertical and horizontal segments that enclose the associated blocks in the voltage island. We define the power-ring synthesis and adjustment problem as follows (see also Figure 2 for an illustration). 
where n is the number of power rings and c i is the number of corners of power ring i.
OUR OPTIMAL ALGORITHMS
To deal with the addressed problem, a two-phase framework is proposed. The framework can produce the optimal solution; in other words, the number of corners in each power ring is minimized while all power rings do not overlap with each other (by patching floorplan whitespaces). In the first phase, a voltageisland contour search algorithm is applied to identify voltage islands and their corresponding power rings, as shown in 
Voltage-Island Contour Search Algorithm
Given a floorplan consisting of rectangular circuit blocks, we first apply a depth-first search (DFS) to identify blocks belonging to each voltage island. Moreover, for each voltage island, we construct two hash tables Hx and Hy corresponding to the x and y coordinates of points defining the blocks, as shown in Figure 3 . The first element in Hx links points p 11 and p 8 since they have the smallest x coordinate; the first element in Hy links points p 1 and p 2 since they have the smallest y coordinate.
Then, given a voltage island, finding its power ring is a contour search problem. Two straightforward, but incorrect methods are illustrated in Figure 4 . In Figure 4 (a), we search the contour by examining the edge positions. If the edges overlap no other edges, they are assumed to be the contour edges. This method, however, cannot distinguish the edges of inner holes, which neither overlap any edges nor are contour edges of the voltage island; consequently, the method might not produce correct results. As shown in Figure 4 (a), the lightly shaded segments are not parts of the contour, but the method might fail to identify them. As shown in Figure 4 (b), the second method tries to search the contour by line sweeping. The algorithm tests if an edge is a contour segment when the scanning line sweeps the edge. This method, however, might not correctly determine the contour segments while sweeping an edge. In Figure 4 (b), the heavily shaded segments of the sweeping line are parts of contour edges while the lightly shaded one is not. Since these two straightforward methods are incorrect, it is therefore desirable to find a correct and efficient method to tackle the contour search problem. We apply the concept of the contour traversal sequence, inspired by the previous work [11] , to develop our algorithm.
Properties of Contour Traversal Sequences
As mentioned before, a contour is composed of a set of vertical and horizontal outer segments. If we trace the respective vertical and horizontal segments counterclockwise from the starting segments with the smallest x and y coordinates, the traversal sequences S * x and S * y would be obtained. Note that in this paper when we say counterclockwise traversal, we mean the traversal In Figure 5 (a), for example, S * x begins in an increasing subsequence < x 1 , x 2 , x 3 >, followed by a decreasing one < x 3 , x 4 >, followed by an increasing one < x 4 , x 5 >, and finally ends in a decreasing one < x 5 , x 1 >.
Here, we also introduce the traversal sequences Sx and Sy to relax the constraint in the definitions of S * x and S * y that the traversals start at the segments with the smallest x and y coordinates; that is, treating Sx and Sy as circular lists, they have the same orders as those of S * x and S * y , respectively, but might start with different segments. Obviously, Sx and Sy are also composed of alternate increasing and decreasing traversal subsequences, but may not start and end with increasing and decreasing subsequences since they may start in the middle of subsequences. In Figure  5 (a), for example, Sx starts at x 2 which is in the middle of the first increasing subsequence in S * x , and thus Sx starts and ends in the increasing subsequences. Note that S * x and S * y are unique, but Sx and Sy are not.
Next, we define an inversion as follows, which is the key to our contour-traversal strategy. a tuple consisting of a major (the first letter) and a minor (the second letter) directions where point σ denotes the possible directions of the succeeding point. Here, U , D, L, and R denote respective up, down, left, and right directions, and the direction pairs without and with parentheses are for the counterclockwise and clockwise traversals, respectively. According to dσ, succeeding point σ will be found, and then according to the inversion after σ , d σ will be set. Then, we repeatedly search succeeding points in the contour and set their direction pairs until coming back to the starting point. Following this strategy, we can traverse the contour correctly. Figure 6(a) . Consider a horizontal inversion. Figure 6( 
In this case, Sx changes to decreasing, but Sy is still increasing, and thus d σ may be set to UL or LU . However, it is impossible to set d σ to LU ; otherwise, the following traversal might enter the voltage island and lead to an incorrect traversal, as shown in the dashed line in

Contour Search Algorithm
Based on the properties of traversal sequences and our proposed contour-traversal strategy, we develop our voltage-island contour search algorithm, as illustrated in Figure 7 . In the following, we detail the algorithm step by step. 
• Steps 1 and 2: Initializing the traversal
The traversal starts at the point σ with the smallest y coordinate (if there are multiple points with the smallest y coordinate, choose the one with the smallest x coordinate) and initially set dσ = RU . It can be seen that the starting point σ is the first element in Hy, as shown in Figure 3 .
Setting dσ = RU is correct. Since σ is the first element in Hy, it is impossible to make dσ related to directions L and D. In addition, we traverse the contour in counterclockwise manner. Hence, R is set as the major direction while U is the minor one; if we set U as the major direction, then the traversal is done clockwise.
• Step 3: Searching the succeeding point
In the traversal, the succeeding point σ must be in the major or minor direction specified in dσ.
Lemma 3. Given the point σ and its direction pair dσ, the succeeding point in the contour (denoted by σ ) must exist in the major or minor direction specified in dσ.
Lemma 3 and the hash-table implementation show that finding the succeeding point in the contour takes constant time on average since searching in hash tables takes constant time on average [2] .
• Step 4: Checking the inversion after σ This is the core step of the algorithm. After obtaining point σ , we check the inversion after σ and then set the direction pair d σ in the next step.
To check the inversion after σ , we should be given the succeeding point of σ . We, however, cannot determine the succeeding point of σ before determining the inversion after σ . Although we do not know where the succeeding point of σ is, we can still guess and then verify it (three times at most).
For a clearer presentation, the point succeeding σ is denoted by σ , and the directions from σ to σ and from σ to σ are denoted by D σ→σ and D σ →σ , respectively. Since the traversal Figure  8 for a clear illustration, in which dσ is set to RU . Note that because the traversal is counterclockwise, the voltage island occupies the region above the segment connecting σ and σ in Figure  8 
• Step 5: Setting d σ
We have been given dσ and the inversion after σ . According to Table 1 , we set d σ .
• Step 6: Confirming the current segment
The segment connecting points σ and σ has been confirmed as a contour segment. We let σ = σ and dσ = d σ to repeatedly search succeeding points in the contour.
• Step 7: Determining the termination
If σ is not the starting point, we repeatedly find succeeding points until coming back to the starting point. If σ is the starting point, the algorithm terminates, and the contour is composed of the points which have been set as point σ.
An Example of Contour Search Algorithm
In Figure 9 (a), we search the contour starting at point p 1 which is the first element in Hy and set dp 1 = RU . Then, we search point p 2 as the succeeding point in the major direction R specified by dp 1 . We check the inversion after p 2 , but no inversion is detected. Hence, we set dp 2 to RU according to Table 1 . Next, since p 2 is not the starting point, we go back to the third step and repeatedly find the succeeding point. In Figure 9 (b), due to the page limitation, we skip the description of the third step which has been presented in the aforementioned example. In the fourth step, an inversion after p 3 is detected because dp 2 →p 3 is in the minor direction of dp 2 , and σ i (p 5 ) exists but neither σ M nor σ m does (the horizontal inversion is detected), as described in the second situation in Lemma 4. Then, according to Table 1 , dp 3 is set to UL. Again, since p 3 is not the starting point, we go back to the third step and repeatedly find the succeeding point.
P t h d bl j i t
In Figure 9 (c), in the fourth step, no inversion is detected and thus dp 5 is set to UL. Similarly, since p 5 is not the starting point, we go back to the third step and repeatedly find the succeeding points. The algorithm would terminate when we come back to p 1 .
Corner-Patching Algorithm
After searching the power ring (contour) of each voltage island, we try to minimize the number of corners (see Definition 3) for the via reduction in the power rings by patching whitespaces into circuit blocks. It should be noted that the resulting power rings will not overlap, because we use only whitespaces for patching to minimize the via count. See Figure 10 for the corner-patching algorithm flow.
We first introduce single and double joints defined in Definitions 5 and 6 and illustrated in Figure 11 . Moreover, single and double joints may be filled by whitespace. In Figure 12 (a), for example, suppose that double joint d 1 in the left voltage island has been filled. Consequently, two single joints individually exist in the two voltage islands. Single joint s 1 associated with the right voltage island could be filled up by a complete whitespace; however, the single joint associated with the left voltage island cannot be filled because there is no complete whitespace that can fill the single joint. The complete whitespace for the single joint associated with the left voltage island is shown by the oblique-line region in Figure 12(b) . Now, we show the optimality of the corner-patching algorithm. We shall first show the correctness of the algorithm flow and then show the optimality of the algorithm. We now present our corner-patching algorithm. We search double joints starting at the point with the smallest y coordinate (if there are multiple points with the smallest y coordinate, choose the one with the smallest x coordinate). Double joints exist in the four situations illustrated in Figure 13(a) . Therefore, each time we scan three contour segments to verify if a double joint exists. If we detect a double joint, we immediately try to fill the double joint. If the double joint can be filled, we update the contour and detect new double joints locally; after patching a double joint, new double joints may be induced. If the double joint cannot be filled, we process the next double joint. After filling all adjustable double joints, we try to search and fill single joints which exist in the four situations illustrated in Figure 13 
EXPERIMENTAL RESULTS
We conducted two experiments in this section. Section 5.1 validates the corner effect in power rings on IR drop, and Section 5.2 presents the experimental results from our algorithms. Figure 9 : (a) The counterclockwise traversal begins at p1 whose direction pair dp 1 is set to RU . p2 is found in the major direction specified by d p 1 , and dp 2 is set to RU because no inversion is detected. (b) p3 is found in the minor direction specified by d p 2 , and dp 3 is set to UL because the horizontal inversion is detected, as described in the second situation in Lemma 4. (c) p 5 is found in the minor direction specified by dp 3 , and dp 5 is set to UL because no inversion is detected.
(a) (b) The corners in a power ring induce vias and increase IR drop. To justify this claim, we tested various numbers of corners in a power ring, and then individually evaluated the IR drop by Cadence SOC Encounter v6.2. We took the r2000 soc circuit from Opencores [12] and synthesized it by Synopsys Design Compiler v2007.12 with the TSMC 0.18μm technology. The circuit layout contain three double and three single joints in its power ring, and the four power pads are attached to the four boundaries of the chip. Table 2 reports the experimental results. Column "power pads" gives the power pads we used, and columns "3d3s", "2d3s", "1d3s", "0d3s", "0d2s", "0d1s", and "0d0s" give the IR drops for
Corner Effect Validation
, s 2 , and s 3 being filled one by one. It is obvious from Table  2 that minimizing the number of corners can significantly reduce IR drop.
Corner Number Minimization by Whitespace Patching
Our algorithms was implemented in the C++ programming language and experimented on a workstation with an AMD-64 2.2 GHz CPU and 8 GB memory running Linux. The benchmark circuits are taken from the GSRC floorplanning benchmarks. Other assumptions in our experiments are listed below. Note that the efficiency and correctness of our algorithms are not affected by these assumptions.
• Four available supply voltages are used in the benchmarks and are randomly assigned to blocks. Note that previous works have shown that two or three supply voltages are sufficient for practical circuit designs [6] .
• The positions of blocks are fixed, and they are given in the original benchmarks; that is, our algorithm is applied at the post-floorplanning stage. Table 3 reports our experimental results. Column "#islands" gives the numbers of the voltage islands, and columns "original," "after double-joint patching," and "after single-joint patching" give the numbers of corners before and after patching double and single joints. The experimental results show that our algorithm can reduce the number of corners by 33% on average. In addition, the total running time for the 16 GSRC circuits is less than one second. For the biggest benchmark circuit n300 that contains 300 blocks, 57 voltage islands, and 862 corners, our algorithm can reduce 298 corners in only 0.06 seconds. The results show that the proposed algorithms are efficient and effective. Figure 15 shows the resulting layouts of n30b and n50b. 
CONCLUSION
In this paper, we have introduced a post-floorplanning powerring synthesis and adjustment algorithm. The proposed algorithm enables power ring alignment to the outer boundaries of voltage islands. This is a novel idea of the power-ring synthesis for MSV designs. Further, the proposed algorithm is adaptable to be embedded in MSV floorplanners because of its efficiency. Of course, it is also can be employed to synthesize the power rings after floorplanning.
