# Proceedings of IEEE East-West Design & Test Symposium (EWDTS'08)

Copyright © 2008 by The Institute of Electrical and Electronics Engineers, Inc.

### SPONSORED BY

### **IEEE Computer Society Test Technology Technical Council**





111c



Lviv, Ukraine, October 9 – 12, 2008

### CONTENTS

| A Systematic Approach for Evaluating Satellite Communications Systems<br>Stefano Di Carlo, Paolo Prinetto, Alessandro Savino, Gabriele Tiotto, Paola Elia   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Facilitating Testability of TLM FIFO: SystemC Implementations<br>Homa Alemzadeh, Marco Cimei, Paolo Prinetto, Zainalabedin Navabi                           |
| A Model for Resistive Open Recursivity in CMOS Random Logic<br>M. Renovell, M. Comte, N. Houarche, I. Polian, P. Engelke, B. Becker                         |
| An Optimized CLP-based Technique for Generating Propagation Sequences<br>F. Fummi, V. Guarnieri, C. Marconcini, G. Pravadelli                               |
| Validation of a Mixed-Signal Board ATPG Method<br>Val´erie-Anne Nicolas, Bertrand Gilles, Laurent Nana                                                      |
| A Low-Cost Optimal Time SICP air Generator<br>I. Voyiatzis, H. Antonopoulou                                                                                 |
| Selected Cost Factors in Modeling and Testing Hardware and Semiconductor Defects by Dynamic Discrete Event Simulation<br>Jack H. Arabian                    |
| HotSpot : Visualising Dynamic Power Consumption in RTL Designs<br><b>T. English, K.L. Man, E. Popovici and M.P. Schellekens</b>                             |
| Characterization of CMOS Sequential Standard Cells for Defect Based Voltage Testing<br>A. Wielgus and W. A. Pleskacz                                        |
| Testing the Control Part of Peripheral Interfaces<br><b>S. Zielski, J. Sosnowski</b>                                                                        |
| Concurrent Processes Synchronisation in Statecharts for FPGA implementation<br>Grzegorz Łabiak, Marian Adamski                                              |
| Parallel Fault Simulation on Multi-core Processors<br>Dmitry E. Ivanov                                                                                      |
| Synthesis of control unit with code sharing and chain modifications<br>Alexander Barkalov, Larysa Titarenko, Jacek Bieganowski                              |
| FSMs Implementation into FPGAs with Multiple Encoding of States<br>Arkadiusz Bukowiec, Alexander Barkalov and Larysa Titarenko                              |
| Reduction in the number of PAL macrocells for the effective Moore FSM implementation<br>A. Barkalov, L. Titarenko, S. Chmielewski                           |
| Partial Reconfiguration of Compositional Microprogram Control Units implemented on an FPGA <b>R. Wisniewski, Alexander A. Barkalov, Larysa Titarenko</b> 80 |

| Coverage-Directed Verification of Microprocessor Units Based on Cycle-Accurate Contract<br>Specifications                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alexander Kamkin                                                                                                                                                                                          |
| Code-Probability Entities for Constrained-Random Verification<br>Diana Bodyan, Ghennady Bodyan                                                                                                            |
| Multidimensional Loop Fusion for Low-Power<br>Dmytro Lazorenko                                                                                                                                            |
| A Synthesis of Common Models of Finite State Machines Using Input and Output Registers of Programmable Logic Devices<br>Adam Klimowicz, Valeri Soloviev                                                   |
| An advanced Method for Synthesizing TLM2-based Interfaces<br>Nadereh Hatami, Zainalabedin Navabi104                                                                                                       |
| Testing Combinational QCA Circuits<br>Mehdi Azimipour                                                                                                                                                     |
| Dependability and Complexity Analysis of Inter-channel Connection Schemes for "N out of M"<br>System-on-Chip<br>Vyacheslav Kharchenko, Vladimir Sklyar, Georgiy Chertkov, Yuriy Alexeev,<br>Ladislav Novy |
| Safety-Critical Software Independent Verification Based on Measurement of Invariants during Static Analysis Sergiyenko Volodymyr, Zavolodko Valeriy                                                       |
| Designing High Productivity Parallel Algorithms with Algebraic and Heuristic Programming<br>Techniques<br>Anatoliy Doroshenko, Mykola Kotyuk, Sergiy Nikolayev, Olena Yatsenko                            |
| Multiple Run Memory Testing for PSF Detection<br>I. Mrozek, V.N. Yarmolik, E. Buslowska                                                                                                                   |
| The analysis of the start up control parameters of the asynchronous electric traction motors<br>Gabriel Popa, Razvan A. Oprea, Sorin Arsene                                                               |
| A novel timing-driven placement algorithm using smooth timing analysis<br>Andrey Ayupov, Leonid Kraginskiy                                                                                                |
| Digital Lock Detector for PLL<br>Vazgen Melikyan, Aristakes Hovsepyan, Mkrtich Ishkhanyan, Tigran Hakobyan                                                                                                |
| Diagnosis of SoC Memory Faulty Cells for Embedded Repair<br>Vladimir Hahanov, Eugenia Litvinova, Karina Krasnoyaruzhskaya, Sergey Galagan143                                                              |
| Testing Challenges of SOC Hardware-Software Components<br>Vladimir Hahanov, Volodimir Obrizan, Sergey Miroshnichenko, Alexander Gorobets149                                                               |

| SoC Software Components Diagnosis Technology<br>Svetlana Chumachenko, Wajeb Gharibi, Anna Hahanova, Aleksey Sushanov                                    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Vector-Logical Diagnosis Method for SOC Functionalities<br>Vladimir Hahanov, Olesya Guz, Natalya Kulbakova, Maxim Davydov                               |
| Testability analysis method for hardware and software based on assertion libraries<br>Maryna Kaminska, Roman Prikhodchenko, Artem Kubirya, Pavel Mocar  |
| Different observation time strategies of outputs in diagnostics of sequential digital circuits<br>Yu. A. Skobtsov, V. Yu. Skobtsov                      |
| Design and Implementation of a Parallel Adaptive Filter Using PBS-LMS Algorithm in a Convex<br>Structure<br>Ali Fathiyan, M. Eshghi                     |
| An IEEE 1500 Compatible Wrapper Architecture for Testing Cores at Transaction Level<br>Fatemeh Refan, Paolo Prinetto, Zainalabedin Navabi               |
| Power-Aware Embedded Software Design<br>Fabian Vargas, Cláudia A. Rocha, Luís Fernando Cristófoli, Luciano Rocha                                        |
| System Level Hardware Design and Simulation with System Ada<br>Negin Mahani, Parnian Mokri, Zainalabedin Navabi                                         |
| Automating Hardware/Software Partitioning Using Dependency Graph<br>Somayyeh Malekshahi, Mahshid Sedghi, Zainalabedin Navabi                            |
| Reliable NoC Architecture Utilizing a Robust Rerouting Algorithm<br>Armin Alaghi, Mahshid Sedghi, Naghmeh Karimi, Mahmood Fathy,<br>Zainalabedin Navabi |
| Method for Modeling and Fault Simulation using Volterra kernels<br>Pavlenko V., Fomin O                                                                 |
| Parity Prediction Method For On-Line Testing a Barrel-Shifter<br>Drozd A., Antoshchuk S., Rucinski A., Martinuk A                                       |
| RTL-TLM Equivalence Checking Based on Simulation<br>Nicola Bombieri, Franco Fummi, Graziano Pravadelli                                                  |
| Estimation of the FPAA specification with use of the Artificial Neural Network <b>Damian Grzechca, Tomasz Golonek</b>                                   |
| TUFFAN: A TLM Framework for Fast Architecture Exploration of Digital Systems<br>Sheis Abolmaali, Parisa Razaghi and Zainalabedin Navabi                 |
| Code Optimization for Enhancing SystemC Simulation Time<br>Homa Alemzadeh, Soheil Aminzadeh, Reihaneh Saberi, Zainalabedin Navabi                       |

| Automatic Test Pattern Generation Algorithm for Bridging Faults in Sequential Circuits<br>F. Podyablonsky, N. Kascheev                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Test Suite Consistency Verification<br>Sergiy Boroday, Alexandre Petrenko, Andreas Ulrich                                                                         |
| A 403-MHz Fully Differential Class-E Amplifier in 0.35 μm CMOS for ISM Band Applications<br>Ghulam Mehdi, Naveed Ahsan, Amjad Altaf, Amir Eghbali                 |
| Signal Processing Verification System for the Programmable Digital Matched Filter<br>Kharchenko H.V., Makovetskiy S.O., Tkalich I.O., Tsopa O.I., Vdovychenko Y.I |
| Building a Research Framework for Integrated Circuit Physical Design<br>Andrey Kamaev, Kirill Kornyakov, Iosif Meyerov, Alexey Sidnev, Artem Zhivoderov251        |
| A High-speed and High Precision IDDQ Measurement for Consumer and Communication SoCs<br>Yoshihiro Hashimoto, Yasuo Furukawa, Nguyen Ngoc Mai Khanh                |
| Creating Test Environment for Consumer Video Devices<br>Andrew Johnson, Oleksandr Yegorov                                                                         |
| An Efficient Inner (De)Interleaver Architecture for DVB-T systems<br>Mojtaba Rezayi, Mohammad Eshghi, and Hamid Reza Tanhaei                                      |
| Redundant tests optimization<br>Dmitriy Speranskiy, Ekaterina Ukolova                                                                                             |
| Sensor Web and Grid Technologies for Flood Applications<br>N. Kussul, A. Shelestov, S. Skakun, Yu. Gripich                                                        |
| Persian Digit Recognition by Fourier Coefficients and Neural Networks<br>Nasim Kazemifard, Pedram Azimi, Saeed Mozaffari                                          |
| Deterministic Distinguishing Tests for Given Fault of Discrete Device Synthesis<br>Dmitriy Speranskiy, Ivan Ukolov                                                |
| Digital Implementation of General Regression Neural Network for Function Approximation<br>Applications <b>Saber Moradi, Mahmoud Tabandeh, Nasser Sadati</b>       |
| Hardware Implementation of Exponential Function Using a Mathematical approach<br>Saber Moradi, Mahmud Tabandeh, Nasser Sadati                                     |
| Automated Generation of Register Transfer Graph for Processors<br>Victor Belkin                                                                                   |
| One Approach to Fault Dictionary Size Reduction<br>Sergey Mironov, Dmitriy Speranskiy                                                                             |
| Software engineering for recognition of electronic elements on the circuit board<br>Dmitry Bagayev, Pavel Khrustalev                                              |

| Automatic Identification of Radiotelephone Transmissions in the Maritime Communication<br>Aleksandr V. Shishkin                                                                                   | 306  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| QCA Parallel Prefix Adder Design<br><b>S. Arab, H. Aghababa, B. Forouzandeh</b>                                                                                                                   | 310  |
| Simple march tests for PSF detection in RAM<br>Ireneusz Mrozek, Eugenia Buslowska                                                                                                                 | 314  |
| Improved Digital Signature Protocols On Elliptic And Hyperelliptic Curves<br>Dolgov V.I., Nelasa G.V.                                                                                             | 320  |
| Cascade Structural Encoding of Binary Arrays<br>Vladimir Barannik, Anna Hahanova                                                                                                                  | 322  |
| Mapping DSP Algorithms into FPGA<br>Oleg Maslennikow, Anatolij Sergiyenko, Tatyana Lesyk                                                                                                          | 325  |
| Precision of FTMpS reliability evaluation based on statistical experiments Romankevych A., Romankevych V., Chernyavskaya K                                                                        | 331  |
| Discrete model for dynamics analysis of the nonlinear oscillating systems with long transien processes and complicated nature <b>Zayats Vasyl</b>                                                 |      |
| Deriving test suites for timed Finite State Machines<br>M. Gromov, D. Popov, N. Yevtushenko                                                                                                       | 339  |
| Checker Design for Arbitrary Subset of Unordered Code Words<br>A. Matrosova, A. Malgin, N. Butorina                                                                                               | 346  |
| Multiple Stuck-at Fault and Path Delay Fault Testable Circuits<br>A. Matrosova, V. Andreeva, A. Melnikov, E. Nikolaeva                                                                            | 356  |
| Minimizing Path Length in Digital Circuits Based on Equation Solving N.Kushik, G.Sapunkov, S.Prokopenko, N.Yevtushenko                                                                            | 365  |
| Utilizing HDL Simulation Engines for Accelerating Design and Test Processes Najmeh Farajipour, S. Behdad Hosseini and Zainalabedin Navabi                                                         | 371  |
| Performance evaluation of In-Circuit Testing on QCA based circuits<br>Nasim Kazemifard, Maryam Ebrahimpour, Mostafa Rahimi, Mohammad Tehrani,<br>Keivan Navi                                      | .375 |
| Partitioning, Floor planning and detailed placement and routing techniques for schematic generation of analog netlist<br>Bikram Garg, Rajeev Sehgal, Ashish Agrawal, Amarpal Singh, Manish Khanna | 379  |
| Parallel computer emulator for digital devices modeling<br>Alexander Chemeris, Svetlana Reznikova                                                                                                 | 383  |

| The Oscillations of an Overhead Contact Line Due to the Pantograph Raising<br>R.A. Oprea, G.C.Popa, S.Arsene                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Reverse Semantic Quality Control Methods in Software Engineering<br>Vladimir L. Pavlov, Anatoliy Doroshenko, Konstantin Zhereb, Olexii Kuchaev     |
| The Interplay of Reliability and Power Consumption in Design of SEU-Tolerant Latches for DSM Technology<br>M. Fazeli, S. G. Miremdi, A. Patooghy   |
| Evaluation of a Concurrent Error Detection Technique Using Power Supply Disturbance Fault<br>Injection<br>M. Fazeli, A. Patooghy and S.G. Miremadi |
| Embodying of High Performance Computation in Matlab Parallel Computing Toolbox for Detection of Spread Spectrum Signals<br>Bohdan Yavorskyy        |
| Implementation of Finite State Machines on the Basis of anEmbedded Memory Block<br>V. Chapenko, K. Boule                                           |
| On Macroplaces in Petri Nets<br>Andrei Karatkevich                                                                                                 |
| Testing of hardware and software for FPGA-based critical systems<br>Yuliya Prokhorova, Sergey Ostroumov, Vladimir Sklyar                           |
| Luxury Wallet – new generation of the SoC based consumer products<br>Mikhail Lodygin                                                               |
| Descriptor Neural Networks And Singular Implicit Dynamic Systems<br>Rutkas A.A                                                                     |
| Tools of the Computer Testing of Knowledge in Mathematical Disciplines<br>Shkil A.S., Naprasnsk S.V., Tsimbaluyk E.S., Garkusha E.V.               |
| Software for problem components estimation in photometric stereo reconstruction<br>Bohdan Rusyn, Yuriy Lysak, Oleksiy Lutsyk                       |
| Method of Digital Treatment of the Information Received by Space Diversity Radars<br>Dmitriy Vasiliev                                              |
| Verification Challenges of Clock Domain Crossings<br>D. Melnik, S. Zaychenko, O. Lukashenko438                                                     |
| AUTHORS INDEX                                                                                                                                      |

### **IEEE EAST-WEST DESIGN AND TEST SYMPOSIUM 2008 ORGANISING COMMITTEE**

#### **General Chairs**

- V. Hahanov Ukraine
- Y. Zorian USA

### General Vice-Chairs

- M. Karavay Russia
- R. Ubar Estonia

#### **Program Chairs**

- S. Shoukourian Armenia
- D. Speranskiy Russia

#### **Program Vice-Chairs**

M. Renovell - France Z. Navabi - Iran

**Publicity Chairs** 

C. Landrault - France S. Mosin – Russia

#### **Program Committee**

- E. J. Aas Norway
- J. Abraham USA
- A. Barkalov Poland
- R. Bazylevych Ukraine
- A. Drozd Ukraine
- E. Evdokimov Ukraine
- A. Chaterjee USA
- E. Gramatova Slovakia
- S. Hellebrand Germany
- A. Ivanov Canada
- V. Kharchenko Ukraine
- K. Kuchukjan Armenia

- A. Matrosova Russia
- V. Melikyan Armenia
- O.Novak Czech Republic
- A. Orailoglu USA
- Z. Peng Sweden
- A. Petrenko Ukraine
- P. Prinetto Italy
- J. Raik Estonia
- A. Romankevich Ukraine
- A. Rvjov Russia
- R. Seinauskas Lithuania
- S. Sharshunov Russia
- A. Singh USA
- J. Skobtsov Ukraine
- A. Stempkovsky Russia V. Tverdokhlebov Russia
- V. Vardanian Armenia
- V. Yarmolik Byelorussia
- A. Yessayan Armenia

#### **Steering Committee**

- M.Bondarenko Ukraine V. Hahanov – Ukraine
- R. Ubar Estonia
- Y. Zorian USA

#### **Organizing Committee**

- S. Chumachenko Ukraine M. Kaminska – Ukraine
- N. Kulbakova Ukraine M. Lobur – Ukraine
- V. Obrizan Ukraine
- T. Sviridova Ukraine

### EWDTS CONTACT INFORMATION

Prof. Vladimir Hahanov **Design Automation Department** Kharkov National University of Radio Electronics, 14 Lenin ave, Kharkov, 61166, Ukraine.

Tel.: +380 (57)-702-13-26 E-mail: hahanov@kture.kharkov.ua Web: www.ewdtest.com/conf/

#### **Diagnosis of SoC Memory Faulty Cells for Embedded Repair**

Vladimir Hahanov, Eugenia Litvinova, Karina Krasnoyaruzhskaya, Sergey Galagan Computer Engineering Faculty, Kharkov National University of Radioelectronics, Lenin Ave. 14, Kharkov, Ukraine, 61166, phone: (057) 70-21-421, (057) 70-21-326 E-mail: hahanov@kture.kharkov.ua; kiu@kture.kharkov.ua

#### Abstract

A method of optimal memory fault repair that differs from analogs by application of algebra-logical technology of fault covering by two-dimensional memory matrix topology is proposed. It enables to obtain minimal and full solutions for subsequent repair in real time, which is based on utilization of spares in the form of memory rows and columns.

#### 1. Introduction

Modern digital systems-on-chip (SoC) include millions of equivalent gates and new high-level design technologies are necessary for their creation [1-3]. SoC memory in the future will occupy more than 90% of chip area that is oriented on use flexible software [3-7,11]. Development of models and methods of quick and exact diagnosis, as well as technologies for repair of faulty cells by on-chip facility in real time and on all life cycle stages of a product are urgent problems. It will enable to decrease quantity of chip pins, to raise yield, to decrease time-to-market, to reduce service costs, as well as to remove output diagnosis and repair facility [1,6,7,12].

The research aim is development of algebra-logical method of embedded matrix memory diagnosis and repair in real time.

The problems: 1) Analysis of SoC Infrastructure Intellectual Property Technologies; 2) Development of an Infrastructure Intellectual Property method on basis of the covering matrix; 3) Formalization of the algebralogical AL-method for embedded memory repair; 4) Analysis of obtained results.

Modern design technologies of digital systems on chips propose along with creation of functional blocks F-IP development of service modules I-IP, which are oriented on complex solving of the project quality problem and yield increasing in manufacturing that is determined by implementation of the following services into a chip [11,14,16]: 1) Diagnosis of failures and faults by analysis of information, which is obtained on the stage of testing and use of special methods of embedded fault lookup on basis of the standard IEEE 1500 [8,13,15];

2) Repair of functional modules and memory after fixation of a negative testing result, fault location and identification of a fault type in carrying out of the diagnosis phase;

3) Measurement of the general characteristics and parameters of a device operation on basis of on-chip facilities, which enable to make time and volt-ampere measurements;

4) Reliability and fault tolerance of a device operation in working that is obtained by diversification of functional blocks, redundancy of them and repair of SoC in real time.

#### 2. SoC Memory Diagnosis and Repair

It is represented the exact method of memory elements diagnosis and repair by spares that enables to cover a set of fault cells by minimally possible quantity of spares. The method is oriented on implementation to the Infrastructure Intellectual Property for SoC functionality. The structure solutions for realization of the method of diagnosis and repair of memory matrix fault cells are proposed. [5-7, 10].

The aim function Z of given research can be defined on the basis of modern progress in the field of on-line memory repair in the following way: minimization of the repair cost (hardware costs) of a memory module  $M = |M_{ij}|$  in the process of SoC operation by means of use the algebra-logical method of minimization of the faulty cells set covering by a system of reserve elements under the constraints N on quantity of ones:

$$Z = \min_{i} [Q_i(F)]_{|Q_i(F) \le N_{max} = N_r + N_c},$$

where  $Q_i(F)$  – the cost of i-th solution variant of the memory module  $M = |M_{ij}|$  repair by means of the minimal subset of rows and columns  $R = \{R_r, R_c\}$  of chip reserve that covers the set F of faulty memory cells  $R \cap F = F, Z^* = max | F_i |, F_i \in F \leftarrow \forall R_i$ .

Method of minimal covering obtainment on an example a memory matrix with five faulty cells [10], two reserve rows and a reserve column (Fig. 1) is considered below. Every reserve component (a row or a column) can repair from one up to n faulty cells, which belong to a row or a column.

The method idea is optimal replacement of faulty memory matrix elements by means of solution of the covering problem of faulty columns by row reserve. For the method illustration it is proposed originally to use the covering matrix of given faults F by some quantity of rows (it can be test patterns or reserve rows) X and

$$|\mathbf{F}| \ge |\mathbf{X}| = \{\mathbf{F}_1, \mathbf{F}_2, \mathbf{F}_3, \mathbf{F}_4, \mathbf{F}_5, \mathbf{F}_6, \mathbf{F}_7, \mathbf{F}_8\} \ge 1$$

 $\geq \{X_1, X_2, X_3, X_4, X_5, X_6\}.$ 

Let the matrix Y is specified:

 $(F_j \cap X_i \neq \varnothing \rightarrow Y_{ij} = l) \, \& \, (F_j \cap X_i = \varnothing \rightarrow Y_{ij} = 0) \, \colon \,$ 

|     | X <sub>i</sub> /F <sub>j</sub>   | F <sub>1</sub> | F <sub>2</sub> | F <sub>3</sub> | F <sub>4</sub> | F <sub>5</sub> | F <sub>6</sub> | F <sub>7</sub> | F <sub>8</sub> |
|-----|----------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|     | X <sub>1</sub>                   | 1              |                |                |                |                | 1              |                |                |
|     | X <sub>2</sub><br>X <sub>3</sub> |                | 1              | 1              |                |                |                | 1              | 1              |
| Y = | X3                               |                |                |                |                | 1              |                |                | 1              |
|     | $X_4$                            | 1              |                |                | 1              |                |                |                |                |
|     | X <sub>5</sub>                   |                |                | 1              | 1              |                |                |                |                |
|     | X <sub>6</sub>                   |                |                |                |                | 1              | 1              |                |                |

The exact solution of the covering problem of faults by minimal quantity of reserve memory rows is based on synthesis of the Boolean function [9] that is written as product of sums, written by constituents of unities, which correspond to columns of the matrix:

 $Y = (X_1 \lor X_4) \& (X_2) \& (X_2 \lor X_5) \& (X_4 \lor X_5) \&$ 

$$\&(X_3 \lor X_6)\&(X_1 \lor X_6)\&(X_2)\&(X_2 \lor X_3).$$

In given case an analytic notation in the Boolean function form, represented in conjunctive normal form (CNF), is the initial model that contains a full set of covering problem solutions that is solved by finding of disjunctive normal form (DNF). The transformation procedure of CNF to DNF by means of all terms multiplication is performed for it. In result of the equivalent transformations, performed in compliance with the algebra of logic rules, it is came out the Boolean function that contains all possible fault covers, defined by four variants of row combinations:

$$\begin{split} &Y = (X_1 X_2 \vee X_2 X_4) (X_2 X_4 \vee X_4 X_5 \vee X_5 X_5 \vee X_2 X_5) \,\& \\ &\& (X_1 X_3 \vee X_1 X_6 \vee X_6 X_6 \vee X_3 X_6) (X_2 X_2 \vee X_2 X_3) = \\ &= (X_1 X_2 X_3 X_4 \vee X_2 X_4 X_6 \vee X_1 X_2 X_3 X_5 \vee X_1 X_2 X_5 X_6). \end{split}$$

The minimal solution of covering problem contains three reserve rows, which can cover 8 faults in a memory matrix:  $Y = X_2 X_4 X_6$ .

For use of the proposed memory repair method it is necessary to remember that every fault Fi in a memory matrix belongs to a row and a column simultaneously. So, transformation of the topological fault model to the covering matrix consists of assignment of row and column numbers, which are distorted by given fault, to every fault.

For instance (Fig.1), where there are 5 faulty cells, which are covered by three columns and 4 rows, the transformation turns a memory matrix into the covering table, where left column specifies one-to-one correspondence between fault coordinates (row and column numbers of a memory matrix) and rows of a fault covering:

|     | -                                |                |                |                |                |                |
|-----|----------------------------------|----------------|----------------|----------------|----------------|----------------|
|     | X <sub>i</sub><br>F <sub>j</sub> | F <sub>1</sub> | F <sub>2</sub> | F <sub>3</sub> | F <sub>4</sub> | F <sub>5</sub> |
|     | $C_2 \rightarrow X_1$            |                | 1              |                | 1              |                |
|     | $C_4 \rightarrow X_2$            |                |                | 1              |                | 1              |
| Y = | $C_8 \rightarrow X_3$            | 1              |                |                |                |                |
|     | $R_3 \rightarrow X_4$            | 1              | 1              |                |                |                |
|     | $R_5 \rightarrow X_5$            |                |                | 1              |                |                |
|     | $R_7 \rightarrow X_6$            |                |                |                | 1              |                |
|     | $R_{10} \rightarrow X_7$         |                |                |                |                | 1              |

In other words, the memory matrix topology is transformed from two-dimensional metrics to onedimensional row structure, which have defined covering features concerning about fault columns.



Fig. 1. Memory matrix with fault cells

The following Boolean function forms logical product of disjunctions, written by constituents of

unities, corresponding to columns of the matrix  $(F_i \cap X_i \neq \emptyset \rightarrow Y_{ii} = 1)$ :

$$Y = (X_3 \lor X_4)(X_1 \lor X_4)(X_2 \lor X_5)(X_1 \lor X_6)(X_2 \lor X_7) =$$

$$= (X_1X_3 \lor X_1X_4 \lor X_3X_4 \lor X_4)(X_1X_2 \lor X_1X_5 \lor X_2X_6 \lor$$

$$\lor X_5X_6)(X_2 \lor X_7) = (X_1X_3 \lor X_4)(X_2 \lor X_7)(X_1X_2 \lor$$

$$\lor X_1X_5 \lor X_2X_6 \lor X_5X_6) = (X_1X_2X_3 \lor X_2X_4 \lor X_1X_3X_7 \lor$$

$$\lor X_4X_7)(X_1X_2 \lor X_1X_5 \lor X_2X_6 \lor X_5X_6) = (X_1X_2X_3 \lor$$

$$\lor X_1X_2X_4 \lor X_1X_2X_3X_7 \lor X_1X_2X_4X_7 \lor X_1X_2X_3X_5 \lor$$

$$\lor X_1X_2X_4X_7 \lor X_2X_4X_6 \lor X_2X_4X_5X_6 \lor X_1X_2X_3X_7 \lor$$

$$\lor X_1X_3X_5X_7 \lor X_1X_2X_3X_6X_7 \lor X_1X_3X_5X_6X_7 \lor$$

$$\lor X_1X_2X_4X_7 \lor X_1X_4X_5X_7 \lor X_2X_4X_6X_7 \lor X_4X_5X_6X_7 =$$

$$= (X_1X_2X_3 \lor X_1X_2X_4 \lor X_2X_4X_6 \lor X_1X_3X_5X_7 \lor$$

 $\vee X_1X_4X_5X_7 \vee X_4X_5X_6X_7.$ 

The equivalent transformations enable to simplify the complex construction – conjunctive normal form – and to obtain the minimal set of all solutions, a number of that is equal to six in this case. Subset of minimal solutions is defined by three conjunctive terms, every of which contains 3 reserve elements for memory matrix repair:

$$Y = X_1 X_2 X_3 \vee X_1 X_2 X_4 \vee X_2 X_4 X_6.$$

## 3. Algebra-Logical Memory Repair Method

The aim function is defined as minimization of reserve components of the memory matrix (S – spare), which are needed for its repair in the process of SoC operation by means of synthesis of disjunctive normal form of faulty elements covering and subsequent choice of the minimal conjunctive term  $X^t(R^t, C^t) \in Y$  that satisfies to limitations on quantity of the reserve rows and columns  $S^r_{max}$ ,  $S^c_{max}$ , which enter into the logical product:

$$\begin{split} & Z = \min_{t=1,n} (|X^t|) |_{|S^r| + |S^c| \leq S_{max}; |S^r| \leq S_{max}^r; |S^c| \leq S_{max}^c} \\ & X^t \in Y = \{X^1, X^2, ..., X^t, ...., X^n\}, \\ & X^t = (X_1^t \& X_2^t \&, ..., \& X_i^t \&, ...., \& X_{m_t}^t), \end{split}$$

where every resulting conjunctive term of the function Y is made from the row and column identifiers  $X^{t} = (R^{t}, C^{t})$ , which cover all faults in a memory matrix. The best solution is a term of minimal length at Quinn mark [9], in which there are rows and columns, covering all faults. In particular case a solution can contain none rows (columns), when existing columns

(rows) from memory matrix reserve are sufficient for memory repair. The model of definition process of minimal quantity of spares, which cover all detected faults in a memory matrix, comes to the following items:

1. Transformation of two-dimensional model of a memory matrix faults to the fault covering table by reserve rows and columns. To achieve of the aim the topological memory model in the form of matrix, identifying detected faults, is considered:

$$\mathbf{M} = \left| \mathbf{M}_{ij} \right|, \mathbf{M}_{ij} = \begin{cases} 1 \leftarrow \mathbf{T} \oplus \mathbf{f} = \mathbf{i}; \\ 0 \leftarrow \mathbf{T} \oplus \mathbf{f} = \mathbf{0}. \end{cases}$$

Here a matrix coordinate is equal to 1, if the fault-free behaviour function of a cell gives unit value on a test, the coordinate is identified as faulty. After fixation of all faults construction of the fault covering table  $Y = |Y_{ij}|, i = \overline{1, n}; j = \overline{1, m}$  is carried out, where columns correspond to the set of detected faults m and rows are numbers of columns and rows of a memory matrix, which have faults:

$$\mathbf{Y} = \left| \mathbf{Y}_{ij} \right|, \mathbf{Y}_{ij} = \begin{cases} 1 \leftarrow \mathbf{C}_i(\mathbf{R}_i) \cap \mathbf{F}_j \neq \emptyset; \\ 0 \leftarrow \mathbf{C}_i(\mathbf{R}_i) \cap \mathbf{F}_j = \emptyset. \end{cases}$$

Instead of the two-dimensional metrics components C and R the one-dimensional vector is used, it is concatenated from two sequences C and R, the power of which is equal to n = p + q:

$$\begin{split} &X = C * R = (C_1, C_2, ..., C_i, ..., C_p) * (R_1, R_2, ..., R_j, ..., R_q) = \\ &= X^c * X^r = (X_1, X_2, ..., X_i, ..., X_p, X_{p+1}, X_{p+2}, ..., X_{p+j}, ..., X_{p+q}). \end{split}$$

At that there exists one-to-one correspondence between the initial set elements (C, R) and the resulting vector X, which is defined in first column of the matrix Y. It is necessary to say that transformation X = C \* Ris carried out for ease of consideration and subsequent forming of disjunctive normal form (uniformity of variables, forming the Boolean function). If the procedure is not carried out the function is defined by two kinds of variables, containing rows and columns of a memory matrix..

2. Construction of conjunctive normal form for analytic, complete and exact solution of the covering problem. After generation of the covering matrix that contains zero and unit coordinates the synthesis of analytic covering form is carried out by writing of CNF by columns. Here a number of conjunctive terms are equal to quantity of table columns and every disjunction is written by unit values of a current column:

$$Y = \bigwedge_{j=l}^{m} (Y_{pj} \vee Y_{qj})_{\{Y_{pj}, Y_{qj}\}=l} = \bigwedge_{j=l}^{m} (X_{pj} \vee X_{qj}).$$

From last expression it is obvious that every column has two coordinates only, which have unit value, and a number of logical products is equal to total quantity of faults m, detected in a memory matrix.

3. Transformation of CNF to DNF that enables to determine all solutions of the covering problem. For that it is necessary to apply an operation of logical multiplication and the minimization (absorption) rules to conjunctive normal form to obtain of disjunctive normal form:

$$Y = \bigvee_{\substack{j=1 \\ j=l}}^{w} (k_{1}^{j}X_{1} \wedge k_{2}^{j}X_{2} \wedge ... \wedge k_{i}^{j}X_{i} \wedge ... \wedge k_{n}^{j}X_{n}), k_{i}^{j} = \{0, l\}.$$

337

It is the generalized DNF notation, where in the limit a number of terms is equal to  $w = 2^n$ , where n is quantity of rows in the generalized set (C,R) or quantity of the variables X in the matrix Y, on the set of which all solutions are formed (fault covering by reserve components); if  $k_i^j$  at  $X_i$  is equal to zero the variable  $X_i$  is nonessential.

4. Choice of minimal and exact solutions of the covering problem. It is related to determination of minimal length conjunctions in the obtained DNF. The following transformation executing rows and columns of a memory matrix on basis of above-mentioned correspondence enables to write a minimal covering or set of ones in two-dimensional metrics of rows and columns, which satisfies the conditions (limitations) of the aim function on quantity of reserve components.

An illustration of the memory matrix repair process model is proposed below. Minimal quantity of reserve components, which cover all faults, is determined. A memory matrix with faults and reserve [10] is represented in Fig. 2.



Fig. 2. Memory matrix with faults and reserve

The matrix has limitations on diagnosis and repair capabilities of ten faulty cells, which are defined by two rows and five columns. In compliance with item 1 of the model of definition process of minimal quantity of spares, which covers all detected faults in a memory matrix, the covering table of ten faults

$$F = (F_1, F_2, F_3, F_4, F_5, F_6, F_7, F_8, F_9, F_{10})$$

is formed. Faults are covered by 11 rows, which are represented in the form of concatenation of the subsets C and R, which are in one-to-one correspondence with the variable vector X:

$$C*R = (C_2, C_3, C_5, C_7, C_8)*(R_3, R_4, R_5, R_7, R_8, R_{10}) \approx$$

$$\approx X = (X_1, X_2, X_3, X_4, X_5, X_6, X_7, X_8, X_9, X_{10}, X_{11}).$$

$$\boxed{\begin{array}{c|c|c|c|c|c|c|c|c|}\hline X_1 & F_1 & F_2 & F_3 & F_4 & F_5 & F_6 & F_7 & F_8 & F_9 & F_{10} \\\hline C_2 \rightarrow X_1 & & 1 & & 1 \\\hline C_3 \rightarrow X_2 & 1 & & 1 & & 1 \\\hline C_5 \rightarrow X_3 & & 1 & & 1 & & 1 \\\hline C_7 \rightarrow X_4 & 1 & & & & & & & & \\\hline\end{array}}$$

| Y = | $C_8 \rightarrow X_5$       |   |   |   |   | 1 |   |   | 1 |   |   |
|-----|-----------------------------|---|---|---|---|---|---|---|---|---|---|
|     | $R_3 \rightarrow X_6$       | 1 | 1 |   |   |   |   |   |   |   |   |
|     | $R_4 \rightarrow X_7$       |   |   | 1 |   |   |   |   |   |   |   |
|     | $R_5 \rightarrow X_8$       |   |   |   | 1 |   |   |   |   |   |   |
|     | $R_7 \rightarrow X_9$       |   |   |   |   | 1 | 1 |   |   |   |   |
|     | $R_8 \rightarrow X_{10}$    |   |   |   |   |   |   | 1 |   |   |   |
|     | $R_{10} \rightarrow X_{11}$ |   |   |   |   |   |   |   | 1 | 1 | 1 |

In compliance with the covering table construction of DNF is performed, the terms are written by unit values of columns:

 $Y = (X_4 \lor X_6)(X_2 \lor X_6)(X_3 \lor X_7)(X_1 \lor X_8)(X_5 \lor X_9) \&$ 

 $\&(X_3 \lor X_9)(X_2 \lor X_{10})(X_5 \lor X_{11})(X_3 \lor X_{11})(X_1 \lor X_{11}).$ 

Subsequent transformations related to obtainment of disjunctive normal form are based on application of The Boolean algebra lows and identities, which enable to carry out logical multiplication of all ten multipliers, subsequent minimization of DNF terms by application of the minimization operator, the absorption axioms, removal of the same terms. Skipped intermediate calculus the final result is represented in the following form:

$$\begin{split} Y = & X_1 X_2 X_3 X_4 X_5 \lor X_2 X_3 X_4 X_5 X_8 X_{11} \lor \\ & \lor X_1 X_2 X_4 X_9 X_3 X_{11} \lor X_1 X_3 X_2 X_4 X_9 X_{10} X_{11} \lor \\ & \lor X_1 X_7 X_{10} X_{11} X_6 X_9 \lor X_6 X_9 X_7 X_8 X_{10} X_{11} \lor \\ & \lor X_2 X_4 X_9 X_3 X_8 X_{11} \lor X_1 X_2 X_4 X_9 X_7 X_{11} \lor \\ & \lor X_2 X_4 X_9 X_7 X_8 X_{11} \lor X_3 X_2 X_4 X_9 X_8 X_{10} X_{11} \lor \\ & \lor X_1 X_2 X_4 X_9 X_7 X_{10} X_{11} \lor X_1 X_2 X_3 X_5 X_6 \lor \\ & \lor X_1 X_3 X_5 X_6 X_{10} \lor X_2 X_3 X_5 X_6 X_8 X_{11} \lor \\ & \lor X_3 X_5 X_6 X_8 X_{10} X_{11} \lor X_1 X_2 X_3 X_{11} X_6 X_9 \lor \\ & \lor X_1 X_2 X_7 X_{11} X_6 X_9 \lor X_2 X_7 X_8 X_{11} X_6 X_9 \lor \\ & \lor X_1 X_2 X_7 X_{11} X_6 X_9 \lor X_2 X_7 X_8 X_{11} X_6 X_9 \lor \\ & \lor X_3 X_8 X_{10} X_{11} X_6 X_9. \end{split}$$

The choice of minimal length terms, which contain 5 variables, forms a set of optimal (minimal) solutions:

$$Y = X_1 X_2 X_3 X_4 X_5 \lor X_1 X_2 X_3 X_5 X_6 \lor X_1 X_3 X_5 X_6 X_{10}.$$

Transformation of obtained function to a coverage that contains variable designations in the form of rows and columns of a memory matrix enables to represent solutions in the following form:

$$Y = C_2 C_3 C_5 C_7 C_8 \lor C_2 C_3 C_5 C_8 R_3 \lor C_2 C_5 C_8 R_3 R_8$$

All obtained minimal solutions satisfy the requirements (limitations) on spare quantity that is determined by numbers:

$$\left(\left|\mathbf{C}^{\mathbf{r}}\right| \le 5\right) \& \left(\left|\mathbf{R}^{\mathbf{r}}\right| \le 2\right)$$

Other solutions, determined in DNF, are no interest, because they have not optimal covering of faulty cells that is determined by quantity of variables (rows + columns) in terms, greater then five. Subsequent technology of embedded repair of faulty cells consists of electrical reprogramming of an address decoder of a column or a row of a memory matrix. In respect to memory, represented in Fig. 2, a procedure of writing or reading of information at access to any cell of column 2 will be readdressed to reserve column 11. In compliance with last obtained solution (first term of DNF function Y) other faulty columns will be replaced on fault-free ones from memory reserve: 3 - on 12; 5 - on 13; 7 - on 14, 8 - on 15.

The computational complexity of algebra-logical memory repair method in the part of solving of the covering problem is determined by the following expression:

$$Q = 2^{|F|} + |C + R| \times 2^{|F|},$$

where  $2^{|F|}$  is costs related to DNF synthesis by logical multiplication of two-component disjunctions (fault coordinate is defined by row and column numbers), quantity of them is equal to quantity of faulty cells;  $|C+R| \times 2^{|F|}$  is upper limit of computational costs, which are needed for minimization of obtained DNF on maximum set of variables that is equal to total quantity of rows and columns |C+R|. In the worst case, when coordinates of all faulty cells are not correlated by rows and columns (they are unique), for instance, diagonal faults, the computational complexity of the matrix method is dependent from quantity of faulty cells only and its analytic notation is transformed to the following view:

$$Q = 2^{|F|} + |C + R| \times 2^{|F|}|_{|C + R| \le 2 \times |F|} =$$
$$= 2^{|F|} + 2 \times |F| \times 2^{|F|} = 2^{|F|} \times (1 + 2 \times |F|)$$

If instead of fault set power to use quantity m of them, the previous expression can be represented in more simple form:

 $Q = 2^{m} \times (1 + 2 \times m) = 2^{m} (2m + 1).$ 

According to the SoC Functional Intellectual Property Infrastructure, the matrix repair method on basis of solving of the covering problem is implemented into a chip as one of I-IP components that is designed for the operability support of SoC matrix memory.

#### 4. Conclusion

The algebra-logical memory repair method is based on solving of the faulty cells covering problem by spares by means of the Boolean algebra apparatus. The method has quadratic computational complexity and can have hardware or software realization that is service module of fault correction, which enables to carry out memory elements repair in the process of operation.

The classical covering problem use two onedimensional vectors (X, F), where the covering operator P enables to find minimal subset of the components X, which cover all elements from F:  $X_{\min} = P(X, F) \leftarrow X \cap F = X_{\min}$  by its aggregate functionality. The statement of covering problem of one-dimensional vector F features by two-dimensional matrix  $M = (C \times R)$  is needed in reduction of both components to a single metrics (such coordinate system that is common denominator for both structures). Such metrics for the matrix  $M = (C \times R)$ and the vector F is one-dimensional structure. So, in this case it is necessary to carry out transformation of two-dimensional structure (memory fault matrix)  $M = (C \times R)$  to one-dimensional one by means of the concatenation operation X = (C \* R) for subsequent solving of the classical covering problem by application of formal actions, which are defined by the operator  $X_{\min} = P(X, F)$ .

Proposed method of optimal memory fault repair differs from analogs by application of algebra-logical technology of fault covering by two-dimensional memory matrix topology that enables to obtain minimal and full solutions for subsequent repair in real time, which is based on utilization of spares in the form of memory rows and columns.

Practical importance of the research consists of implementation of the method to SoC Functional Intellectual Property Infrastructure. It enables to raise yield essentially (5-10%) on the electronic technology market by means of faulty chip repair in the process of production and operation, as well as to increase the life cycle duration of memory matrixes by repair of them in real time.

On-chip repair is oriented on all objects, which have an address: memory, multiplexers, matrix processors. If it is necessary to repair other structures, they must be designed with an allowance for component addressability. The addressability and regularity of components turns a system into reliable, robust, repairable and durable one.

Further research is oriented on development of testability structure of the system and hardware BIRA module for embedded memory repair in appearance of faults on production and operating stages.

#### 5. References

- P. Rashinkar, P. Paterson, L. Singh System-on-chip Verification: Methodology and Techniques, Kluwer Academic Publishers, 2002, 393 p.
- [2] IEEE-1800 IEEE Standard for System Verilog Language, 2005, 586 p.
- [3] S. Hamdioui, G. N. Gaydadjiev, A. J. Van de Goor. The State-of-the-art and Future Trends in Testing Embedded Memories, *Records IEEE International Workshop on Memory Technology, Design and Testing*, San Jose, CA, August 2004, pp. 54-59.
- [4] Y. Zorian Today's SoC Test Challenges, *ITC International Test Conference*, 2005.
- [5] S.Shoukourian, V. Vardanian, Y.Zorian SoC Yield Optimization via an Embedded-Memory Test and Repair Infrastructure, *IEEE Design and Test of Computers*, 2004, pp. 200-207.
- [6] L. Youngs, S. Paramanandam Mapping and Repairing Embedded-Memory Defects, *IEEE Design and Test of Computers*, 1997, pp. 18-24.

- [7] Y.Zorian, S. Shoukourian Embedded-Memory Test and Repair: Infrastructure IP for SoC Yield, *IEEE Design* and Test of Computers, 2003, pp.58-66.
- [8] Y. Zorian, A. Yessayan IEEE 1500 Utilization in SoC Design and Test, *ITC International Test Conference*, 2005.
- [9] K. Rossen Discrete Mathematics and its Applications, McGraw Hill, 2003, 824 p.
- [10] A.N. Parfentiy, V.I. Hahanov, E.I. Litvinova SOC Infrastructure Intellectual Property Models, *ASU and automation devices*, No. 138, 2007, C.83-99.
- [11] Z. Yervant What is Infrustructure IP?, *IEEE Design & Test of Computers*, May-June 2002, pp. 5-7.
- [12] Z. Yervant, G. Dmytris Gest editors' introduction: Design for Yield and reliability, *IEEE Design & Test of Computers*, May-June 2004, pp. 177-182.
- [13] IEEE 1500 Web Site. http://grouper.ieee.org/groups/1500/.
- [14] D. Densmore, R. Passerone, A. Sangiovanni-Vincentelli A Platform-Based taxonomy for ESL design, *Design&Test of Computers*, September-October 2006, pp. 359-373.
- [15] F. DaSilva, Y. Zorian, L. Whetsel, K. Arabi, R. Kapur Overview of the IEEE P1500 Standard, *ITC International Test Conference*, 2003, pp. 988–997.
- [16] M.F. Bondarenko, G.F. Krivoula, V.G. Ryabtsev, S.A. Fradkov, V.I. Hahanov *Design and diagnosis of computer systems and networks*, Kiev: NMTS VO, 2000, 306 p.

Camera-ready was prepared in Kharkov National University of Radio Electronics by Dr. Svetlana Chumachenko and Volodymyr Obrizan Lenin ave, 14, KNURE, Kharkov, 61166, Ukraine

> Approved for publication: 20.09.2008. Format 60×841/8. Relative printer's sheets: . Circulation: 150 copies. Published by SPD FL Stepanov V.V. Ukraine, 61168, Kharkov, Ak. Pavlova st., 311

Матеріали симпозіуму «Схід-Захід Проектування та Діагностування – 2008» Макет підготовлено у Харківському національному університеті радіоелектроніки Редактори: Світлана Чумаченко та Володимир Обрізан Пр. Леніна, 14, ХНУРЕ, Харків, 61166, Україна

> Підписано до публікації: 20.09.2008. Формат 60×84<sup>1</sup>/<sub>8</sub>. Умов. друк. арк. . Тираж: 150 прим. Видано: СПД ФЛ Степанов В.В. Вул. Ак. Павлова, 311, Харків, 61168, Україна