DesignForTest 01
DesignForTest 01
Jiun-Lang Huang
                                                                                    Hard to set to 1,
                                                                                    easy to set to 0.
                                                            Difficult to observe.
VLSI System Testing                                  5                                   Jiun-Lang Huang, GIEE/ICDA, NTU
       Testability Analysis
         • The process of assessing the testability of a logic circuit by calculating a set
              of numerical measures for each signal.
primary input 1 1
primary output 0
                          1/1       1/1                          3
                  a                                                  2/6         4
                                                                                      5/7
                                                1/1                                          q
                                                           3/5
                                                                           2/7
                          1/1                   1/1              3
                      b                                              2/7
                                                                                             p
                                    1                      3/5                        2/7
                                          2/2
                             1/1
                                                2
                                    1
                          1/1             2/2                                                r
                  c                                 3/5                               3/5
                          CC0/CC1
VLSI System Testing                                   12                         Jiun-Lang Huang, GIEE/ICDA, NTU
       SCOAP Example — CO
                          1/1
                          1/1/4      1/1
                                     1/1/8                           3
                  a                                                        2/6/3
                                                                           2/6           4
                                                                                              5/7/0
                                                                                              5/7
                                                 1/1
                                                 1/1/8                                            q
                                                             3/5/6
                                                             3/5
                                                                                 2/7/3
                                                                                 2/7
                          1/1/6
                          1/1                    1/1
                                                 1/1/6               3
                      b
                                                                                                  p
                                                                         2/7/0
                                                                         2/7                  2/7/0
                                                                                              2/7
                                     1                       3/5/2
                                                             3/5
                                         2/2
                                         2/2/3
                             1/1
                             1/1/4
                                                 2
                                     1
                          1/1/4
                          1/1            2/2
                                         2/2/3                                                    r
                  c                                  3/5/0
                                                     3/5                                      3/5/0
                                                                                              3/5
                          CC0/CC1
VLSI System Testing                                   13                                 Jiun-Lang Huang, GIEE/ICDA, NTU
       Remarks on SCOAP
         • The controllability and observability numbers approximate the number of
              circuit lines that must be set to control or observe a given circuit line.
                         0       1/1/6
                             a                    e0                1 e'
                                 1/1/6          2/3/4
                             b                                          g 4/3/3   Six wires are specified
                                         Four wires are specified                 to set h to 0.
                                         to observe e.
                       0 1c      1/1/6                                            0 e
                                                                    1 1               h   6/4/0
                                 1/1/6                                            1
                       0 1d                             f   3/2/4   0
                                                                                  Four wires are specified
                                                                                  to set h to 1.
                   probability-based
                                             C0(s)                C1(s)              O(s)
                 testability measures
            • 0 ≤ C0, C0, O ≤ 1
            • C0 (s) + C1 (s) = 1
VLSI System Testing                                     16                       Jiun-Lang Huang, GIEE/ICDA, NTU
         • Probability-based controllability calculation rules:
            • The derivation process is similar to SCOAP, with different rules.
            • Assume that gate inputs are independent.
            • A smaller C1(s)/C0(s) indicates that it is harder to set s to 1/0.
                                                C0                                    C1
                primary input*                  p0                              p1 = 1 - p0
                       AND               1 - ∏(input C1's)                    ∏(input C1's)
                       OR                  ∏(input C0's)                     1 - ∏(input C0's)
                       NOT                  (input C1)                             (input C0)
                       XOR           C0(a)C0(b) + C1(a)C1(b)             C0(a)C1(b) + C1(a)C0(b)
                      BRANCH                (stem C0)                              (stem C1)
primary output 1
stem max(branches' O)
[L.-T. Wang, C.-W. Wu, and X. Wen, VLSI Test Principles and Architectures, Morgan Kaufmann Publishers, 2006]
            • For BIST applications that utilize pseudo-random pattern generation, insert test points or
                adjust PI weights to address this issue.
            • They are derived through logic or fault simulation with given patterns.
            • Statistical sampling to reduce the number of simulated patterns.
            • Collect, for all or interested signals, the numbers of occurrences of 0's, 1's, 0-to-1
                transitions, and 1-to-0 transitions.
1/0 0/1
x x/0 x/1
0/1 1/0
x x/0 x/1
                                                                          D
                                                                                           Q
                                                                          SI         D Q       D Q          D Q     OP_output
                                                                 1                             SI           SI
          CP_input    D Q                 D Q        D Q                  SE
                                                                                               SE           SE
            TM                                                  SE
             CK                                                 CK
                                           CP_input                OP_output
                                                      TM    SE
                                                                 SI   P   Q       R       S       T       U
         • The SE (scan enable) input selects the                Q        P   Q       A       S       T       U
              DFF input.
            • In the normal and capture modes, SE is set to 0 to capture the D input value when
                triggered.
            • In the shift mode, SE is set to 1 to capture the SI input value from when triggered.
VLSI System Testing                                     31                                        Jiun-Lang Huang, GIEE/ICDA, NTU
       Full-Scan Design
         • All storage elements are
              replaced with scan cells.               primary
                                                       inputs
                                                                                 combinational logic
                                                                                                                             primary
                                                                                                                             outputs
Ri = ⟨POi, PPOi⟩. SE
PI PIi PIi+1
                  PI                                  PO    PO                              POi
                                 combinational
                                    logic                   PPO                             PPOi
                      PPI                            PPO
                                                                                  shift        hold      capture   hold                shift
                                                                                                   SE:              SE:
                                                                                                  1 0              0 1
                                    scan cells
                                    muxed-D
                      scan_in                    scan_out
                                                                             SI      PPI1                                         SI      PPI2
                            SE
                            CK                                                                observe
                                                                         PPO0       SO                                    PPO1           SO
                                                                                                PO
CK
SE
PI 01 00
SI 0 0 1 1 1 0
                                                                                           PPO
              to control and observe non-scanned FFs.
                                                                                                           non-scanned
                                                                                                             flip-flops
                                                                              scan cells
                                                                              muxed-D
                                                                    scan_in                 scan_out
                                                                                                           non-scanned
                                                                              scan cells
                                                                              muxed-D
                                                                                                             flip-flops
            • TPG complexity: cycle breaking, maximum sequential    scan_in
                                                                        SE
                                                                                            scan_out
                depth.                                              sys_CK
                                                                                              gated
                                                                                              clock
         • Cycle breaking
            1.Construct a structure graph (s-graph).
2.Remove vertices until the graph becomes a directed acyclic graph (DAG).
            • If the sequential depth is D, any single fault can be tested with at most D vectors.
         • One may break only large loops and keep self and small loops to reduce
              the scan-induced overhead.
FF4 FF5
                                                     3           1
                        1   2    4      5
                                                     4           5