# **MICROPROCESSOR FREE RUN TESTING**

By

# **MICHAEL NUGENT**

Project Report submitted to the Department of Electrical Engineering of the Higher Technical Institute Nicosia Cyprus in partial fulfilment of the requirements for the diploma of

# **TECHNICIAN ENGINEER**

in

# ELECTRICAL ENGINEERING

**June 1990** 

#### MICROPROCESSOR FREE RUN TESTING

by Michael Nugent

# SUMMARY

The objectives of this project were to study the testing methods available when a microcontroller is Free-Running and to apply these methods for fault finding on a microcontroller.

The project is therefore divided into two main parts . The construction of the microcontroller to be tested and the study and application of the fault finding techniques and instruments on this microcontroller .

<u>Construction</u>: The Z80 8-bit family of components was used in the construction because this is superior in both software and hardware capabilities to most 8-bit microcomputer systems on the market. To explore these capabilities apart from the Central Processing Unit (CPU) and Memory , the Z80 Serial (DART) and Parallel (PIO) Input/Output devices and the Z80 Clock Timer Circuit(CTC) were included in the construction. This microcontroller communicates with an ATARI terminal via serial transmission which is enabled using the CTC for the generation of the baud rates and the SIO for the interfacing circuit.

<u>Fault finding techniques and instruments</u>: First, various troubleshooting instruments were examined, starting from the simple hand held instruments and their applications and going to the more sophisticated ones (Logic and Signature Analyser). Next, the techniques were analysed and these included the Free-Run Test and Self Test programs. This microcontroller is capable of testing 2K RAM chips by using certain Self Test routines, an application also examined in the Self Test techniques.

By following the above sequence , the troubleshooting techniques were studied and the Free Run test was carried out being fully aware of hardware and software aspects of the Z80 based system . Also , since the instruments were examined with reference to existing ones in the workshop , the Free Run test was carried out both easier and with more efficiency .

PAGE

#### ACKNOWLEDGEMENTS

#### SUMMARY

| Ι | NT | RODUCTIO | Ν |
|---|----|----------|---|
|   |    |          |   |

| PART                     | 1 : CONSTRUCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| 1.2<br>1.3<br>1,4<br>1.5 | HARDWARE CONFIGURATION<br>Specifications<br>Address Bus<br>Data Bus<br>Control Bus<br>Clock and Reset Circuit<br>Power Requirements                                                                                                                                                                                                                                                                                                                                                    | 1<br>1<br>2<br>3<br>4                                                          |
| <b>2</b><br>2.1<br>2.2   | MEMORY INTERFACING AND ORGANIZATION<br>Types of Memory<br>Design<br>2.2.1 Size<br>2.2.2 Access Time<br>2.2.3 Decoding                                                                                                                                                                                                                                                                                                                                                                  | 5<br>5<br>5<br>7                                                               |
|                          | <pre>INTERFACING INPUT OUTPUT DEVICES<br/>Introduction<br/>Decoding<br/>Z80 Parallel Input/Output Device ( PIO )<br/>3.3.1 Modes<br/>3.3.2 Port Signals<br/>Serial Transmission<br/>3.4.1 Synchronous and Asynchronous Transmission<br/>3.4.2 RS-232C<br/>3.4.3 Line Driver and Receiver Module<br/>3.4.4 Z80 Dual Asynchronous Receiver/Transmitter<br/>(a) Description<br/>(b) Input/Output Capabilities<br/>(c) Transmit and Receive Pin Functions<br/>(d) Z80 DART Registers</pre> | 8<br>9<br>10<br>10<br>10<br>11<br>11<br>12<br>13<br>14<br>14<br>14<br>15<br>16 |
| 3.5                      | <pre>(e) Software Application<br/>Z80 Clock Timer Circuit ( CTC )<br/>3.5.1 Description<br/>3.5.2 Block Diagram<br/>3.5.3 Operation<br/>3.5.4 CTC Application</pre>                                                                                                                                                                                                                                                                                                                    | 17<br>19<br>19<br>20<br>21                                                     |

### MICROPROCESSOR SYSTEM BLOCK DIAGRAM

#### MICROPROCESSOR SYSTEM PCB

| PART | 2 | 9<br>9 | MICROPROCESSOR | TROUBLESHOOTING | TECHNIQUES | AND |
|------|---|--------|----------------|-----------------|------------|-----|
|      |   |        | INSTRUMENTS    |                 |            |     |

| 4   | INSTRUMENTS                      |      |
|-----|----------------------------------|------|
|     | Hand Held Tools                  | - 23 |
|     | 4.1.1 Logic Probe                | 23   |
|     | 4.1.2 Logic Pulser               | 24   |
|     | 4.1.3 Current Tracer             | 26   |
| 4.2 | Logic Analyser                   | 28   |
|     | 4.2.1 Display                    | 28   |
|     | 4.2.2 Clock and Clock Qualifiers | 29   |
|     | 4.2.3 Triggering                 | 30   |
| 4.3 | Signature Analyser               | 31   |
|     | 4.3.1 Introduction               | 31   |
|     | 4.3.2 Operation                  | 31   |
|     | 4.3.3 Signature Window           | 33   |
|     | 4.3.4 HP 5006 Signature Analyser | 34   |
| 5   | TROUBLESHOOTING TECHNIQUES       |      |
| 5.1 | Self Test Programs               | 35   |

| Sell I           | est rrograms                                        | 35                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5.1.1            | RAM Tests                                           | 35                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | (a) Checkerboard Test                               | 35                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | (b) Marching 1's and O's                            | 35                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | (c) Complementary Address Sequence                  | 35                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5.1.2            | ROM Tests                                           | 36                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | (a) Checksum Routine                                | 36                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | (b) Cyclic Redundancy Check ( CRC )                 | 36                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Free Run Testing |                                                     | 37                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6.1.1            | System Kernel                                       | 37                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6.1.2            | The Test                                            | 37                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6.1.3            | Free Running with a Logic Analyser                  | 37                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6.1.4            | Free Running with a Signature Analyser              | 39                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | (a) Address Signatures                              | 39                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | (b) ROM Signatures                                  | 41                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | 5.1.1<br>5.1.2<br>Free F<br>6.1.1<br>6.1.2<br>6.1.3 | <ul> <li>(b) Marching 1's and 0's</li> <li>(c) Complementary Address Sequence</li> <li>5.1.2 ROM Tests <ul> <li>(a) Checksum Routine</li> <li>(b) Cyclic Redundancy Check ( CRC )</li> </ul> </li> <li>Free Run Testing</li> <li>6.1.1 System Kernel</li> <li>6.1.2 The Test</li> <li>6.1.3 Free Running with a Logic Analyser</li> <li>6.1.4 Free Running with a Signature Analyser <ul> <li>(a) Address Signatures</li> </ul> </li> </ul> |

## SOFTWARE APPLICATION OF THE MICROCONTROLLER

### CONCLUSIONS

#### 42

### REFERENCES

### APPENDICES

| I    | Z80 CPU                          |
|------|----------------------------------|
| II   | Z80 PIO                          |
| III  | Z80 CTC                          |
| IV   | Z80 DART/SIO                     |
| V    | TTL DEVICES                      |
| VI   | MEMORIES                         |
| VII  | INSTRUMENTS                      |
| VIII | VT52 TERMINAL                    |
| IX   | LINE DRIVER AND RECEIVER MODULES |