# テスト容易化機能的時間展開モデルを用いた故障検出率向上のためのテスト生成法 日大生産工 〇 石山 悠太 日大生産工 細川 利典

#### 1 まえがき

近年の半導体微細化技術の発展に伴い,設計され る超大規模集積回路(Very Large Scale Integrated circuits: VLSI)の高集積化・複雑化により,VLSIの 設計コストの増大が問題となっている[1]. LSI の設 計生産性を向上させる手法として,動作レベルの回 路記述からレジスタ転送レベル(Register Transfer Level: RTL)の回路を生成する動作合成が提案されて いる[2].動作レベルの回路記述は RTL の回路記述と 比較して高い抽象度で記述されるため,設計生産性 に優れる.また,LSI の高集積化に伴い,一般的な LSI テスト手法であるスキャンテストのテスト実行時間 は急激に増加している.

文献[3·5]の手法では回路のデータパス部とコント ローラ部を分離しながら設計していることが前提と なる.しかしながら、データパス部とコントローラ部 を分離して設計することにより、その分離のための 付加回路が必要となる.一方、回路のデータパス部と コントローラ部を分離しない回路設計を前提とした 非スキャンテストに基づくテスト容易化設計手法も 提案されている[6].文献[6]ではデータパスのテスト 容易な構造に基づいたコントローラ拡大が提案され ている.

これまで提案されてきた順序回路のテスト生成ア ルゴリズム[7][8]は、回路構造にのみ着目してテスト 系列を生成する.したがって、テスト容易な構造に基 づいてテスト系列が生成されるとは限らない.文献 [9]ではサイクル展開可能 RTL 回路を定義し、データ パスのテスト容易化設計と、テストコントローラを 付加した回路に対して制約付きテスト生成を行うこ とで、テスト生成の時間展開数を有限化している.文 献[10][11]では、コントローラの状態遷移を網羅する ようにデータパスの機能的時間展開モデル[11]を生 成するテスト生成手法が提案されている.この手法 ではテスト生成時に回路の機能動作時における制御 信号・状態信号の値を制約として付与する.これによ り、テスト生成時における回路の時間展開数を機能 動作のレイテンシに有限化し、解空間が削減される。 機能的時間展開モデルを用いたテスト生成

(FTEM\_ATPG)のアルゴリズムは正当化処理を効 果的に行うために SAT(Satisfiability Problem)が適 用されることがある.しかしながら,高集積化・複雑 化した回路に対して FTEM\_ATPG を適用すると, SAT の CNF(Conjunctive Normal Form)のデータ量 が膨大になり,メモリ領域が不足し FTEM\_ATPG が 動作を停止してしまう問題も生じている.

本論文では,FTEM\_ATPGの問題を解決するため のアルゴリズムを提案し,従来のアルゴリズムでは 動作しなかった回路に対するテスト生成の実行をす る手法を提案する.

## 2 機能的時間展開モデルを用いたテスト生 成

機能的時間展開モデルを用いたデータパスのテス ト生成[10][11]は、コントローラ部から入力される制 御信号の系列とコントローラ部へ出力する状態信号 系列を制約値として、指定した時間数分展開された 時間展開モデルに対してテスト生成を行う.機能的 時間展開モデルは時間展開数が有限であり、さらに 制御信号系列と状態信号系列を制約として付加する ため、制約を付与しない構造的時間展開モデルを用 いたテスト生成と比較してテスト生成が高速になる [11].

## A Test Generation Method for Increase Fault Coverage Using Easily Testable Functional Time Expansion Models

Yuta ISHIYAMA and Toshinori HOSOKAWA

-143 -

### 3 含意ノードを用いた正当化

信号線 k からの値 v(v∈{0, 1})の割当て要求を少な くとも 1 つの外部入力まで一意に後方追跡[12]でき る経路が存在するとき,信号線 k を含意ノードとい う.

外部入力数を M,決定ノードとなる含意ノード数 を N としたとき,PODEM[12]アルゴリズムなどの 外部入力を決定ノードとするアルゴリズムでは,解 空間の大きさは外部入力に値 v を割当てる組合せの  $2^{M}$ となる.全ての信号線が決定ノードの候補になる 場合では,回路中の総信号線数を L とすると解空間 の大きさは全ての信号線に値 v を割当てる組合せの  $2^{L}$ となる.ここで L≫M という関係が成り立つので, 外部入力を決定ノードとすることによって,全信号 線を決定ノードにするよりも解空間を狭めることが できる.

含意ノードを決定ノードとするアルゴリズムでは, 解空間の大きさは含意ノードに値 v を割当てる組合 せの 2<sup>N</sup>となる.決定点となる含意ノードは外部入力 を1つ以上含意するような信号線なので M≧N とい う関係が成り立つ.含意ノードを決定ノードとする ことで外部入力を決定ノードにするよりも解空間を 狭めることができる.

図 1 に例題回路を示し、含意ノードを用いた正当 化の説明をする.図 1 の信号線 A, B は外部入力で ある.



図1 含意ノードを用いた正当化の例

この例では信号線 I に論理値 1 を割当てる要求に 対する後方追跡を考える.ただし,信号線 D にはす でに論理値 0 が割当てられているものとする.

まず,後方追跡を用いて信号線 I の正当化を行う例 を示す. I=1 から後方追跡を行い G=1→C=1→A=0 の 目標を設定する. A=0 を決定木に挿入し, A=0 から 含意操作を行うと, A=0, E=0, H=0 となる. まだ I=1 は正当化されていないため, I=1 の正当化のための後 方追跡を再度行う. その結果 G=1→C=1→B=0 の目 標を設定する. B=0 を決定木に挿入し, B=0 から含 意操作を行うと, B=0, C=1, F=0, G=1 となり I=1 の正当化が完了する.

次に,含意ノードを用いて信号線 I の正当化を行う 例を示す. 信号線 I に論理値 1 を割当てる要求から 外部入力 A, B まで一意に後方追跡できる経路が存 在するかを確認する. この例では I の入力信号線 G, H ともに外部入力 A, B まで一意に後方追跡できる 経路が存在するため G, H ともに含意ノードになり 得る. ここではまず G を含意ノードとする. G=1 か ら含意操作を行うと, C=1, A=0, B=0, E=0, F=0, H=0 となり, I=1 の正当化が完成する.

図2に図1で示した例の決定木を示す.



図2のaは信号線Iに対して論理値1を正当化す るための決定木,図2のbは含意ノードGを用いた 信号線Iに対して論理値1を正当化するための決定 木をそれぞれ示している.

図 2 に示すように、含意ノードを用いることで決 定木に挿入されるノード数が少ない.これにより含 意ノードを用いることで解空間を削減できることが わかる.

#### 4 FTEM\_ATPG のアルゴリズム

本章では、FTEM\_ATPGの問題であるメモリの消 費量を抑えるために、値の正当化に用いられていた SATの処理を近似化したモデルについて説明する.

まず, SAT とは与えられた乗法標準形 (Conjunctive Normal Form: CNF)に含まれる全ての 論理変数の値を 1(真)または 0(偽)に定めることで, CNF 全体の値を1にできる割当てが存在するか否か を判定する問題である. SAT は CNF を入力として 問題を解決するため, SAT を用いてテスト生成を行 うためには,対象の論理回路を CNF に変換する必 要がある.表1に論理ゲートに対する CNF 変換規則 を示す.各論理ゲートは表 1 の規則に従い, CNF に 変換する. それぞれの括弧で括られた論理式を節と いい,節を論理積した式が各ゲートの CNF である. 回路全体の CNF は各論理ゲートの CNF を論理積 することで表現できる.

表1 論理ゲートの CNF 変換規則

| ゲートタイプ | 入力  | 出力 | ゲートに対するCNF式                                                                                  |
|--------|-----|----|----------------------------------------------------------------------------------------------|
| AND    | X,Y | Z  | $(X + \neg Z) \cdot (Y + \neg Z) \cdot (\neg X + \neg Y + Z)$                                |
| OR     | Х,Ү | Z  | $(\neg X + Z) \cdot (\neg Y + Z) \cdot (X + Y + \neg Z)$                                     |
| NOT    | Х   | Y  | $(X + Y) \cdot (\neg X + \neg Y)$                                                            |
| BUFF   | Х   | Y  | $(\neg X + Y) \cdot (X + \neg Y)$                                                            |
| EXOR   | X,Y | Z  | $(\neg X + Y + Z) \cdot (X + \neg Y + Z) \cdot (\neg X + \neg Y + Z) \cdot (X + Y + \neg Z)$ |

一般に SAT を用いたテスト生成では,対象回路に おいて正常に動作する正常回路と,故障の影響を仮 定した故障回路の2つを用意し,正常回路と故障回 路を組み合わせた合成回路をテスト生成モデルとす る.図3に SAT を用いた組合せ回路のテスト生成モ デルの図を示す.



図3 SATを用いた組合せ回路テスト生成モデル

合成回路の外部入力数は対象回路の外部入力数と 同一であり、それぞれが対応する正常回路と故障回 路の外部入力と接続している.合成回路の外部出力 は、正常回路と故障回路の対応する各外部出力を EXOR 演算し、その各 EXOR 演算の出力を OR 演 算したものとなっている.このため、故障の影響が 外部出力に伝搬され故障を検出できる時、合成回路 の外部出力の値は1 となる.SATを用いたテスト生 成は、この合成回路の出力が1 となるような外部入 力の組合せを求める手法である.

FTEM\_ATPG では、順序回路に対する時間展開モ

デルに対して CNF 作成を行う.時間展開モデルとは 順序回路の組合せ回路部の接続関係を時間軸に展開 した回路である.順序回路は時間展開モデルで表現 することによって,組合せ回路として扱うことがで きる.図4に SATを用いた時間展開テスト生成モデ ル(時間展開数3)を示す.また,本手法が扱う故障 モデルは単一縮退故障モデルである.したがって,図 4のモデルは単一縮退故障を故障モデルとした時間 展開テスト生成モデルである.



図4 SATを用いた時間展開テスト生成モデル

a, b, c は外部入力, d, e, f, g は外部出力, h,
i, j, k は疑似外部出力である.また,各変数の添字
である数字は時刻を表している.1時刻目の疑似外部
出力であるh<sub>1</sub>, i<sub>1</sub>, j<sub>1</sub>, k<sub>1</sub>は2時刻目の疑似
外部入力としてh<sub>2</sub>, i<sub>2</sub>, j<sub>2</sub>, k<sub>2</sub>に接続される.2時刻
目以降も同様に接続されている.この時間展開モデルの出力が1となるような外部入力の組合せを求める.

時間展開モデルに対する SAT を用いたテスト生成 では展開数に応じて正常回路及び故障回路を必要と するので, CNF も時間展開数に比例して増大する. したがって,高集積及び複雑な回路や時間展開数が 多くなるにつれて CNF も増大し,メモリの消費量が 増大する.提案手法では,CNF を削減した正常回路 のみの近似正当化モデルを提案する.このモデルに よりメモリの消費量を抑えることができる.しかし ながら,故障回路の CNF を生成せずに正当化処理を 実行しているため,故障回路を用いた正確なモデル での正当化と比較して,故障の検出が保証されない. つまり,未検出故障数が増加する.それらの未検出故 障に対して,含意ノードを用いたテスト生成を実行 し、検出故障数の増加を目指す.

#### 5 実験結果

表 2 に, 故障回路の CNF を生成せずにテスト生成 を実行した結果を示す. 故障モデルは単一縮退故障 モデルとし,実験に用いた回路は ARF[13], add2 で ある.

|  | 回路名           | ARF  |            | add2       |         |         |
|--|---------------|------|------------|------------|---------|---------|
|  | 実験方法          | 故障回路 | 故障回路<br>なし | 故障回路<br>あり | 故障回路なし  |         |
|  |               | あり   |            |            | 含意ノードなし | 含意ノードあり |
|  | 総故障数          | NA   | 133892     | 78         | 78      | 78      |
|  | 検出故障数         | NA   | 125032     | 73         | 68      | 75      |
|  | 打切り故障数        | NA   | 10         | 0          | 0       | 0       |
|  | テスト不可能<br>故障数 | NA   | 5817       | 3          | 3       | 3       |
|  | 未解決故障数        | NA   | 3033       | 2          | 7       | 0       |
|  | テストパターン数      | NA   | 3067       | 7          | 11      | 9       |
|  | 故暗梌出率         | NA   | 02 28%     | 02 50%     | 87 18%  | 06 15%  |

表 2 実験結果

「故障回路あり」列は従来通り故障回路を CNF に 含む正確なモデルによるテスト生成結果を示し,「故 障回路なし」は提案手法である故障回路の CNF を削 減する近似モデルによるテスト生成結果を示す. 含 意ノードの実装は add2 にのみ適用されている.「故 障回路なし」に対する ARF は多量の CNF によるメ モリの消費により,実験結果を得られなかった.しか しながら,提案手法ではメモリの消費量を削減する ことによりテスト生成を実行することができた. add2 における実験結果は従来手法と比べて未検出故 障数が多い.これは,故障回路の CNF を生成せずに 正当化処理を実行しているためである.しかしなが ら,含意ノードを用いた正当化処理を実行すること により,未検出故障数が削減し故障検出率が増加し た.

#### 6 おわりに

本論文では,FTEM\_ATPGの未正当化信号線の処 理に用いられている SAT の影響で動作しなかった問 題を解決するためのアルゴリズムを提案し,従来手 法ではテスト生成ができなかった回路に対してテス ト生成を実行することができた.故障回路の CNF を 生成しないことにより,メモリ消費量を抑えること ができた.しかしながら,近似モデルであるため未検 出故障数が増加してしまう.そこで含意ノードを用 いた正当化処理を行うことにより未検出故障数を削 減することができた.

今後の課題として, 含意ノードを用いた未正当化 信号線に対する正当化を行う処理を大規模回路に適 用することが挙げられる.

### 参考文献

- 藤原 秀雄,"ディジタルシステムの設計とテスト",工学図書株式会社,2004.
- M. C. McFarland, A. C. Parker, R. Camposano, "The high-level synthesis of digital systems", Proc. IEEE, pp. 301-318, 1990.
- [3] M. T. -C. Lee, W. H. Wolf, and N. K. Jha, "Behavioral synthesis for easy testability in data path allocation", Int. Conf. Computer Design, pp. 29-32, Oct. 1992.
- [4] M. T. -C. Lee, W. H. Wolf, and N. K. Jha, "Behavioral synthesis for easy testability in data path scheduling", IEEE International Conference on Computer-Aided Design, pp. 616-619, 1992.
- [5] Tianruo Yang, Zebo Peng, "Integrated Scheduling and Allocation of High-Level Test Synthesis", ASIC Conference 1998.
  Proceedings. Eleventh Annual IEEE International, pp. 81-87, Sep 1998.
- [6] L. M. FLottes, B. Rouzeyre, L. Volpe, "A Controller Resynthesis Based Methods for Improving Datapath Testability", IEEE International Symposium on Circuits and Systems, pp. 347-350, May 2000.
- [7] W. T. Cheng, "The back algorithm for sequential test generation", Proc. 1988 IEEE Int. Conf. on Computer Design, pp. 66-69, Oct. 1988.
- [8] T. M. Niermann and J. H. Patel, "HITEC: A Test Generation Package for Sequential Circuit", in Proc. Of the European Design Automation Conf., pp. 214-218, Feb. 1991.
- [9] Hideo Fujiwara, Hiroyuki Iwata, Tomokazu Yoneda, and Chia Yee Ooi, "A Non-Scan Designfor-Testability for Register-Transfer Level Circuits to Guarantee Linear-Depth Time Expansion Models, " IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, Vol. 27, No. 9, pp. 1535-1544, Sept. 2008.
- [10] Toshinori Hosokawa, Teppei Hayakawa, and Masayoshi Yoshimura, "A Comprehensive Functional Time Expansion Model Generation Method for Datapaths Using Controllers", The Eleventh Workshop on RTL and High Level Testing (WRTLT'10), pp. 131-138, Dec. 2010.
- [11] Kazuya Sugiki, Toshinori Hosokawa, and Masayoshi Yoshimura, "A Test Generation Method for Datapath Circuits Using Functional Time Expansion Models", The Ninth Workshop on RTL and High Level Testing (WRTLT'08), pp. 39-44, Nov. 2008.
- [12] P. Goel and B. C. Rosales, "Test generation and dynamic compaction of tests," in Proc. 1979 Annu. Test Conf, Cherry Hill, NJ.
- [13] S. P. Mohanty, N. Ranganathan, E. Kougianos, and P. Patra, "Low-Power High-Level Synthesis for Nanoscale CMOS Circuits," Springer, 2008.