Measurements in 1149.4 environments – correcting the infrastructure switches influence by Felgueiras, Manuel C. et al.
1 
Measurements in 1149.4 environments – correcting the infrastructure 
switches influence 
 
Abstract 
Measuring the values of discrete components frequently takes place during 
the test or debug phase of Printed Circuit Boards (PCB). This operation 
requires tools that are based on some access type. The shrinking geometries 
constrain the straightforward use of tools based on physical access. One of the 
aims of the IEEE1149.4 Std. is to facilitate those on-board measurements. This 
infrastructure relies on electronic access that includes high quality analog 
buses and a set of electronic switches, which enable to completely isolate a 
component under characterization, e.g. by injecting a known current and 
measuring the voltage across it. During this process, the infrastructure 
switches have a negative impact in the measurement accuracy. This paper 
analyses the measurement of one resistor in two situations: connected 
between a pin and ground and between two pins. The infrastructure switches 
that affect the measurement quality are identified and the upper limit of its 
systematic error is characterized. When the systematic error is completely 
defined then it is possible to remove its negative effect from the final result. 
 
1- Introduction 
In many PCB´s, discrete components are mainly used for coupling different 
circuit stages and for device configuration. The IEEE1149.4 [1] test 
infrastructure was presented as a formal extension of the IEEE1149.1 [2] Std. 
for the Mixed-Signals (MS) area. Its scope includes: 
- Interconnect test 
- Parametric test (characterization of discrete components) 
- Internal test   
  
The IEEE1149.4 test infrastructure includes high quality internal analog buses 
that can be used as embedded analog probes, when the PROBE mandatory 
instruction is selected. The standard stipulates a minimal set of mandatory 
requirements while also allowing its reuse for many others purposes. The 
infrastructure reuse are suggested to: 
2 
- detect deviations to the nominal performance [3] 
- perform RF measurements [4] 
- on-line monitoring and reconfiguring functions in safety critical 
applications [5] 
- perform analog diagnosis through the quiescent nodal analog voltage 
[6] 
- support the testing of ADCs and DACs [7] 
- support debug operations in MS circuits [8,9] 
- test specific parameters of digitals circuits (e.g. VIH ) [10] 
 
The market acceptance of this test infrastructure has been slow and to 
promote it, several actions have taken place: (a) one compliant Integrated 
Circuit (IC) has been produced [11]; (b) analog extension to BSDL has been 
proposed to support automatic test generation [12]; (c) a check integrity 
procedure has been proposed [13]; (d) its use for monitoring internal 
analog/digital nodes [9]. 
It is clear today the benefits due to the use of analog buses to support 
measurements, even in digital circuits, as presented and patented by INTEL 
[14]. The tradeoffs associated to the costs and the benefits are encouraging 
the use of this test infrastructure [15,16]. The analog infrastructure bus 
characterisation and some experimental results have been presented [17,18]. 
The present work analyses the individual errors introduced by the 1149.4 
switches during the measurement process of one resistor. We describe a 
methodology to remove the effect introduced by each involved switch, 
whenever possible. We use the 1149.4 compatible IC SCANSTA400 [19] to 
verify and validate our analysis. This work intends to provide a simple formula 
to correct the measurement process errors caused by non-ideal switches.  This 
formula is especially useful for those people that use the analog bus to 
perform measurements through electronic access. 
 
2 – Determining the value of one resistor placed between an ABM and GND 
The methodology to calculate the value of a resistor, via the 1149.4 
infrastructure, consists on: (1) injecting a known current value in the resistor, 
3 
via AB1, and (2) measuring the voltage across the resistor, via AB2, as 
presented in Figure 1.  
 
Figure 1 – Determining the value of one resistor placed between an ABM and GND. 
 
The source current is recommended to provide a stable current value and also 
to prevent excessive current values that may damage test infrastructure 
during the measurement operation. The initial value for RX is R1, and its value 
is calculated by: 
 
R1 = V1 / I1 [2.1] 
 
where V1 and I1 correspond to the initial measured values of the voltage and 
current across Rx, respectively. The resistor calculated value is affected by 
several error sources:  
• εV – associated to the voltmeter accuracy 
• εA - associated to the ammeter accuracy 
• εM1 – associated  to the switches resistance RSB2 and RS6 (RSB2 + RS6 > 0 Ω) 
• εM2 – associated to the voltmeter resistance (RV ≠ ∞Ω) 
 
The total relative error in the calculation process of Rx is given by: 
εRX = εV + εA + |εM1| + |εM2| [2.2] 
   
εV is the relative error due to the voltmeter limited accuracy and its value is 
usually indicated in the respective instrument manual. εA is the similar 
relative error for the ammeter. εM1 corresponds to the error introduced by the 
measurement methodology, and is due to the influence of the switch 
resistances SB2 (RSB2) and S6 (RS6). The voltage measured by the voltmeter is 
4 
lower than the actual voltage across Rx, as it includes the voltage drop at RSB2 
and RS6. The reduction of the voltage measured by the voltmeter is given by: 
 
∆V = - ( RSB2 + RS6 ) . IV [2.3] 
 
and the associated error is: 
 
εM1 = ∆V / V = - ( RSB2 + RS6 ) / RV [2.4] 
 
where RV is the voltmeter internal resistance. The minus signal means that 
the voltage measured by the voltmeter is less than the expected value and 
hence the calculated RX will be lower than the correct value. To remove this 
error, a new value should be calculated as follows: 
 
V2 =  V1 [ 1 + ( RSB2 + RS6 ) / RV ) ] [2.5] 
 
The IEEE1149.4 Std. defines that value of RSW2 (equal to RSB2 plus RS6, i.e. RSW2 
= RSB2 + RS6) should be lower than 10 kΩ1 (a similar definition is made for 
RSW1). We now have two possibilities: (1) if the exact value of RSB2 + RS6 is 
known, we calculate V2 and hence εM1 = 0; (2) If only the upper limit of RSB2 + 
RS6 is known, a new voltage value V2, equal to V1, will be used in the following 
calculations. In this last case, εM1 should be calculated through formula [2.4]. 
In both we consider a new current value I2, equal to I1, to be used in the 
following calculations. εM2 is the other method error and is due to the 
voltmeter internal resistance. The V2 / I2 relation does not correspond to the 
desirable calculated resistance but to a parallel association between R2 and 
RV, i.e.: 
 
V2 / I2 = R2 = ( R3 . RV ) / ( R3 + RV ) [2.6] 
 
To remove this error, a new resistance value R3 must be calculated as follows: 
 
 R3 = R2 / [ 1 - ( R2 / RV ) ]    [2.7] 
 
                                         
1 IEEE1149.4Std., 9.4.1.b  
5 
 
where: 
 
εM2 = - ( R2 / RV ) [2.8] 
 
In order to better understand the previous operations, a chart with the 
implicit algorithm is presented in Figure 2. 
 
Measured values 
V1, I1
εV = f (V1)
εA = f (I1)
RSW2 is a known 
value?
V2 = 1 + ( RSW2 / RV )
I2 = I1
|εM1| = 0
Y N
V2 = V1
I2 = I1
|εM1| = RSW2 / RV
 Max[ RSW2 ] is 
known?
R2 = V2 / I2
Correct error 
due to RV ?
Y N
R3 = R2 / [1 - ( R2 / RV) ]
|εM2| = 0
Y N
R3 = R2
|εM2| = R2 / RV
RX = R3
εRX = εV + εA + |εM1| + |εM2|
Accuracy unknown
 
 
Figure 2 – Rx algorithm calculating the value of a resistor placed between an ABM and 
GND.  
 
6 
 
The chart includes all possible decisions in the RX calculation process, allowing 
the user to evaluate the impact of a given error source (e.g. the non-zero RSB2 
ohmic value) in the final result. Notice that not every switch included in the 
measurement path (e.g. RSB1) affects the RX calculation process. 
 
3 – Determining the value of one resistor placed between two ABMs 
The measurement of one resistor placed between two ABMs is similar to the 
previous case, as we can see in the Figure 3. 
V
AT1
AT2
TBIC
S6
S5
Vcc
SB1
SB2
ABM_A2
A2
Rx
A3
SG
ABM_A3
A
SCANSTA400
 
Figure 3 - Determining the value of one resistor placed between two ABMs. 
 
The difference is that we now have a new error source due the presence of 
RSG. The initial value for the calculated RX is again given by: 
 
R1 = V1 / I1 [3.1] 
 
However, the total relative error of Rx is now: 
 
εRX = εV + εA + |εM1| + |εM2|+|εM3| [3.2] 
 
Errors εM1 and εM2 were explained in the previous section. εM3 is a new method 
error associated to the presence of RSG. The calculus of RX follows the same 
steps as explained in the previous section until a value for R3 is obtained. 
However this value does not correspond to the real resistance between the 
two pins, but rather to a series formed by R4 and RSG, i.e.: 
7 
 
R3 = R4 + RSG [3.3] 
 
The error value εM3 is given by: 
 
εM3 = RSG / R3 [3.4] 
 
To remove this error, R4 must be calculated as follows: 
 
R4 = R3 - RSG [3.5] 
 
which, by its turn, requires characterizing the internal resistor RSG. This may 
be done with an additional test, as presented in Figure 4. 
V
AT1
AT2
TBIC
S6
S5
Vcc
SB1
SB2
ABM_A2
A2
Rx
A3
SG
ABM_A3
A
SCANSTA400
 
Figure 4 – Determining the resistance value of the RSG switch. 
 
To determine the ohmic value of RSG the rules explained in the previous 
section should be applied. Notice that in the configuration presented in Figure 
4, RX is in series with RS5 and RSB1, which do not affect the measurement 
process, as the resistor under characterization is now RSG. In order to better 
understand the previous operations a new chart with the implicit algorithm is 
presented in figure 5. 
8 
Measured values 
V1, I1
εV = f (V1)
εA = f (I1)
RSW2 is a known 
value?
V2 = 1 + ( RSW2 / RV )
I2 = I1
|εM1| = 0
Y N
V2 = V1
I2 = I1
|εM1| = RSW2 / RV
 Max[ RSW2 ] is 
known?
R2 = V2 / I2
Correct error 
due to RV ?
Y N
R3 = R2 / [1 - ( R2 / RV) ]
|εM2| = 0
Y
N
R3 = R2
|εM2| = R2 / RV
RX = R4
εRX = εV + εA + |εM1|+ |εM2| + |εM3| 
Accuracy unknown
Correct error 
due to RSG ?
Y
R4 = R3 - RSG
|εM3| = 0
R4 = R3
|εM3| = RSG / R3
 
Figure 5 - Rx algorithm calculating the value of a resistor placed between two ABMs. 
 
4 – The case study  
Our analysis was validated with the IC SCANSTA400, an 1149.4 compatible IC. 
The data-sheet of this IC contains only the basic information and the values 
9 
for RSW1 and RSW2 are not supplied. Thus we have made some tests to 
determine them. The obtained results are presented in Table 1. 
 
Table 1  - RSW1/RSW2 resistor values for the IC SCANSTA400. 
 
Pin name Current value 
(mA) 
Voltage value 
(V) 
RSW1/2 
location 
RSW1/2 value 
(kΩ) 
A1 0,436 0,3955 RSW1_A1 0,907 
A1 0,435 0,3957 RSW2_A1 0,909 
A2 0,435 0,3978 RSW1_A2 0,914 
A2 0,435 0,3957 RSW2_A2 0,909 
A3 0,435 0,3980 RSW2_A3 0,915 
 
The schematic o the used current source is presented in Figure 6, for 
illustrative purposes. 
 
5V
10K 1K
Q1
BC557
Q2
BC557
1K
5V
 
Figure 6 - Current source used during the measurement operations. 
 
For measuring one resistor placed between an ABM and GND we used the 
circuit showed in Figure 1. To control the IC TAP (Test Access Port) we used 
an in house PC application, named JTAGer [20], which can control two TAPs. 
The program is presented in Annex 1. The voltage and current values read 
are: 
 
V1= 2,176 V  [4.1] 
I1= 0,458 mA  [4.2] 
 
The initial value for RX is:  
10 
 
R1 = 2,176 / 0,458 . 10 -3 = 4,75 kΩ  [4.3] 
 
The relative error εRX  is calculated as follows: 
εV= 0,05%RDG + 3 DIG = 0,0019 or 0,19%   [4.4] 
εA= 0,05%RDG + 3 DIG = 0,0071 or 0,71%   [4.5] 
|εM1|= ∆V/V = (RSB2 + RS6 )/RV = RSW2_A2/ RV = 907 / 10.106 = 0,01%   [4.6] 
|εM2| = RM/RV = 4, 75 .103 / 10 . 106 = 0,0005 or 0,05%   [4.7] 
εRX = εV + εA + |εM1| + |εM2| = 0,19 + 0,71 + 0,01 + 0,05 = 0,96 %     [4.8] 
 
In this case it is not possible to remove errors εM1 and εM2 because they are 
much less than the sum given by εV + εA, thus the correcting operations have 
no effect. In this case, using a voltmeter and an ammeter with higher 
accuracy (i.e. equal to or less than 0,1%) would cause the errors associated to 
the method  (εM1 and εM2) to have an higher impact in the calculation of  RX. 
The resulting RX is: 
 
RX = R1 = 4,75 kΩ  [4.9] 
 
The overall accuracy in this calculation method is less than 1%. The value of 
RX measured with a high accuracy instrument is: 
 
RXR = 4 757,0 Ω  [4.10] 
 
so a coherent value has been obtained. 
For measuring one resistor placed between two ABMs we used the circuit 
illustrated in Figure 3. The correspondent JTAGer program is presented in the 
Annex 2. The voltage and current values read are: 
 
V1= 2,412 V  [4.11] 
I1= 0,448 mA [4.12] 
 
11 
To characterize RSG we use the circuit illustrated in Figure 4. The obtained 
results are: 
 
VSG= 0,2732 V  [4.13] 
ISG= 0,447 mA  [4.14] 
 
R1 = 2,412 / 0,448 . 10 -3 = 5,38 kΩ  [4.15] 
 
The relative error εRX is : 
εV= 0,05%RDG + 3 DIG = 0,0017 or 0,17%  [4.16] 
εA= 0,05%RDG + 3 DIG = 0,0072 or 0,72%  [4.17] 
|εM1|= ∆V/V = (RSB2 + RS6)/RV = RSW2_A2/ RV = 909 / 10.106 = 0,01%  [4.18] 
|εM2| = RM/RV = 5,38 .103 / 10 . 106 = 0,0005 or 0,05%  [4.19] 
 
The calculated value for RSG is: 
 
RSG = 0,2732 / 0,447 . 103 = 611 Ω  [4.20] 
 
Notice that in the calculation process of RSG the associated εM1 and εM2 errors 
may be disregarded. Returning to the calculation of RX, the value for εM3 is 
obtained through: 
 
εM3  = RSG / RM = 611 / 5,38 . 103 = 0,114 or 11,4%  [4.21] 
 
This error source is unacceptable and must be removed. 
 
R4 = RM3 - RSG = 5,38 . 103 – 0,611 . 103 = 4,77 kΩ  [4.22] 
 
The total error and the final value for RX are, respectively. 
 
εRX = εV + εA + |εM1| + |εM2| + |εM3| = 
     = 0,17 + 0,72 + 0,01 + 0,05 + 0 = 0,95 % [4.23] 
RX = R4 = 4,77 k Ω  [4.24] 
12 
   
The obtained result is also coherent. Notice that the εM3 error source has been 
removed. To achieve better results it is imperative to use T&M instruments 
with better accuracy. 
 
5 – Conclusion 
The measurement in discrete components using electronic access mechanisms 
is an usual task in present integrated systems. In this work we proposed a 
methodology to analyse the errors introduced by the 1149.4 infrastructure in 
order to evaluate when its impact in the measurement quality is acceptable 
or be removed. Although the presented analysis has been conducted on an 
IEEE1149.4 compliant device, the calculation method may be applied to other 
analog buses. The impact of each switch has also been characterized, which 
may help analog designers to better understand which particular switch type 
to use in a particular location.   
 
Annex 1 
                    //  ************************************************************* 
                    //  *   Determining the value one resistor placed ABM_A1 - GND  * 
                    //  ************************************************************* 
                    // IC: SCANSTA400-National 
                    // Author: M.Felgueiras 
                    // Test conditions: 
                    // Mode=0 
                    // C0=0 
                    // C1=0 
                    // CE=1 
                    // CE1=0 
                    //  
start:              // ---------- 
seltap0;            //  
serflg0;            //  
rst;                //  
                    //  
A:                  // 
                    // 
state irshift;      // 
ld cnt,20d;         // 
nshfcp 1FFFEh,80000h,C0000h; // SAMPLE/PRELOAD 
jerr ERRO1;         // 
tms1;               // 
                    // 
state drshift;      //   
ld cnt,48d;         //   
nshf 00000300C000h; //   
jerr ERRO1;         //   
tms1;               //    
                    // 
state irshift;      // 
ld cnt,20d;         // 
nshfcp 00000h,80000h,C0000h; // EXTEST 
jerr ERRO1;         //     
tms1;               // 
                    // 
jmp A;              // 
13 
                    //    
ERRO1:              // 
halt;               //Read V1 and I1 values 
 
Annex 2 
 
                    //  *************************************************************** 
                    //  *  Determining the value one resistor placed ABM_A1 – ABM_A3  * 
                    //  *************************************************************** 
                    // IC: SCANSTA400-National 
                    // Author: M.Felgueiras 
                    // Test conditions: 
                    // Mode=0 
                    // C0=0 
                    // C1=0 
                    // CE=1 
                    // CE1=0 
                    //  
                    //------------- 
                    // 
start:              // 
seltap0;            //  
serflg0;            //  
rst;                //  
                    //     
state irshift;      // 
ld cnt,20d;         // 
nshfcp 1FFFEh,80000h,C0000h; // SAMPLE/PRELOAD 
jerr ERRO1;         // 
tms1;               // 
                    // 
state drshift;      //  
ld cnt,48d;         // 
nshf 0000030100c0h; //  
jerr ERRO1;         //  
tms1;               //    
                    // 
state irshift;      // 
ld cnt,20d;         // 
nshfcp 00000h,80000h,C0000h; // EXTEST 
jerr ERRO1;         // 
tms1;               // Read V1 and I1 
                    // 
                    // 
state drshift;      //  
ld cnt,48d;         //  
nshf 000003050080h; //  
jerr ERRO1;         //  
tms1;               // Read V1 and I1 
                    //  
                    // 
state irshift;      // 
ld cnt,20d;         // 
nshfcp 00000h,80000h,C0000h; // EXTEST 
jerr ERRO1;         //    
tms1;               // Read Vsg and Isg 
                    //  
ERRO1: 
halt;               // 
14 
 
 
Acknowledgements 
We would like to thank Mr. Adan Osseiram for providing the SCANSTA400 ICs 
used in the validation phase of this work. 
 
References 
[1] IEEE Standard for a Mixed-Signal Test Bus, March 2000, IEEE Std. 
1149.4, ISBN 0-7381-1755-2. 
[2] IEEE Standard Test Access Port and Boundary-Scan Architecture, 
October 1993, IEEE Std. 1149.1, ISBN 1-55937-350-4. 
[3] J. McDermid, “Limited Access Testing: IEEE1149.4”, Proceedings of 
the International Test Conference, 1998, pp388-395. 
[4] P. Syri, J. Hakinen, M. Moilanen, ”1149.4 Compatible ABMs for Basic 
RF measurements”, Proceedings of the Design Automation and Test 
in Europe, 2005, pp 172-173. 
[5] C. Jeffrey, R. Cutajar, S. Prosser, M. Lickess, A. Richardson, S. 
Riches “The integration of on-line monitoring and reconfiguration 
functions using IEEE1149.4 into critical automotive electronic contro 
unit”, Proceedings of the Design Automation and Test in Europe, 
2005, pp 153-158. 
[6] O. Decoudray-Acevedo J. Ramirez-Angulo, “Inovative built-in self-
test schemes for on-chip diagnosis, compliant with the IEEE1149.4 
mixed signal test bus standard”, Journal of Electronic Testing, vol 9, 
pp 21-28, 2003. 
[7] S. K. Sunter, “Testing High Frequency ADCs and DACs with a low 
Frequency Analog Bus”, Proceedings of the International Test 
Conference, 2003, PP 228-235. 
[8] U. Kac, F. Novak, F. Azais, P. Nouet, M. Renovell, ”Extending IEEE 
std. 1149.4 Analog Boundary Modules to Enhance Mixed-Signal 
Test”, IEEE Design & Test of Computers, March-April 2003, pp 32-39. 
[9] M. Felgueiras, G. Alves, J, Ferreira, “Debugging mixed-signal 
circuits via the IEEE1149.4 Std. – analysis of limitations and 
15 
requirements”, Proceedings of the 12th IEEE International Mixed 
Signal Testing Workshop, June, 2006, pp 2-7. 
 
[10] S. K. Sunter, B. Nadeau-Dostie, “Complete, Contactless I/O Tesing – 
Reaching the Boundary in Minimizing Digita IC, Testing Cost”, 
Proceedings of the International Test Conference, 2002, pp 446-455. 
 
[11] S. Sunter, K. Filiter, J. Woo, P. McHugh, “A general purpose 1149.4 
IC with HF Analog Test Capabilities”, Proceedings of International 
Test Conference, 2001, pp38-45. 
[12] B. Suparjo, A. Ley, A. Cron, H. Hhrenberg, “Aalog Boundary-Scan 
Description Language (ABSDL) for Mixed-Signal Board Test”, 
Proceedings of the International Test Conference, 2006. 
[13] M. Felgueiras, G. Alves, J. Ferreira, “Integrity checking of 1149.4 
extensions to 1149.1”,  Proceedings of the XXI Conference on Design 
of Circuits and Integrated Systems, September 2006, pp (CD).    
[14] T. Frodsham et al, “Apparatus for I/O leakage self-test in an 
integrated circuit”, US Patent 6262585, July 2001. 
[15] S. Sunter “The P1149.4 Mixed Test Bus: Costs and Benefits”, 
Proceedings of the International Test Conference, 1995, pp 444-450. 
[16] S. K. Sunter “Cost/benefits analysis of the P1149.4 mixed-signal test 
bus”, IEE Proc.- Circuits Devices Syst. Vol. 13, nº6, December 1996, 
pp 393-398.   
[17] I. Duzevik, “Preliminary Results of Passive Component Measurement 
Methods Using an IEEE 1149.4 Compliant Device”, Proceedings of 
the Board Test Workshop, 2002.       
[18] T. Saikkonen, M. Milanen, “Component Value Calculations for 
Measurements in 1149.4 Environments”, Proceedings of the 12th 
International Mixed Signal Testing Workshop, June 2006, pp 77-82. 
[19] http://www.national.com/ds/ST/STA400EP.pdf 
[20] JTAGer site: http://paginas.fe.up.pt/~jmf/pcsd0304/jtager.htm 
 
 
16 
 
 
