Mixed-signal systems-on-a-chip (SoCs) 
Introduction
At present, mixed-signal systems-on-a-chip (SoCs) are widely used, due to cost advantages. They often include voice band analog circuits, but this introduces a serious testing problem due to the uncontrollability of the analog core inputs and the unobservability of the digital core outputs. This problem is solved by the IEEE 1149.4 standard [10] , but with very high design-for-testability (DFT) hardware overhead on the analog core, long test times, and limited test signal bandwidth.
We propose a new test architecture for monolithic SoCs with voice-band analog hardware cores and on-board digitalto-analog converters (DACs), as well as microprocessors and/or digital signal processors (DSPs). With test patterns, we stimulate the digital core that drives the analog core through the DAC, so that in test mode, the digital core generates a sequence of high-quality samples that, when converted to an analog signal by the DAC, provide the multi-tone analog test waveform for the analog core. This eliminates an on-chip analog waveform generator solely for analog test, and the need to shift in control signals to configure the 1149.4 analog pin DFT hardware to receive an analog test waveform from an automatic test equipment (ATE) through external analog test signals.
We first analyze the analog core and determine the multitone analog test waveform needed for static linearity and distortion tests. We digitize the desired multi-tone waveform, accounting for the DAC resolution. Bisaria and Bushnell's [2] method characterizes an arbitrary sequential circuit. They stimulate the digital circuit with random inputs, and record the autocorrelation of the digital outputs and the cross-correlation between each digital output and each digital input, in a matrix C [2] . They record the flip-flop correlations, by treating each one as a pseudo primary input, pseudo primary output pair. Their method usually predicts the next input sequence necessary for the sequential circuit to generate a desired output sample, by multiplying the output sample by C. This input sequence will generate the desired output sample set for the digital core, with the exception of a few primary outputs (POs). They provide DFT hardware to control these POs directly. This uses far less DFT hardware than the 1149.4 standard.
We also test the digital core that is being used as a tone generator (TG) . We analyze the digital core cascaded with the DAC using a digital core input sequence that provides the conventional ramp (at the digital core output) for testing the DAC for differential non-linearity (DNL), integral non-linearity (INL), and signal-to-noise ratio (SNR). Excessive DNL indicates either a defective DAC or digital stuck-at faults in the digital core. A simulation indicates which stuck-at faults are tested in this fashion. The undetected stuck-at faults in the digital core are targeted using sequential automatic test-pattern generation (ATPG). We apply the vectors generated for these faults, called ATPG test vectors, to the digital core. We measure the SNR for the DAC while these vectors are applied, and compare that to the noise floor. But, the SNR measured at this output will be the combined SNR of the DAC and the analog core. We overcome this by tapping the value at the output of the DAC with an analog MUX (AMUX) so that the raw DAC output is routed to an output analog pin. Stuck-at faults in the digital core cause the noise of the DAC to rise above the noise floor and are detected in this fashion. However, some stuck-at faults alias with the good machine noise in the DAC, so between the digital core outputs and the DAC, we magnify the effect of aliasing faults by activating hardware that flips the most significant bit (MSB) going from the digital core into the DAC, thus grossly magnifying the noise effect of the fault.
We created five SoCs and analyzed their testing and DFT Section 2 discusses prior work, Section 3 presents our architecture, Section 4 describes our SoC test procedure, Section 5 proves that our testing is complete, Section 6 presents results, and Section 7 concludes.
Prior Work
The test architecture for testable SoCs [3] uses a test source to provide test vectors, a test sink for an on-chip signature analyzer, and a test access mechanism (TAM), which is a userdefined test data communication structure. The test controller is the 1149.1 boundary scan test access port (TAP) and controller. The SoC has boundary scan hardware added to all digital and analog pins, with the analog portion tested using the IEEE 1149.4 standard [10] . Dufort and Roberts [4] generated multi-tone sinusoidal signals by periodically applying digital pulse code modulation (PCM) bit streams to a sigma-delta modulator. Ozev et al. [11, 12] proposed a system-level test synthesis methodology for mixed-signal designs using a basic block level test translation approach. This finds signal paths through which the test inputs and responses can propagate. Fang and Kerkhoff [5] proposed a core-based algorithm for finding the tolerance-box for each individual analog core in a given mixed-signal SoC. They determine the tolerance box for each analog core, and then for the entire test path. Sehgal et al. [13] optimized TAMs and test scheduling for mixed-signal SoCs. Tofte et al. [14] and Ong et al. [9] proposed built-in-self-test (BIST) for mixed-signal SoC's using a second-order delta sigma modulator, and an on-chip DSP for generating the digital test stimulus.
Linearity testing of DACs involves applying a ramp signal as input to the DAC. The actual response is compared with the expected response by an ATE to determine static parameters such as DNL and INL [7, 8] . Hassan et al. [6] tested DACs by inserting them into an oscillating loop to form a sigma-delta modulator.
Mixed-Signal SoC DFT Architecture
The new SoC test architecture is in Fig. 1 . The digital core, the N-bit DAC, and the analog block are the CUTs. These are the testing components of this architecture:
The tone generator block (TG) is the digital core and the N-bit DAC-under-test. The analog block or core is the various analog components-under-test (CUTs). The primary inputs (PIs) input the test patterns and signalś I 1 I L µ input the good machine responses to test the TG and operate the tone generator. The analog PO observes the analog block output. The DAC OUT pin, which is the raw DAC output before reconstruction filtering, is MUXed to the analog PO for observing the TG block output. The bit flipping block (optional) magnifies stuck-fault effects in the least significant bits (LSBs) by flipping the MSB as well, when the LSB flips, to introduce a huge distortion in the output analog spectrum due to the fault. Stuck-at faults affecting the LSBs of the digital core outputs are unlikely to significantly distort the Fast Fourier Transform (FFT) of the DAC output, but flipping makes the stuck-at faults observable through the DAC. Digital and Analog MUXes. The MUXes (M 0 to M M 1 ) are controlled using the T M 1 pin, to apply direct digital signals to selected bits of the DAC in order to make it synthesize a desired analog test waveform. The digital core synthesizes a sample set for a nearly correct realization of a desired analog multi-tone test waveform. However, a few bit positions usually need to be provided directly, for high waveform quality, by these MUXes. In the M M 1 MUX, the T M 1 T M 2 pins select signals from either the digital core, the bit flipping block, or the external pin. We observe the DAC output signal DAC OUT directly without reconstruction filtering through an AMUX, controlled by signal T M 2 , on the analog output of the system. Table 1 shows the four operation modes, depending on 
Modes of Operation.
T M 1 T M 2 . Multiplexers M 0 to M M 1
Tone Generator
We test the TG by: (1) testing the digital core by propagating the digital faults through the DAC and observing their effects in the analog output, and (2) testing the DAC with input test patterns generated by the given digital core. Digital test input patterns are applied at the PIs and the analog output is observed at the DAC OUT pin (see Fig. 2 ). The tone generator has errors due to digital block stuck-at faults, and DAC nonlinearity errors and noise. We test DAC errors with SNR and DNL tests.
The TG is tested by capturing the digital core and DAC fault effects in the DAC output signal.
1. The DAC errors are detected by applying the DAC test patterns and from the worst case DNL error, the offset error, and the gain error (called the DNL test). The N-bit DAC ramp test input sequence ranges from minimum (0) to maximum code (2 N 1 ) and back again, for 50 cycles. 2. The digital core stuck-at faults can be detected in the DAC output, by using the ATPG and DAC test vectors to excite and propagate fault effects to the DAC output, where they perturb the analog spectrum in phase or magnitude.
The DAC test patterns can also propagate the faulty responses from the digital core through the DAC to its analog output, but not all digital stuck-at faults are detected this way. 
Next, during SNR test, the ATPG test patterns detect the digital core stuck-at faults that were previously undetected. We find the noise floor of the DAC in terms of the SNR using the DAC test patterns and then find the SNR using the ATPG test patterns (SNR ATPG ). A fault in the digital core makes SNR ATPG noise f loor. Sometimes, the digital faults are detected by neither the DNL nor the SNR test, because their fault effect aliases with DAC errors. If a stuck-at fault flips only an LSB, then due to DAC errors, its effect on the analog output may be less than an LSB error, and the DNL test declares the TG good. For the SNR test, the SNR ATPG will be much closer to the noise floor. Detecting the digital core faults using the SNR test depends on the aliasing probability of the digital core stuck-at faults with the good noise in the DAC, which is determined by pre-testing analysis (see Section 4.3).
The digital core faults with 1 or 2 LSB errors will produce maximum error using the bit flipper DFT hardware, where the MSB of the DAC is flipped if there is a flipping due to a fault in any of the low-order bits. This hardware is described in Subsection 4.4. Thus, all faults produce a DNL error greater than 1 LSB and are detected by the DNL test, or the SNR AT PG is less than the noise floor and faults are detected by the SNR test.
Testability of the Tone Generator
We analyze the cases where the faulty digital core and DAC can be detected using the DNL and SNR tests. A TG can have any one of these cases:
The DAC is faulty. Case 2: The digital core is faulty. Case 3: Both the DAC and the digital core are faulty.
For Cases 1 and 3, the DNL test will find the DAC faulty. For Case 2, the DAC is good, and the worst DNL, offset, and gain errors will be below the DNL cut o f f , o f f set cut o f f , and gain cut o f f values and the DNL test will find the DAC to be good. Some digital core stuck-at faults may alias with the good DAC noise and be undetected by either DNL or SNR tests.
In Case 2, faults that were not detected by the DNL test are now detected by the SNR test and if the SNR AT PG value of these detected faults is near the noise floor, then the test will declare the digital core good, even though the fault effects are detectable at the digital core PO. Since the DAC is good, the DNL test will declare the DAC and the TG good. To avoid this, we determine the aliasing probability of the stuck-at faults of a circuit with the good DAC noise using pre-testing analysis. If there is aliasing, then bit flipping is used to eliminate it completely. The DAC errors will be within their tolerance limits and these errors will be averaged over a number of cycles. For stuck-at faults with high aliasing probability, bit flipping removes aliasing.
Pre-Testing Analysis
Pre-testing analysis determines whether the stuck-at faults of a given circuit alias with the good noise of the DAC. We prove that digital core faults will get detected in the presence of good noise in the DAC, as follows: The optional bit flipping block (see Fig. 5 ) is used only if stuck-at faults in the digital core alias with DAC noise. The inputs DC MSB (the MSB of the digital core) and DC S are from the digital core and the inputs I 1 I L are from the external pins and provide the expected good machine response. DC S is the bit that flips. Usually, none or one bit is selected for bit flipping.
Bit Flipping to Increase Digital Fault Effects
Bit flipping increases the digital fault effect in the DAC analog output, so that the DNL exceeds 1 LSB (DNL cut o f f ) and the SNR will be less than the noise floor by 1 dB in the presence of digital core faults. A 1 dB SNR difference between the noise floor and the SNR AT PG equals 2 or 3 LSB errors.
We select the digital core output bit(s) for which the MSB of the digital core (DC MSB ) is flipped. A is the number of faults that are aliasing and V is the number of test vectors. Let max count A ¢V denote the upper bound on the number of times bit k can flip. If bit count k denotes the number of times a bit k has flipped for the faults (from simulation) and f ault count k denotes the number of faults for which bit k flipped, then bit k's weight is:
Bits are sorted according to their weights in decreasing order to give a preference list, and are selected as follows:
Flip the DC MSB , when there is a flipping in the bit from the preference list. Determine the DNL and SNR change caused by the faults in the DAC analog output. Select the bit(s) for which, on flipping DC MSB , the maximum DNL error for each of the faults exceeds 1 LSB or the SNR for each of the faults is maximal.
If the selected bit flips, then DC MSB is flipped. The occurrence of flipping in the selected bit is determined by comparing the actual response with the expected (good machine) response. We flip DC MSB when due to a fault, the selected bit flips, but DC MSB does not flip. Otherwise, DC MSB is not flipped. Fig. 5 is the bit flipping hardware to flip DC MSB when only one digital core output bit flips (DC S is one of the LSBs affected by the fault). The new DC MSB value is:
Proceedings of the 19th International Conference on VLSI Design (VLSID'06)
Note that MSB new and T DO are the same signal. For example, let the bit selected by the bit selector for flipping the MSB be bit 0. Table 2 shows the result of flipping the MSB for the given expected and actual responses. The MSB 
Testing the Bit Flipping Hardware.
The bit flipping block is tested in the digital test mode, with test patterns applied at pins I 1 , I 2 , DC S , and DC MSB , and faults are observed at T DO. For cases where we select more than one LSBs of the digital core for bit flipping (we select at most 2), so that their fault effects can be magnified by flipping the MSB of the digital core, we will use multiple bit-flipping blocks. These blocks are tested by wiring their outputs to multiple T DO pins. We MUX any of the available SoC output pins in test mode to route T DO 1 and T DO 2 to the pads.
Reconstruction Filter and Analog Block Testing
The reconstruction filter in Fig. 2 is tested separately from the DAC using TG tones, to avoid aliasing of the DAC and reconstruction filter noise. The analog components in the analog block are tested using the TG [1] (see Fig. 2 ). The inputs to the TG block are the digital test patterns, from the PIs. The fault-free response of the digital core is converted into analog test tones by the DAC. 
Proof of Digital Core Fault Coverage

Results and Analysis
The test scheme has two stages. There are two possible outcomes:
Stage I -Tone Generator Test
Case 1: If the DAC parameters calculated are within the tolerance limits and the SNR calculated using the ATPG test patterns is the same as the noise floor, then neither the digital core nor the DAC is faulty (the TG is good). Case 2: If either the DAC parameters calculated are outside the tolerance limits or the SNR calculated using the ATPG test patterns is less than the noise floor by 1 dB, then the TG is faulty.
Stage II -Analog Component Test
The different analog components in the analog block are tested by generating the required analog test tones using the TG block, which is found to be good from Stage I. For both Stages I and II, test patterns were applied for 50 cycles to average out noise. Table 3 , four of which used a low-pass filter (LPF) as the analog core. Note that pcont2 is an 8-bit controller for DSP applications. The results shown in Table 4 are for SoC5 and were obtained by simulations on a SunBlade 100 SPARC system. Three external pins are required for controlling bits 5, 6, and 7 of the DAC directly for generating test tones, and other bits are controlled from the digital core. All five SoCs had a 100% test case coverage (TCC). The TCC is:
Proceedings of the 19th International Conference on VLSI Design (VLSID'06) T CLK has a 2 ns period (1/500 MHz). Table 6 shows the test The IEEE 1149.4 standard analog test bus is slow, and usually has less than 1 MHz bandwidth [3] . Components are usually tested with 10 KHz F 100 KHz [10] . For the new scheme the frequency of the test tones depends on the digital test clock period (T CLK ) and the number of test tone patterns P. If T CLK 2 ns, then the sampling frequency is F S 500 MHz. Let P 100. The generated tone frequency is:
F F S P 500 ¢ 10 6 100 5 MHz Fig. 6 shows the generated test tone frequency as a function of T CLK and P. The test tone frequency decreases as P increases, but we still have much greater bandwidth than the 1149.4 bus. Figure 6 : Test tone frequency generated using the new scheme
Comparison with BIST Distortion Testing. Table 7 compares the performance of our new method for noise testing and distortion testing with that of Tofte et al. [14] . In their method, they generate a test waveform using a linear feedback shift register (LFSR), convert it to an analog signal with a DAC, stimulate the analog core, loop back the analog output of the core, and digitize the looped-back signal with an analog-to-digital converter (ADC). In our method, instead we engage the DFT hardware to configure the tone generator, apply digital test vectors to the digital pcont2 core, convert the pcont2 outputs to an analog signal with an 8-bit DAC, and apply the DAC output to the analog circuit. They calculate cross-correlation between the LFSR signal and the digitized response of the analog core as a signature, whereas we use an ATE to examine the spectrum of the analog core directly. In both methods, the stimulus for LPF test was 33 cycles of a 20 625 KHz tone, and the stimulus for the band-pass filter (BPF) test was 206 cycles of a 128 75 KHz tone. For the experiments using our method, the tone amplitude was 1 V pp (Volts peak-to-peak). Both results were produced by analog simulation. In their work, they inject white noise with the LFSR, whereas we inject good machine white noise of 2 mV RMS into the DAC. We see that for the LPF, our method generated slightly higher noise than theirs, but our total harmonic distortion (THD) was significantly lower. THD is the ratio of the signal energy in the harmonics of the fundamental to the energy of the fundamental. For the BPF, we not only had lower noise, but also significantly lower THD. This is because their LFSR pattern generator inserts huge amounts of high amplitude white noise into the circuit, due to its random nature, whereas our tone generator is tailored to create the desired multi-tone waveform at the desired frequencies, with noise coming only from the DAC good machine noise. Thus, our method is superior.
Failure Effect Analysis. The proposed test scheme can diagnose down to the individual components of the SoC. Stage I of the test scheme determines whether the digital core, the DAC, the DFT hardware, or some combination of these is failing. The bit flipping hardware detects whether a digital core stuck-fault propagates to a DAC LSB. Stage II detects whether the analog core fails using the tones generated from the fault-free tone generator. So, we can diagnose down to each block in Figure 1 , except that we cannot differentiate between faults in the reconstruction filter and faults in the analog block.
Conclusion
We proposed a new test architecture for mixed-signal SoCs where we use existing digital cores and DACs as an analog tone generator for either full or partial analog built-in selftest. The advantages are that it generates very precise multitone analog test waveforms, without the overhead of a custom, on-chip analog multi-tone waveform generator or a DSP. Also, analog multi-tone waveform generators are notoriously difficult to manufacture accurately in volume production, due to analog component variations. We showed that this architecture can test 100% of the testable digital core stuck-at faults by using an external ATE to examine the spectrum of the analog output signal, where the fault effects show up as magnitude or phase disturbances. The results for this new SoC test method show that the digital faults can be detected without using the 1149.4 boundary scan hardware by propagating the faults through the DAC and analog core, and then observing them in the analog domain.
On five SoCs, where the analog cores were either 1st-order low-pass filters or 1st-order Σ ∆ modulators, we covered 100% of the analog core faults, complete static linearity tests of the DAC, and 100% of the testable digital core stuck-at faults. This method requires 78.6% less test hardware than the 1149.4 standard, while providing better fault detection. Only rarely do we require the bit flipping block. Analog components can now be tested using the tones generated from the tone generator block (consisting of a modified digital core and DAC) instead of using the analog test bus to provide the tones. The test time was reduced by 74% compared to using the 1149.4 analog test bus, due to the elimination of scan shifting sequences. This testing method has much higher bandwidth than the 1149.4 bus, and therefore can generate test tones of 15 MHz for a digitized waveform sample set of size 50.
Future Work. The bit flipping block in this method could be extended to detect whether any one of the output bits of the digital core flips due to a fault, not just the one or two LSBs. This use will increase the hardware overhead of the bit flipping block, since good machine outputs must now be provided to the DFT hardware for all bits during testing. We propose to use this information in the diagnosis of the digital core. Furthermore, we will use the concept of the on-chip pattern generation using the digital core and DAC in testing high-speed serial input/output interfaces (SERDES).
