

| Title        | 大規模集積回路のレイアウト合成手法に関する研究          |
|--------------|----------------------------------|
| Author(s)    | 福井,正博                            |
| Citation     | 大阪大学, 1999, 博士論文                 |
| Version Type | VoR                              |
| URL          | https://doi.org/10.11501/3155637 |
| rights       |                                  |
| Note         |                                  |

The University of Osaka Institutional Knowledge Archive : OUKA

https://ir.library.osaka-u.ac.jp/

The University of Osaka



# 大規模集積回路のレイアウト合成手法 に関する研究

1999年

福井 正博

| $\frown$ |            |
|----------|------------|
| (1)      |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          | 大規模集積回路のレイ |
|          |            |
|          |            |
|          | に関する切      |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          | 1999年      |
|          |            |
|          |            |
|          |            |
|          |            |
|          | 福井正        |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |
|          |            |

# (アウト合成手法 研究

Ξ

博

本論文は、著者が昭和56年から昭和58年にかけて大阪大学工学部電子工学科および大 阪大学大学院工学研究科博士前期課程において、および、昭和59年から平成10年にかけて 松下電器産業半導体研究センターおよび半導体先行開発センターにおいて、それぞれ行っ た大規模集積回路の配置配線手法に関する研究成果および標準セルの自動合成に関する 研究成果をまとめたものである。

本論文は、大規模半導体集積回路のレイアウト設計の効率化と品質向上を論じるものであり、 全7章から構成される。

本研究では、ゲートアレイ方式LSIの配置配線を行う場合に、セルの等価端子に対するネッ トの割り当てを最適化することによって、配線処理を簡易化できることに着目し、等価端子の割 り当て手法を提案し、実験によりその有用性を明らかにする。

ついで、階層的に LSI の配置配線するためのチップフロアプラン法を考察し、複数の動作条 件に対して電源幅を最適化する電源配線、および信号線の概略配線経路を最適化する方法 を用い、配線の面積およびブロックの面積を精度良く推定することによってブロックの配置およ び形状を最適化する方法を提案し、実際の LSI チップへの適用例を示しながら、その実用性 について述べる。

さらに、階層配置配線設計において、ブロックの設計が全て終わった後のブロック間配線を 効率良く行う方法を考察し、面積の最小化とタイミングの最適化を同時に行う概略配線手法、 ブロック間の位置を最適化し、ブロック間を L 字形状を含むチャネルに分割しグリッドフリーチ ャネル配線を実行することにより、全ての詳細配線を実現する方法を提案し、その実用性につ いて述べる。

最後に、ランダムロジックブロックや、データパスブロック、メモリ、等を構成するレイアウトの最 小単位であるリーフセルのレイアウトの自動合成手法を考察し、トランジスタのサイズ決め、2次 元のトランジスタ配置配線、コンパクションからなるリーフセルの合成手法を提案し、標準セルの 合成への適用例を示し、その実用性を示す。 本論文は全体を7章に分けて構成する。

# 内容梗概

# 関連発表論文

# I. 学会誌等採録論文

- 1. M. Fukui, N. Shinomiya, S. Saika, T. Akino, and S. Kuninobu, "Lavout abstraction and technology retargeting for leaf cells," IEICE Transactions on Fundamentals of Electronics. Communications and Computer Sciences, Vol. E81-A, No.12 (December 1998), to be published.
- 2. M. Fukui, M. Tanaka, and M. Imai, "Design optimization by using flexible pipeline modules." IEICE Transactions on Fundamentals of Electronics, Communications and Computer Sciences, Vol. E81-A, No.12 (December 1998), to be published.
- 3. T. Shiohara and M. Fukui, "A pin assignment and global routing algorithm for floorplanning." IEICE Transactions on Fundamentals of Electronics, Communications and Computer Sciences, Vol. E81-A, No.8 pp. 1725-1732 (August 1998).
- 4. S. Saika, M. Fukui, N. Shinomiya, and T. Akino, "A two-dimensional placement algorithm for cell synthesis and its application to standard cells," IEICE Transactions on Fundamentals of Electronics, Communications and Computer Sciences, Vol. E80-A, No.10, pp. 1883-1891 (October 1997).
- 5. M. Fukui, A. Yamamoto, R. Yamaguchi, and S. Hayama, "SMILE- Hierarchical layout system for building block LSI," International Journal of Computer Aided VLSI Design, Vol. 1, No. 3, pp. 281-302 (March 1989).
- 6. M. Fukui, A. Yamamoto, R. Yamaguchi, S. Hayama, and Y. Mano," A block interconnection algorithm for hierarchical layout system," IEEE Transactions on Computer-Aided Design of Integrated Circuits And Systems, Vol.CAD-6, No.3, pp. 383-391 (May 1987).
- 7. 福井正博、築山修治、白川功、"ゲートアレイ方式 LSI の端子割り当て問題に対する一手法"、 電子情報通信学会論文誌(C), Vol. J66-C, No. 12, pp. 1172-1179 (1983年12月).
- 8. S. Tsukiyama, I. Harada, M. Fukui, and I. Shirakawa, "A new global router for gate array LSI," IEEE Transactions on Computer-Aided Design of Integrated Circuits And Systems, Vol.CAD-2, No. 4, pp. 313-321 (October 1983).

# 11. 研究集会等発表論文(査読あり)

- 1. M. Tanaka, M. Fukui, and S. Kuninobu, "A precise estimation model of cell area and transistor capacitance for transistor size optimization," in Proc. Synthesis and System Integration of Mixed Technologies, pp. 241-247 (October 1998).
- 2. 田中正和、福井正博、雑賀俊二、"正確な面積/容量推定にもとづくトランジスタサイズ最適化 手法"、電子情報通信学会回路とシステム軽井沢ワークショップ, pp.125-130 (1998年4月).
- 3. M. Fukui, M. Tanaka, and M. Imai," Design optimization by using flexible pipelined modules," in Proc. Synthesis and System Integration of Mixed Technologies, pp. 176-183 (December 1997).
- 4. S. Saika, M. Fukui, N. Shinomiya, and T. Akino, "A two-dimensional placement for cell synthesis," in Proc. on Asia and South Pacific Design Automation Conference, pp. 557-562

(January 1997).

- 通信学会回路とシステム軽井沢ワークショップ, pp. 229-234 (1996年4月).
- Synthesis and System Design, pp. 33-39 (December 1995).
- Synthesis and System Integration of Mixed Technologies, pp. 17-23 (July 1995).
- Asia-Pacific Conference on Circuits and Systems, pp. 184-189 (December 1992).
- 1991).
- 294-299 (January 1990).
- Design, pp. 447-452 (September 1987).
- 1985).
- 465-469 (May 1984).
- pp. 596-599 (October 1983).
- 1009-1012 (May 1982).

### III. その他研究会等発表論文

- 21-26. (1997年10月).
- VLD96-100, pp. 31-38 (1997年3月).
- 手法とその評価,"電子情報通信学会ソサイエティ大会、p. 59 (1996年8月)

5. 福井正博、四宮典子、雑賀俊二、秋濃俊郎、"テクノロジフリーレイアウト合成方法"、電子情報

6. T. Akino, M. Fukui, T. Sawai, and N. Shinomiya, "Relations between logic synthesis and physical synthesis in deep sub-microns," in Proc. International Workshop on IP Based

7. M. Fukui, N. Shinomiya, and T. Akino, "A new layout synthesis for leaf cell design," in Proc. Asia and South Pacific Design Automation Conference, pp. 259-264, (August 1995).

8. N. Shinomiya, M. Fukui, and T. Akino, "A new sea-of-cells style layout synthesis," in Proc.

9. M. Fukui, and A. R. Newton, "Optimum module generation for semi-custom," in Proc. IEEE

10. M. Fukui and A. R. Newton, "Multi-output module generation for semi-custom design," in Proc. Synthesis and Simulation Meeting and International Interchange, pp. 181-190 (June

11. M. Fukui, Y. Tanaka, and T. Akino, " An algorithm for power and ground routing in building block VLSI," in Proc. Synthesis and Simulation Meeting and International Interchange, pp.

12. M. Fukui, A. Yamamoto, R. Yamaguchi, S. Hayama, and Y. Mano, "A new routing algorithm for building block layout system," in Proc. European Conference on Circuit Theory and

13. M. Fukui, S. Hayama, and Y. Mano "A new block interconnection algorithm for VLSI layout system," in Proc. International Symposium on Circuits and Systems, pp. 1039-1042 (June

14. S. Tsukiyama, M. Fukui, and I. Shirakawa, "A heuristic algorithm for a pin assignment problem of gate array LSI's," in Proc. International Symposium on Circuits and Systems, pp.

15. S. Tsukiyama, I. Harada, M. Fukui, and I. Shirakawa, "A placement and routing algorithms for gate array LSI," in Proc. International Conference on Computer Design: VLSI in Computers,

16. S. Tsukiyama, I. Harada, M. Fukui, I. Shirakawa, and H. Ozaki, "An algorithm of global routing for master slice LSI," in Proc. International Symposium on Circuits and Systems, pp.

1. 四宮典子、福井正博、西垣泰男、"リーフセル用配線システム,"信学技報, CPSY97-71, pp.

2. 田中正和、福井正博、"レイアウトを考慮したトランジスタサイジングの一手法,"信学技報,

3. 四宮典子、福井正博、田中正和、雑賀俊二、秋濃俊郎、"屈曲ゲートを用いたレイアウト最適化

- 4. 雑賀俊二、福井正博、四宮典子、秋濃俊郎、"セル合成におけるトランジスタ配置手法"、信学 技報, VLD95-156, pp. 105-112 (1996年3月).
- 5. 四宮典子、福井正博、雑賀俊二、秋濃俊郎、"屈曲ゲートを用いたレイアウト最適化手法," 信 学技報, VLD95-155, pp. 97-104 (1996年3月).
- 6. 福井正博、雑賀俊二、秋濃俊郎、"トランジスタのレイアウトモデルに柔軟性を持たせたコンパ クション方法,"信学技報, VLD95-50, pp. 29-37 (1995年6月).
- 7. 四宮典子、福井正博、秋濃俊郎、"シー・オブ・セルズ型レイアウト・アーキテクチャの提案," 信 学技報, VLD94-115, pp. 45-52 (1995年3月).
- 8. 福井正博、秋濃俊郎、"VLSI のリーフセル合成に関する一手法," 信学技報、VLD94-65, pp. 13-19 (1994年10月).
- 9. 川上善之、山口龍一、福井正博、羽山繁、秋濃俊郎、"論理回路の規則的繰り返しが多く存在 するブロックにおけるセル配置の一手法,"信学技報、VLD89-48 pp. 73-79 (1989年10月).
- 10. 塩原孝弘、福井正博、羽山繁、"フロアプランにおけるピン配置の一手法"、信学技報、 VLD88-87, pp. 9-16 (1989年2月).
- 11. 福井正博、岩崎知恵、羽山繁, "チャネル構造列挙の一手法," 情処研報,DA44-10, pp. 75-82 (1988年10月).
- 12. 福井正博、山本敦志、岩崎知恵、羽山繁, "ブロック形状最適化の一手法," 電子情報通信学 会秋季全国大会, pp. A-1-163<sup>~</sup>164 (1988年9月).
- 13. 福井正博、山本敦志、岩崎知恵、羽山繁, "VLSIレイアウト設計におけるブロック形状ピン配置の最適化の一手法," 信学技報、VLD88-4, pp. 25-32 (1988年4月).
- 14. 重本一郎、福井正博、羽山繁, "自動レイアウトシステムにおけるレイアウト検証の手法," 情報 処理学会第36回全国大会. pp. 2027-2028 (1988年3月).
- 15. 福井正博、塩原孝弘、高木善之、羽山繁, "自動レイアウトシステムにおける遅延時間最適化の手法," 情報処理学会第36回全国大会, pp. 2025-2026 (1988年3月).
- 16. 山口龍一、福井正博、山本敦志、羽山繁, "階層的レイアウトシステムにおけるスタンダードセル自動配線の一手法,"情報処理学会第34回全国大会, pp. 1969-1970 (1987年10月).
- 17. 山本敦志、福井正博、山口龍一、羽山繁, "階層的レイアウトシステムにおけるスタンダードセル自動配置の一手法,"情報処理学会第34回全国大会, pp. 1991-1992 (1987年10月).
- 18. 山本敦志、福井正博、羽山繁、間野洋治郎, "シミュレティッドアニーリング法を用いたスタンダ ードセル自動配置の一手法,"信学技報, CAS86-191, pp. 25-31 (1987年1月).
- 19. M. Fukui, A. Yamamoto, R. Yamaguchi, S. Hayama, and Y. Mano," Hierarchical routing system for building block LSI," 信学技報, CAS87-66, pp. 99-104 (July 1987).
- 20. 福井正博、山本敦志、山口龍一、羽山繁、間野洋治郎, "階層的レイアウトシステムにおける自動配線の一手法,"信学技報, CAS85-149, pp. 9-16 (1986年1月).
- 21. 福井正博、山本敦志、羽山繁、間野洋治郎、"チャネル構成の一手法,"電子情報通信学会 半導体・材料部門全国大会, pp. 70-71 (1985年10月).
- 22. 福井正博、竹田信弘、築山修治、白川功、尾崎弘、"マスタスライス方式LSIに対する一配線 手法,"信学技報、CAS82-148, pp. 55-60 (1982年2月).
- 23. 福井正博、築山修治、白川功、尾崎弘、"チャンネル配線の一手法,"信学技報、CAS81-121, pp. 91-98 (1981年2月).
- 24. 福井正博、築山修治、白川功、尾崎弘、"チャンネル配線の一手法,"電子情報通信学会全国 大会, p. 2-336 (1980年8月).

目 次

| 第1章 | 序論                              | . 1 |
|-----|---------------------------------|-----|
| 第2章 | 大規模集積回路設計とレイアウト合成技術の概要          | .2  |
| 2.  | 1 緒言                            | .2  |
| 2.  | 2 ゲートアレー方式 LSI のレイアウト設計の流れとその課題 | . 5 |
| 2.  | 3 階層的レイアウト設計の流れとその課題            | . 5 |
|     | 2.3.1 チップフロアプランにおける課題           | . 5 |
|     | 2.3.2 ブロックレイアウトにおける課題           | . 5 |
|     | 2.3.3 ブロック間配線における課題             | . 6 |
| 2.  | 4 セルレイアウト設計の流れとその課題             | . 6 |
| 2.  | 5 本研究の位置付けと意義                   | .7  |
| 2.  | 6 結言                            | .8  |
| 第3章 | ゲートアレイ方式LSIの等価端子割り当て手法          | .9  |
| 3.  | 1 緒言                            | .9  |
| 3.  | 2 等価端子割り当て問題の定義                 | 10  |
| 3.  | 3 等価端子割り当てのアルゴリズム               | 12  |
| 3.  | 4 実験と結果の考察                      | 17  |
| 3.  | 5 結言                            | 19  |
| 第4章 | 階層的配置配線におけるフロアプラン手法             | 20  |
| 4.  | 1 緒言                            | 20  |
| 4.  | 2 チップフロアプラン問題                   | 20  |
|     | 4.2.1 レイアウトモデル                  | 20  |
|     | 4.2.2 階層的配置配線フロー                | 22  |
| 4.  | 3 ブロック間配線とピン配置                  | 24  |
|     | 4.3.1 初期配置アルゴリズム                | 25  |
|     | 4.3.2 分散配置アルゴリズム                | 26  |
| 4.  | 4 電源配線                          | 27  |
|     | 4.4.1 電源配線問題                    | 28  |
|     | 4.4.2 電源配線アルゴリズム                | 29  |
| 4.  | 5 ブロック形状最適化                     | 30  |
| 4.  | 6 ブロック面積の推定                     | 33  |
| 4.  | 7 フロアプラン実験例                     | 33  |
| 4.  | 8 結言                            | 34  |
| 第5章 | ブロック間配線手法                       | 35  |
| 5.  | 1 緒言                            | 35  |
| 5.  | 2 配線構造の定義                       | 35  |
| 5.  | 3 概略配線                          | 36  |
|     | 5.3.1 処理概要                      | 36  |
|     |                                 |     |

| 5.3.2 初期配線             |
|------------------------|
| 5.3.3 再配線              |
| 5.4 詳細配線               |
| 5.4.1 処理概要             |
| 5.4.2 ブロックの位置決め        |
| 5.4.3 チャネル構造決め         |
| 5.4.4 チャネル配線           |
| 5.5 実験と結果の考察           |
| 5.6 結言                 |
| 第6章 標準セルの自動合成手法        |
| 6.1 緒言                 |
| 6.2 テクノロジマイグレーション処理フロー |
| 6.3 レイアウト抽象化モデル        |
| 6.3.1 配置要素の抽象化モデル      |
| 6.3.2 配線の抽象化モデル        |
| 6.4 レイアウト再合成処理概要       |
| 6.5 アルゴリズム             |
| 6.6 実験と結果の考察           |
| 6.7 結言                 |
| 第7章 結論                 |
| 謝辞                     |
| 参考文献                   |

# 第1章 序論

高集積化、

高性能化

の進展

近年、大規模集積回路の高集積化および高性能化の要望はとどまるところを知らず、システ ムオンチップと言われるように、1チップ上にメモリやアナログの入出力、プロセッサ等を同時に 搭載されるようになってきている。このような設計規模の増大に対応して、設計効率の向上が重 要な課題となっている。一方、半導体集積回路の微細化技術は、図 1.1 に示すように、2000 年には 0.18µm の時代を迎え、配線遅延の増大や、製造ばらつきの増大、電源電圧降下やノ イズの増大など、設計時に考慮すべき問題も複雑化している。[1]



設計自動化の流れを遡ると、1970年代には、標準セル方式の設計手法が提案された。これ は、NAND やフリップフロップ等の論理要素を標準セルという形で準備し、それらをチップ上に 配置配線する方式である。論理レベルで回路およびレイアウト設計を行うことが可能となったこ とと、標準セル自動配置配線技術との相乗効果によって、回路レイアウト設計効率が大幅に向 上した。1980年代には、論理回路の自動合成技術が実用化され、論理回路設計工数も大幅 に向上した。その後、機能記述からレイアウトを合成するシリコンコンパイラや、規則性の高いレ イアウトを自動化するモジュール合成システムなども提案され、大規模集積回路の設計自動化 技術は産業の発展に多大な貢献をしてきた。 1990年代のディープサブミクロン時代を迎えるころから、信号遅延に占める配線遅延の比

|    | 1988 | 1991       | 1994                 | 1997         | 2000       | 2003       |
|----|------|------------|----------------------|--------------|------------|------------|
| (  | 0.8  | 0.5        | 0.35                 | 0. 25        | 0.18       | 0.10       |
| 5  | 0万   | 100万       | 200万                 | 400万         | 700万       | 1000万      |
|    | 60   | 100        | 160                  | 200          | 300        | 400        |
| _  | _    |            |                      | 動作合成         | 戈 動        | 作合成        |
|    |      |            |                      | 動作合成         | 戈 動        | 作合成        |
|    | 論我   | 里合成        | 論理合成                 | 論理合          | 成論         | 理合成        |
| ゥト | 41   | 自動<br>(アウト | (融合化)<br>自動<br>レイアウト | 自動<br>レイアウ   | + 11       | 自動<br>(アウト |
| im | 0    | 路sim       | セル合成                 | モジュー 合成      | <i>n</i> = | ア流用        |
| D  | Т    | CAD        | TCAD                 | バーチャ<br>ファクト | ルリコン       | カレント<br>設計 |

図1.1 大規模集積回路の規模の増大と設計自動化の変遷

-1-

率が増加傾向を示すようになってきた。しかも、設計規模の増大比率は依然大きく、効率的で かつ物理的条件を考慮したレイアウト算法を深く追及すべき状況にある。本論文は、このような 背景において、主に物理レベル合成・最適化について著者が行ってきた研究をまとめる。

第2章では、用途によって異なる大規模集積回路のレイアウト構造と方式、各方式におけるレ イアウト合成の課題について概説した後、本研究の位置付けと、意義目的について述べる。

第3章では、ゲートアレイ方式LSIの設計TAT(turn around time)を短縮するために有効な 等価端子割当手法について提案を行い、その有効性を実験によって確める。

第4章では、多くの機能ブロックから構成されるシステムLSI に対するレイアウト合成のため のチップフロアプラン手法の提案を行う。また、フロアプランの部分問題へのアプローチとして、 ブロックの外部ピン配置および概略配線手法、および電源配線手法、ブロック形状最適化手 法について提案し、第2章で示したレイアウト合成の課題に対して有効であることを、理論的、 実験的に示す。

第5章では、実用的なブロック間配線に対して、面積最小化と遅延条件の満足の両方を実 現できる方法について提案し、いくつかの実 LSI への適用例によって、その効果を示す。

第6章では、最近、とみに重要性を増してきたライブラリセルの自動生成、および、再利用技 術に関する提案を行う。特に、プロセステクノロジが更新されたときにレイアウトセルを再利用す るための方法として、従来のコンパクション手法では困難とされていた配線ジョグ位置の最適化 に関して有効な方法を提案する。実際のライブラリ設計への適用例によって、本手法の有効性 を示す。

最後に第7章で、本研究によって達成された内容をまとめ、今後の課題に対する展望を述べ 3.

# 第2章 大規模集積回路設計とレイアウト合成技術の概要

# 2.1 緒言

一般に大規模集積回路はその開発方法により、大きく、セミカスタムLSIと、カスタムLSIの2 種類に分類される。セミカスタムLSIは、スタンダードセル方式、ゲートアレイ方式等に代表され、 用途としては多品種少量生産向きである。ゲートアレイ方式は、あらかじめトランジスタをアレイ 状に配置し、拡散工程までを済ませたマスタースライスを準備しておき、受注に応じて金属配 線以降の工程をす方式である。拡散工程までが事前に行われているので、受注から出荷まで の製造期間が短い。ゲートアレイ方式LSIのレイアウト構造の例を図 2.1 に示す。アレイ状に配 置されたセル行間に配線を施すためのチャネル領域を設ける。セル上およびチャネル上に配 線を施すことによって、論理機能を持つ回路が実現される。



スタンダードセル方式のレイアウト構造を図 2.2 に示す。スタンダードセル(標準セル)と言わ れる論理機能を有するセルをあらかじめライブラリとして準備しておき、これらのセルを LSI チッ プ上に配置配線することによって、レイアウトを実現する方式である。同方式は、レイアウト設計 後、製造工程を実施するので、配線領域をあらかじめとっておく必要は無く、必要最小限のチ ャネル領域を確保すれば良い。ゲートアレイ方式に比べて製造工程に時間がかかるが、セル のレイアウトや配線領域が最小化できるため面積効率が良い。ゲートアレイよりは多量生産向き である。

図 2.1 ゲートアレイ方式 LSI のレイアウト構造例



図 2.2 スタンダードセル方式 LSI の例

カスタム方式は、特に多量生産向き LSI の設計に適用されるものであり、面積や遅延時間を 最大限に抑える方式である。同方式は、開発工数を抑えるために、標準セルによって構成する ブロックも含むが、多くはカスタム設計によって得られるブロックから構成される。同方式は比較 的大規模なものが多く、図 2.3 に示すようなビルディングブロック方式設計が持ちいられる。



図 2.3 カスタム LSI の例

- 4 -

2. 2 ゲートアレイ方式 LSI のレイアウト設計の流れとその課題 ゲートアレイ方式 LSI では、配線のためのトラック数があらかじめ定まっている。レイアウトエ 程は、配置、概略配線、詳細配線の順に行われるが、詳細配線の段階で配線が不可能とわか れば、設計修正が生じ、大幅な設計コスト増につながる。このような不利益を回避するために、 設計のできるだけ初期段階で後段の工程を簡単化する処理が求められる。

2.3 階層的レイアウト設計フローとその課題 前述の図 2.3 に示したビルディングブロック方式は、各々の機能ブロックを設計した後、それ らをブロック間配線によって組み上げるという階層的なレイアウト方法が用いられる。同方式の レイアウト設計は、概ね、(1)チップフロアプラン、(2)ブロックレイアウト、(3)ブロック間配線の 3段階から構成される。本節ではそれぞれの処理内容と課題について述べる。

2.3.1 チップフロアプランにおける課題 ブロックの配置とブロック形状の最適化、ブロック外部ピン配置と概略配線、電源配線経路等 を決定する処理である。実用上、以下の点を考慮する必要がある。 (i) ブロックの概略配置は人手で決める場合が多い。その場合には、できるだけ指定され た配置を尊重して、ブロックの形状最適化を行う。 (ii) フロアプラン設計は、形状可変なブロックに対して形状に対する要求を与え、各々ブロ ックが同要求に近いサイズで設計されること想定している。形状に対する要求と実際に設 計されるブロックの形状や面積との間にずれがあったり、ブロック間配線領域の推定精度 が低い場合には、無効領域やチップ面積増の原因となる。 (iii) ブロック外部ピン配置およびブロック間概略配線は、ブロックおよびチップ面積、ブロッ ク間配線長に与える影響がそれぞれ大きい。ブロック間の面積がチップ全体の約4~6割 程度を占めることや、ブロック間配線遅延がシステム速度に大きな影響を与えるなどの要 因を考えると、ブロック間配線の最適化がブロック面積最小化以上に重要である。しかし ながら、外部ピンが局所的に集中して配置されると、ブロック内およびブロック間の一部に 配線が集中し面積増をもたらすので、外部ピンをある程度分散させることも重要である。 (iv) 電源配線に関しては、各々のブロックの消費電力は動作状態に応じて常に変化して いることを考慮する必要がある。どの状態でもエレクトロ・マイグレーションや熱破壊が起き ないように配線幅を確保し、ブロック電源端子の電圧低下を抑え、しかも、チップ面積を 最小化することが重要である。従来手法では、各々のブロックの最大消費電流や、平均 消費電流に基づき電源幅を求めるものは存在したが、必要最小幅にならず面積の増大 を招いたり、すべての状態に対して障害が起きないことを保証できないなど課題があった。

2.3.2 ブロックレイアウトにおける課題 標準セル方式ブロックの配置配線に対しては、タイミングを満足し、かつ、面積を最小化する

- 5 -

配置配線が求められる。[2,3] モジュール合成に関しては、メモリ等のセル2次元アレイを合 成するのに適したアレイコンパイラー[4]や、データパス等には、セル合成を用いてトランジスタ レベルからブロックを合成する方法[5] などが用いられる。いずれに対してもも人手設計並み の高集積度と、設計期間の短縮が求められる。

# 2.3.3 ブロック間配線における課題

ブロック間配線は、レイアウトが完了したブロック間の配線を行う問題である。同問題に対して 提案されている方法は、大きく2種類に分割される。1つは線分探索または迷路法を用いてチッ プ全体を同時に配線する手法[6,7]であり、もう一つはブロック間配線領域を隣接するブロック 間の帯状の配線領域(チャネル)に分割し、各チャネル毎に配線を行う手法である。[8.9]

線分探索を手法は、ブロック上の空き領域を自由に通過でき、多層化への展開が容易であ るなどの柔軟な配線ができる反面、あらかじめブロック位置を固定してから配線を行うため未配 線や無効領域が生じやすい。また、チャネル配線手法より同時に取り扱う領域が広いため、計 算時間および記憶容量が大となる。一方、チャネル配線手法は、チャネル構造が決まれば、高 速でかつ未配線を生じずに配線を行なえるため、比較的大規模なチップに対しても効率的に レイアウトできるメリットがある。

ブロック間配線はブロック内以上に、チップ面積や遅延に及ぼす影響が大きいため、タイミン グを考慮したチップ面積最小化手法が強く求められる。

# 2.4 セルレイアウト設計の流れとその課題

標準セルや 1/0 セル等の トランジスタレベルのレイアウト設計は、高集積化が要求されるこ とから、従来は人手設計が中心であった。しかし、近年のプロセス設計ルールの複雑化、設計 量の増大に伴い、設計自動化の要望が高まっている。[10]

セル設計は、新規に回路からレイアウト設計までを通して行う場合もあるが、設計期間の大 幅な短縮要望により、古いプロセスで設計した回路やレイアウト設計を流用し、新しいプロセス にあったレイアウト設計を行うテクノロジマイグレーションの重要性がより高まっている。

回路からレイアウトまでの設計フローとそれぞれの課題を以下に示す。

- (1) 回路設計:動作記述からトランジスタレベル回路を設計する処理である。2進関数のグラ フ的表現方法である BDD(Binary Descision Diagram)からトランジスタのスイッチングネット ワークを合成する方法[11,12]が提案されており、パストランジスタロジックに対する実用化 が進んでいる。しかしながら、一般のトランジスタ回路を合成する技術に関して十分有効 な手法は提案されていない。
- (2) トランジスタサイジング:回路構造が決まった後に、各々のトランジスタサイズを最適化し てやることによって、所望の性能の回路を得る処理である。[13] トランジスタの性能は、 ゲート幅だけでなく、拡散やゲート、配線等の寄生容量に大きく依存するため、それらを

考慮して回路最適化を行うことが重要である。[14]

- 積以下にすることが求められる。[17]
- 等の問題がある。[19]
- (6) 最終レイアウトからの回路・遅延パラメータの抽出とライブラリ登録。

テクノロジマイグレーションにおいては、上記の(2)および(5)の処理が必要であり、課題とし ても同様の課題が存在する。

# 2.5 本研究の位置付けと意義

以上で述べたように大規模集積回路のレイアウト合成問題は複雑多岐に渡り、しかもその規 模が増している。効率良く良好な解を得るためのレイアウト合成技術の研究は、今後も益々重 要となることが予想される。本研究は、このような大規模化・複雑化する大規模集積回路のレイ アウト合成問題について検討を加え、新しい有用な手法を構築することを目的とする。 本研究の第1の意義は、ゲートアレイ方式LSIにおいて、配線成功率を高め、手戻りの少な い設計フローを構築し、設計TATの短縮を図ることである。ゲートアレイ方式 LSI のレイアウト 設計において、チャネル配線を容易化するための等価端子割当手法について述べる。本手法 の特徴は、チャネル配線時に問題を複雑化する主要因である上下制約をできるだけ取り除い てやることであり、実験により配線率が向上することを示す。[22]

本研究の第2の意義は、大規模化するフルカスタム方式LSIの設計工数と期間を短縮すると 同時に、面積・遅延において良好な結果を得ることである。本論文では、ブロックの形状や、ブ ロック間配線が占める面積に対する推定精度を向上させ、チップフロアプラン時の推定値と、ブ ロックレイアウトおよびブロック間配線の実現後の結果とのずれを極力減らし、無駄な領域の発

(3) トランジスタ配置: トランジスタの配置を求める処理である。 1985 年に上原他[15] による 1次元トランジスタ配置のセル合成が提案されて以来、数多くのシステムや手法が提案さ れている。[16] しかし、人手設計されるセルは1次元のみならず、2次元的な配置によっ て面積削減を図っている。自動化に於いても、2次元配置モデルを用いて人手設計の面

(4) トランジスタ配線: トランジスタ間の配線を行う処理である。[18,19] セル内のトランジスタ 間配線においては、セルの高さ制約の考慮や、トランジスタからの配線引き出し位置決め

(5) コンパクション: トランジスタやコンタクト等の配置要素と配置要素間の配線を含む図形を デザインルールを満たし、かつ、最小面積となるようにコンパクションする処理である。

最近、プロセス設計ルールの複雑化により、プロセス開発からデザインルール決定まで の期間が長期化する傾向にある。また、デザインルールが一旦決定しても、後の小変更 が多発している。このため、コンパクション処理の重要性が増している。従来法の中では、 縦あるいは横のいずれかの方向のみを扱う1次元コンパクションより、それらを同時に扱う 2次元コンパクションが効果的である。[20,21] しかし、配置要素間の配線のジョグ発生 およびコンパクションを効果的に扱うことが、困難な問題として残っている。[20]

-7-

生をできるだけ抑える手法を提案する。[23] 同処理フローに関しては、ブロックの配置と形状 最適化のそれぞれの処理を分離する方法を提案する。与えられたブロック配置の隣接配置関 係を崩さない範囲でチャネル構造を列挙し、それらの中から最も良好な解を選択する。更に、 チップフロアプランの部分問題として、チップ面積の最小化とブロック間配線長の最小化を目 標としてブロック外部ピン位置の最適化を行うピン配置手法の提案[24]と、動的な動作条件を 考慮に入れた電源配線手法を提案する。[25] 次に、ブロック間配線問題に対しては、タイミン グ制約を満足しつつ配線面積を最小化する概略配線方法、ブロック間の配線を複数の直線型 および L 字型チャネルに分割し、全ての配線チャネルの処理順を決定する方法、ブロックの相 対距離を最適化し配線後のチップ面積を最小化する方法等についてそれぞれ提案し効果を 示す。[26]

本研究の第3の意義は、プロセス変更や設計変更に柔軟に対応できるレイアウト設計再利用 技術を構築することである。トランジスタレベルからのレイアウト合成の要素技術として用いられ るレイアウト再生成手法について提案する。従来のレイアウト再生成技術として良く用いられる コンパクション方法では、配線ジョグの発生をどこにどれだけ設けるかを決定することが困難な 問題として知られていたが、本手法では配線情報を一旦抽象化した後、図形の移動と同時に 配線を再生成する方法を用いる。実際のライブラリセル設計に用いて良好な結果を得ることを 示す。[27]

### 2.6 結言

本章では、大規模集積回路のレイアウト設計について概要を示しレイアウト合成技術の直面する課題、および、本研究の位置づけと意義について述べた。

ゲートアレイ方式 LSI は、配線領域が固定されるため、配線の成功率を高めることが全体の 設計期間短縮において重要である。本研究では、等価端子割り当て手法と有効性を示すこと を第1の意義とする。

次に、大規模なカスタム方式 LSI に対する階層的レイアウト設計に対しては、高精度なブロ ックおよびブロック間配線の面積推定に基づくチップフロアプランの最適化が重要である。また、 ブロック間配線は、未配線を無くすことによりレイアウト設計を効率化すると共に、タイミング制約 を満たす面積最小の解を得ることが重要である。本研究においては、チップフロアプランとブロ ック間配線に適した処理フローと最適化手法を提案し、大規模化するフルカスタム方式LSIの 設計工数削減し、かつ、面積・遅延において良好な結果を得ることを第2の意義とする。

最後に、標準セル設計に関しては、最近のプロセス設計ルールの複雑化の影響により、テク ノロジマッピング、特に、コンパクション自動化の要望が増している。本研究においては、従来 困難であった配置要素間の配線のジョグ発生および配置要素の移動を同時に扱う問題に対 する手法提案を行い、その有効性を示すことを第3の意義とする。

# 第3章 ゲートアレイ方式 LSI の等価端子割り当て手法

# 3.1 緒言

集積回路技術の進歩に伴い、少量多品種のLSIの生産量が増大しているが、このようなLSI を効率良く生産するために、ゲートアレイ方式LSIが良く用いられ、又そのレイアウト設計には 自動配置配線設計システムが運用されている。[28,29] このゲートアレイ方式LSIにおいては、 配線領域があらかじめ固定されているため、配線が一部のチャネルに集中せずチップ全体に 均一に分布することが、100%の配線率を得る上で重要となる。このため、配線設計は通常各 ネットのチャネル単位の大まかな配線経路を求めるグローバル配線、次に各ゲートセルが持つ 論理的に等価な端子のうちのどれに各ネットの信号線を接続すべきかを決定し、チップ全体の 配線問題をいくつかの2行2層配線問題に分割する端子割り当て、最後に各チャネルでの詳 細な配線を決定するチャネル配線の成否に大きな影響が知られているが、これに対する有効な 手法はあまり報告されていない。

本章では、このシステムにおいて用いられている端子割り当て手法について考察する。本手 法は、各チャネルにおける上下制約グラフ[30,31]上のサイクルの個数および配線密度を減少 させることを目的として、全てのチャネルを総合的に考慮しつつ端子割り当てを行うものである。 本手法の効果を調べるために、実際の回路例に対して、乱数を用いて端子割り当てをおこなっ た場合との比較もおこなったので、それについても報告する。

# 3.2 等価端子割り当て問題の定義

本論文で対象とするゲートアレイ方式LSIのチップ構造を図 3.1 に示す。各セルは一つの論 理ゲートの機能を持ち、同図に示すように、所下の辺上に電気的に等価な端子を持つ。 1 /Oセルに囲まれたセル以外の部分が配線領域で、これは水平及び垂直チャネルに分けられ る。各垂直チャネルにおいて、一つのセル行上の隣接する2つのセルに挟まれた部分を貫通 セル(feedtrough cell) と呼ぶ。

グローバル配線は、与えられた各ネットの配線経路がどのチャネルを通過するかを決定する ものであるが、(例えば図 3.2(a)参照)、この配線経路に対して、端子割当問題を記述するため に、次のような信号ピンおよびその接続要求を定義する。すなわち、各ネットの配線経路がセ ルに接続する部分及び貫通セルを通過する部分のそれぞれに対応して信号ピンを設け、これ らに付随して、各チャネルでの配線経路の方向を接続要求として表わす。例えば、図 3.2(a)の ような配線経路に対しては同図(b)のような *P<sub>1</sub>* から *P<sub>6</sub>* の信号ピン、及び矢印で示されるような 各信号ピンの接続要求が与えられる。



図 3.1 ゲートアレイ方式 LSI のレイアウト構造



それに対する信号ピンと接続要求の例(b)

同図 3.2(b)において、信号ピン  $P_2$  および  $P_6$  はゲートの入力端子に対応して設けられたもの であるから、各セルの論理的に等価な端子が存在する垂直トラック 8 または 9 のいずれに 割り当てても良く、 $P_3$  や  $P_4$  も各貫通セル内の垂直トラック 5 又は 6 のいずれに割り当てても

良い。それに対して、信号ピン  $P_1$ は、ゲートの出力端子に対応して設けられたもので、トラック 2 にのみ置ける。このような各信号ピンを置くことができる対直トラックをPの割当て可能トラッ クと言い、Pの割当て可能トラックの集合をT(P)と表わす。|T(P)|=1であるような信号ピ ンPを固定信号ピン、それ以外を浮動信号ピンと言う。又、信号ピンPが属するネットをN(P)で表わす。

このように、ネットをセルのどの端子に接続すべきか、あるいはネットの配線を貫通セル内の どの垂直トラックに通すべきかという問題を、対応する信号ピンをどの垂直トラックに置くかという 問題として表現すれば、本文で考察する端子割当問題とは、各セル行内にあるすべての信号 ピンを以下にして重複なく割当可能トラックに割り当てるかという問題となる。この端子割当てに より、チップ全体の配線問題は、全ての水平チャネルと左右両端の垂直チャネルにおける2行 2層配線問題に帰着することができる。

ところで、各水平チャネルでの配線を、一つの層に置かれた水平線分(幹線)およびもう一方 の層に置かれた垂直線分(支線)とそれらを結ぶスルーホールによって実現する場合には、上 下制約グラフ *G*, で表現される各幹線間の上下制約が生じる。良く知られているように、この上 下制約グラフ *G*, がサイクルを含む場合には、配線を実現するために図 3.3(a) のネット1、3、 および 8 のような幹線分割を行わなければならない。このような幹線分割は、スルーホールの 個数を増加させ LSI 設計上好ましくないばかりでなく、これらを効率的に扱う良いアルゴリズム が無いため、100%チャネル配線ができないことが多い。

例えば、図 3.3(a)の端子割り当てを変更し、同図(b)のようにすれば、幹線分割は不必要となり、必要な水平トラック数も減少する。又、チャネル配線において、必要な水平トラック数はその チャネルの配線密度の最大値以上であるから、これを減少させる端子割り当てを行うことも重要 である。例えば、図 3.3(a)の左から第3番目の端子列上の配線密度は3であるが、同図(b)のよう な端子割り当てを行うことにより、配線密度を2とすることができる。



図 3.3 等価端子割当と必要なトラック本数



以上の点を考慮し、本文では各水平チャネルにおいて、次の条件を満たす結線要求を生成 するような端子割り当てを見い出す発見的な手法を提案する。

(I) 上下制約グラフのサイクルが少ない。

(II) 最大密度が(チャネルの容量 - α)

(III) 上下制約グラフの辺の個数が少ない。

ここで、チャネルの容量とは、その水平チャネル内で利用しうる水平トラックの個数であり、又 αは外部から入力するパラメータで、0≦α≦2である。以下では、求める割り当てが条件(I)を 満たすことを最優先とし、次に条件(II)を優先する。

# 3.3 等価端子割り当てのアルゴリズム

ここで提案する等価端子割り当て手法は、各浮動信号ピン Pの割り当て可能トラック集合 T(P)の要素を順次減らしてゆき、全ての信号ピンを固定信号ピンとして終了する。

いかでは、まず条件(I)および条件(II)を満たす割り当てを求める手続きについて述べ、その後 全体のアルゴリズムを述べる。

条件(1)を満たす割り当てを見い出すため、各セル行 i に対して、以下に示すようなラベル付 き有向グラフ  $G_{L}(i)$  を導入する。  $G_{L}(i)$  の各頂点は、セル行 i に存在する信号ピン P に対 応し、各有向辺  $e = (P_i, P_k)$ とそのラベルを次のように定めるものとする。

(1) P<sub>k</sub> が固定(浮動)信号ピンであり、セル行 i のすぐ上の第 i+1 セル行内に、ネット N(P<sub>i</sub>) にぞくする浮動(固定)信号ピン  $P_b$  で  $T(P_b) \supset T(P_b) \subset T(P_b) \subset T(P_b)$ であるも のが存在する場合には、辺  $e = (P_j, P_k) を G_L(i)$ に付加し、これに正のラベル  $P_h$ を付ける。 (2) P, が固定信号ピンであり、第 i + 1 セル行内に、ネット N(Pi) に属す固定信号ピン P, で、 $T(P_h) = T(P_k)$ であるものが存在する場合には、辺 $e = (P_i, P_k)$ を $G_i(i)$ に付加し、 これに負のラベル - P,を付ける。

グラフ  $G_{L}(i)$  において、正のラベル  $P_{k}$ をもつ辺  $e = (P_{j}, P_{k})$ が存在するということは、第 iセル行の信号ピン $P_k$ と第i + 1セル行の信号ピン $P_k$ が同一垂直トラックに割り当てられるなら ば、第*i*および*i*+1セル行の間の第*i*+1水平チャネルにおいて、ネットN(P<sub>i</sub>)とネット N(Pk)の間に上下制約が生じるということを示している。一方、負のラベル - Pkを持つ辺  $e = (O_1, O_k)$ が存在するということは、そのような上下制約がすでに確定してしまったことを示 している。従って、グラフ G<sub>L</sub>(i) がサイクルを含み、かつ現在の固定信号ピンの割り当てを変 更しないならば、第iあるいは、第j+1セル行内の浮動信号ピンの今後の割り当てによっては、 第i+1水平 rp チャネルにおける上下制約グラフにサイクルが生じることになる。

しかし、G<sub>1</sub>(i) のサイクルが正のラベル P<sub>2</sub>を持つ辺を含むならば、信号ピン P<sub>2</sub>または P<sub>4</sub> のいずれか一方は、浮動信号ピン、他方は、固定信号ピンであるが、その浮動信号ピンの割り 当て可能トラック集合から、もう一方の固定信号ピンが割り当てられたトラックを取り除くことによ

り、この辺eを除去し、上下制約グラフ上にサイクルを生じないようにすることができる。 たとえば、図 3.4(a) に示すような状況に対して、G,(i) は、同図(b)のようになり、このグラフ のサイクルを解消するために、 $T(P_2) = \{t_2, t_3\}$ から、 $T(P_3) = \{t_2\}$ を取り除くと同図(c)のよ うな信号ピンの割り当てが得られ、ここに対応する G,(i) は同図(d)のようになる。 このグラフ G,(i) は、手続きの進行に伴って、セル行 iのある浮動信号ピンが固定信号ピン に変化するごとに G<sub>L</sub>(i) を更新しつつ作成する。この更新時に、正のラベルを持つ辺を含む サイクルが生成されたならば、このサイクルを解消するための操作を行い、さらに G,(i) を更 新する。また、同一セル行の同一トラックに信号ピンが重複して割り当てられることの無いよう に、固定信号ピンPが生成されるごとに、Pと同じセル行にある信号 P'で、 $T(P') \supset T(P)$ となるもの全てに対して、T(P')からT(P)を取り除くという操作を行う。





以下に、G<sub>1</sub>(i)を更新する際の一連の操作(手続きFIX)を記述するが、FQは、グラフ G,(i)の更新の手続きがまだ実行されていない固定信号ピンを保持するキューである。また、 SP(i,t)はセル行iの垂直トラックt上に割り当てることのできる信号ピンの集合を示し、rp は、信号ピンPが属するセル行を表わす。さらに、S(P)は、信号ピンPが属するセル行ある いは垂直チャネルとしたとき、ネットN(P)に属しかつセル行 rp-1 に含まれる信号ピンの内、



(b)



図 3.4 グラフ G<sub>L</sub>(i)に対する処理例

COL にあるもの、COL の左にあり COL にもっとも近いセル列あるいは垂直チャネル上にある もの、および COL の右にあり、COL に最も近いセル行あるいは垂直チャネル上にあるものの 集合である。図 3.2 の例では、 $S(P_4) = \{P_3\}, S(P_3) = \{P_1, P_2\}$ となり、たとえ P, の属するセ ルの右隣のセルにこのネットの信号ピンがあったとしても、それはS(Pa)に含まれない。

# <手続き **FIX**>

- 1. キュー FQ が空でない限り、FQ から固定信号ピン Pを一つ取り出し、以下の 2.~5. の操作をおこなう。ただし、Pの割り当てられたトラックをt。とする。
- 2.  $SP(rp_1, t_n)$ の要素が唯一つであり、かつそれが Pと同ネットに属さない時、それを Iと し、後述の手続き ADJ1 (1,P) を行う。それ以外の時、SP (rp-1,t,)の各要素 1 につ いて、 $N(I) \neq N(P)$ の時に限り、後述の手続き ADJ2 (1, P)を行う。
- 3. SP(rp, t,) の要素が唯一つであり、かつそれが P と同ネットに属さないとき、それを u と し、手続き ADJ (P, u) を行う。それ以外の時、 $SP(rp + 1, t_n)$  の各要素 u について  $N(u) \neq N(P)$ の時に限り、後述の手続き ADJ2 (P, u)を行う。
- 4.  $SP(rp, t_n)$ の要素の内、P以外の各要素 qについて、T(q)から  $t_n$ を除去する。この とき、q が新たに固定信号ピンとなった場合には、q を FQ に入れる。そうでない場合に は、SP(rp+1, t,)の要素が唯一つである時に限り、その要素を u とし頂点 q に入る  $G_{L}(rp)$ の辺でラベルが u のものを全て  $G_{L}(rp)$ から開放除去する。
- 5. 1. へ戻る。

# <手続き ADJ1 (1, u)>

信号ピン1及び u は共に固定信号ピンであり、r,=r, +1 である。

- 1.  $G_{I}(r_{I})$ 上で L に入る辺を全て開放除去し、さらに S(u) の各要素 a に対して、辺 e =(a,1)を作り、そのラベルを - uとする。
- 2.  $G_{L}(r_{I})$ 上で I を含む強連結成分[31]  $G_{I} = [V_{I}, E_{I}]$ を求め、 $|V_{I}| = 1$  であるか、ある いは E, 中に正のラベルを持つ辺がなければ終了する。あればそのような辺 e=(a, b) を選び、そのラベルをxとして3。を行う。
- 3. 信号ピン b 及び x の内、浮動信号ピンである方の割当可能トラックの集合から、固定信 号ピンであるほうが割当られたトラックを取り除き、更に、G, (r,)上で b に入る辺の内、ラ ベルが x であるもの全てを開放除去する。この時、新たな固定信号ピンが生成されたな らば、それをFQに入れて2。に戻る。

<手続き ADJ2 (1, u)>

信号ピン1及び u の内、どちらか一方は、固定信号ピンであり、他方は浮動信号ピンである。

- に対して、辺 e=(a,1)を作り、そのラベルを u として終了する。
- 生成されたならば、それを FQ に入れて終了する。

次に、条件(II)を満たす割当を見い出す手続きについて考察する。まず、各チャネルを図 3.5 に示すような領域に分割し、各領域において、その上下のセル行に属する信号ピンの割 当ての中で、その領域内の最大配線密度を(チャネルの容量 -α)より大とするような割当てが ある場合にその領域を密領域、そうでない場合にその領域を疎領域とよぶ。 端子割当ての進行に連れて、各信号ピンPの割当て可能トラックの集合T(P)が変化す るために、いくつかの領域において、その領域内の可能な最大配線密度が減少し、初め密領 域であったものも疎領域に変わることがある。端子割当てが条件(II)を満たすためには、すべて の領域が疎領域となって端子割当てが終了しなければならない。



密領域を疎領域に変えるように T(P)を変更して行くことができるように、各信号ピン Pに 対して、TYPEを次のように定義する。TYPEは、S, L, 及び R の3つのフラグからなる集合 {S, L, R} の部分集合で、信号ピンP が存在するセルあるいは貫通セルのすぐ上あるいは、 すぐ下の領域が密領域であり、

1. S(u)の要素で  $G_{L}(r_{I})$ において、1の子孫であるものがなければ、S(u)の各要素 a

2. さもなくば、信号ピン1及び u の内、浮動信号ピンである方の割当可能トラック集合から、 固定信号ピンであるほうが割当られたトラックを取り除く。この時、新たな固定信号ピンが

図 3.5 水平チャネル上の領域

- (i) その密領域で、Pの接続要求が左(右)へ向かう矢印を持ち、かつ、右(左)へ向かう矢 印を持たない時、TYPE(P)はフラグ L(R)を含み、
- (ii) その密領域で、Pの接続要求が左あるいは右へ向かう矢印のみからなる場合には、 TYPE(P)は、フラグSを含む。

例えば、図5に示された信号ピンP, P, P, およびP4に対してTYPE(.)はそれぞれ、Ф 

信号ピンPのTYPE(P)がフラグRを含みLを含まない場合ならば、PをT(P)に属す割当 て可能トラックのなかで、できるだけ右に割り当てることにより、P が存在するセルあるいは貫通 セルが接する蜜領域での配線密度を減少させる可能性のあることがわかる。フラグSは、この ような割当てを行う際に、どの信号ピンを優先するかを決定するために用いられる。

各信号ピンPのT(P)が変化するのは新しく固定信号ピンができたときのみであから、密 領域を疎領域に変更したり、TYPEを更新したりする操作は、新しく固定信号ピンが生成され る毎に行えば良い。その手続きの詳細はここでは、省略するが、手続きFIXの操作5のところに 正しく組み入れているものとする。以下に端子割当て手法(手続きPIN-ASSIGN)の概略を 示す。

# <手続き PIN-ASSIGN>

[操作1(初期化)]各セル行iに対して、以下の操作を繰り返す。

- 1. G,(i)を頂点だけからなるグラフとし、キュー FQ を空とする。
- 2. 各垂直トラック t に対して SP(i, t)を求める。
- 3. セル行 *i* に属する各信号ピン *P* に対して、*T*(*P*) 及び *S*(*P*)を求め、*TYPE*(*P*)を空 とする。

[操作2(TYPEの初期化)] 各領域Aに対して、それが密領域か否かを調べ、密領域ならば 以下の操作を行う。

1. 領域 A 内で左(右) へ向かう接続領域を持ちかつ右(左) へ向かう接続要求を持たない信 号ピンP に対して、TYPE(P) にフラグ L(R)を立て、PのAにおける接続要求が左あ るいは右方向のみであるならば、フラグSも立てる。

[操作3( $G_L(i)$ の初期化)]各固定信号ピンPをFQに入れた後、手続きFIXを行う。 [操作4(併合の処理)] ある領域において、その上下のセル行に同一ネットに属する信号ピン があり、それらが共通の割当て可能トラックを持つならば、これらの信号ピンを同一の垂直 トラックに割り当てる方が、配線密度を下げ、上下制約を作らないという点で有利である。 そこで、このような信号ピン  $P_i$  及び、 $P_k$  に対して、常に  $T(P_i) = T(P_k)$  となるような制限を 与え、これらが同一の垂直トラックに割り当てられるようにする操作を、P.とP.の併合という。 この併合の操作を全ての密領域に対して行った後、疎領域に対して行う。この時、新たに

固定信号ピン Pが生じたならば、そのたびに PをFQに入れ、手続きFIXを行う。 [操作5(浮動信号ピンの位置決定)] 浮動信号ピンが存在していなければ終了。存在するなら ば、最も多数の密領域に接するセル行をi,とし、第i,セル行から始めて第r セル行まで、 その後に、第 i.-1 セル行から始めて、第1セル行まで以下の操作を繰り返す。

- 操作を行う。
- T(P)の中で、最も左(右)のトラックをtとし、 $T(P) = \{t\}$ とする。
- 生じないように Pが割当られるトラック tを選ぶ。 i=i。の場合には、任意にtを選ぶ。
- (iii) PをFQに入れ、手続きFIXを行った後、2。へ戻る。

この手続きのように、信号ピンの割当を1つずつ発見的に決定していく方法では、処理の途 中で T(P)が空となる信号ピン Pが生じることもある。このような場合には、そのような信号ピン P が属するセルあるいは、貫通セル内に属する信号ピンを任意に再割当する。この割当により、 このセルあるいは貫通セルの接する水平チャネルにおいて、上下制約グラフがサイクルを持っ たり、併合した方がよいような信号ピンが併合されなかったりする。

### 3.4 実験と結果の考察

本端子割当手法を FORTRAN を用いてプログラムし、我々の自動レイアウトシステムに組み 入れて、比較的小さな回路に対して実験を行ったところ表1のような結果を得た。図 3.6 は回路 C のチャネル配線も行った最終のレイアウト結果の一部を示す。使用した計算機は NEC-ACOS1000 である。さらに、本手法の評価を行うために、表1の3つの例題について、乱数を用 いて各ピンの割当を行い、その結果に対してチャネル配線を施した場合の各水平チャネルで の配線結果と、本手法を用いた場合の配線結果を比較してみた。その結果を図 3.7 に示すが、 ここで、横軸の番号は水平チャネルの番号であり、縦軸は各水平チャネルの配線に要した水平 トラックの本数とそのチャネルの容量 c との差 (d - c) である。又、丸印 • が乱数による場

-16-

1. 現在処理中のセル行を iとし、セル行 i に浮動信号ピンが存在する限り 2. を行う。 2. セル行 i の浮動信号ピン P で、その TYPE(P)が  $\{S, L\}$  あるいは、 $\{S, R\}$ 、 $\{L\}$ あるいは{R}、およびそれ以外のものの集合を、それぞれ X, Y, および Zとし、以下の

(i)  $X \neq \Phi$  ならば、X から任意の信号ピン Pを選び、 $X = \Phi$  かつ  $Y \neq \Phi$  ならば、Y から任意の信号ピンを選ぶ。この Pに対して、TYPE(P)がフラグ L(R) を含むならば、

(ii)  $X = \Phi$  かつ  $Y \neq \Phi$  ならば、Z の中から、割当可能トラックの個数が最小の信号ピン Pを一つ選ぶ。T(P)の中から、条件(III)をできるだけ満たすようにトラック tを一つ選 び、 $T(P) = \{t\}$ とする。すなわち、 $i \neq i$ 。の場合には、第iセル行とその直前に 2。 の操作が終了したセル行との間の水平チャネルにおいて、できるだけ上下制約関係が

-17-

合、四角印 ・が本手法による場合の結果を表わしている。この結果より、本手法が各チャネル の最大配線密度を減少させるのに有効であることが分かる。特に、同図 3.7(b) の第11および 第12水平チャネルでの結果より、本手法がチップ全体を総合的に考慮している様子が伺える。 本手法を用いた場合には、3つの例題のどのチャネルにおいても100%配線が実現できた。し かし、乱数を用いて割当てを行った場合には、星印 \*をつけた水平チャネルにおいて、巡回 配線要求の原因により100%配線が不可能となったので、各チャネルから1つのネットを取り除 いてチャネル配線を行った。図7はその結果を示している。また、いくつかのチャネルにおいて、 上下制約グラフの上にサイクルが生じた。そのような水平チャネルの丸印 •の傍に、上下制約 グラフ中の2個以上の頂点を持つ強連結成分の個数を())に示した。



図 3.6 回路Cのレイアウト図の一部



(a)



図 3.7 本手法とランダム割当の場合との比較、(a) 回路 A, (b) 回路 B, (c) 回路 C

# 3.5 結言

本文では、端子割り当ての一手法を提案した。本手法は、各水平チャネルにおいて、上下 制約グラフができるだけサイクルを持たず、かつ、最大配線密度が(チャネルの容量 –  $\alpha$ ) 以下となるように、最終的に各信号ピンの割当可能トラックを唯一つにして、端子割当を決定す る。この時、ラベル付き有向グラフ $G_L(i)$ や、フラグの集合  $TYPE(\cdot)$ 等を用い、チップのチャ ネル全体を総合的に考慮している。

本手法の効果を調べるために、乱数を用いて端子割当てを行った場合との比較を行った。 その結果より、本手法の有効性がある程度確認できた。

これまでに発表された自動レイアウトシステムでは、単純な初期割当とその改善という試行錯 誤的な技法によって端子割当を行うものが多く、またその記述も少ない。その中で、比較的詳 細に述べられているものに文献[32]があるが、これでもチャネル毎に試行錯誤的な技法を繰り 返しており、本手法のように、目的(I),(II),および,(III)を満たす端子割当を全チャネルを総合 的に考慮しながら見出すものではない。

# 第4章 階層的配置配線におけるチップフロアプラン手法

# 4.1 緒言

本章では、まず、チップフロアプラン問題の扱うレイアウトモデルについて示す。次に、フロア プランが扱う最適化対象の相互関係について議論し、それに基づきチップフロアプランに適し た処理フローを提案する。本論文が提案するフローは、(1)ブロック配置とブロック形状最適化 の処理を分割する、(2)ブロック形状最適化では、概略フロアプランの最適化を行った後、詳 細フロアプラン最適化を行うものである。

次に、フロアプランの部分問題として、ピン配置・概略配線、電源配線、ブロック形状最適化 のそれぞれの手法を説明する。最後に、フロアプラン後チップレイアウトを行ったレイアウト図の 一例を示し、実用的かつ良好な結果が得られることを示す。

# 4.2 チップフロアプラン問題

#### 4.2.1 レイアウトモデル

本論文が扱うレイアウトモデルは、図 4.1 に示すものを考える。





領域をチャネルと呼び、チップの配線領域全体をチャネルの組み合わせで表現したものをチャ ネル構造と呼ぶ。一般に、ブロックの配置が同じであってもチャネル構造は一意的ではない。 ブロックは、複数の形状を取り得るか否かにより可変形状と固定形状の2種類に分類される。可 変形状ブロックは内部のセルや配線、外部ピン位置等が変更可能であるブロックのことであり、 標準セルで構成されるブロックや、データパスブロックの一部、等はこれに含まれる。一方、メ モリ等のカスタム設計ブロックは固定形状ブロックとして扱う。

チップ面積を評価するためにチャネルポジショングラフ Gar, および、Gar を用いる。 Gar は図 4.2 に示すように各頂点がブロックの縦辺に、各辺がブロックまたはサブチャネル(2個の 隣接するブロックに挟まれた配線領域であり、チャネルの一部となる)に対応し、各辺は、重み としてブロック幅又はサブチャネルの配線に必要な幅をもつ。グラフ Gar 上の最長路長はチッ プレイアウトに必要な x 方向の最小幅を示しており、x 方向のチップサイズの最小化を行うため には、最長路上の各サブチャネルが最小幅で実現されることが必要かつ十分な条件である。こ れらのサブチャネルはチップ面積の最小化という点で重要な意味を持つので、本論文ではこの ようなサブチャネルをクリティカルサブチャネルと呼んで区別する。同様に y 方向についても G<sub>w</sub>、クリティカルサブチャネルを定義できる。



図 4.3 に示すような、ブロック形状の取り得る候補をグラフで表現したものをブロックの形状 関数 [34] という。ブロックの高さを縦軸H、幅を横軸Wに取り、形状の取り得る高さと幅の値を グラフ上にプロットする。一般のフロアプラン問題において、形状関数による表現は広く用いら れている。ところが、形状関数の精度が低ければ、予想してなかった場所にデッドエリア(無効 領域)を生じさせることになる。例えば、ブロックの面積・形状は外部ピンの位置などによって最 大20%程度変化する。このため、フロアプランの最適化においては、外部ピンの位置などに よる影響を考慮した形状関数を高速、かつ、高精度に計算できる推定モデルを準備することが 重要である。

図 4.2 チャネルポジショングラフ G.



図 4.3 ブロックの形状関数

# 4.2.2 階層的配置配線フロー

図 4.1 に示したような、階層設計されたLSIを配置配線する場合に、以下に示すような複数 の最適化対象と最適化目標を扱う必要が生じる。

- (i) 最適化対象:
  - ・ブロックの配置
  - ・可変形状ブロックの外部ピン位置、形状
  - 概略配線経路、電源配線経路と幅
- (ii) 最適化目標と制約
  - ・チップ面積の最小化
  - ・ 信号線の遅延制約(各ネットに対して最大遅延制限)の満足
  - ・電源配線条件制約(ブロックの電源端子における最低電源電位、電源線における) 最大電流密度の制限)の満足

チップフロアプラン問題は、これらの最適化を大局的に行うことが目的となるが、それぞれ の最適化対象は、図 4.4 に示すように、他の最適化対象の影響を強く受ける。この相互依存 関係が、チップフロアプラン問題を複雑なものにしている。例えば、ブロック形状を最適化する 場合、精度の良いブロック形状関数に基づいて処理を行うことが重要(図 4.4 中 A) であるが、 ブロックの面積を精度良く推定するためには、外部ピンの配置が与えられる必要がある。(図 4.4 中 B)しかしながら、ピン配置を最適化するためには、ブロックの形状及びチャネル構造 が最終形に近いものが与えられている必要がある(図 4.4 中 C) といったようなサイクリックな 相互依存関係がある。



図 4.4 チップフロアプランの最適化対象の相互依存関係

従来のフロアプランシステムでは、ブロックの配置と形状最適化に焦点をあてるものが多く存 在した。[35,36] また、ブロック配置を変更しながら、ブロック間配線の推定も変更させるといっ た技術なども紹介されている。[37,38] しかしながら、これら手法の課題としては、ブロックの配 置および形状の決まってない段階での配線領域見積もりを行うため、ブロック形状関数および ブロック間配線の推定精度を上げることが原理的に困難である点である。そのため、フロアプラ ン処理において、面積最小化等が効果的に行われたとしても、実際にブロックの配置・配線お よびブロック間の配線を行ってやると、推定誤差の大きなところで無効領域が発生する。

本論文では、これらのブロック形状関数およびブロック間配線の推定精度を上げることの重 要性に着目して、システムの提案と構築を行う。本システム構築時に考慮した主なポイントは以 下の2点に集約される。

- ステップに分割し、順番に処理を行う。
- ピン配置も徐々に最適化を進めていく方法を採る。

(1) 図 4.4 を見ると、ブロック配置、ブロック間詳細配線、それ以外 の3つのグループ間に はサイクリックな依存関係がない。また、ブロック形状関数の推定精度は、ブロックの配 置および外部ピン配置を前提とすることにより、飛躍的に向上する。このため、最適化 問題をブロック配置、形状最適化(狭義のフロアプラン)、ブロック間詳細配線の3つの

(2) ブロック形状最適化と概略配線・ピン配置(狭義のフロアプラン)は、最適化対象がサイ クリックな相互依存関係になっているため、それぞれの対象を概略の最適化から詳細 な最適化へ徐々に移行させ、ブロック形状関数の精度を徐々に上げつつ、概略配線と これらを考慮し、具体的なレイアウト設計フローとしては、以下に示すものを実現する。

(STEP1) ブロックの概略配置

- (STEP2) 概略ブロック形状関数
- (STEP3) 概略ブロック形状最適化
- (STEP4) 概略ピン配置、グローバル配線
- (STEP5) 高精度ブロック形状関数
- (STEP6) 高精度ブロック形状最適化
- (STEP7) 電源配線
- (STEP8) 詳細ピン配置、グローバル配線
- (STEP9) ブロック内の配置配線
- (STEP10) ブロック間詳細配線

本章の以降の節では、これらの内、STEP2 から STEP8 からなる狭義のフロアプランに 関する技術の要素技術として、ピン配置手法および概略配線手法、電源配線手法、ブロック形 状最適化手法のそれぞれについて述べる。STEP10のブロック間配線方法、および、全体の レイアウト合成結果に関しては次章で述べる。STEP1のブロック配置手法に関しては、力学モ デル[39]を用いた方法を開発したが、ブロックは多くの場合人手配置が行われる。また、ブロッ ク内の配置配線手法に関しては、本論文では詳細に触れないので、文献を参照されたい。 [40,41]

# 4.3 ブロック間配線とピン配置

ピン配置の目的としては、一般的に配線長の最小化が目的とされる[42]が、本論文では、ブ ロック面積の増大を避けるため、ピン集中の回避も同時に考慮する。ピン配置処理は2段階で 行われる。まず、初期配置においては、各々のブロックのピンがブロックの中央に集中している と仮定して、最小経路法によって外部ピンを出す位置を決定する。しかしながら、これでは局所 的に端子が集中するため、各々のピンに対して、配置可能な領域と、配置の優先度を定義し、 全てのピンの優先度をなるべく満足しかつピンの配置を分散させる方法を用いる。以下に、ア ルゴリズムを詳しく述べる。

ブロック間の配線領域は、図4.5に示すような、チャネルグラフの各辺を等間隔 Hで分割し、 それぞれの辺の間に頂点を設定した配線グラフ G.を用いて表現する。 G.の各辺に対応する 配線領域を分割領域(division area)と呼ぶ。ブロックのピンは、まず、ブロック周辺のいずれか の分割領域に割り当てる。未定形状ブロックに対応する面には、中心に頂点を付加し、そこか らブロック各辺の中央に最も近い G, 上の頂点へ仮想枝を付加する。更に、フィードスルーを 表現する為に、4辺上の頂点が相対する辺同士の頂点を結ぶフィードスルー枝を付加する。



ピンを分割領域に割り当てるときに、1個の分割領域当たりに割り当てることのできる同一ブ ロックのピンの個数の上限値を設定する。これをピン配置容量と定義する。また、各分割領域に 割り当てた個数をピン配置密度と定義する。 本ピン配置手法は、初期配置、分散配置および詳細配置の3段階より構成される。まず初期 配置の段階では、ピン配置容量を無視し、配線長最小化のみを考慮したピン配置を求める。次 に分散配置の段階では、ピン配置容量を定義して、ピン配置密度を分散させるための配置改 善を行う。最後に詳細配置の段階では、分散領域からピン座標への割り付けを行う。

# 4.3.1 初期配置アルゴリズム

チャネル構造が与えられた時に、ピンの初期配置を求める手続き INIT ASSIGN は、以 下の手順で行う。

# <手続き INIT ASSIGN>

図 4.5 配線グラフ G, と分割領域

1. (配線グラフ G, 作成) 図 4.5 に示したような配線グラフ G, を作成する。フィードスルー を表現する枝は、フィードスルーピンを配置する辺を求める為のものである。同辺には通過 可能な本数を示す容量を与える。 グラフ G,の各辺には、以下のように重みを与える。ブ ロック間配線領域に対応する辺の重みは、辺に対応した分割領域の長さ Hとする。中心 からブロック周辺を結ぶ辺の重みは、(中心から周辺の点までのマンハッタン距離)\*aと する。 a はピン配置を求める為の探索木が、未定形状ブロックを通過しにくくするための ペナルティを与えるパラメータである。フィードスルーに対応する辺の重みは、(フィードス ルーの長さ)\*b とする。b はピン配置を求める為の探索木がフィードスルーを通過しにく

-25-

くするためのペナルティを与えるパラメータである。 a, b は共に 1.1 としている。未定形 状ブロックのピンの初期位置は、全てのブロック中心の頂点とし、固定形状ブロックのピン の初期配置は、同ピンに最も近い頂点とする。(注:各ピンは最終的に、ブロック周辺上の いずれかの頂に割り当て、フィードスルーネットをフィードスルーを表現する枝に割り当て 3)

- 2. ネットを囲む矩形の大きさの順で、以下を行う。
- 1) ネット毎にグラフ G, 上でのスタイナ木 Tを求める。スタイナ木を求めるアルゴリズムは、 文献[43] に示された方法を用いる。
- 2) 以下の処理をスタイナ木 T上で、取り除く枝がなくなるまで行う。Tのリーフとなる頂点 v を探し、同頂点に接続する枝を e, v のもう一方の頂点を u とする。 v と u が同じブロ ック内あるいは周辺の領域に対応した頂点である場合、e=(v,u)を削除する。
- 3) ネットに含まれる各ピン P, に対して、 P, を含むブロックの周辺上で、かつ、T が占め る領域をピンP,の初期配置とする。

# 4.3.2 分散配置アルゴリズム

初期配置では、配線長の最小化のみを考慮していた為、ピンが局所的に集中し、ピン配置 容量を越える個数のピンが配置された分割領域が点在している。本分散配置は、各分割領域 に割り当てられたピンの個数がピン配置容量以下となるようにいくつかのピンを移動し、ピンの 配置を分散させることを目的とする。

初期配置からピンを移動する場合には、どのピンをどちらの方向へどれだけの距離を移動す れ良いか、どのピンは初期配置にできるだけ固定したほうが良いか、等を良く考慮し実行するこ とが重要な課題である。本論文では以下のことを考慮し、配置改善を行う。

- (1) クリティカルネットに属するピンは、他のネットのピンより初期配置に優先的に割り当てる。
- (2) ネットの全端子を囲む矩形の周辺上に接するピンは、同矩形の内部に存在するピンに比 べて、同ネットの配線長に与える影響が大きいため、それらのピンを割り当てる先としては、 同矩形の内部の分割領域を優先する。
- (3) 配線の折れ曲がり数が少なくなるようなピン配置を優先する。
- (4) 1つのネット内で、同一サブチャネル上の分割領域に割り当てられる2端子が存在する場 合、これらのピンの座標位置が揃うように配置を調整する。

ピンの分散配置においては、ブロック B に含まれる各ピンに対して、B の周辺上の分割領域 D1, D2, ..., D, のどの領域に割り当てるかという優先度と、各分割領域に割り当てることのでき るピンの個数を図 4.6 に示すような有向2部グラフ G。(B)を用いて表現する。同グラフは各ブ ロック B に対して1個を定義する。同グラフの頂点は、配置すべき各ピンに対応した頂点集合  $V_p = \{p_1, p_2, ..., p_k\}$ と、ブロックBの各分割領域に対応した頂点集合  $V_q = \{D_1, D_2, ..., P_k\}$  $D_{a}$  および仮想頂点 s と t より構成される。同グラフの各有向枝 e は容量 c(e) を属性 としてもつ。頂点 p, に対応するピンを頂点 D, に対応した分割領域へ割当て可能な場合に、

有向枝  $e_{ii} = (P_i, D_i)$ を与え、容量を  $c(e_{ii}) = 1$ とする。各枝には、前述の割当ての優先度 をコストへ表現した重みを与える。

ピンの分散配置は、各々のブロック Bのグラフ G。(B)に対して、頂点 s から t への最 大フロー[43]を求め、フローが1となる枝に対応したピンの割当てを選択することによって決定 することができる。本ピン配置手法によって得られるピン配置とネットの表示例を図 4.7 に示す。 これを見れば、ネットの混雑度が解消されていることが伺える。





# 4.4 電源配線

チップ内の電源配線を行う方法について述べる。電源配線は信号配線に比較して、いくつ かの困難な点が存在する。まず、配線の接続が、木構造のみならず一般のグラフ構造を対象と する点である。次に、考えられる全ての動作状態に対して必要以上の配線幅にすると共に、チ ップ面積削減のために配線幅を最小化する必要がある。 従来提案されている電源配線手法では、木構造のみを扱うもの[44]が、まず提案され、その 後、一般的なグラフ構造を扱う数学的手法が提案された。[45,46] しかしながら、動作状態と しては、平均動作状態あるいは最大電流のいずれかしか扱うことができなかった。また、配線総 面積の最小化を目的としたものであった。 本論文では、以下の点で従来手法を改善した方法について述べる。

図 4.6 ピン配置を分散させるために用いる2部グラフ

図 4.7 ピン配置による配線混雑度の解消

-27-

- (1) 一般的なグラフ構造を扱う。
- (2) 配線面積の最小化でなくチップサイズの最小化を目的とする。
- (3) 複数の動作状態を考慮して全ての状態でエレクトロマイグレーションや熱断線を引き 起こさないよう電源幅を最適化する。

# 4.4.1 電源配線問題

電源配線の入力としては、図 4.8 に示すような電源配線構造を与える。電源配線構造は、電 源パッドからブロックの電源ピンに至る配線の構造として考えられるブロック間全ての枝を与え る。これは、冗長な配線要素も含むが、最適化の処理の中で、不要な配線成分は幅を0にして 取り除く。更に、表 4.1 に示すように、メモリからのデータ読み出しやデータの変換等の各々の 動作状態における各ブロックの消費電力を与える。全ての動作状態の集合をBPとする。



図 4.8 電源配線構造

表 4.1 複数の動作状態におけるブロックの消費電力の例

| ブロック     | А   | В   | С  | D   | E   | F  | G   |
|----------|-----|-----|----|-----|-----|----|-----|
| 最大電流[mA] | 50  | 30  | 80 | 28  | 16  | 37 | 55  |
| 動作状態1[%] | 100 | 100 | 0  | 0   | 0   | 0  | 0   |
| 動作状態2[%] | 100 | 100 | 50 | 0   | 30  | 30 | 0   |
| 動作状態3[%] | 0   | 0   | 50 | 100 | 100 | 0  | 100 |
| 動作状態4[%] | 0   | 0   | 0  | 0   | 50  | 50 | 50  |

-28-

電源配線最適化の目的はチップ面積の最小化である。チップ面積を評価するために図 4.2 に示したチャネルポジショングラフ Gar,および、Garを用いる。電源配線構造の各枝は、サブ チャネルに対応しており、チャネルポジショングラフ Gor,および、Gor によって、面積に直接 影響をあたえるクリティカルサブチャネルとそれ以外に区別できる。クリティカルサブチャネルの 位置は、電源配線の幅を変更する毎に変更されることがあるが、随時更新が行われているもの とする。本電源配線手法においては、クリティカルサブチャネルに置ける電源配線 iの集合を Lとし、Lに含まれる電源線幅 W, の総和を最小化することによって面積の最小化を図る。本 論文で扱う電源配線問題は以下のように定式化できる。

(i) 目的関数 *F* → *min*.  $F = \Sigma W_i$ 

と電圧降下である。

ただし、エレクトロマイグレーションあるいは熱破壊を起こさない様に電流密度の最大値を制 限する。また、電源から各々のブロックの電源端子に至るまでの電圧降下に対しても制限を与 える。

# (ii) 制約式

をVmin、Vmaxとすると、次式で表現できる。  $V_{min} \langle V_{in} \langle V_{max} \rangle$ 表現できる。

 $I_i / W_i < K$ すなわち、

 $dV_{ip} < K * \rho * I_i$ 

# 4.4.2 電源配線アルゴリズム

以下に、電源配線のアルゴリズムを示す。

<電源配線アルゴリズム>

(1) 十分な幅の電源配線を各辺に与える。

---(4.1)

 $= \sum (\rho * I_{i} * I_{in} / dV_{in}) ---(4.2)$ 

ここで、pは一つの動作状態であり、pはシート抵抗値、1,は電源配線iの 長さ、 Iip、 dVipはそれぞれ、電源配線 iに動作状態 pにおいて流れる電流値

電圧降下の制約条件は、電源ピンjの電位を Vie としたとき、その上限下限それぞれ

また、電流密度の制限は、単位幅あたりの電流密度の上限をKとすると、次式で

----(4.4) ----(4.5)

----(4.3)

(2) 目的関数 Fの値が変化している間、以下の(3)~(6)を行う。

(3) 水平方向と垂直方向のクリティカルサブチャネルを見つける。

- (4) 各頂点における電位と各辺における電流を求める。(ここでは、配線幅が十分に取ってある ので、制約条件の式 4.3、式 4.5 は満足している。)
- (5) 電位を最適化し、電流の分布を変化させずに目的関数 Fを最小化する。すなわち、次式 4.6 を、式 4.3 と式 4.7 の制約のもとで最小化する。

$$F' = \sum_{i \in L} \max_{p} (C_{ip} / dV_{ip}) \qquad ---(4.6)$$

ここで、 $C_{in} = \rho * I_i * I_{in}$  は定数であり、L はクリティカルサブチャネルの集合であ 3.

 $dV_{ip} < K * \rho * I_i$ ---(4.7)

ここで、dVinは動作フェーズ pの時の辺 iの電圧降下である。

(6) 電位を変化させずに、電流の分布を最適化し、目的関数 F を最小化する。すなわち、 次式 4.8 を Kirchoff の電流則(式 4.9)のもとで最小化する。

| $F''=\Sigma$ max                | $(D_{ip} * I_{ip})$                              | (4.8 |
|---------------------------------|--------------------------------------------------|------|
| $i \in L$ p                     |                                                  |      |
| $z \in \mathcal{C}, D_{ip} = r$ | * <i>l<sub>i</sub> / dV<sub>ip</sub></i> は定数である。 |      |

ここで、Ei は頂点 j に接続した辺の集合であり、Iin は動作フェーズ p の時の辺 i を 流れる電流である。

ステップ(5)において、制約条件は線形であるが、目的関数は非線形である。この問題は、 内部ペナルティ関数を用いることによって、解くことが可能である。[47] ステップ(6)におい ては、目的関数と制約条件は共に線形であり、線形計画法で解くことができる。

# 4.5 ブロック形状最適化

ブロックの形状最適化は、与えられた配置(例を図 4.9 に示す。) に対して考えられる全て のチャネル構造を列挙し(例を図 4.10 に示す。)、それぞれのチャネル構造に対して、ブロック 形状の最適化を行い、面積が最小となるものを選択し、その後ブロックのレイアウトおよびブロッ ク間配線の処理を行いチップレイアウトを完了する。



| BLKB BLK12 B   |           |
|----------------|-----------|
| BLK18 BLK14    | BLK22     |
| BLK19E KI BLK1 | 6 BLK20   |
| BLK21 BLK7     | BLK10 LK9 |
| F BLK11        | = BLK6    |

|            | BLK12 B | BLK5       | K13      |
|------------|---------|------------|----------|
| ELK18      | BLK14   |            |          |
| BLK21<br>F | BLK7    | E.         | .K20     |
| BLK11      | BLK6    | BLK10<br>F | LK9<br>E |

図 4.10 列挙されたチャネル構造の例

各々のチャネル構造に対してブロック形状を最適化する方法としては、[48] で提案された 方法を使う。概略の手順は、図 4.11 に示す。チャネル構造として。右下のグラフにある構造を 仮定する。この構造の形状関数はこの構造を構成するブロック A, B, C, それぞれの形状関数 を組み上げることによって作成できる。まず、水平に隣接したブロック A と B の両方を囲む矩 形の形状関数(右上図)は、A, B 各々の形状関数のグラフを水平方向に加え合わすことによ って求める。次に、ブロック A と B の両方を囲む矩形とブロック C は、垂直に隣接しているの で垂直方向に加え合わせる。このようにして、ブロックA, B, C 全体を囲む矩形の形状関数(右

-30-

図 4.9 ブロック配置の例



下図)を求める。次に、右下の形状関数の各ポイントの内、設計目標にあったポイントを選ぶ。 設計目標としては、例えば、面積を最小化するポイント、与えられた幅に収まるもので高さを最 小化するものなどである。この例では、丸で囲まれたポイントが選択されたとする。このポイント の形状を実現するための、各々のブロックにおける形状は、先程、加え合わせたのと逆方向に ポイントをたどって求める。チャネル構造の列挙は、図 4.12 に示すように、DFS法により、チャ ネルを切り領域を2分する操作を階層的に繰り返すことによって求める。[49]



図 4.11 チャネル構造が与えられた場合のブロック形状最適化



図 4.12 チャネル構造列挙手法

# 4.6 ブロック面積の推定 [50]

ブロック形状最適化においては、各々のブロックに対する精度の高い形状関数を求める必 要があるが、本論文では、(1)ピン配置が与えられるとする、(2)いくつかの形状に対して、実 際にブロック生成を行い、その結果によって形状関数のパラメータフィッティングを行う、といっ た方法を用いる。従来手法[30-33] では、ブロックの面積を一定と仮定するモデルを用いてい たが、実際の標準セルブロックのセル行数を変えて形状を変えた実験によれば、ブロック形状 (H: 高さ、W: 幅)において、W\* Hの値は一定では無く、セル行数 Rの増加に伴い、 若干 W\* Hが、減少する傾向がある。理由としては、ブロック内のローカルな配線は、セルの 高さに付着したようなイメージで捉えられ、見かけ上のセル高を高くしたことに相当するが、ブロ ックに含まれるグローバルな配線による領域は、形状が変化しても、幅方向、高さ方向、共に一 定であると考えられる為である。ブロック内のグローバルな配線が占める幅および高さ方向の領 域をそれぞれ、b,dとすれば、ブロックの形状関数は次式で予想できる。

$$W = a / R + b$$
  

$$H = c * R + d$$
  

$$(a, b, c, d \atriangle \begin{subarray}{c} & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & & \\ & & \\ & & & \\ & & \\ & & \\ & & & \\ & & \\ & & &$$

# 4.7 フロアプラン実験例

図 4.9 に本フロアプラン処理を行った後、ブロックおよびブロック間の配置配線を行った結 果の例を示す。この図でわかるように、ブロック間の配線領域にあまり無駄な領域が発生してい ない。配線領域の密度も十分考慮して、形状最適化が行われたことを示している。



----- (4.10) ---- (4.11)

図 4.13 配置配線結果の例

-33-

# 4.8 結言

本章では、チップフロアプラン問題の扱うレイアウトモデルと、フロアプランが扱う最適化対象 の相互関係について議論した。チップフロアプランに適した処理フローとして、ブロック配置と ブロック形状最適化の処理を分割し、かつ、ブロック形状最適化においては、概略の最適化を 行った後、詳細の最適化を行うフローを提唱した。そうすることにより、ブロック形状関数の推定 精度を飛躍的に向上させることができ、ブロック間に無駄な領域が無く、各配線チャネルが効 率良く使用た最終レイアウト例を示すことができた。

電源配線、ピン配置、概略配線機能を備え、且つ、これらを考慮した上で最適なチャネル構 造を選択し、ブロック形状を最適化する手法を開発した。ピン配置においては、ピンを分散させ る機能により、配線集中を回避した。電源配線に関しては、複数の動作状態における電流条件 を満足する電源配線方法を示した。

# 第5章 ブロック間配線手法

# 5.1 緒言

ブロック間配線を行う方法として、線分探索を用いた手法[6,7]と、チャネル配線を基本とす 本論文ではチャネル配線を基本とし、従来チャネル構造が決定できない場合が存在する問

る方法[8,9]の2種類の構成方法が考えられる。前者はブロック上の空きエリアを自由に通過 できるなどのフレキシブルな配線が可能な反面、あらかじめブロック位置を固定してから配線を 行うため未配線や、無効領域が生じやすい。逆に後者は基本的に分割統治法であるので、計 算複雑度が低く、高速で且つ大規模なデータ処理が行えるといった特徴がある。チャネル構造 が定義できれば、未配線を生じずに配線を完結することができるといった大きなメリットがある。 題を解決した。本手法の特徴は、面積最小化とタイミング条件の満足の両方を考慮したグロー バル配線、L 字型チャネルを導入しアサイクリックなチャネル構造を得るチャネル構成法、およ び凹凸のあるチャネルを効率良く配線するチャネル配線方法等である。

# 5.2 配線構造の定義

図 5.1 に示すように隣接するブロックに挟まれた、帯状の配線領域をサブチャネル、サブチ ャネル同士が交差する点をチャネルクロスといい、サブチャネルを辺で、サブチャネルの両端 のチャネルクロスをその辺に接続する頂点で表現したものをチャネルグラフという。隣接するサ ブチャネルを併合して得られる帯状の配線領域をチャネルといい、チャネルグラフをチャネル の集合で行現したものをチャネル構造という。



チャネルが交差する状況に応じてチャネル配線の処理順に制約が生じる。たとえば、チャネ ル e とチャネル f は T 字型に接しているため、e の方を先に処理しなければならない。このよ

図 5.1 チャネル構造の例

うな処理順をチャネル処理順といい、この順序制約をグラフで表現したものをチャネル処理順 グラフ G, という。図 5.1 に対応する G, の例を図 5.2 に示す。





本手法の配線処理は、各ネットの配線が通過するサブチャネルの集合を求める概略配線、 その後チャネル構造を作成しチャネル処理順にしたがって各チャネルの配線を行う詳細配線 の2段階で行う。

# 5.3 概略配線

#### 5.3.1 処理概要

概略配線の処理は以下の手順で行う。

- 1. (サブチャネルの構成) チャネルグラフを作成する。
- 2. (電源グローバル配線)電源ネットの配線経路と配線幅を決定する。
- 3. (初期配線) 面積最小化を目的として、各ネットの概略配線経路を求める。
- 4. (再配線) 面積最小化および配線遅延値の最適化を目的として再配線を行う。

#### 5.3.2 初期配線

ここでは、ブロック間配線領域を図 5.3 に示すようなグローバル配線グラフ Gpでモデル化す る。Gpは各サブチャネルを間隔 d (d は外部からパラメータで与える) で等間隔となるように 分割し、各分割点およびチャネルクロスを頂点に対応させ、隣接する分割点またはチャネルク ロスa, b, 間の辺 e=(a, b) に対応付けたものである。ブロック上のピンは最も近い分割領 域に属しており、各ネットのグローバル配線はこれらの分割領域の集合で表わされる。各分割 領域 a の配線に必要な幅 w(a)は、ブロックのでっぱり及び、分割領域のを通過する配線を できるだけ詰めたときに必要な幅のことをいう。各クリティカル領域(critical division area)上で、 w(a)を最大にする分割領域をクリティカル分割領域という。クリティカル分割領域に新たな配

線が通過するとチップレイアウトに必要なサイズが増大するので、できるだけこのような配線を 避けることが好ましい。そこで、GR のクリティカル分割領域に対応する辺のコストを他の辺のコ ストより大きくなるように与え、最小コストパス法により配線経路を求める。



<初期配線アルゴリズム>

- >> のを、他の辺には dを与える。
- 3
- 3. (経路探索) 2. の順で各ネットnの配線経路を求める。
- を  $\{ p0 \}$ 、 グローバル 配線 R(n) を空とする。
- ストパスを求めそれを R(n) に付加する。
- 3-3. この操作を未配線端子がなくなるまで繰り返す。
- 3-4. 各分割領域の配線密度、クリティカル分割領域、コストを更新する。

### 5.3.3 再配線

初期配線のようにネットを順次配線する方法では、クリティカル分割領域も順次変更されるた め、初期に処理したネットの配線は、配線後のクリティカル分割領域を十分考慮していない。そ こで、クリティカルなサブチャネルに属し、かつ、2個以上にサブチャネルにわたるネットの配線 を引き剥がし、初期配線段階3の処理で再配線を行う。(手続き 再配線 A)

1. (初期化) G<sub>R</sub> を作成し、電源配線された状態を初期状態として各分割領域の配線密度及 びクリティカル分割領域を求め、クリティカル分割領域に対応した辺にコスト C+a (C

2. (ネットの順序づけ)全ネットを、ネットの全端子を含む最小矩型の周辺長の昇順でソートす

3-1. ネット n の全端子を囲む最小矩型の中心に最も近い端子を p0,既配線端子集合 P

3-2. 集合 Pの全端子を囲む最小矩型の最も近い未配線端子 pi から R(n) への最小コ

図 5.3 グローバル配線グラフ G とクリティカル領域

次に、全ネットに対して、出力ピンから入力ピンに至るパス毎に信号遅延時間を計算し、あら かじめ与えられた要求値(最大許容遅延時間)の 70%を超えるパスを含むネット n に対して以 下の再配線手続きを行う。

<手続き 再配線 B(n)>

ネット n のグローバル配線を R, (n), G, の辺のコストを全て d として初期配線のステップ 3. の処理で求めた配線を R<sub>2</sub>(n),同じ G<sub>R</sub>に対して初期配線ステップ 3. で出力端子を P<sub>a</sub> とし、遅延の大きい入力端子から順に最小コストパスを求めて得た配線を R<sub>3</sub>(n)とする。 R<sub>1</sub>  $(n), R_{2}(n), ..., R_{3}(n)$  それぞれについて遅延時間を計算し、ネットに含まれるパスの (遅延時間/要求値)の最大値を最小とする配線を選び、元の配線 R<sub>1</sub>(n)と置き換える。

### 5.4 詳細配線

# 5.4.1 処理概要

詳細配線の処理は以下の手順で行う。

- 1. (ブロックの位置決め)面積最小化を目的としで、ブロックの位置決めをおこなう。
- 2. (チャネル構成)アサイクリックなチャネル処理順となるように直線および L 字型チャネル によるチャネル構造を求める。
- 3. (チャネル配線)チャネル処理順に従って各チャネルの配線をおこなう。

# 5.4.2 ブロックの位置決め

チップ面積を最小化するためには、各クリティカルサブチャネルを最小幅で実現すること(条 件 A)が必要かつ十分であることは既に述べた。クリティカルサブチャネルを含むチャネルにお いて、クリティカルでないサブチャネル部分の配線余裕がなく、しかもその部分の配線がグロー バル配線の見積り幅より広い領域を必要とした場合には、クリティカルサブチャネル部分での 空き領域が生じ条件 A を満足しなくなる。このため、x, y, 両方向について、条件 A を満足す るためには、クリティカルでないサブチャネルの配線余裕を分散させる必要がある。

ここでは、ブロック B, B'間のチャネル幅、配線に必要な幅を d(B, B')、 w(B, B')、 配線余裕度を、

a(B, B') = (d(B, B') - w(B, B')) / w(B, B') ---(5.1)で定義し、各ブロック B について、左側に隣接するブロックで、配線余裕度を最小にするもの を B, 右側で同様のものを B,としたとき、B,および B,それぞれとの間の配線余裕度が等しく なるような配置を求めることを目的とする。(v 方向についても同様)

<ブロック位置決めアルゴリズム> ブロックの位置決定

各々のブロックの両側における領域の広さに対する配線面積の比を均一化する。 1. 各ブロックが移動しなくなるまで以下をおこなう。

- 1-1. 各ブロック B について  $a(B, B_i)$ ,  $a(B, B_i)$  を求める。
- 1-2. ブロック B, B' 間のチャネル幅を d(B, B') とするとき、各ブロック Bを  $\Delta x$  (B) = min (d(B, B<sub>1</sub>), d(B, B<sub>r</sub>)) \* (d(B, B<sub>1</sub>) - d(B, B<sub>r</sub>)) だけ左へ移動する。
- 1-3. y方向についても1-1。1-2。と同様の移動を行う。

### 5.4.3 チャネル構造決め

チャネル処理順グラフ G。にサイクルがある場合、サイクル上のチャネルを選び、チャネルが クロスする部分をスイッチボックスとし、スイッチボックスでチャネルを分割することによりサイクル を除去する手法が提案されているが、この手法は100%配線を保証できない。このため、本論 文では L 字型チャネルを含むアサイクリックなチャネル構造を構成し、各チャネルを順次配線 することにより100%配線を保証する手法を用いる。

G。上にサイクルがある場合、サイクル上の T 字型チャネルクロスを L 字型および直線チャ ネルに分割し、サイクルを除去する(図5)。このとき、L 字型チャネルは配線が困難なため、で きるだけ配線が容易な部分で構成するのが望ましい。本手法ではサイクル上のチャネルの内、 L 字型チャネルを構成可能な部分をさがし、それが複数個ある場合は、構成されるL 字型チャ ネルの配線が容易な領域において構成する操作を繰り返すことにより、アサイクリックな G.を 得る。

< G。のサイクル除去アルゴリズム>

- 1. G. の強連結成分を求める。
- 2. 頂点数が 2 以上の強連結成分 Gsi がなくなるまで、以下を行う。
- 2-2. E の枝の内、次の評価関数が最小となるものを選ぶ。ここで、u, v'は枝 e に対応した
  - $W(e) = C * \alpha + \beta (C > \beta)$

2-1. G<sub>si</sub> に含まれる有向枝 (u, v) の内、u, v, ともに G<sub>si</sub> に属する頂点に向かう有向枝の 本数が1 であるものを E\* に加える。ただし、終点 v を共通とする始点 u が複数個あ る場合は、vの子 sとuのチャネル間隔 d(u,s)が最小の物のみを E\* に加える。

T字型チャネルクロス部で形成されるL字型チャネル u-v'の直線チャネル部分である。

 $\alpha = 0: u, v'$  ともにクリティカルでない

= 1: u, v' のうち1つだけがクリティカルである

= 2: u, v' ともにクリティカルである

# B: u, v' のうち短い方のチャネルの長さ

2-3. チャネル u, vをし 字型チャネル u-v'と直線チャネル v" に分割し、グラフ G を更 新する。

本手法の処理例を図 5.4 に示す。



図 5.4 チャネル構造決めとグラフ G.の例

#### 5.4.4 チャネル配線

従来の多くの配線システムは、配線領域を格子で表現し、配線格子上に配線やコンタクトを 置く方式がとられている。この方式は簡便である反面、チャネル配線に必要な幅が増大する欠 点がある。そこで、本論文では配線格子の制約を受けないグリッドフリー方式を採用した。加え て、L字チャネル配線にも対応するため、次の特徴を持たせた。

- (1) 凹凸のあるチャネル形状の配線が可能。
- (2) 三方が固定されたチャネルの配線が可能。

<チャネル配線アルゴリズム>

- 1. (初期配線トポロジーを求める) 同ネットの隣接する端子間に1本の水平線分(幹線)を 配し、幹線の両端(端子点)から端子に向かって垂直線分(支線)を引く。ただし、こ の段階では、まだ各幹線の位置はまだきまっていない。
- 2. (重みつき制約グラフ G\_の作成) 幹線間の位置制約を示すグラフ G\_を作成する。 G\_ の重みwのついて有向辺(a, b)は、幹線aを幹線bよりwまたはそれ以上

- の間の位置制約を示す有向枝を G. に付加する。
- 正を行う。
- だけアルミに置き換える。

# <手続き TRUNK\_ASSIGN>

- 1(a) とする。
- する未割り当て頂点 B の集合とする。
- (3) S., S. がともに空でない限り以下を行う。

当てる。

- Q(v) =

上に配置しなければならないことを示し、重みwのついて無向辺(a, b)は、幹 線 a, b に上下関係の制約はないが、距離 w またはそれ以上離さなければなら ないことをしめす。さらに、チャネル形状の各水平線分およびチャネルの上端 S、お よび下端 T に対応した頂点を G. に付加し、これらの間および、これらと各幹線と

3. (幹線分割) G\_にサイクルがあるばあい、チャネル形状に凹凸がある場合、G\_に長い パスがある場合、固定された幹線がある場合等には、チャネル配線が不可能にな ったり、配線に必要な幅が大きくなったりするので、配線トポロジーおよび G\_の修

4. (幹線割り当て) 各幹線を後述の手続き TRUNK ASSIGN によって割り当てる。 5. (メタル最大化) アルミ、ポリシリコンの2層配線の場合、支線のポリシリコン部分をできる

(1)  $G_a$ 上で S から各頂点 a への最長路長を u(a), a から T への最長路長を

(2) 未割当ての頂点の u 値、1 値の最小値をそれぞれ umin, Imin とする。 S. を umin < u(a) < umin + VCL (VCL は水平線分とコンタクト間の最小矩型)を満足する未割り当て頂点 Aの集合、 $S_i \in Imin < I(a) < Imin + VCL を満足$ 

(3.1) S, (または S,) 中に S, (または S,) 中の他の頂点に向かう無向枝のな い頂点あるいは、固定幹線に対応した頂点 v\* をチャネルの上辺(また は下辺)から距離 u(v\*)(または I(v\*))の場所に割り当てる。

(3.2) S<sub>n</sub> (または S<sub>1</sub>)中で、以下の値 Q(v)を最大にする頂点vをチャネ ルの上辺(または下辺)から距離u(v)(またはI(v))の場所に割り

-C1 \* u(v) + C2 \* I(v) + C3 \* h(v) + C4 \* p(v) ---(5.1)(vが S,に含まれる場合)

-C1 \* I(v) + C2 \* u(v) + C3 \* h(v) - C4 \* p(v) ---(5.2) (vが S,に含まれる場合)

ただし、C1からC4は定数であり、C1 >> C2>> C3>> C4 である。

ここで、h(v)は、チャネル左端から、頂点v に対応した幹線の右端 までの距離、pはチャネル上方への割り当て優先度である。(両端の 支線が上方(または下方)に接続しているものに1(または -1)、 その他場合に 0 を与える)

(3.3) G, umin, lmin, S, S, を更新する。

# 5.5 実験と結果の考察

図 5.5 は、グローバル配線および、ブロック位置決めを行った結果である。各サブチャネル 内の配線に必要な幅を図示し、クリティカルでないサブチャネルの配線余裕度が分散している 様子が伺える。

本ブロック間配線を実際のいくつかの VLSI 回路に適用した結果を表 5.1に示す。計算機は IBM3081, プログラミング言語は FORTRAN77 を使用した。ここで、グローバル配線での面積 は、配線間隔を VCL (コンタクトと配線の間隔)として見積もっている。再配線 A により、多少面 積の改善が得られている。グローバル配線と詳細配線結果の面積差がわずかであるのは、詳 細配線で最適解に近い解が得られていることを示している。図 5.6 は回路 A について、再配線 B 前後の遅延時間分布の変化を示す。縦軸は要求値と計算結果の比、横軸はネット番号であ る。いくつかのネットについて遅延時間が改善されており、再配線 B 以前に遅延計算値と要求 値との比が最大111%であったのが、最大82%にまで減っている。



図 5.5 ブロック位置決めの例



(a)

| 回路名   |      | А                    | В                    | С                    |
|-------|------|----------------------|----------------------|----------------------|
| ブロック数 |      | 14                   | 15                   | 11                   |
| ネット数  |      | 397                  | 337                  | 414                  |
| ピン数   |      | 1434                 | 980                  | 1142                 |
| ゲート数  |      | 10000                | 6200                 | 3800                 |
| 面     | 概略配線 | 54.49mm <sup>2</sup> | 34.05mm <sup>2</sup> | 58.09mm <sup>2</sup> |
| 積     | 詳細配線 | 54.74mm <sup>2</sup> | 34.05mm <sup>2</sup> | 58.13mm <sup>2</sup> |
| 計算    | 概略配線 | 43 sec               | 20 sec               | 47 sec               |
| 時間    | 詳細配線 | 74 sec               | 12 sec               | 62 sec               |



再配線後

(b)

図 5.6 概略配線による遅延条件の改善

表 5.1 ブロック間配線結果の例

本レイアウト合成システムは、実際のLSI約30品種の開発において適用された。図 5.9 に、全 自動でレイアウト合成を行った LSI の内、代表的な結果を示す。(使用マシン:DEC mini computer 1MIPS 程度)



64bitMPU 約100万Tr) CPU Time: フロアプラン: 20m in ブロック内レイアウト:50H ブロック間配線: 30min 図 5.7 カスタムLSIのレイアウト合成例



画像用DSP 約100万Tr) CPU Time: フロアプラン: 5m in ブロック内レイアウト: 10H ブロック間配線: 20m in



CDROM用LSI 約30万Tr) CPU Time: フロアプラン: 10m in ブロック内レイアウト: 20H ブロック間配線: 20min

# 5.6 結言

本章では、ブロック間配線に対するアプローチとして、初期配線後、面積改善と遅延改善の ための再配線を行うことで、面積最小化とタイミング条件の満足の両方を考慮したグローバル 配線手法について述べた。実験結果により、面積増を極力減らしながら、遅延条件を大幅改善 する結果を得た。

詳細配線は、チャネル配線を基本とするが、L字型チャネルを導入しアサイクリックなチャネ ル構造を得るチャネル構造決定法と凹凸のあるチャネルを効率良く配線するチャネル配線方 法によって、常に100%配線を行える方法を提案した。

実験により短時間で遅延特性の良いレイアウト結果が得られることを確認した。また、実際の 大規模集積回路への適用例により実用面でも活用され、良好な結果を得ていることを示した。

# 第6章 標準セルの合成手法

#### 6.1 緒言

従来、リーフセルの面積は、チップ面積ひいてはチップコストに直接的な影響を与えることか ら、人手による設計が行われていた。昨今のライブラリ開発頻度の増加によりライブラリ自体の ライフサイクルタイムは短期化の様相を示しているため、設計期間の点からも設コストの点から も大幅な削減が要望されており、人手コストを十分にかけて開発することが困難となりつつある。 以上のような理由から、テクノロジフリーなライブラリセル合成技術の重要性はますます高まりつ つある。しかしながら、従来のセルレイアウトの合成方法では、計算機処理を簡単化するために、 様々な制約を有し、それらの制約がプロセスに対する独立化や、人手設計セルの流用や、レイ アウトの最適化を妨げる場合が多い。例えば、上原、他 [15] を始めとする多くのリーフセル合 成システムは、トランジスタを1次元配置したモデルを用いるため、一般に人手設計されたリー フセルの配置情報をコンパクションによって再利用することができない。

そこで、本論文では、[53]において、トランジスタの2次元配置モデルをセル合成に導入し、 トランジスタ配置に関しては人手設計並みのフレキシビリティを有するレイアウトモデルに対する セル合成方法を提唱した。今回、更に、トランジスタ上のメタル引き出しコンタクトの位置・形状 最適化や、トランジスタ上のメタル配線通過を可能とし、且つ、ゲートの折曲げを取り入れること によって、より柔軟にプロセス変化に対応できるレイアウトモデルと、そのレイアウト合成方法を 報告する。

レイアウトデータの抽象化と言う概念に関しては、従来あまり論じられることがなかった。ほと んどの場合、マスクレイアウトの方式は λ ルール [54] あるいは、単に図形間のスペーシングル ール等が変化するのみであると仮定されており [55,56,57]、レイアウトの構造変化(例えば、 配線層の増加や、トランジスタ拡散領域の製造方法の変化によるレイアウトの自由度増大等) は考慮に入れられてなかったためである。一例、として、シンボリックレイアウトの手法が挙げら れる。文献 [58] はトランジスタを1個のシンボルで表現し、デザインルールに対してテクノロジ 独立を実現する。しかし、この方法では、ゲートの折曲げや、トランジスタ上からのメタル配線の 引き出し位置の自由度に対応できない。SPARCS コンパクタ [59] では、トランジスタ上の配 線禁止領域と端子領域をそれぞれ、ポリゴン図形で表現された protection frame(配線禁止領 域), terminal frame(端子領域) によって表現し、トランジスタやコンタクトはセルとして実現する 方法が示されている。しかしながら、トランジスタ上の各々の図形要素の位置・形状が固定化さ れているため、レイアウト合成で課題となる図形の移動や最適化処理は出来ない。

図 6.1 に、(a) 非サリサイドプロセスにおけるセルレイアウト例と、(b) サリサイドプロセスにお けるセルレイアウトの違いを示す。図 6.1(a) では、拡散上に大きなコンタクトが打たれているが、 図 6.1(b) では、十分小さなコンタクトが打たれるのみであり、拡散領域の中でコンタクトを打つ 位置に関しての自由度が増大している。



図 6.1 トランジスタのレイアウト例

このようなプロセス・テクノロジのバリエーションを吸収するためには、例えば、次のような構造 変化を許容する必要がある。

- (i) 拡散領域の形状に自由度がある。
- (ii) ゲートの45°折曲げが可能である。
- トランジスタのソース及びドレイン上から信号を引き出すためのコンタクト・パッドの大 (iii) きさ及び位置に自由度がある。

本論文では、トランジスタと配線に関する柔軟性の高いレイアウトモデルと、レイアウト再生成 の手法を提案する。本手法の効果が顕著に表れる例として、図 6.2 に従来のコンパクションシ ステムによる結果との比較を示す。コンパクションシステムは、配線を図形要素の一つとして扱 い、できるだけ周りとの位置関係を保存しようとするため、不要な遠回りの配線を生じることがあ る。本手法によれば、配線を一旦抽象化し、配置要素のコンパクション処理と同時に配線を再 度生成し直すので、良好な配線結果を得ることができる。



によるレイアウト再生成結果例、(c) 本手法によるレイアウト再生成結果例

# 6.2 テクノロジマイグレーション処理フロー

本論文で示すテクノロジマイグレーションの手法は、主要な2つの処理より構成される。一つ は、与えられたレイアウトデータを一旦、テクノロジフリーな抽象化されたデータに変換する処 理である。もう一方は、このテクノロジフリーデータに基づき、ターゲットプロセスに合わせたレイ アウトを再合成する処理である。抽象化されたテクノロジフリーデータは、トランジスタのレイアウ トや配線のジョグ等に関して十分柔軟性をもったものである。以下の節では、本論文が提案す るレイアウト抽象化モデルについて述べた後、レイアウト再合成のアルゴリズムの説明を行い 最後に実際のライブラリセルへの適用例によりその効果を示す。

# 6.3 レイアウト抽象化モデル

トランジスタや配線コンタクト等のレイアウトの配置要素の図形抽象化モデルと、配置領域お よび配線の表現モデルについて示す。

# 6.3.1 配置要素の抽象化モデル

トランジスタレベルのレイアウト合成において、(1)トランジスタ上のメタル第1層引き出しコンタ クトが、第1層メタル配線に対して配線禁止領域となること、(2) 同コンタクトの位置及び大きさ の最適化が求められること、(3)トランジスタ上の同コンタクト以外の領域には第1層メタル配線 の通過が認められること、の理由により、トランジスタのレイアウトモデルとしては、図 6.3 に示 すようにトランジスタ拡散領域に対応する矩形と、同矩形に含まれるコンタクトに対応した矩形 によって表現する。尚、トランジスタ拡散領域の外形及び、コンタクトの大きさ、位置等は、レイ アウト合成処理の中で順次最適化される。



図 6.3 トランジスタの図形アブストラクション

トランジスタ拡散領域の矩形の辺上には、ゲートの端点となるポリシリコン層の端子を備える。 コンタクトに対応した矩形には、同矩形の中央にメタル第1層への端子を備える。ピンと、コンタ クトのアブストラクションは、1個の矩形で表現し、その中央に端子を与える。 拡散領域の共有化されたトランジスタの集合は、拡散島という概念で呼ばれる。拡散島のレ

-47-

イアウト合成に関しては、ゲート折曲げを行い、拡散島上を通過するメタル第1層配線を同時に 左詰めし、拡散島部分のレイアウトを合成する拡散島レイアウト生成システムをサブシステムとし て用いる。

# 6.3.2 配線の抽象化モデル

本手法は、スピットとネットターゲットという配線抽象化のための新しいデータ構造を導入する。 図 6.4 (a) に従来から用いられているシンボリック配線を示し、図 6.4(b) に同配線をスピットと ネットターゲットで抽象化した例を示す。スピットは、セル上に複数配置される垂直線であり、 同領域に配置された矩形と、水平配線を縦に串刺しにするデータ構造である。スピット上の矩 形及び配線交点は同スピット上で順番付けがされている。ネットターゲットは、配線の部分を 表現する点として定義し、1)矩形の端子上、2)配線分岐点上、3)スピットを横切る点、の各 場所に生成する。各々のネットターゲットをリンクする情報によって、配線経路と矩形との位置 関係を表現する。



図 6.4 スピットとネットターゲット

# 6.4 レイアウト再合成処理概要

抽象化された配置要素の各矩形の垂直方向の位置制約を表現するために、図 6.5 に示す ような制約グラフを用いる。同グラフの頂点は、各々の矩形に対応しており、頂点間の枝には、 対応する矩形間に同領域を横切る配線を引くためのスペースを与える。この処理は前述の各 スピットで隣接する矩形の間に存在する配線(ネットターゲット)を見ることによって行う。

レイアウト再合成処理においては、最初の段階に、この上下方向の配置制約グラフを用いて、 最小経路法により、各々の配置要素の垂直方向の位置決めを行う。その後、スキャンラインを

用いて、水平方向のコンパクション、配線の再生成、拡散島トランジスタの図形生成を同時進 行させる手法により、最終レイアウトを生成する。図 6.6 に水平スキャンによるレイアウト合成処 理の概要を示す。









(b) 図 6.5 制約グラフ



図 6.6 処理フロー概要

図 6.6(a) では、配線がネットターゲットとそれらの接続関係によって表現されている。この水 平スキャン処理は、スキャンラインを左から右へ移動させながら、前述の全ての同時処理を行っ ていく方法である。すへての配線層に対して、包括線を定義し、スキャンし終わった配置要素 や配線をすべて包括する。配線の先端を表現するフロントというデータ構造を用いる。フロント はスキャンライン上に位置し、スキャンラインの右移動に伴い、右側で一番近い同ネットのネット ターゲットにできるだけ近づくようにスキャンライン上を上下動する。実際の配線は、フロントが 移動したときにその軌跡となって実現される。まず、最初の段階では、スキャンラインと全ての包 括線は左端に位置する。フロントは、スキャンラインが端子をスキャンしたときに発生し、同ネット の配線をし終わったときに消滅する。図 6.6 (b)に示すように、スキャンラインが右に移動すると き、フロントはできるだけつぎのネットターゲットに近づくように上方向に移動し、フロントの軌跡 を配線として生成し、包括線によって生成された配線をカバーする。次に、図 6.6(c) では、ス キャンラインは配置オブジェクト左端をスキャンし、同配置オブジェクトを左詰めする。このとき、 配置要素は、包括線の所まで移動できる。次に、図 6.6(d) では、スキャンラインは配置要素の 左端をスキャンし、同配置要素を包括するように包括線を更新する。この間、フロントは同配置 要素に邪魔されているので、つぎのネットターゲットに近づく動きはできない。次に、図 6.6(e) では、配置要素の障害が無くなり、スキャンライン上を下方向に移動可能となるので、次のネッ トターゲットに向かって移動し、その軌跡を配線として生成する。以上示したように、本手法によ れば、配置要素のコンパクションと配線の最生成を同時に進めることができ、必要な場所に配 線の折れ曲がりが発生できる。尚、配置要素が単一の矩形でなく、複数の矩形からなる拡散島 の場合、には、図 6.6(c) と同様に、スキャンラインが拡散島をスキャンすると同時に、同拡散島 の図形生成を行い、同図形をを左詰めする。

# 6.5 アルゴリズム

本処理では、概略配線と同様に、矩形の移動と、詳細配線の実行を進めるために、領域の 左から右方向に走査するスキャンラインを設定する。配置領域の左端には、コンパクション及び 配線処理が終了したことを示すバウンダリを設ける。バウンダリは、スキャンラインが矩形の右側 をスキャン仕終わった時、あるいは、フロントの移動に伴って配線が生じた場合に同矩形や、配 線を含むように更新される。

スキャンするためのポイントリストを作成する。スキャンするポイントは、端子の存在す 1. る場所、あるいは、矩形の右あるいは左端の点である。これらを、x 座標でソートした 順番にスキャニングポイントリストを作成する。途中で、矩形や端子の移動があっても、 スキャンの順番は変化しない。(図 6.7 参照)

All Carlins



| 2.   | スキャニングポイントリストに従っ |
|------|------------------|
| 2.1. | スキャンライン上の配紙      |
|      | るだけターゲットに近~      |
|      | 5°               |
| 2.2. | スキャンラインが、スキ      |
|      | (A) 端子をスキャンした    |
|      | ・新しい配線フロントの      |
|      | せ、配線を左端のバウ       |
|      | ・結合できなかった浮動      |
|      | 理での配線を待つ。        |
|      | (B) 矩形の左端をスキー    |
|      | ・該矩形に関する配置ス      |
|      | ・スキャンライン上に配紙     |
|      | 同矩形が拡散島の右端       |
|      | れる矩形を全て同時に       |
|      | ダリは更新されていない      |
|      | 島生成システムが同配       |
|      | イントによるスケジューリ     |
|      | る。(図 6.8 参照)     |
|      | (C) 矩形の右端をスキ・    |
|      | ・該矩形に関する配置ス      |
|      | ň                |

図 6.7 スキャニングポイントリストの作成

って、順次スキャンラインを移動しながら以下を行う。

線フロントを、デザインルールを満足する範囲で、でき づく方向に移動する。フロントの移動に伴い、配線を行

ャンする場所に応じて以下の処理を行う。

時は、

生成を行い、隣接する同ネットの配線フロントと結合さ ンダリに積み上げる処理を行う。

めの配線フロントは右側へ延ばすことにより、以後の処

ャンした時は、

オブジェクトの左方向へのコンパクションを行う。

泉禁止領域を設定する。

器であった場合、拡散島生成を行い、同拡散島に含ま 左詰めする[60]。ただし、この段階では、左端のバウン い。拡散島上を通過する配線があった場合でも、拡散 線を通過する領域を確保していれば、スキャニングポ リングに従って概略配線で指定された場所に形成され

ャンした時は、

オブジェクトを左端のバウンダリに積み上げる処理を行



図 6.8 拡散島図形生成処理、(a) 矩形による抽象化データ、 (b) 生成された拡散島図形

# 6.6 実験結果

図 6.9、図 6.10 それぞれに、本システムによって合成した標準セルの例を示す。人手設計と 同様の結果が得られている。また、表 6.1には、配置以降の処理を自動で行い、人手設計と比 較した結果を示している。約9割のデータに関して人手並みの結果が得られたことを示している。



(a)





図 6.10 自動合成における適用例 (a) 配線処理後、(b)再生成後



(b) 図 6.9 テクノロジマイグレーションの適用例 (a) 変換前、(b)変換後



| 表 6.1 | 人手設計との比較 |  |
|-------|----------|--|
|       |          |  |

| セル名    | トランジスタ数 | セル幅(*1)<br>(本手法) | セル幅(*2)<br>(人手設計) | 人手比 (%)<br>(*1/*2) | 計算時間(sec) |
|--------|---------|------------------|-------------------|--------------------|-----------|
|        |         |                  |                   |                    |           |
| NAND6A | 18      | 24.0             | 24.0              | 100                | 0.43      |
| NAND6B | 18      | 24.0             | 24.0              | 100                | 0.47      |
| OR2    | 6       | 10.3             | 9.6               | 107                | 0.17      |
| OR4B   | 10      | 14.4             | 14.4              | 100                | 0.27      |
| OR5B   | 12      | 24.0             | 24.0              | 100                | 0.25      |
| NOR2   | 6       | 12.0             | 12.0              | 100                | 0.12      |
| NOR3A  | 6       | 9.6              | 9.6               | 100                | 0.15      |
| NOR3B  | 9       | 16.8             | 16.8              | 100                | 0.22      |
| NOR5A  | 10      | 14.4             | 14.4              | 100                | 0.27      |
| NOR5B  | 14      | 19.2             | 19.2              | 100                | 0.33      |
| NOR6A  | 20      | 24.0             | 24.0              | 100                | 0.43      |
| NOR6B  | 20      | 26.6             | 24.0              | 111                | 0.63      |
| BUF1   | 8       | 15.9             | 14.4              | 110                | 0.18      |
| BUF2C  | 25      | 34.4             | 31.2              | 112                | 0.54      |
| BUF7   | 8       | 12.0             | 12.0              | 100                | 0.18      |
| BUF8   | 8       | 12.0             | 12.0              | 100                | 0.22      |
| INV1   | 18      | 24.4             | 24.0              | 102                | 0.32      |
| XOR2   | 16      | 23.8             | 19.2              | 124                | 0.33      |
| XOR3   | 26      | 37.2             | 36.0              | 103                | 0.68      |
| FF1    | 23      | 31.2             | 31.2              | 100                | 0.57      |
| FF2    | 26      | 36.1             | 36.0              | 100                | 0.73      |
| FF3    | 38      | 59.6             | 55.2              | 108                | 1.17      |

注)\*1,\*2,それぞれのセル幅のユニットは設計グリッドを用いている。.

# 6.7 結言

本文では、トランジスタに対する新しいレイアウトモデルを示し、プロセスの変化に容易に追 従出来ることを示した。同レイアウトモデルを用いて、柔軟性の高い概略配線方法と、配線とコ ンパクションを同時進行させることによって、レイアウトを実現するトランジスタレベルの新しいレ イアウト生成方法を示した。また、実験により、レイアウト合成結果が人手設計並みの良好な結 果であることも示した。本システムを、実際のライブラリ開発において適用し、約3時間で300セ ルのレイアウトを回路から合成、約1時間で既存セルからの流用を行うことができた。(使用マシ ン環境:SUN SPARKStation20、C言語によってコーディング) 合成された300セルの内、 90%は人手で1セルあたり半日かけて作られたレイアウト結果の面積に匹敵する。(残りの1 0%は、人手より約5~10%大きくなった。) 本システムの実用化により、セルライブラリの総 開発工数は約10分の1に削減された。

# 第7章 結論

大規模集積回路のレイアウト合成に関する研究として、まず第1章では、産業的背景を述べ、 大規模集積回路の規模および設計困難度が今後ますます増大するため、レイアウト合成の技 術革新も意欲的に進めていく必要があることを示した。

第2章では、大規模集積回路の複数のレイアウト構造(方式)について解説し、それぞれの構造(方式)に対する課題をまとめ、本研究の意義として、(1)ゲートアレイ方式LSIのレイアウト合成において、手戻りの少ない設計フローの構築すること、(2)大規模化するフルカスタム方式LSIの設計工数と期間を短縮すると同時に、面積・遅延において良好な結果を得ること、(3)セルライブラリの新規および流用設計工数と設計期間を短縮することのそれぞれの重要性について示した。

第3章では、ゲートアレイ方式LSIの配線成功率を向上するための等価端子割り当て手法 を提案し、有効性を確認した。本手法によれば、ランダムに等価端子割当を行う場合に比較し て、与えられた配線トラックに対する余裕が、1 ~ 2 本余計に確保できることを示した。また、 詳細配線のトラック数を増加させる主な要因である上下制約グラフの上下矛盾の個数を大幅に 減少することを確認した。

第4章では、大規模集積回路のフロアプランを最適化する方法を提案し、実LSIのレイアウト 合成への適用により効果を実証した。配線領域の面積も考慮しながら各々のブロックの形状を 精度良く最適化することを、配線チャネルが効果的に使用されている実験例によって示した。 また、ブロック外部ピン配置に関しては、ピンの分散とブロック間概略配線長の最小化を同時に 解決する方法を述べ、実験によりブロック間配線の混雑度合いが緩和されることを示した。さら に、電源配線に関しては、複数の動作状態を考慮し、配線要素における電流密度の上限値と ブロック端子における電圧降下の制限を満足し、かつ、チップ面積を最小化する方法について 述べた。

第5章では、大規模集積回路のブロック間配線方法として、面積最小化と遅延制約の満足との両方の評価指標に対して良好な結果を得るための概略配線手法を提案した。実験により、 配線遅延対遅延制約の比の最大値が、111%(障害あり)から、82%(全遅延制約を満足)ま で減らすことを確認した。また、L字チャネルを使った配線領域分割方法を提案し、実LSIの配 置配線により有効性を実証した。

第6章では、標準セルの合成方法として、トランジスタに対する新しいレイアウトモデルを提案 し、同モデルを用いて柔軟性の高い配線、コンパクション、と拡散島図形生成を同時に進行さ せる方法を提案し、実セルライブラリへの適用により有効性を確認した。ライブラリシリーズの約 300セルに対して実験を行い、90%のセルに関しては、レベルの高い設計者が人手で約半日 /セルかけて設計した面積と同等であった。残りの10%に対しては、人手設計より5%~10% 大きくなったが、設計者に対して良好な初期解をあたえることにより、実ライブラリ開発のトータ ルの設計工数を約1/10 に削減し実用面でも大きな効果を示した。 今後は、図7.1 に示すように、設計規模がますます大規模化する様相を示している。設計 上流でのHDL等の記述言語の使用をより普及し、設計抽象度を上げて行くことに加えて、設 計の再利用化を推し進める必要がある。レイアウト設計に関しても有効性の高いテクノロジ変換 技術の確立と実用化を進めることが課題として上げられる。





次に、微細化に伴って、ノイズや製造ばらつきの回路およびレイアウトに対する影響が無視 できないものとなってきており、微細化物理現象を考慮したレイアウト最適化も重要となる。さら に設計抽象度の上位化に伴い、ハイレベル合成やハード・ソフト・コデザインといったレベルで も、レイアウトイメージを与え遅延等に対する推定を可能とする上流設計用のフロアプラン技術 の確立も重要と考える。(図7.2)



図7.2 設計抽象度の上流へのシフトと競争ポイントの推移



-57-

本論文を執筆するにあたり多数の方々のお世話になりましたので、ここに記して感謝の意を表します。

大阪大学在学中に御指導を賜るとともに、本論文の作成にあたり終始懇切なご指導とご教 示を賜りました大阪大学工学研究科情報システム工学専攻 白川功教授に厚く感謝を申し上 げます。さらに本論文をまとめるにあたり、有益なご指導とご助言を賜った大阪大学工学研究 科情報システム工学専攻 藤岡弘教授、村上孝三教授に厚く感謝申し上げます。

大阪大学においてご指導、ご鞭撻を賜った大阪大学 尾崎弘名誉教授に深く感謝致します。 大阪大学在学中に直接のご指導を賜るとともに、つねに励ましとご助言をいただく中央大学理 工学部電気電子工学科 築山修治教授に心から感謝致します。松下電器産業株式会社半導 体研究センターにおいて研究の機会を与えていただくとともに多大なご支援をいただきました 現 松下電器産業株式会社特別顧問 水野博之氏、現 松下電器産業株式会社顧問 堀内 司朗氏、現 研究本部副本部長 竹本豊樹氏に深く感謝の意を表します。また、半導体開発 本部において本研究に対してご援助とご指導をいただきます半導体開発本部本部長 古池進 氏、半導体開発本部半導体先行開発センター所長 西嶋修氏に深く感謝致します。さらに松 下電器産業株式会社での研究生活のほぼ全般に渡って、あたたかくご指導とご鞭撻いただい た現 松下電器産業株式会社半導体開発本部マイコン開発センター所長 間野洋治郎氏、現 近畿大学生物理工学部電子システム情報工学科 秋濃俊郎教授に深謝致します。

本論文の第3章における研究は、大阪大学において、現日本電信電話株式会社原田育 生氏、現株式会社東芝池田敏雄氏、現日本電気株式会社木本務氏、および現シャー プ株式会社竹田信弘氏と共同で進めたものです。ここに記して感謝の意を表します。

第4章および第5章の研究は、松下電器産業株式会社半導体研究センターにおいて行った ものです。システム開発に際してのご協力とご討議を頂きました現研究本部医療画像情報開 発チームリーダ羽山繁氏、現半導体開発本部半導体先行開発センター山口龍一主任技 師、山本敦志技師、川上善之技師、蕪尾知恵技師、現半導体開発本部 CE システム開 発センター 田中康弘技師、株式会社松下ソフトリサーチ 塩原孝弘リーダ に感謝致します。

第6章の研究は、松下電器産業株式会社半導体研究センターおよび半導体開発本部にお いて進めたものであります。本研究に対するご指導ご鞭撻をいただく現 半導体開発本部マイ コン開発センター主担当 国信茂郎氏、半導体開発本部半導体先行開発センター主担当 松 澤昭氏に感謝の意を表します。また、ライブラリ開発の観点からの有益なご討論をいただいた 半導体先行開発センター 大谷一弘リーダ、岡晶久リーダ、藤原睦主任技師、谷口博樹技 師、石坂高志氏 に感謝致します。さらにシステム開発へのご協力とご討議をいただいた半 導体先行開発センター 雑賀俊二技師、四宮典子技師、田中正和技師、株式会社松下ソ フトリサーチ 森下直人技師に謝意を表します。 最後に、日頃より有意義なご助言、ご討論いただく半導体開発本部の皆様に感謝の意を表 します。

なお、第3章の研究の一部は、文部省科学研究費補助金:一般研究 B57460117(昭和57、 58年度)の援助のもとに行われたものです。

# 参考文献

- [1] SIA, "The national technology roadmap for semiconductors: Technology Needs," SEMATEC (1997).
- [2] G. Persky, D. Deutsch, and D. Schweikert, "LTX-A system for directed automatic design of LSI circuits," in Proc. Design Automation Conference, pp. 399-407 (1976).
- 山本敦志、福井正博、羽山繁、間野洋治郎、 "シミュレティッドアニーリング法を用いた [3] スタンダードセル自動配置の一手法,"信学技報, CAS86-191, pp. 25-31 (1987).
- D. Dura and T. Tsang, "A sub-micron ASIC low power static RAM compiler," in Proc. [4] International Conference of Computer-Aided Design, pp. 226-230 (1996).
- 川上善之、山口龍一、福井正博、羽山繁、秋濃俊郎、"論理回路の規則的繰り返しが [5] 多く存在するブロックにおけるセル配置の一手法,"信学技報、VLD89-48 pp. 73-79 (1989).
- [6] T. Adachi, H. Kitazawa, M. Nagatani, and T. Sudo, "Hierarchical top down layout design method for VLSI chip," in Proc. Design Automation Conference., pp. 785-791 (1982).
- M. Y. Hsueh and D. O. Pederson, "Computer-aided layout of LSI circuit building-[7] blocks," in Proc. International Symposium on Circuits and Systems, pp. 474-477 (1979).
- S. Kimura, N. Kubo, T. Chiba, and I. Nishioka, "An automatic routing scheme for [8] general cell LSI," IEEE Transactions on Computer-Aided Design of Integrated Circuits And Systems, vol. CAD-2, no. 4, pp. 285-291 (1983).
- W. M. Dai, T. Asano, and E. S. Kuh, "Routing region definition and ordering scheme [9] for building block layout," IEEE Transactions on Computer-Aided Design of Integrated Circuits And Systems, Vol. CAD-3, no. 3, pp. 218-225 (1984).
- [10] Barbara T. : "Make-or-buy library decision faces COT/foundry customers", Coumputer Design (1997).
- [11] 瀧和男、"パストランジスタ論理に関する動向調査報告,"情処学 DA シンポジウム, pp. 147-154 (1997).
- [12] M. Fukui and A. R. Newton, "Optimum module generation for semi-custom," in *Proc.* IEEE Asia-Pacific Conference on Circuits and Systems, pp. 184–189 (1992).
- J. Fishburn and A. Dunlop,"TILOS: A posynomial programming approach to [13] Transactions istor sizing", in Proc. International. Conference. on Computer-Aided Design, pp. 326-328 (1985).
- [14] M. Tanaka, M. Fukui, and S. Kuninobu, "A precise estimation model of cell area and Transactions istor capacitance for Transactions istor size optimization," in Proc. Synthesis and System Integration of Mixed Technologies, pp. 241–247 (1998).
- [15] T. Uehara and W.M. VanCleemput, "Optimal layout of CMOS functional arrays," IEEE Transactions Computer, vol.-30, pp. 305-312 (1981).

- No.10, pp. 1883-1891 (1997).
- [18] (1986).
- [19] 71, pp. 21-26. (1997年).
- [20]
- [21]
- [22]
- [23] Vol. 1, No. 3, pp. 281-302 (1989).
- and Computer Sciences, Vol. E81-A, No.8 (1998).
- [25] Interchange, pp. 294-299 (1990).
- [26] No.3, pp. 383-391 (1987).
- [27] published.
- [28] (1976).
- [29]

[16] S. Saika, M. Fukui, N. Shinomiya, and T. Akino, "A two-dimensional placement algorithm for cell synthesis and its application to standard cells," IEICE Transactions on Fundamentals of Electronics, Communications and Computer Sciences, Vol. E80-A.

[17] M. Fukui, N. Shinomiya, and T. Akino, "A new layout synthesis for leaf cell design," in Proc. Asia and South Pacific Design Automation Conference, pp. 259–264 (1995).

H. Shin and A. Sangiovannni-Vincentelli, "MIGHTY: A rip-up and re-route' detailed router," in Proc. International. Conference. on Computer Aided Design, pp. 2-5

四宮典子、福井正博、西垣泰男、"リーフセル用配線システム、"信学技報、CPSY97-

H. Shin and A. Sangiovannni-Vincentelli, "Two dimensional compaction by 'Zone Refining'," in Proc. of Design Automation Conference, pp. 115–119 (1986).

W. Wolf, J. Newkirk, and R. Dutton, "Two-dimensional compaction strategies," IEEE International Conference on Computer Aided Design, pp. 90-91 (1983).

福井正博、築山修治、白川功、"ゲートアレイ方式 LSI の端子割り当て問題に対する一 手法"、電子情報通信学会論文誌(C), Vol. J66-C, No. 12, pp. 1172-1179 (1983年).

M. Fukui, A. Yamamoto, R. Yamaguchi, and S. Hayama, "SMILE- a hierarchical layout system for building block LSI," International Journal of Computer Aided VLSI Design,

[24] T. Shiohara, and M. Fukui, "A pin assignment and global routing algorithm for floorplanning," IEICE Transactions on Fundamentals of Electronics, Communications

M. Fukui, Y. Tanaka, and T. Akino, "An algorithm for power and ground routing in building block VLSI," in Proc. Synthesis and Simulation Meeting and International

M. Fukui, A. Yamamoto, R. Yamaguchi, S. Hayama, and Y. Mano, "A block interconnection algorithm for hierarchical layout system," IEEE Transactions actions on Computer-Aided Design of Integrated Circuits And Systems, Vol.CAD-6,

M. Fukui, N. Shinomiya, S. Saika, T. Akino, and S. Kuninobu, "Layout abstraction and technology retargeting for leaf cells," IEICE Transactions on Fundamentals of Electronics, Communications and Computer Sciences, Vol. E81-A, No.12 (1998) to be

R. Kamikawa, K. Kishida, A. Osawa, I. Yasuda, and T. Chiba,"Placement and routing program for masterslice LSI's," in Proc. Design Automation Conference, pp. 245-250

K. Ueda, Y. Sugiyama, and K. Wada, "An automated layout system for masterslice LSI: MARK," IEEE Journal of Solid-State Circuits, SC-13,5, pp. 716-21(1978).

- [30] T. Yoshimura and E. S. Kuh, "Efficient algorithms for channel routing," IEEE Transactions on Computer-Aided Design of Integrated Circuits And Systems, pp. 25-36 (1982).
- [31] 福井正博、築山修治、白川功、尾崎弘、"チャンネル配線の一手法、"信学技報、 CAS81-121, pp. 91-98 (1981年2月).
- R. Tarjan, "Depth-first search and linear graph algorithms," SIAM Journal Computer, I, [32] 1, pp. 146-160 (1972).
- [33] 野田、寺井、佐藤、八原、"多様なデバイスのゲートアレイニ適用可能な配線プログラム、" 信学技報、CAS82-79 (1982).
- [34] R. Otten, "Automatic floor-plan design," in Proc. Design Automation Conference., pp. 261-267 (1982).
- K. Maling, S. H. Muller, and W. R. Heller, "On finding most optimal rectangular [35] package plans," in Proc. of Design Automation Conference, pp. 663–670 (1982).
- [36] S. Tsukiyama, K. Koike, and I. Shirakawa, "An algorithm to to eliminate all complex triangles in a maximal plannar graph for use in VLSI floor-plan," in Proc. International. Symposium on Circuits and Systems, pp. 321-324 (1986).
- [37] D. Wong and C. Lin, "A new algorithm for floor-plan design," in Proc. Design Automation Conference, pp. 101-107 (1986).
- [38] W. M. Dai and E. S. Kuh, "Simultaneous floor-planning and global routing for hierarchical building block layout," in Proc. International. Conference. on Computer Aided Design, pp. 334-340(1986).
- [39] K. Ueda, "Placement algorithm for logic modules," *IEE Electronics Letter*, 10, 10, pp. 206-208 (1974).
- 山口龍一、福井正博、山本敦志、羽山繁、"階層的レイアウトシステムにおけるスタン [40] ダードセル自動配線の一手法,"情報処理学会第34回全国大会, pp. 1969-1970 (1 987年10月).
- [41] 山本敦志、福井正博、山口龍一、羽山繁, "階層的レイアウトシステムにおけるスタンダ ードセル自動配置の一手法,"情報処理学会第34回全国大会, pp. 1991-1992 (198 7年10月).
- [42] M. Pedram, M. Marek-Sadowska, and E.S.Kuh, "Floorplanning with pin assignment," in Proc. International. Conference. on Computer Aided Design, pp.98-101 (1990).
- [43] E. L. Lawler, "Combinatorial optimization: networks and matroids," *Holt, Rinehart and* Wilson, N. Y. (1976).
- [44] S. Chowdhury and M. A. Brewer, "Minimal area sizing of power and ground nets for VLSI circuits," in Proc. MIT Conference on Advanced Research in VLSI (1986).
- [45] S. Chowdhury, "Optimum design of reliable IC power networks having general graph topologies," in Proc. Design Automation Conference, pp. 787-790 (1989).
- S. Haruvama, and D. Fussell, "A new area-efficient power routing algorithm for VLSI [46]

1129 (1985).

- and Control, Vol. 59, pp. 91-101 (1983).
- [49] pp. 75-82 (1988).
- [50] 通信学会秋季全国大会, pp. A-1-163~164 (1988).
- [51] 36 (1982).
- 52
- [53]
- [54]
- [55] Design Automation Conference, pp. 434–440 (1976).
- 56 6, The Benjamin/Cummings Publishing Co. (1988)
- vol. sc-20. No.3, pp. 799-803 (1985)
- [58]
- [59]
- 60 法,"信学技報, VLD95-155, pp. 97-104 (1996年3月).

layout," in Proc. International. Conference. on Computer Aided Design, pp. 1123-

[47] R. Fletcher, "Practical methods of optimization," Vol. 2, John Wiley & Sons (1981).

[48] L. Stockmayer, "Optimal orientations of cells in slicing floorplan designs," *Information* 

福井正博、岩崎知恵、羽山繁, "チャネル構造列挙の一手法," 情処研報, DA44-10,

福井正博、山本敦志、岩崎知恵、羽山繁, "ブロック形状最適化の一手法," 電子情報

T. Yoshimura and E. S. Kuh, "Efficient Algorithms for Channel Routing," IEEE Transactions on Computer-Aided Design of Integrated Circuits And Systems, pp. 25-

T. G. Hamachi and J. K. Ousterhout, "A Switch-box Router with Obstacle Avoidance," in Proc. Design Automation Conference, pp. 173-179 (1984).

M. Fukui, N. Shinomiya, and T. Akino, "A new layout synthesis for leaf cell design," in Proc. Asia and South Pacific Design Automation Conference, pp. 259-264 (1995).

C. Meed and L. Conway, "Interduction to VLSI Systems," Addison Wesley (1979).

D. Gibson and S. Nance, "SLIC - Symbolic Layout of Integrated Circuits," in Proc.

B. Preas and M. Lorenzetti,"Physical Design Automation of VLSI Systems," Chapter

[57] P. Kollaristsch and N. Weste, "TOPOLOGIZER", IEEE Journal Solid-State Circuits,

P. Smith and S. Daniel, "The VIVID System approach to technology Independence," in Proc. of Design Automation Conference, pp. 115-122 (1984).

J. Burns and A.R. Newton, "SPARKS: A New Constraint-Based IC Symbolic Layout Spacer," in Proc. Custom Integulated Circuit Conference, pp. 534-539 (1986).

四宮典子、福井正博、雑賀俊二、秋濃俊郎、"屈曲ゲートを用いたレイアウト最適化手

