SoC Software Components Diagnosis Technology by Chumachenko, Svetlana et al.
SoC Software Components Diagnosis Technology 
 
 
Svetlana Chumachenko, Wajeb Gharibi, Anna Hahanova, Aleksey Sushanov 
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 novel approach to evaluation of hardware and 
software testability, represented in the form of register 
transfer graph, is proposed. Instances of making of 
software graph models for their subsequent testing and 
diagnosis are shown.  
 
1. Introduction  
 
There are technologies of hardware testing and 
testable design, which enable to solve the problem of 
SoC service effectively [1-10]. On the other hand, 
there are not effective models and methods of the given 
problem solving on the electronic technology market.  
To realize testable design and diagnosis of SoC 
software components the universal model of software 
components representation in the form of register 
transfer and control graph is developed. An algorithm 
of software diagnosis is proposed. An instance of 
software diagnosis technology utilization is considered. 
The research aim is adaptation of the hardware 
testing methods to the service of SoC software 
components.  
The research problems: 1) Adaptation of Thatte-
Abraham-Sharshunov register transfer model [4,5] to 
the solving of software testing problem; 2) Application 
of the model for faulty statements diagnosis on basis of 
use the fault detection table.  
 
2. Software diagnosis technology  
 
At development of large size software 
verification of development project on the correctness 
of statements is urgent problem. Complex software 
includes great many branches and verification of 
software on every logical path is rather complex 
problem. A method of faulty statements (errors or 
faults) searching for software that is based on 
representation of software algorithm in the form of 
graph structure for subsequent test generation and fault 
diagnosis is considered below on an example. Lets it is 
necessary to verify the software that realizes 
computation of the following sum of functions: 
.32x
;32x
,
,
2)xsin(
)3xsin(
)x(
;12x
;12x2
;2x
;7x3
;3x2
;3x
x
),x()x(S

















 
One of the possible problem solution variants on 
C++ language is represented by the following listing: 
Listing 3.1.  
#include <iostream> 
#include <math.h> 
using namespace std; 
int main() 
{ 
 const double Pi=3.14159; 
 double F, w, f, x; 
 cin>>x; 
if (x<2) f=x+3; 
else if ((x>=2) && (x<12)) f=2*x-3; 
else f=-3*x+7; 
if (x<2./3.*Pi)  
w=sin(x+Pi/3); 
else w=sin(Pi*x)+2; 
F=f+w; 
cout<<F<<endl; 
 return 0; 
} 
Lets an error takes place in a statement of 
computational part of software. Instead of the correct 
statement  
else w=sin(Pi*x)+2; 
the following one is written: 
else w=sin(Pi*x) - 2; 
It is necessary to detect faulty statement in 
program code by using the testing technology, based 
978-1-4244-3403-9/08/$25.00 ©2008 IEEE
on the graph code model. Software diagnosis stages 
include 4 procedures below. 
1. Making of register transfer graph.  
Graph ribs are a set of code fragments or separate 
operations (Fig. 1); graph points are points of 
information monitoring (registers, variables, memory), 
which are used for forming of assertions too. 
 
Fig. 1. Register transfer graph  
A number of test points in the graph (registers, 
variables, memory) should be adequate to diagnose of 
given resolution. Otherwise it is necessary to carry out 
the analysis of register transfer graph testability for 
software and to determine the minimal additional 
quantity of observation lines for forming of assertions, 
which enable to detect faulty modules with given 
diagnosis resolution. Every rib (see Fig. 1) is marked 
by an arithmetic operation set: {1} – summation; {2} – 
multiplication; {3} – subtraction; {4} – division; {5} – 
obtainment of trigonometric sine. In a case when there 
is a branch in a program a number of outgoing ribs 
from a point is equal to quantity of adjacent sinks that 
is formed by branch statements in respective part of a 
program. 
Thus, for the code fragment of the instance: 
if (x<2) f=x+3; 
else if ((x>=2) && (x<12)) f=2*x-3; 
else f=-3*x+7; 
there are three ribs, outgoing from the point X. 
Computational results 321 I,I,I , which depend on the 
variable X, are checked in the points 321 R,R,R  
respectively. In a case of execution of the operation 1I  
the following branch is realized: 
if (x<2./3.*Pi) w=sin(x+Pi/3); 
else w=sin(Pi*x)+2;  
Then the general summation operation for all 
transactions is carried out regardless of which branch 
statements had been executed. 
F=f+w;  
The summation operation is executed on various 
ribs (the objects D6C6B6A6 I,I,I,I ), but all of them 
correspond to the same part of the program code. So, 
faultless execution an operation on a rib eliminates a 
fault on other three ones. On next stages of software 
diagnosis these objects are merged to 6I . The result 
are checked in the final point Y. 
The method of software algorithm representation 
by graph structure enables to show all possible variants 
of software execution, as well as to simplify realization 
of next diagnosis stage of software and forming of 
minimal test. 
2. Test synthesis and analysis. A set of ribs are 
written in the form of disjunctive normal form (DNF), 
where every term is one-dimensional path from input 
port to output, which covers a subset of internal lines: 
Y3XY2XY15XY14XP  . In the aggregate 
one-dimensional paths, represented in DNF, cover all 
possible transactions – graph points and ribs. An 
aggregate of code fragments or statements (activation 
instructions), written by disjunction, is brought to 
conformity with every rib. For instance, the path X14Y 
activates execution of operations on ribs A641 I,I,I . At 
that the ribs 1I  and A6I  have only one statement, and 
consecutive execution of three statements corresponds 
to the identifier 4I . The test )]1)(541)(1[(P1   that 
activates the path X14Y ensures the correctness check 
of all statements. Thus, the test of minimal covering of 
all graph points and ribs by commands, which activate 
graph ribs and therefore data movement to observation 
points, can be written: 
)].1)(21[()]1)(32[(
)]1)(521)(1[()]1)(541)(1[(P

  
Subsequent DNF transformation consists of 
removal of brackets to obtain complete test that 
enables to check transactions in a graph, which cover 
all points and ribs in various combinations: 
)1211()3121(
)151121111()151141111(P


. 
The obtained test is redundant; it is not always 
acceptable for large size software, because of there is 
large quantity of test patterns. So, the ability to create 
minimal length test of given resolution is very 
important. Such test is formed by solving of the 
covering problem of all graph points and ribs and 
activation of code fragments sets. When testing it is 
supposed that hardware components, used in the 
software are faultless. 
3. Fault detection table making. Fault detection 
table is oriented on verification of code fragments sets 
on ribs, which form data activation paths to the 
observation points (graph points). In compliance with 
comparison of experimental data of tested software and 
expected responses the output response vector V is 
formed. In a case of result failure on an observed line 
the respective coordinate of the vector V takes on a 
value “1” for the test pattern under consideration. The 
X 
R1 
R2 
R4 
R3 
R5 Y I5={1,2,5} 
I1={1} 
I2={2,3} 
I3={1,2} 
I4={1,4,5} I6A={1}
I6B={1}
I6C={1} 
I6D={1} 
fault detection table of code fragments on complete test 
Y3XY2XY15XY14XP  , where test patterns 
are written in general form (a set of one-dimensional 
paths), is shown below: 
111Faults
0111Y3X
0111Y2X
111111Y15X
011111Y14X
VIIIIIIIIIIIII
T
615552514544413231232211j
i
 
The symbolic notation I jk  means execution of a 
statement that is on the rib I j  and has index k. For 
instance, 22I  means execution of statement sequence 
of the rib 2I  at activation of the path X2Y and 
production operation that corresponds to the fragment 
of source program code: 
else if ((x>=2) && (x<12)) f=2*x-3;  
The diagnosis resolution for the test at the value 
of vector V = (0100) is determined by three possible 
faults: 555251 IIIF  . Value “1” of the vector V for a 
test-vector under consideration means that when 
issuing second pattern the activation of respective 
commands execution is took place. The minimal set of 
DNF terms, which make out all single faults of 
program fragments of a register transfer graph, is 
minimal diagnosis test. Next term set (here it coincide 
with complete test) makes out faults of all instructions, 
determined in DNF: 
)1211()3121()151121111()151141111(P  . 
Reduction impossibility is conditional on that removal 
any term does not provide activation of one or several 
fragments. Then complete and extended fault detection 
table is made that is formed by a term set above. Every 
obtained test pattern is divided on parts – terms. First 
test pattern )151141111(   consists of three terms: 
(111), (141) and (151). Every of them has own position 
in a column. All possible executable operations, which 
are designated ikI , where j – rib identifier in a graph, k 
– statement that transforms data on j-th rib, is 
distinguished across. The graph path to which a term 
under consideration is applied is considered. For 
instance, term (141) is applied to first test pattern that 
activates the path X14Y. The extended fault detection 
table is: 
01121
01111
01131
01121
1111151
1111121
1111111
0111151
0111141
0111111
VIIIIIIIIIIIII\T
2
1
2
2
1
1
615552514544413231232211ii
 
Every term number means execution of a statement 
on respective graph rib. First nimber “1” provides 
activation of the statement {1} 1I , so opposite 
respective column “1” is put. Column values of the 
extended fault detection table are moved from the FDT 
of code fragments that is defined on complete 
generalized test. But coordinate value is written for 
every test term. Extended fault detection table enable 
to show the results of every test pattern execution and 
to simplify the fault detection procedure with given 
resolution. 
4. Diagnosis. In compliance with numbers of “1’ 
in the output response vector V quantity of disjunctive 
CNF terms is formed. Every term is line-by-line 
writing of faults by logical operation “OR”, which 
influence on distortion of output functional signals. 
Then transformation CNF to DNF by the Boolean 
algebra is carried out: 
.III
IIIIIIIIIIII
IIIIIIIIIIII
IIIIIIIIIIII
IIIIIIIIIIII
IIIIIIIIIIIII
)III)(III)(III(F
615161
116161526155526152116111
615511611161516155116151
615251555251525111615111
555111115161115161111161
61521155521152116111551111
615511615211615111







 
To reduce the obtained set of possible faults the 
Boolean algebra laws are used: 
;AAA  ;BCACC)BA(;ABBA   
);CB(AC)BA(  ;AAA 
AA)BA(;AA)BA(  , it enables to obtain 
the expression:  
.IIIII
IIIIIIIIII
IIIIIIIIIIII
IIIIIIIIIII
IIIIIIIIIII
IIIIIIIIII
IIIIIIIIIIF
6155525111
61516111616152615552
615211611161551161116151
6155116151615251555251
5251116151115551111151
61115161111161615211
55521152116111551111







 
Then such elements jkI  from F, which are 
executed in other test patterns with value 1Vi  , are 
removed. A set of objects, contained the operations, 
which transform data at program execution uniquely 
and correctly, is formed: 
.IIIIIIII)}21()11(
)31()21()151()141{(}Y3X,Y2X,Y14X{H
61454432312322112
1

  
After the reduction a single DNF term is 
obtained: 
.III)IIIIII
II(\)IIIII(H\F'F
555251614544323123
22116155525111


 
It means that the software functions with error at 
execution one of the statements {1,2,5} on the rib 5I . 
Really, an error takes place on linear program 
part that is applied to a rib of the statement sequence 
5I , namely 51I  – execution of subtraction instead of 
summation. 
More exact diagnosis (to within statement) is 
possible if to use the greater quantity of test points that 
complicates diagnosis because of necessity to make 
longer tests. The proposed method enables to analyze 
software on presence of errors in the code and helps to 
detect their location. Testing and verification of 
software is the main problem at programming, and its 
solving enables to raise software quality and to obviate 
unforeseen results of its execution. The proposed 
method is based on representation of software 
algorithm by the graph structure, where ribs are 
statement sequences or code fragments, and points are 
information monitoring points for making of 
assertions. Creation of minimal quantity of test patterns 
enables to decrease time of fault detection. At that tests 
have to cover all possible transactions. Test points 
quantity has to be minimal and sufficient for diagnosis 
of given resolution. 
 
3. Conclusion  
 
The innovative technologies of software testable 
design, based on effective test development and 
verification of digital system-on-a-chip components, 
are considered.  
1. The universal model of software and hardware 
component in the form of directed register transfer and 
control graph, on which the testable design, test 
synthesis and analysis problems can be solved, is 
represented. 
2. The technology of software testing and 
diagnosis on basis of synthesis the graph register 
transfer models is proposed. 
3. The practical importance of proposed methods 
and models is high interest of the software companies 
in innovative solutions of the effective software testing 
and verification problems above. 
4. References 
 
[1] Francisco DaSilva, Yervant Zorian, Lee Whetsel, 
Karim Arabi, Rohit Kapur. Overview of the IEEE 
P1500 Standard, ITC International Test Conference, 
2003, pp. 988#997.  
 
[2] Abramovici M., Breuer M.A. and Friedman A.D. 
Digital System Testing and Testable Design, Computer 
Science Press, 1998, 652 .  
 
[3] V.I.Hahanov, S.V.Chumachrnko, WGharibi, 
E.Litvinova. Algebra-logical method for SoC 
embedded memory repair, Proceedings of the 15 
International Conference &Mixed design of integrated 
circuits and systems[, Poland, 2008, pp. 481-486.  
 
[4] Thatte S.M., Abraham J.A. Test generation for 
microprocessors, IEEE Trans. Comput., 1980, C-29, 
No 6, pp. 429-441.  
 
[5] Sharshunov S.G. Construction of microprocessor 
tests. 1. The general model. Data processing check, 
Automation and telemechanics, 1985, 11, pp. 145-155.  
 
[6] Zorian Yervant. What is Infrustructure IP? IEEE 
Design & Test of Computers, 2002, pp. 5-7.  
 
[7] Douglas Densmore, Roberto Passerone, Alberto 
Sangiovanni-Vincentelli. A Platform-Based taxonomy 
for ESL design, Design&Test of computers, September-
October, 2006, pp. 359-373.  
 
[8] Bergeron, Janick. Writing testbenches: functional 
verification of HDL models. Boston: Kluwer Academic 
Publishers, 2001, 354 p.  
 
[9] Zorian Yervant. Guest Editor’s Introduction: 
Advances in Infrastructure IP, IEEE Design and Test 
of Computers, 2003, 49 p.  
 
[10] Shameem Akhter, Jason Roberts. Multi-Core 
Programming, Intel Press, 2006, 270 p.  
 
