Algebra-Logical Repair Method for FPGA Logic Blocks by Hahanov, Vladimir et al.
Algebra-Logical Repair Method for FPGA Logic 
Blocks 
Vladimir Hahanov, Eugenia Litvinova, Wajeb Gharibi, Olesya Guz 
1
Abstract – An algebra-logical repair method for FPGA 
functional logic blocks on the basis of solving the coverage 
problem is proposed. It is focused on implementation into 
Infrastructure IP for system-on-a chip and system-in-package. 
A method is designed for providing the operability of FPGA 
blocks and digital system as a whole. It enables to obtain exact 
and optimal solution associated with the minimum number of 
spares needed to repair the FPGA logic components with 
multiple faults.  
Index terms – digital system, system-on-a chip, system-in-
package, FPGA functional logic blocks. 
I. INTRODUCTION 
At present there are many scientific publications, which 
cover SoC/SiP testing, diagnosis and repair problems [1-16, 
19-20]. The testing and repair problem for the digital 
system logic components has a special place, because repair 
of faulty logic blocks is technologically complicated 
problem. Existing solutions, which are proposed in 
published works, can be divided on the following groups:   
1. Duplication of logic elements or chip regions to 
double hardware realization of functionality. When faulty 
element is detected switching to faultless component by 
means of a multiplexer is carried out [4]. The FPGA models, 
proposed by Xilinx, can be applied for repair of Altera 
FPGA components. At repair the main unit of measure is 
row or column.  
2. Application of genetic algorithms for diagnosis and 
repair on basis of off-line FPGA reconfiguration not using 
external control devices [5]. The fault diagnosis reliability is 
99%, repair time is 36 msec instead of 660 sec, required for 
standard configuration of a project.    
3. Time-critical FPGA repairing by means of 
replacement of local CLBs by redundant spares is proposed 
                                                          
Manuscript received June 9, 2009.  
Vladimir Hahanov is with the Kharkov National University of 
Radioelectronics, Ukraine, 61166, Kharkov, Lenin Prosp., 14, room 321 
(corresponding author to provide phone: (057)7021326; fax: 
(057)7021326; e-mail: hahanov@ kture.kharkov.ua).  
Eugenia Litvinova is with the Kharkov National University of 
Radioelectronics, Ukraine, 61166, Kharkov, Lenin Prosp., 14, room 378 
(phone: (057)7021421; fax: (057)7021326; e-mail: kiu@ 
kture.kharkov.ua).  
Wajeb Gharibi is with Kingdom of Saudi Arabia (e-mail: 
gharibiw2002@yahoo.com),  
Olesya Guz is with the Donetsk Institute of Road Transport, Donetsk, 
Ukraine (e-mail: kiu@kture.kharkov.ua) 
 
in [6,7]. In critically important applications the acceptable 
integration level for CLB replacement is about 1000 logic 
blocks.  
The repair technologies for digital system logic, 
implemented on-chip FPGA, are based on existence or 
introduction of LUT redundancy after place and route 
procedure executing. Physical faults, which appear in the 
process of fabrication or operation, become apparent as 
logical or temporary failure and result in malfunction of a 
digital system. Faults are tied not only to the gates or LUT 
components but also to a specified location on a chip. The 
idea of digital system repairing comes to the removal of a 
fault element by means of repeated place and route 
executing after diagnosis. At that two repair technologies 
are possible: 1) Blockage of a defective area by means of 
development the control scripts for long time place and 
route procedure. But it is not always acceptable for real time 
digital systems. The approach is oriented on removal the 
defective areas of any multiplicity. Blockage of the 
defective areas by means of repeated place and route 
executing results in repair of a digital system. 2) Place and 
route executing for repairing of real time digital systems can 
result in disastrous effects. It is necessary the technological 
approach that allows repairing of the digital system 
functionality for milliseconds, required for reprogramming 
FPGA by new bitstream to remove defective areas from 
chip functionality. The approach is based on preliminary 
generation all possible bitstreams for blockage future 
defective areas by means of their logical relocation to the 
redundant nonfunctional chip area. The larger a spare area 
the less a number of bitstreams, which can be generated a 
priori. Concerning multiple faults, not covered by a spare 
area, it is necessary to segment a digital project by its 
decomposition on disjoin parts, which have their own Place 
and Route maps. In this case a digital system that has n 
spare segments for n distributed faults can be repaired. The 
total chip area consists of (n+m) equal parts. 
The research objective is development of repair method 
for FPGA logic blocks on basis of use the redundant chip 
area.  
Problems: 1) Development of an algebra-logical repair 
method for logic blocks of a digital system on basis of 
FPGA. 2) Development of a method for logic blocks matrix 
traversal to cover FPGA faulty components by spare tiles. 
3) Analysis of practical results and future research.  
R&I, 2009, №2 49
II. ALGEBRA-LOGICAL REPAIR METHOD FOR FPGA BLOCKS 
The exact repair method for FPGA logic blocks by means 
of spares is represented. It enables to obtain quasi-optimal 
solution of coverage problem for faulty cells set by 
minimum quantity of spares. The method focuses on the 
implementation of digital system-in-package functionality 
to the Infrastructure IP. The objective function is 
minimization of FPGA spares tS , needed for the repair of 
faulty blocks in the SiP operation by means of synthesis the 
disjunctive normal form of fault coverage and subsequent 
selection of a minimum conjunctive term 
tt
tm
t
i
t
2
t
1
S)S,...,S,...,S,S(   that answers the constraints on 
the number of spares pm t ! , which enter into the logical 
product: 
}.S,...,S,...,S,S{
*S);S...S...SS(S,)S(minZ
pj21
nt21
ptm
t
n,1t
"
"#####"" !
"  
FPGA functionality model is represented by a matrix of 
logic blocks operating by rows and columns of the structure 
.MM ij"  In the process of designing the matrix attached 
to a spare, consisting of rows and columns, which can be 
readdressed in the process of structure reconfiguration, 
when faults are detected. 
A model of determining the minimum number of spares 
(rows and columns), covering all detected faults in a matrix 
of FPGA logic blocks, comes to the following items: 
1. Making a coverage table for detected faulty FPGA 
blocks by spare rows and columns. To achieve the goal a 
topological model of testing results for FPGA functionality 
is considered in the form of matrix, coordinates of which 
identify detected faults (faultless and faulty blocks):   
$
%
&
"'(
"'(
""
.0fT0
;1fT1
M,MM ijij                 (1) 
Here the matrix coordinate is equal to 1 if modulo 2 sum 
of faultless behaviour for the block f and real test response 
give 1 value, which corresponds to the defect in a block. 
After FPGA testing and fixation all faulty blocks the 
construction of faults coverage table 
m,1j;n,1i,YY ij """  is performed. Here columns 
correspond to a fault set (“1” coordinates), fixed in the 
matrix M ( mM " ), rows are numbers of columns and 
rows of FPGA blocks matrix, which cover faults, indicated 
in columns: 
$
%
&
)"*(
)+*(
""
.F)R(C0
;F)R(C1
Y,YY
jii
jii
ijij         (2) 
Operating by rows and columns, which contain faults, we 
can find an optimal solution in the form of fault coverage in 
the metrics of faulty rows and columns. Then the trivial 
reassignment procedure is carried out for faulty rows and 
columns, which replaced by faultless FPGA spare 
components.  
To improve the solving of coverage task one-dimensional 
vector, concatenated from two sequences C and R by power 
n = p + q, is used instead of two-dimensional metrics 
components: 
).X,...,X,...,X,X,X,...,X,...,X,X(X*X
)R,...,R,...,R,R(*)C,...,C,...,C,C(R*CX
qpjp2p1ppi21
rc
qj21pi21
,,,,""
"""
 (3) 
At that there is one-to-one correspondence between 
elements of initial sets (C, R) and resultant vector X that is 
established in the first column of Y matrix. Transformation 
R*CX " is carried out for ease of consideration and 
subsequent construction the disjunctive normal form in the 
frame of uniformity in the variables, which form the 
Boolean function. If given procedure is not performed, a 
function will be defined by variables of two types, which 
consist rows and columns of a memory matrix. 
2. CNF forming by analytic, complete and exact solving 
of the coverage task. After the forming of a coverage matrix 
that contains zero and unit coordinates, the synthesis of 
coverage analytic form by writing CNF for unit coordinates 
of matrix columns is carried out. A number of conjunctive 
terms is equal to quantity of table columns, and the length 
of a disjunctive term is equal to quantity of “1” in the 
column: 
).XX()YY(Y qjpj
m
1j
1}qjY,pjY{qjpj
m
1j
#-"#-"
"
"
"
  (4) 
Last expression shows that every column identifies two 
variants of fault coverage – rows and columns. So a column 
has only two coordinates, which have unit value, and 
numbers of logical products is equal to total quantity of 
faults m, detected in FPGA matrix.   
3. Transformation CNF to DNF enables to obtain all 
solutions of the coverage task. For this it is necessary to 
apply the logical product operation and minimization rules 
to the conjunctive normal form to get disjunctive normal 
form: 
}.1,0{k),Xk...Xk...XkXk(Y
j
in
j
ni
j
i2
j
21
j
1
w
1j
"-----#"
"
 (5) 
The generalize DNF is represented here; a number of 
terms is equal to n2w " , n – numbers of rows in the set 
(C,R) or quantity of variables X in the matrix Y. All 
possible solutions (fault coverages by spares) are written by 
the set of row identifiers for a coverage table. If i
j
i
Xatk  is 
equal to zero, iX  is changed to an insignificant variable. 
4. Choice the minimum and exact solutions of the 
coverage task. The procedure involves the determination of 
minimum length conjunctive terms by Quine in the DNF. 
Its subsequent transformation to the rows and columns of a 
memory matrix on basis of earlier correspondence enables 
to write the minimum coverage (or a set of them) by two-
50 R&I, 2009, №2
dimensional row and column metrics that satisfies the 
constraints of the objective function on spare quantity. 
5. Realization of reassignment procedure for faulty rows 
and columns by similar faultless components of FPGA 
spare.  
Example 2.2. Fulfill the repair process for FPGA matrix 
to determine the minimum quantity of spares, covering all 
faults. The matrix with faults and spares, highlighted by 
black color [19,20], is shown in Fig. 1. 
11
12
13
1
10
2
9
3
8
4
7
5
6
6
5
7
4
8
3
9
2
10
1
11 12 13 14 15
 
Fig. 1. FPGA with faults and spares 
The matrix has a spare for diagnosis and repair of faulty 
cells that is two rows and five columns. According to item 1 
of the model for determining the minimum quantity of 
spares, covering all detected faults of a memory matrix, a 
coverage table for 10 faults 
)F,F,F,F,F,F,F,F,F,F(F 7,93,95,82,78,55,53,48,25,22,2"  
and eleven rows is formed: 
11XR
1XR
1XR
11XR
1XR
111XR
11XC
1XC
111X 
11X 
11X 
FFFFFFFFFF
F
X
Y
119
108
97
85
74
62
58
47
35
23
12
7,93,95,82,78,55,53,48,25,22,2
j,i
i
.
.
.
.
.
.
.
.
.
.
.
"
 (6) 
Power or the number of rows in the table is determined 
by concatenation of columns C and rows R, which are in the 
one-to-one correspondence with the vector of variables X: 
).X,X,X,X,X,X,X,X,X,X,X(X
)R,R,R,R,R,R(*)C,C,C,C,C(R*C
1110987654321
98754287532
"/
/"
  (7) 
Construction of CNF is performed by a coverage table by 
means of writing the terms for unit values of columns: 
).XX)(XX)(XX)(XX)(XX(&
&)XX)(XX)(XX)(XX)(XX(Y
1141121039185
8372656361
#####
#####"
  (8) 
Getting of disjunctive normal form is based on the 
Boolean algebra identities, which allows performing the 
logical multiplication all ten multiplicands and the 
subsequent minimization of DNF terms by applying the 
operator abaab "# , absorption axioms and removing the 
same terms.  
The final result is: 
.XXXXXX
XXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXY
11109876
1110876111987631187631
119765311753111109862
1110862111986321186321
1196532115321111087641
10986421086421986432
86432196543254321
#
####
####
####
####
####
###"
  (9) 
The choice of minimum length terms with 5 variables in 
given case determines a set of minimal solutions: 
11753111532154321 XXXXXXXXXXXXXXXY ##"   (10) 
Transformation of the function to the coverage that 
contains variables in the form of FPGA rows and columns 
enables to represent the terms as follows:  
.RRCCCRCCCC     Y 948529853287532 ##"   (11) 
All minimum solutions satisfy the requirements on 
quantity of spares, determined by numbers: 
)2R(&)5 ( rr !! . 
The subsequent repair technology for faulty FPGA blocks 
is electrical reprogramming of an address decoder for 
FPGA column or row. Concerning FPGA shown in Fig. 1 
the readdressing of columns with faulty logic blocks to 
spare columns is realized, for instance, in compliance with 
first term of (11) that defines the relation: 
1514131211columnSpare
87532columnFaulty
. 
The computational complexity of an algebra-logical 
repair method for solving of the coverage task [17,20] is 
determined by the following expression: 
FF
2RC2Q 0,," ,                     (12) 
where 
F
2  – costs related to the synthesis of DNF by means 
of logical multiplication two-component disjunctions, the 
number of which is equal to quantity of faulty blocks (the 
fault coordinate is determined by a row or column number); 
F
2RC 0,  is upper limit of computational cost needed to 
minimize the DNF on limiting set of variables that is equal 
to total quantity of rows and columns RC, .  
In the worst case, when the coordinates of all faulty 
blocks are not correlated by rows and columns (unique), for 
instance, diagonal faults, computational complexity of the 
matrix method becomes dependent on the number of faulty 
cells only, and its analytic form is transformed to the 
following expression: 
).F21(22F22
2RC2Q
FFF
F2RC
FF
0,0"00,"
"0,," 0!,
    (13) 
If to use the numbers of faults m instead of the power of a 
fault set the previous expression is represented in simpler 
form: 
).1m2(2)m21(2Q mm ,"0,0"             (14) 
R&I, 2009, №2 51
According to the Functional Intellectual Property, an 
algebra-logical repair method for FPGA logic blocks on 
basis of solving the coverage task is implemented into a 
chip as one of Infrastructure IP components that is designed 
for support of FPGA blocks and SoC availability. 
III. GALLS METHOD FOR A LOGIC BLOCK MATRIX TO 
COVER THE FAULTY FPGA COMPONENTS BY SPARE TILES 
Topology of a chip is represented by the tile matrix 
q,1j;p,1iMM ij """  scalable horizontal and vertical by 
integers ( qp0 ). Every tile ijM  has 
2
n  logic blocks. The 
matrix has an arbitrary number of faults, equal to k. There 
are less or equal 2n  faulty logic blocks in every tile. An 
example of a tile matrix with faults is shown in Fig. 2. Here 
the dimension of tile n is equal to 3 and matrix dimension in 
the number of tiles by rows and columns is equal to 5. 
11
14
12
15
1
10
13
2
9
3
8
4
7
5
6
6
5
7
4
8
3
9
2
10
1
11 12 13 14 15
 
Fig. 2. FPGA block matrix in the number of tiles 
The traversal method for a matrix of logic blocks is 
represented by the steps below. It is designed to repair the 
FPGA components and enables to get quasi-optimal 
coverage of all faulty blocks by minimum numbers of spare 
tiles. 
1. Determination of coordinates for all faulty blocks of 
the matrix ijMM " , specifies the topology of a chip. 
2. Construction of binary coverage matrixes for faulty 
blocks by traversal of the tiles in rows and columns, which 
dimension is determined by the parameters respectively: 
q,1j;n/p,1i,MM r
ijr
""" ; 
n/q,1j;p,1i,MM !
ij!
""" . 
Here every n coordinates of a row (column) is replaced 
by one coordinate with value that is determined by )f(f cr  
function Or of n coordinates. 
$
%
&
"##(
(
""
}.1,0{X),1XX()X1X()XX1(1
);000(0
)f(fM cr!
ij
 
For instance, a procedure for obtaining a row traversal 
matrix gives the result 
111011
110110
MM
101010
010000
100001
010110
100000
110000
MM r
ijr
rf
ij ""1.1""
. 
Here each column is compressed in the two coordinates 
on the rules of logical operation Or, because the tile 
parameter n is equal to 3 here and below. 
Similarly a procedure for obtaining a column traversal 
matrix gives the result 
11
10
11
11
10
10
MM
101010
010000
100001
010110
100000
110000
MM !
ij!
cf
ij ""1.1""
. 
3. Determination of coverage quality criteria for faulty 
blocks by using the binary matrixes on basis of counting the 
numbers of unit coordinates reduced to the actual unit 
matrix. 
The row coverage criterion faulty blocks is determined 
by the following expression: 
2 2
" " 3
3
4
5
6
6
7
8
,9
"
n/p
1i
q
1j
r
ijr
i
r
i
r M
1LH
1
Q . 
Here )L(H r
i
r
i
 – maximum (minimum) index of j-th 
coordinate for a row of the matrix r
ij
M , after (before) 
which there are only zero coordinates in a row. Actually 
1LH r
i
r
i
,9  is the units spread interval in rows of the 
matrix r
ij
M , which gives the sum of unit row coordinates. 
Further reduced estimates for all rows are added, which is 
the criterion of row coverage for faulty blocks. 
The column coverage criterion is the following: 
2 2
" " 3
3
3
4
5
6
6
6
7
8
,9
"
n/q
1j
p
1i
c
ijc
j
c
j
c M
1LH
1
Q . 
Here )L(H c
j
c
j
 – maximum (minimum) index of j-th 
coordinate for a column of the matrix c
ij
M , after (before) 
which there are only zero coordinates in a column. Actually 
1LH c
j
c
j
,9  is the units spread interval in columns of the 
matrix !
ij
M , which gives the sum of unit column 
coordinates. Further reduced estimates for all columns are 
52 R&I, 2009, №2
added, which is the criterion of column coverage for faulty 
blocks. 
4. The decision on the choice of strategy }S,S{S cr"  for 
coverage of faulty logic blocks by spares by means of 
comparing the values of the structurization criteria cr Q,Q  
for the rows and columns: 
$
%
&
:(
;(
"
.QQS
;QQS
S
crc
crr
 
In the first case, the faulty blocks coverage strategy is 
realized by sequential traversal of all tile rows. The second 
one – the traversal of tile columns is done. 
5. The tile traversal strategy by rows is realized by the 
modified matrix r
ij
M . Each matrix row is represented by 
the binary vector )M,...,M,...,M,M(M r
iq
r
ij
r
1i
r
1i
r
i
" . Step 1. 
Nulling of a zero coordinate counter and a spare tile 
counter: 0Q,0j "" . Step 2. Sequential scanning of the 
vector elements 0M1jj r
ij
"(,"  up to the first “1” 
encountered )1njj,1QQ(1Mr
ij
9,","." . From this 
“1” it is counted n tiles, which are covered by the spare tile. 
The number of spare tiles Q is increased by 1. Step 3. If the 
condition qj :  is true – the end of row processing. 
Otherwise – go to step 2. The procedure is applied to all 
rows of the modified matrix r
ij
M ( !
ij
M ), resulting in 
counter Q will contain the minimum number of spares to 
cover all faulty blocks. Similarly the tile traversal strategy 
by columns ( !
ij
M ) is performed. In this case the index i is 
changed instead of j in a traversal procedure. 
6. Definition of the coverage quality for obtained solution 
by means of counting the number of faulty blocks of the 
matrix, reduced to the minimum number of spares N, 
covering all faulty blocks: 
2
"
"
n
1i
icr F
N
1
Q . 
7. The end of finding of a quasioptimal cover of faulty 
blocks by spares.  
Example. For FPGA, shown in Fig. 2, according to item 
2 of the repair model the construction of two matrixes is 
performed:  
010101010101010
011101001000100
010100101011110
010110010010100
101010010011010
MM r
ijr
""
 
10000
01110
00011
11000
11101
00000
10111
01010
10101
01000
01110
10001
00110
11011
00100
MM !
ij!
""
 
Further, in accordance with paragraph 3, the calculation 
of the structurization criteria is performed for the matrix 
above: 
64,2
13
7
12
6
13
8
12
6
14
7
M
1LH
1
Q
n/p
1i
q
1j
r
ijr
i
r
i
r ",,,,"
3
3
4
5
6
6
7
8
,9
" 2 2
" "
;
58,2
14
7
13
7
14
7
13
7
12
6
M
1LH
1
Q
n/q
1j
p
1i
c
ijc
j
c
j
c ",,,,"
3
3
3
4
5
6
6
6
7
8
,9
" 2 2
" "
. 
As it can be seen from the above-mentioned criteria, the 
number of faulty coordinates in the columns reduced to the 
unit matrix is less than in the rows. Therefore, subject to 
item 4, the strategy for solving the coverage problem by 
column traversal is chosen: ).58,2Q64,2Q(S crc ":"(  
Structural appeal of columns higher then rows, because 
the number of faults reduced to the matrix less than in the 
first case. 
This strategy gives the actual quality of coverage – the 
number of faulty logic blocks of the matrix (by one spare 
tile), reduced to the necessary quantity of spares that is 
equal to: 
.8,120/36F
N
1
Q
n
1i
i
*
c """ 2
"
 
For comparison – the row traversal procedure gives a 
lower quality: 
.71,121/36F
N
1
Q
n
1i
i
*
r """ 2
"
 
The final coverage of a fault set has one tile more (21) 
than the solution obtained by the first method (20). So, the 
choice of coverage strategy on the basis of calculation and 
comparison the criteria for counting the number of unit 
coordinates, reduced to the actual unit matrix, confirms 
their consistency and the subsequent optimality of obtained 
coverage. 
Fig. 3 shows statistics of the processing of different types 
logic block matrixes with faulty components. It 
demonstrates correctness of applying the proposed criterion, 
which shows the optimal and efficient strategy of matrix 
traversal to obtain minimum coverage of faulty logic blocks 
by spare tiles in all cases except the last one. In the latest 
variant the structurization criteria by rows greater than by 
R&I, 2009, №2 53
columns 55,1Q78,1Q cr "<"  that is the basis of covering 
the faults by columns. In this case the coverage quality is 
125,1Q*! "  that corresponds to 16 spare tiles needed to 
repair all 18 faulty blocks. While the optimal solution is 
traversal of the matrix by columns, where the coverage 
quality is 2,1Q*! "  that corresponds to 15 spare tiles only. 
1
1,2
1,4
1,6
1,8
2
2,2
2,4
2,6
2,8
Qr 2,64 2,03 2 2,11 1,77 2,22 1,78
Qc 2,58 2,05 1,71 1,8 1,72 1,96 1,55
Q*r 1,71 1,5 1,4 1,38 1,29 1,4 1,2
Q*c 1,8 1,42 1,4 1,47 1,29 1,6 1,125
1 2 3 4 5 6 7
 
Fig. 3. Structurization criteria and coverage quality for the examples 
IV. SOFTWARE “AGALLS” FOR COVERING OF FAULTY 
FPGA COMPONENTS BY SPARE TILES 
Software «aGalls» is designed for covering of faulty 
FPGA components by spare tiles by using the traversal 
method for logic block matrix.  
The initial information is represented by a matrix of tiles 
q,1j;p,1iMM ij """ , the dimension qp0 , where each 
tile has n*n logic blocks. The initial quantity of faults k is 
made to the matrix. The software detects the coordinates of 
all faults, constructs the binary coverage matrixes for faulty 
blocks by means of traversal the tiles by columns and rows, 
and calculates the quality criteria of fault coverage (Fig. 4).  
  
Fig. 4. Calculation results 
The program provides the opportunity to review the 
changes of temporary matrixes after covering the faulty 
blocks both horizontally and vertically. In addition, the 
actual number of spare tiles needed to cover all faults is 
displayed; it enables to estimate the correctness of the 
selected solution on the basis of calculating the criteria (Fig. 
5). 
 
Fig. 5. Coverage of a matrix with faults and spares  
An algorithm for solving the coverage problem 
implemented in the software is represented below and in 
Fig. 6. 
 
Fig. 6. Model of solving the optimal coverage task  
1. Beginning of solving the coverage problem for a logic 
block matrix by spare tiles.  
2. Determination of the coordinates for all faulty blocks 
of the matrix.  
3. Construction of the binary coverage matrixes for faulty 
blocks to traverse the tiles by rows and columns.  
4. Construction the fault coverage for the modified matrix 
by means of their traversal by rows.   
5. Detection the first and last “1”. 
6. Counting the number of “1” in a row. 
7. Increment number of rows processed.  
8. Calculation of the structurization criteria by rows. 
9. Implementation of items 4, 5, 6, 7 for columns. 
54 R&I, 2009, №2
10. The decision on the choice of faulty blocks coverage 
strategy in the direction corresponding to the lower value of 
the criterion. 
11. Nulling of zero coordinates counter and spare tile 
counter 0Q,0j "" . 
12. Sequential scanning of the vector elements 
0M1jj r
ij
"(,"  up to the first “1’ 
)1njj,1QQ(1Mr
ij
9,","."  by rows. 
13. From this “1” it is counted n tiles, which are covered 
by the spare.  
14. The value Q is incremented by 1. 
15. If qj :  – the end of row proceeding, otherwise – 
item 11. 
16. Implementation of items 10, 11, 12, 13, 14 at 
traversal by columns. The end of searching the quasioptimal 
coverage of faulty blocks by spare tiles.  
To check the validity of the criteria 200 experiments for 
the matrix M was carried out; the dimension of matrix is 
p*q, the number of blocks in the tile is n horizontally and 
vertically, and the number of faults is k, where 
.)qpn(,3k;7,3q;5,2n;7,3p 00""""  
As a result, by using the criteria the most efficient way to 
repair has not been determined in 29% of cases, 
respectively a positive result – 71%. Fig. 7 presents 
diagrams showing the values of structurization criteria and 
coverage quality at the traversal of the modified matrix by 
rows and columns for the 10 examples. The dimension of 
the matrix was constant: 4 tiles in the horizontal and 5 ones 
vertical, the dimension of the tiles was 3*3 blocks. 
0
1
2
3
4
1 2 3 4 5 6 7 8 9 10
Qr
Qc
Q*r
Q*c
Fig. 7. Structurization criteria and coverage quality 
The software is used to verify and test the method for 
obtaining the quasioptimal fault coverage by minimum 
quantity of spare tiles. It can be implemented into a chip as 
embedded Infrastructure IP component, where the initial 
information about the topology of a chip has to be 
memorized during Place and Route process. 
V. CONCLUSION 
Algebra-logical repair method for FPGA logic blocks on 
the basis of solving the coverage task is focused on the 
implementation into a chip as one of Infrastructure IP 
components. It is designed to repair the FPGA blocks and 
SiP as a whole. 
The method enables to obtain exact and optimal solution 
associated with the minimum number of spare blocks 
needed to repair the FPGA logic components with multiple 
faults.  
The traversal method for a logic block matrix is designed 
to repair the FPGA components by obtainment the solution 
in the form of quasioptimal coverage for all faulty blocks by 
minimum number of spare tiles. A choice one of two 
traversal strategies for rows or columns of a logic block 
matrix on the basis of the structurization criteria, which 
determine a number of faulty blocks, reduced to the unit 
modified matrix of rows or columns. 
The technological solutions represented in the survey and 
proposed methods for diagnosis and repairing of digital 
system-on-a-chip and system-in-package correlates well 
with the analytical market research of electronics in 2009 
and is formulated in the form of Gartner's Top 10 Strategic 
Technologies for 2009: 1) Virtualization. 2) Cloud 
Computing. 3) Servers – Beyond Blades. 4) Web-Oriented 
Architectures. 5) Enterprise Mashups. 6) Specialized 
Systems. 7) Social Software and Social Networking. 8) 
Unified Communications. 9) Business Intelligence. 10) 
Green IT [http://www.gartner.com/]. 
As well as Gartner's Top 10 correlates well with the 
analytical research of Computer Sciences Corporation 
(CSC), represented as 7 tendencies: 1) New media. Internet 
has become a full-fledged framework for creating and using 
audio, video and text content in a planetary scale. 2) Social 
software. Social networks attract millions of users, using the 
common interests. 3) Enhanced Reality. Gradually, but 
persistently it enters our lives. Virtual reality, where images 
of the users travel through the virtual worlds, it becomes 
practical in finding suitable products, services, products 
without their prior purchase. 4) Transparency of 
information. It will let you see yourself and the world with a 
given degree of detail by means of sensors and internet-
cameras placed in the office, and throughout the world. The 
other side of the coin is how to hide and preserve personal 
space. 5) Wireless innovations. They allow running any 
application on any device, anywhere in the world. Here we 
should expect the appearance of conflict related to the 
division of frequencies between telecommunications 
operators, radio and television, cable and satellite 
companies, Internet service providers. It is expected the 
integrated solution of the problem on the basis of wireless 
technologies with mobile Internet-services. 6) New 
hardware and software platforms. Level of virtualization is 
increased. The number of applications which function on 
the same computer under different operating systems is 
growing exponentially. «Cloud computations», when a 
consumer pays for the use of computer infrastructure and 
applications to providers, stored client data on your own 
servers, significantly alter the entire calculation structure. 
Prospects of nanotechnology" molecular, quantum and 
optical computing become more realistic. Instead of silicon 
chips lighter and smaller elements: the atoms, DNA, spins 
of electrons and light will work. 7) Intelligent world. 
Semantic and networking technologies allow computing 
R&I, 2009, №2 55
devices to interpret the information on the algorithms of 
natural intelligence, whether text, voice, image, or life 
situations. Computers will be to teach, give advices, make 
predictions based on information received from the 
environment and the individual person. Self-learning 
semantic retrieval applications is developed in the Internet. 
A truly intelligent world is made, where people and 
computers will be able to talk and communicate with each 
other based on a combination of semantic and network 
technologies. This will result in the appearance of artificial 
intelligence, and possibly hyperintelligence, reading human 
thoughts [http://www.pcweek.ru/]. 
REFERENCES 
[1] Kwang-Ting (Tim) Cheng. The Need for a SiP Design and Test 
Infrastructure // IEEE Design and Test of Computers.– May–June, 
2006.– P. 181.  
[2] Fontanelli A. System-in-Package Technology: Opportunities and 
Challenges // Quality Electronic Design, 2008.– ISQED 2008, 9th 
International Symposium.– March, 2008.– P. 589 – 593.  
[3] Appello D., Bernardi P., Grosso M., Reorda M.S. System-in-package 
testing: problems and solutions // IEEE Design & Test of 
Computers.– Vol. 23, Issue 3.– May-June, 2006.– P. 203 – 211.  
[4] Subhasish M.; Huang W.-J., Saxena N.R., Yu S.-Y., McCluskey E.J. 
Reconfigurable architecture for autonomous self-repair // IEEE 
Design & Test of Computers.– Volume 21, Issue 3.– May-June, 
2004.– P. 228-240.  
[5] Ross R., Hall R. A FPGA Simulation Using Asexual Genetic 
Algorithms for Integrated Self-Repair // Adaptive Hardware and 
Systems, 2006.– AHS 2006.– First NASA/ESA Conference on 
Volume.– Issue 15-18 June 2006.– P. 301 – 304.  
[6] Habermann S., Kothe R., Vierhaus H.T. Built-in self repair by 
reconfiguration of FPGAs // Proceedings of the 12th IEEE 
International Symposium on On-Line Testing.– 2006.– P. 187-188.  
[7] S. Pontarelli, M. Ottavi, V. Vankamamidi, A. Salsano, F. Lombardi. 
Reliability Evaluation of Repairable/Reconfigurable FPGAs // 21st 
IEEE International Symposium on Defect and Fault-Tolerance in 
VLSI Systems (DFT'06) .– October, 2006.– P. 227-235.  
[8] Koal T., Vierhaus H. T. Basic Architecture for Logic Self Repair // 
14th IEEE International On-Line Testing Symposium.– 2008.– P. 
177–178.  
[9] Kothe R., Vierhaus H.T., Coym T., Vermeiren W., Straube B. 
Embedded Self Repair by Transistor and Gate Level Reconfiguration 
// IEEE Design and Diagnostics of Electronic Circuits and Systems.– 
2006.– P. 208–213.  
[10] Mange D., Sipper M., Stauffer A., Tempesti G. Toward self-repairing 
and self-replicating hardware: the Embryonics approach // Evolvable 
Hardware, Proceedings of the Second NASA/DoD Workshop.– 
2000.– P. 205-214.  
[11] Miclea L., Szilard E., Benso A. Intelligent agents and BIST/BISR – 
working together in distributed systems // Proceedings of the Test 
Conference.– 2002.– P. 940-946.  
[12] Rashad S. Oreifej, Carthik A. Sharma, Ronald F. DeMara. Expediting 
GA-Based Evolution Using Group Testing Techniques for 
Reconfigurable Hardware // Reconfigurable Computing and FPGA's, 
2006. ReConFig 2006. IEEE International Conference.– Sept., 
2006.– P. 1-8.  
[13] Anand D., Cowan B., Farnsworth O., Jakobsen P., Oakland S., 
Ouellette M.R., Wheater D.L. An on-chip self-repair calculation and 
fusing methodology // IEEE Design & Test of Computers.– Volume 
20, Issue 5.– Sept.-Oct., 2003.– P. 67-75.  
[14] Wang S.-J., Tsai T.-M. Test and diagnosis of faulty logic blocks in 
FPGAs // IEEE Proceedings Computers and Digital Techniques.– 
Vol. 146, Issue 2.– March, 1999.– P.100 – 106.  
[15] Pontarelli S., Cardarilli G.C., Malvoni A,. Ottavi M., Re M., Salsano 
A. System-on-chip oriented faulttolerant sequential systems 
implementation methodology // IEEE International Symposium on 
Defect and Fault Tolerance in VLSI Systems.– Oct., 2001.– P. 455 – 
460.  
[16] Peter Rickert, William Krenik. Cell Phone Integration: SiP, SoC, and 
PoP // IEEE Design and Test of Computers.– May–June, 2006.– P. 
188-195.  
[17] Rossen K. Discrete Mathematics and its Applications, McGraw Hill, 
2003. 824p.  
[18] IEEE 1500 Web Site. http://grouper.ieee.org/groups/1500/.  
[19] Hahanov V., Hahanova A., Chumachenko S., Galagan S. Diagnosis 
and repair method of SoC memory // WSEAS transactions on circuits 
and systems.– Vol.7.– 2008.– P. 698-707.  
[20] Hahanov V., Obrizan V., Litvinova E., Ka Lok Man. Algebra-logical 
diagnosis model for SoC F-IP // WSEAS transactions on circuits and 
systems.– Vol. 7.– 2008.– P. 708-717. 
 
56 R&I, 2009, №2
