## 80C320 CPU DEBUGGER P-1383 PROJECT REPORT SUBMITTED BY AARTHI VENKATESHAN KARTHICK . R MARY SUSANA GEORGE RAJESH KUMAR . N SENTHIL KUMAR . R GUIDED BY Mr. S. GOVINDARAJU, M.E., MISTE. Assistant Professor, ECE Dept. IN THE PARTIAL FULFILMENT OF THE REQUIREMENTS FOR THE AWARD OF THE DEGREE OF BACHELOR OF ENGINEERING IN ELECTRONICS & COMMUNICATION ENGINEERING OF THE BHARATHIAR UNIVERSITY COIMBATORE Department of Electronics & Communication Engineering KUMARAGURU COLLEGE OF TECHNOLOGY Coimbatore-641 006. ## DEPARTMENT OF ELECTRONICS AND COMMUNICATION ENGINEERING KUMARAGURU COLLEGE OF TECHNOLOGY COIMBATORE-641006. (Affiliated to Bharathiyar University) #### CERTIFICATE This is to certify that the Project Report entitled 80C320 CPU DEBUGGER has been submitted by in partial fulfillment for the award of the degree of Bachelor of Engineering in #### **ELECTRONICS AND COMMUNICATION ENGINEERING** of the Bharathiar University, Coimbatore – 641 006 during the academic year 2000-2001 Faculty Guide Head of the Department Certified that the Candidate was examined by us in the project work viva-voce Examination held on $\frac{1}{\sqrt{3}\sqrt{2\sigma}}$ (and the university Register No. was Internal Examinar External Examiner ### CERTIFICATE This is to certify that the following students of KUMARAGURU COLLEGE OF TECHNOLOGY, Coimbatore, of branch Electronics & Communication Engineering Aarthi Venkateshan R Karthick R Senthil Kumar N Rajeshkumar Mary Susana George had undertaken their project entitled "80C320 CPU DEBUGGER", from June 2000 to March 2001 at our Industry and have successfully completed it. Their performance during that period was found to be good. We wish them all success. Place: Coimbatore Date : March 8, 2001 Industry Seal er Polytronic<mark>s Limit</mark>co ICHY HOAD NALLUR POST ATORE-641 005. V SRINIVASAN Manager - R&D K K VENKATARAMAN Vice President - R&D premier polytronics ltd. # "The secret of success is to put your best forward, nurtured at every step by the great men who give you the sense of direction" We thank our Principal **Dr.K.K.** Padmanabhan B.Sc(Engg), M.Tech, Ph.d and the Management for the facilities provided in the college to accomplish this project. We place on record our deep sense of gratitude to our Head of the Department **Prof. Muthuraman Ramasamy,** M.E, MISTE, MIE, C.ENG(I), MBMESI, MIEEE(USA) for his constant encouragement and support throughout the project. We are greatly indebted to our guide **Prof. S. Govindaraju**, M.E, M.I.S.T.E for his invaluable advice and gentle reminders, that really motivated us through many a tough encounter, only to help us reach our goal. We would be failing in our duty if we do not express our bountiful thanks to Mr. S. N. Ramachandran, Director, Premier Polytronics Limited who opened the doors of opportunity and paved the way for our project. We profoundly thank the Vice President, Research and Development Mr.K.K.Venkataraman and Manager, Research and Development Mr. V. Srinivasan who helped us carry out this project meticulously within the stipulated time. We profusely thank **Mr. E. Saranavanakumar** for fine-tuning our technical potential and helping us bridge our theoretical and practical knowledge, in spite of his busy schedule. We are grateful to Miss. Amirtham for giving us hours of beneficial training during this project. We express our heartfelt thanks to Mr. Vijaykumar, Mrs. Geethanjali and Mrs. Rajeswari who helped us in the completion of our project. We thank all the staff of Premier Polytronics Limited and the Electronics and Communication Engineering Department who was a source of strength in this project. In the world of Textile Industry today, Automation is the key to tomorrow's technology. This Evergreen industry with all the blooming ventures has many an advanced machines. The PREMIER HFT TESTER developed by Premier Polytronics Limited; Coimbatore is used to test the various fibers of cotton. A method of quality assurance is extended to reduce the time span and fatigue of workers, as time and energy are two valuable resources of mankind. The firmware Project titled "80C320 CPU DEBUGGER" has two major sections namely the Hardware and the Software divisions. The aim of this project is to test the Controller board of the HFT tester and trace the defects if any. The status of the CPU board is indicated by means of LED's in the front panel of the jig. The 80C320 controller used is the brain of this machine; its meticulous design includes a number of peripherals of which every parameter needs to be tested for the proper functionality of the machine. On the Hardware front, three printed Circuit Boards have been fabricated besides the Front Panel wherein the control switches and LED's indicate the status of the controller board. On the Software front, coding has been written in the assembly language of 80C320. The Test Jig is a user-friendly interface that has found real-time application in the company as the versatile CPU board is used in many of their products. ### INDEX | Acknowledgement | Page No. | |----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------| | Synopsis | | | Contents 1. Introduction | 1 | | <ul><li>1.1 Company Profile</li><li>1.2 HFT 9000 Machine</li><li>1.3 Project Description</li></ul> | , | | 2. Hardware | 6 | | 2.1 Test Jig Overview | | | 2.2 An insight into the Test Jig 2.2.1 Power Supply F 2.2.2 Interface PCB 2.2.3 Display PCB | PCB | | 2.3 Fabrication of PCB's | | | 3. Software | 22 | | <ul> <li>3.1 Introduction to Assembly Pro</li> <li>3.2 Details of Testing Process</li> <li>3.3 Algorithm</li> <li>3.4 Flowchart</li> <li>3.5 Coding</li> </ul> | ogramming | | 4. Operating Instructions | 74 | | <ul><li>4.1 Test Procedure</li><li>4.2 Handout</li></ul> | | | 5. Debugging | 82 | | 6. Limitations of the System | 83 | | 7. Scope for Expansion | 84 | | 8. Conclusion | 85 | Bibliography Premier Polytronics Limited is a part of the Premier Mill group. The company was started in 1983 with technical and financial collaboration from Zellweger Uster. From 1996, Premier has been independently manufacturing and marketing worldwide. Premier's complete range of products includes Fibre testing, Yarn testing, Online monitoring, Winding and continues to manufacture splicers with Mesdan, Italy. The customers of Premier are about 1000 spinning mills currently. More than 30% of the sales turnover comes from exports. This ISO 9001 certified company had received the R & D award for the years 96-97 and 97 –98. This company has CE certification for most of its products and has received the Government of India Department of Electronics award for excellence in Electronics. Besides this, Premier has received the EEPC award for export excellence and the FITEI special export award in 98-99. Any product of Premier Polytronics Limited has a seal of quality and is a symbol of consistent competence. Premier is a company surging ahead in tune with tomorrow's technology offering the best in the field of Textiles. The PREMIER HFT TESTER is used to test the quality of various types of fibers of cotton. The HFT is the acronym to high volume fiber testing. The machine is semi automatic since the sample and the tested cotton has to be inserted and removed manually. All the parameters are measured indirectly. ### Parameters to be measured: - Length of the fiber - Strength of the fiber - Micronaire of the fiber - Colour of the fibre ### Length of the fiber: The length of the fiber is measured using a separate module with the aid of OPTICAL MEASUREMENT. The optical module consists of a modulator and a demodulator. The modulator modulates the supply frequency in a suitable range. We are going for modulation and corresponding demodulation to avoid external light interference. A stepper motor is used with a step size of 1.8 degrees / pulse. The length is obtained from the number of steps moved by the stepper motor. ## Strength of the fiber: The strength of the fiber is measured using a FORCE TRANSDUCER. The force transducer is of F-type. The force transducer consists of JAWS used for clamping the sample cotton. The jaw consists of two parallel plates out of which one plate is fixed and the other plate is movable. The strength for breaking the cotton is converted into the equivalent difference current. This difference current is converted in to an equivalent voltage. ## Micronaire of the fiber: In order to make the micronaire measurement, we place a known weight of cotton inside the system. A burst of air is supplied into the system where an air transducer is placed. This difference in air pressure is amplified and converted into an equivalent voltage from which the micronaire is calculated. ## About the CPU board: The 80C320 controller board is that which controls and coordinates the functions of this ELECTROMECHANICAL machine. The machine is called as an electromechanical machine because the electronic board controls the movements of the pneumatic parts. The Digital switches monitor the pneumatic part's movement and solenoid coils. The switch is ON when an input is given and OFF when an input is not given. The two inputs which the controller needs is the digital IN and the state of the digital switches. The supply given to the coil is called as digital OUT. The pneumatic controls are established with the help of two stepper motors. Stepper motor-1 controls the direction of motion (*forward or backward*). Stepper motor-2 controls the pulse. 24v DC drives the stepper motor. In order to avoid back EMF in the circuit we go for Drag and Drivers. Drag and Driver circuit is an important circuit, which is similar to a chopper, or a slipper circuit. The function of the dragon driver is to energize the coil of the motor. With the toggling of the trigger switches, we can sense the movements of the pneumatic movements. To have a user-friendly communication with the machine, visual basic 6 is used as the front-end tool. The computer sends the input serial data to the controller. In response, the controller sends the control signals to various parts of the system. A Fibro - sampler is used to check if the required amount of cotton in order to check for the size, length and weight. ## Sequence of operation for measuring length: From the fibro sampler the sample cotton is placed in the machine on the pulse switch. Now the pulse switch is activated and is in the ON condition and its status is sent to an inductive sensor. Now again the inductive sensor sends a pulse to check whether the pulse switch is till in ON condition. If the condition is true, it causes the toggling of the switches in the optical module and hence the length is measured and displayed in the computer screen. Our project deals with the testing of the CPU board of the Premier HFT Tester, which has been developed at Premier Polytronics Limited, Coimbatore. The various parameters to be tested are done by means of our Test Jig, which by large means reduces the time involved in debugging and facilitates easy tracking of errors. The CPU board, which is to be tested, has a number of peripherals, the functionality of which is under test. A firmware project - the Test Jig can be divided overall into two parts – Hardware and Software. The Hardware side of the project includes the building of three Printed Circuit Boards namely the Power Supply Board, Interface board and the Display Board. The Front panel Display board and the Back Panel board are also present besides the PCB's. The Software side includes the assembly language programming which is dealt with in detail later. The wiring forms the bridge between the hardware and the software The testing of the CPU board is made in a user-friendly manner, and the testing of the modules can be done in a simple yet effective manner. The errors may be identified and the needful may be done. | Area to be tested | Test Methods | |------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. 81C55 | Set in Dip switches and the outputs are given to LED's. | | 2. Serial Communication | To transmit a fixed message in MAX 232 (U8), write a message in the program and receive the same message | | 3. RAM | Write data on NVRAM, retrieve it and display it in PC. | | <ul><li>4. A/D Converter</li><li>5. D/A Converter</li><li>6. Multiplexer</li></ul> | Some Analog inputs are given, one of them is elected using a multiplexer In order to digitize we Pass it through a ADC and use a DAC to convert the digital signal, thus when the DAC outputs are Correct, all the above Peripherals are tested | Test Jig The PCB's that were fabricated are namely the Power supply board, Interface Board and Display Board. The power supply board, which provides the supply for the entire Test Jig, a transformer is present inside the Jig. The Interface PCB is placed parallel to the top plate of the Test Jig, so that the CPU board to be tested can be mounted on the jig through the J1 and J2 Euro connectors. The side of the Jig consists the power supply board. The interface board forms the junction of all the signals. The signals from the CPU board come to the interface board and then go to the display board. The display board consists of all the input and output signals. The display PCB lies behind the Front panel, which consists of all the control switches and output LED's. #### Required output from power supply: | VOLTAGE | CURRENT | |---------|---------| | +5V | 1A | | +15V | 0.5A | | -15V | 0.5A | | +24V | 0.5A | | | | #### Block diagram of power supply: #### Description of power supply circuits: The blocks used in the circuit are - Transformer - Bridge - Filter capacitor - Voltage regulator The transformer used is a step-down transformer. A bridge rectifier is used followed by a voltage regulator. For positive output voltages we use a positive voltage regulator in the 78 series and for a negative output voltage we us ea negative output voltage regulator in the 79 series ## **Application Circuit:** ## Positive voltage Regulator: ## Negative voltage regulator: The diode protects the device when the output voltages are higher than input uring differential load conditions, during power on/off etc.. ## Circuit diagram for an output of 5V/1A: voltage range used for 5V/1A is (8-20)V Vo=5V Vin=a minimum of 8V ~10 V D.C Vdc=1.2 V \*Vac =10V Vac~8.33V So we require (0-9)V transformer. ## Circuit diagram for 15V and -15V output(0.5A): Voltage range used: (18-30)V and (-18.5 to -30)V Vin=a minimum of 18V ~ 20 V D.C Vdc=1.2 V \*Vac =10V Vac~16.6V Vac~17V So we require (0-17)V transformer. Vin=11.7V =12V ## Circuit diagram for an output of 24V/0.5A: voltage range used for 24V/0.5A is (28-38)V $V_0=24V$ Vin=a minimum of 28V ~30 V D.C Vdc=1.2 V \*Vac =26.66V Vac~27V So we require (0-27)V transformer. ### Printed circuit board: For 7805(ie 5V) package To3 package All the rest, $+12\hat{V}$ , $+15\hat{V}$ and $-15\hat{V}$ , we use the 220 package, The input voltages provided to board, are AC voltages: 0-12V used for +5V 0-15V used for +15V 0-24V used for +24V 0-17V used for -15V We may use a 6-pin PTR, individual 2-pin PTR's for the positive voltages. A separate 2-pin PTR is given to avoid confusion. ## Input side: in the output, PTR's are connected, again a 6-pin PTR and voltages may be checked using a DMM. - - ## INTERFACE BOARD As the name indicates this board forms an interface or interlink between the motherboard, which is to be tested and the display board where the outputs are indicated. The signals from the motherboard are received in the interface board and they are split up depending on their functionality. #### They are - Signals going to the display PCB - Signals going to the back panel - Power supply signals ## DESCRIPTION OF THE COMPONENTS USED - A 6 pin PTR has all the power supply signals necessary for the jig (i.e.) +5 V, +15 V, -15 V,+24 V .The 24 V provision is left for further use. - The 16 digital inputs and 16 digital output signals are divided using four 8-pin headers. Now these signals are connected to the front panel end components like switches and the LED's using external wiring. - A 3 pin header which has the serial communication transmission signals like Txd and Rxd - There is a 4 pin header which connects to the switches S17, S18, S19 - (to be obtained) - A 6-pin header, which contains all the DAC, signals going to the display PCB for further comparison. - A 6- pin header, which has external wiring with, the rotary switch in the front panel. Thus all the signals are separated and used as required. The interface board has two euro-64 connectors upon which the 2- Euro connectors of the motherboard will sit. Thus the interface board provides total interface to the signals of the jig. #### DISPLAY PCB The display PCB contains the necessary display circuitry. The end components like the switches and the LED 's are placed on the front panel and the corresponding wiring is done from the display PCB to the front panel and from the front panel to the interface board. In the display PCB we have the current limiting resistors necessary for the LED's. We have the lm339 comparator IC's to compare the DAC output voltage levels and the fixed voltage level of 2.29V ## Components list: | Interface board. | Components | Quantity | |------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------| | | Resistor network Relimate conn-8pin Relimate conn-4pin Relimate conn-3pin Relimate conn-2pin PTR connector-6pin | 2<br>5<br>3<br>1<br>1<br>2 | | Display board: | Resistors-3.3k 3.9k 4.7k 470E DTCON-9pin Relimate-2pin Relimate-4pin LED LM339 PTR-2pin Relimate-8pin | 1<br>1<br>2<br>30<br>1<br>2<br>1<br>30<br>2<br>1<br>2 | The process of making of the PCB involves the following steps namely - Drawing the schematic - Routing the PCB - Obtaining the legend - Plotting - Sketching the routes using copper ink - Etching - Alcohol Treatment - Assembling of the Components #### **Drawing of the Schematic:** The schematic is drawn using software called the Cadstar. This software has a library, which contains almost all the electronic components, which are necessary for the PCB. The electronic components are also classified according to their ratings. That is, for example in the case of resistor, the various range of resistors like 1K, 10K, 100K etc are present which can be made use according to the necessity. Thus using this library we select the components required and draw the schematic. ### Routing the PCB: Now the schematic diagram has to be routed by using the option called Auto Routing. In order to fulfill our circuit requirements some changes are made in the auto routed PCB manually and finally we get the legend ready. #### Plotting of the PCB: From the legend obtained the points where the components are to be inserted are plotted using the plotter. Then as the next step, the copper coated side of the PCB is filed mildly using Eversheet. ## Sketching the Routes using Copper ink: A special type of ink is used to sketch the routes. The above process is done manually. Using photo-filming technique can also do this. There is not being any intersection of the lines, have a start in used to avoid the intersection. #### **Etching:** The process of etching is done using ferric chloride solution. The PCB is placed in a tray containing the above solution. The tray is shaken slightly so that the ferric chloride solution will react with copper. The copper chloride obtained as a result dissolves in the water and is separated. Thus the routes (where the ink is present) above the copper stay making the routes very clear. ### **Alcohol Treatment:** The PCB obtained in the above step is cleaned using Ether solution. Thus the band is now ready for assembling. ## Assembling of the components: Now the components are assembled on the board and they are soldered. Now the board is ready. The central idea of the working of the project is that the EPROM in the CPU board is removed and replaced by a test EPROM. The test EPROM overrides the entire board. The software necessary for the controlling the micro controller and other hardware is loaded into this EPROM. Before loading or in fact programming the EPROM, the assembly language codes are written using the assembler. The assembler that we have used here in our project is called ASM A.51. Intel Corporation developed this assembler for the Dallas make micro controller chip 80C320. The software, which is written, is loaded in the assembler and finally compiled. Now this particular file is converted into hex file and is used to program the test EPROM. Now our software sits on the board. The assembler Asm.a51 is very easy and comfortable to use. It runs on DOS. The instruction set of 80C320 shares a lot in common with the 8051 family. There are 111 instructions. They are based on the following categories: > Arithmetic Instructions - 24 ➤ Logical Instructions - 25 Data Transfer Instructions - 28 > Bit Manipulator Instructions - 12 Program Branching Instructions - 22 ## Features of the Instruction Set: Instructions are faster than the original 8051. The numerical average of all opcodes is approximately a 2.5 to 1 speed improvement. Speed sensitive applications would make the most use of instructions that are three times faster. Another important feature is the dual data pointer feature. It allows the user to eliminate wasted instructions when moving a block of memory. ### AREAS TO BE TESTED: - DIGITAL MODULE - ANALOG MODULE - MEMORY MODULES: - INTERNAL MEMORY MODULE - EXTERNAL MEMORY MODULE - POWER ON SELF TEST #### **DIGITAL MODULE:** In the digital module, we have two 8155 peripheral port interfaces. Each 8155 PPI consists of three ports namely port A, port B and port C. Out of which Port A and port B are 8 bit ports and Port C is a 6 bit port. We now use the two 8 bit ports for the purpose of checking the Digital module. The logic behind checking the Digital lines is as follows - 1) Configure port A and port B of one 8155 PPI as input port. - 2) Configure port A and port B of the other 8155 PPI as output port. - 3) The inputs are given to the ports through SWITCHES. - 4) The outputs are displayed in the corresponding LED'S. - 5) When one or more switches is closed, the voltage scan loop will detect the corresponding line or lines and send the outputs to the corresponding LED'S - 6) The glow of the LED'S indicates that the corresponding lines are without any error. - 7) If any LED doesn't glow it indicates that an error has occurred either in the LED or in the corresponding ports. ## ANALOG MODULE: In the analog module of the original CPU system, we have an 8 to 1 multiplexer with 8 analog signal lines as inputs. The output line of the multiplexer is tied with the 12 bit bipolar (+10V to -10V) ADC. The output of the ADC is given to the 8 bit unipolar (0 to +5V) DAC. The logic for the checking the ANALOG MODULE is as follows, - 1) An analog voltage of 2.2Volts D.C is generated with a power supply voltage divider network and this voltage is supplied to the 8 analog input lines of multiplexer through an 8 way rotary switch so that only one input line is supplied at a particular time. - 2) The line is supplied by the switch is sensed and the corresponding value for selecting the sensed line is given to the selection lines of multiplexer. - 3) Hence the particular analog voltage line is selected and the signal is sent to the ADC. In the ADC, conversion is initiated by giving appropriate control signals and the control loop is made to wait till the end of conversion indication by specific signals. - 4) Once we get the end of conversion signal, the digitized data is read from the ADC and is stored in convenient RAM locations, after the completion of the above process the control is given to the DAC. - 5) In the DAC, the digitized data from the ADC is again converted to analog voltage. - 6) The analog output from the DAC is compared again with 2.2Volts with +/-10% tolerance in an external comparator circuit using LM339, which drives green LED to the forward biased condition. Hence, when the output voltage generated by the DAC crosses the specified threshold, the green LED glows showing that there is no error. Incorporating appropriate conversion routines does the conversion of digitized data from 12 output lines of ADC to 8 input lines of DAC. ## **MEMORY MODULE:** - 1) Memory locations from the first location are selected one by one sequentially. Data is written arbitrarily in the same sequence for all the locations. - 2) Now, the data in the RAM locations are read back and verified for their correctness by comparing with the original data. - 3) If it is found that the data in the memory location has been corrupted, we indicate that glowing the appropriate LED'S has damaged the RAM. ## **POWER ON SELF-TEST:** A self-check routine is included in the system firmware. This routine is positioned at the starting of the main routine. Thus routine flashes all the LED'S in the display panel board to ensure the proper working #### Digital Module U5: 8155 PPI (Programmable Peripheral Interface) with Port A, Port B, Port C as output ports. U4: 8155 PPI (Programmable Peripheral Interface) with port A and port B as input ports and port C as output ports. - Move the address of port A of U4 to data pointer. - Read the data from the port A (i.e.,) input from first 8 switches (S1-S8) and debounce these values. - Move the address of port A of U5 to the data pointer and move to debounced data to port A of U5. - Now the address of port B of U4 is moved to the data pointer and the above mentioned process is repeated for port B. - All the steps mentioned above are put inside a loop and this total scan loop is rotated in short intervals. #### **Memory Module** #### (a) External Memory Module: - In the CPU PCB the externally interfaced memory ranges from 6000h to7FFFh. - The data pointer is made to point the starting location (i.e.,) 6000h. - Sample data for writing into the RAM is stored in registers and is incremented, as the data pointer gets incremented. - Data is moved from the register and is written into the location pointed by the data pointer. - Now the accumulator is cleared and then the data from the written location is again moved to the accumulator and is compared with the original data previously written. - If the data's match perfectly for all locations, the OK signal is displayed. - If even one location looks damaged an error signal is displayed. #### (b) Internal Memory Module - Inside the micro controller 80c320, we have ON chip scratch pad RAM with user area from 20h to 7Fh. - The same logic applied in the testing of external RAM is applied here. #### Analog Module - An analog signal of 2.2V is given to an 8 way rotary switch, which supplies 8 inputs of the multiplexer (CH0-CH7). Hence at a particular point of time, only one analog channel (multiplexer input) is fed. - The analog channel fed at a particular time is identified with the aid of digital switches S1-S8. - Selection values are outed at port C of U4 into the selection lines of the multiplexer. Hence the supplied channel is selected and connected to the ADC. - Initiate conversion in ADC and continuously check for End Of Conversion (EOC) signal and store the digitized data in separate memory location. - The data stored in the memory location is compared with the corresponding values for it's upper and lower limits. - If the conditions are satisfied on comparison, appropriate value is sent to the DAC in order to drive the green LED, which is the OK signal and the error signals are displayed. ``` HFT9000 TEST JIG PROGRAM - 80C320 ;Microcontroller - 8155 ;Peripheral interface 48Z08 ; RAM - AD 574 ;AD Converter - TLC 7226 ; DA Converter - 27C512 ; EPROM ;Digital in ppi_u4 ; control word 0e000h equ ppi_u4_cw ;port a 0e001h equ ppi_u4_pa ;port b 0e002h equ ppi_u4_pb ;port c 0e003h equ ppi_u4_pc ;Digital out ppi_u5 ; control word 0c000h equ ppi_u5_cw ;port a 0c001h equ ppi_u5_pa ;port b 0c002h equ ppi_u5_pb ; Interal RAM locations 038h equ intmed_a ;averaged LSB 039h equ intmed_b ;averaged MSB 03ah equ intmed c ; for taking average 03bh equ count ``` | l ha há | equ | 03ch | ;MSB data | |-----------------|------------|--------|-----------------------| | data_hi | equ | 03dh | ;LSB data | | data_lo | equ | 08eh | ; C | | ckcon | equ | 020h | ;converted data of | | conv_c | 0 4 | | | | intmed_c | equ | 021h | ;converted data of | | conv_b | <u>1</u> - | | | | intmed_b<br>dbl | bit | 20h.0 | ; | | db1<br>db2 | bit | 20h.1 | ; | | db3 | bit | 20h.2 | ; | | | bit | 20h.3 | ; | | db4<br>db5 | bit | 20h.4 | ; | | db6 | bit | 20h.5 | ; | | db7 | bit | 20h.6 | ; | | db8 | bit | 20h.7 | ;bit initializations | | dcl | bit | 21h.0 | ; | | dc2 | bit | 21h.1 | ; | | dc3 | bit | 21h.2 | ; | | dc4 | bit | 21h.3 | ; | | dc5 | bit | 21h.4 | ; | | dc6 | bit | 21h.5 | ; | | de7 | bit | 21h.6 | ; | | dc8 | bit | 21h.7 | ; | | aco . | | | | | ; ADC | | | | | strt_conv | equ | 0a000h | ;start conversion for | | ADC<br>lsb_rd | equ | 0a001h | ;LSB data read | ``` ;first dac 04000h equ dac_1 04001h ;second dac equ dac 2 04002h ;third dac equ dac 3 04003h ;fourth dac equ dac 4 org 0h start ljmp 03h org reti 0bh org reti 013h org reti 1bh org reti org 23h lcall ser_deci reti 2bh org reti 03bh org reti ``` 043h org reti org 04bh reti org 053h reti org 05bh reti org 0100h ## start: mov sp,#07fh clr ea lcall key\_deb lcall init\_80c320 lcall init\_u4\_ppi lcall key\_deb lcall init\_u5\_ppi lcall key\_deb lcall key\_deb lcall key\_deb lcall delay\_1 lcall delay\_1 lcall clr\_ports lcall key\_deb ljmp main\_loop \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ``` init_80c320: tmod, #00100001b mov ;0001 0010 ; 0001 #016h ckcon, #017h ; mov 0110 b scon, #01010000B mov th1, #0e6H mov tl1,#0e6H mov tr1 setb ex1 clr ;setb ea setb es ret init_u4_ppi: ;port a-->i/p port b-->i/p port mov A, #0ch c-->o/p mov dptr, #ppi_u4_cw movx @dptr,A ret init u5_ppi: ;port a-->o/p port b-->o/p mov A, #003h mov dptr, #ppi_u5_cw movx @dptr,A ret clr ports: ; clears the port-a of u5 mov dptr, #ppi_u5_pa mov A, #Offh movx @dptr,A ;clears the port-b of u5 mov dptr, #ppi_u5_pb ``` ``` movx @dptr, A ret mov dptr, #ppi_u4_pc se 001: mov a, #001h movx @dptr,a ljmp adc_mod mov dptr, #ppi_u4_pc se 010: mov a, #002h movx @dptr,a ljmp adc_mod mov dptr, #ppi_u4_pc se 011: mov a, #003h movx @dptr,a ljmp adc_mod ************* mov dptr, #ppi_u4_pc se_100: mov a, #004h movx @dptr,a ljmp adc_mod mov dptr, #ppi_u4_pc se 101: mov a, #005h movx @dptr,a ljmp adc_mod mov dptr, #ppi_u4_pc se 110: mov a, #006h movx @dptr,a ``` ``` ljmp adc_mod mov dptr, #ppi_u4_pc se 111: mov a, #007h movx @dptr,a ljmp adc_mod se_000: mov dptr, #ppi_u4_pc mov a, #000h movx @dptr,a ljmp adc_mod adc_mod: mov intmed_a, #0h mov intmed_b,#0h mov intmed_c, #0h mov count, #010h temp: mov data_hi,#0h mov data_lo,#0h clr a mov dptr, #strt_conv movx @dptr,a mov data_hi, #0h mov data_lo,#0h nop lcall stil_conv mov dptr, #strt_conv ``` ``` movx a,@dptr swap a mov data_hi,a mov dptr,#lsb_rd movx a,@dptr swap a clr c ``` ``` addc a,intmed_a mov intmed_a,a mov a,data_hi addc a,intmed_b mov intmed_b,a mov a,#0h addc a,intmed_c mov intmed_c,a djnz count,temp ljmp dac_mod ``` \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* ``` loop_100: ;anlog module check routine setb p1.1 setb pl.4 setb p1.5 start_2: lcall clr_ports lcall delay_1 clr a mov dptr, #ppi_u4_pa movx a,@dptr mov R4,a lcall key_deb clr a nop movx a,@dptr xrl a,R4 jnz start_2 mov a, #0ffh mov r0,a xrl a,r4 jz se_clear mov a, #0feh mov r0,a xrl a, R4 jz se_000xx mov a, #0fdh mov r0,a xrl a,R4 ``` jz se\_001xx mov a,#0fbh mov r0,a xrl a,R4 jz se\_010xx mov a,#0f7h mov r0,a xrl a,R4 jz se\_011xx mov a,#0efh mov r0,a xrl a,R4 jz se\_100xx mov a,#0dfh mov r0,a xrl a,R4 jz se\_101xx mov a,#0bfh mov r0,a xrl a,R4 jz se\_110xx mov a,#07fh mov r0,a xrl a,R4 jz se\_111xx ljmp first ``` ***************** Stil conv: setb p3.2 repeat: nop jb p3.2, repeat ret loop_100x: ljmp loop_100 main_loop: first: clr a mov a,90h anl a, #00dh xrl a,#000h ;flashing the leds initially jz loop_000xx mov a,90h anl a, #00dh xrl a,#001h ;internal RAM check routine jz loop_001 mov a,90h anl a, #00dh xrl a,#004h ``` ``` ;external RAM check routine jz loop_010 mov a,90h anl a, #00dh xrl a,#005h ; digital module check routine jz loop_011x mov a,90h anl a,#00dh xrl a,#008h ; analog module check routine jz loop_100x mov a,90h anl a, #00dh xrl a, #009h ;serial comn check routine jz loop_101x limp first se_clear: lcall clr_ports ljmp loc_fault_dac loop 101x: ljmp loop_101 loop 010: ;external RAM check routine setb p1.1 setb pl.4 setb p1.5 lcall delay_4 ``` ``` mov dptr, #06000h ;data mov R5,#000h mov R6, #000h ;count_lo ;count_hi mov R7, #000h Lop1: mov a, R5 movx @dptr,a clr a nop nop nop movx a,@dptr clr c subb a, R5 jnz loc_fault_eramx inc r5 inc dptr mov r6, dpl mov r7, dph clr c mov a, r6 subb a, #0ffh mov a,r7 subb a, #07fh jc lop1 jmp loc_ok_eram ******************* loop_000xx: ljmp loop_000x ``` ``` loop_001: ``` ``` ;internal RAM check routine setb pl.1 setb pl.4 setb p1.5 lcall delay_4 ; COUNT mov r2,#0h mov R1,#020h mov R5,#000h ;data j1: mov a,r5 mov @R1,a clr a nop mov a, @R1 clr c subb a, R5 Jnz loc_fault_sram inc R5 inc R1 inc r2 mov a, #07fh clr c subb a, R1 jnz j1 jmp loc_ok_sram start_2x: lcall clr_ports ljmp start_2 ***************** ``` ``` xrl a,r0 jnz start 2x ljmp loc_ok_dac loc_fault_eramx: ljmp loc_fault_eram ****************** loc_fault_dac: clr p1.5 setb pl.4 setb pl.1 lcall delay 1 setb pl.5 clr p1.4 setb p1.1 lcall delay 1 setb p1.5 setb pl.4 clr pl.1 lcall delay 1 mov a, 90h anl a, #00dh xrl a,#008h jnz firstx mov dptr, #ppi_u4_pa movx a,@dptr xrl a,r0 jnz start 2x ``` mov dptr, #ppi\_u4\_pa movx a,@dptr ``` loop_000x: ljmp loop_000 loop_011x: ljmp loop_011 lcall clr_ports ljmp first loc_ok_sram: lcall flash1 mov a,90h anl a, #00dh xrl a,#001h jz loc_ok_sram ljmp first ******************* loc_ok_eram: lcall flash1 mov a,90h anl a,#00dh xrl a,#004h jz loc_ok_eram ljmp first loc ok dac: lcall flash1 mov a,90h anl a, #00dh xrl a,#008h ``` jnz firstx ``` ljmp loc_fault_dac loc_fault_sram: clr p1.5 setb p1.4 setb pl.1 lcall delay_1 setb p1.5 clr p1.4 setb pl.1 lcall delay_1 setb p1.5 setb pl.4 clr p1.1 lcall delay_1 mov a,90h anl a, #00dh xrl a,#001h jz loc_fault_sram ljmp first loc_fault_eram: clr p1.5 setb p1.4 setb p1.1 lcall delay_1 setb p1.5 clr p1.4 ``` ``` setb pl.1 lcall delay_1 setb p1.5 setb p1.4 clr p1.1 lcall delay_1 mov a,90h anl a,#00dh xrl a,#004h jz loc_fault_eram ljmp first ******************** ;flashing the LEDs initially loop 000: lcall flash ljmp first ;digital module check loop 011: routine clr pl.1 clr p1.4 setb p1.5 ; count for scanning four times mov R0,#004h start1: mov dptr, #ppi_u4_pa movx a,@dptr mov R4,a lcall key_deb ``` movx a,@dptr ``` xrl a,R4 jnz start1 mov a, R4 mov dptr, #ppi_u5_pa movx @dptr,a nxt_port: mov dptr, #ppi_u4_pb movx a,@dptr mov R4, a lcall key_deb movx a,@dptr xrl a,R4 Jnz nxt_port ---- - DA mov dptr, #ppi_u5_pb mov a, K4 movx @dptr, a updt: djnz r0, start1 ljmp first flash: p1.1 setb p1.4 setb p1.5 setb delay_1 lcall p1.1 clr p1.4 clr p1.5 clr delay_1 lcall ``` ret ``` ******************** flash1: setb pl.1 clr p1.4 clr p1.5 lcall delay 1 clr p1.1 p1.4 clr setb p1.5 lcall delay 1 clr p1.5 clr p1.1 setb p1.4 lcall delay 1 ret delay 1: mov R4, #007h 1P3: mov R3, #0ffh 1p2: mov R2,#0ffh lp1: nop djnz r2, lp1 djnz r3, lp2 djnz r4,1p3 ret delay 4: equals 45 in decimal; mov R4, #02dh LP6: ``` ``` mov R3, #0ffh 1p5: mov R2, #0ffh nop lp4: djnz r2,1p4 djnz r3,1p5 djnz r4,1p6 ret ****************** key deb: r1,#01h mov 100p3: r2,#0ffh mov loop2: r3,#0ffh mov loop1: r3,loop1 djnz djnz r2,loop2 r1,100p3 djnz ret dac mod: ljmp out_8155 dac1: clr c mov a, intmed_b subb a, #00h mov a, intmed_c subb a, #08h ``` ``` jnc comp_a ljmp dac fault comp a: clr c mov a, intmed_b subb a, #06fh mov a, intmed_c subb a, #009h jnc comp b ljmp dac_fault ******************** comp b: clr c mov a, intmed_b subb a, #028h mov a, intmed_c subb a, #00ah jc dac_ok ljmp dac_fault dac fault: ljmp loc_fault_dac mov a, #0ffh ;; mov dptr, #dac_1 ;; movx @dptr,a ;; mov dptr, #dac_2 ;; movx @dptr,a ;; mov dptr, #dac_3 ;; ``` ``` movx @dptr,a ;; mov dptr, #dac_4 ;; movx @dptr,a ;; lcall delay_4 ;; ljmp first dac ok: ljmp loc_ok_dac mov a, #0h ;; mov dptr, #dac_1 ;; movx @dptr,a ;; mov dptr, #dac_2 ;; movx @dptr,a ;; mov dptr, #dac_3 ;; movx @dptr,a ;; mov dptr, #dac_4 ;; movx @dptr,a ;; lcall delay_4 ;; ljmp first ;; out_8155: mov a, intmed_c cpl a mov conv_c, #000h clr c rlc a jc bl clr db1 ``` ``` blx: rlc a jc b2 clr db2 b2x: rlc a jc b3 clr db3 b3x: rlc a jc b4 clr db4 b4x: rlc a jc b5 clr db5 b5x: rlc a jc b6 clr db6 b6x: rlc a jc b7 clr db7 b7x: rlc a jc b8 clr db8 b8x: mov a,intmed_b cpl a mov conv_b, #000h clr c rlc a jc cl clr dc1 clx: rlc a jc c2 clr dc2 ``` ``` rlc a c2x: jc c3 clr dc3 rlc a c3x: jc c4 clr dc4 c4x: rlc a jc c5 clr dc5 rlc a c5x: јс с6 clr dc6 rlc a c6x: jc c7 clr dc7 rlc a c7x: jc c8 clr dc8 c8x: mov dptr, #ppi_u5_pa mov a, conv_c movx @dptr,a mov dptr, #ppi_u5_pb mov a, conv b movx @dptr,a lcall delay_1 lcall delay_1 ljmp dac1 ``` ``` b1: setb db1 ljmp blx setb db2 b2: ljmp b2x b3: setb db3 ljmp b3x setb db4 b4: ljmp b4x setb db5 b5: ljmp b5x b6: setb db6 ljmp b6x b7: setb db7 ljmp b7x setb db8 b8: ljmp b8x c1: setb dc1 ljmp clx c2: setb dc2 ljmp c2x ``` setb dc3 ljmp c3x c3: ``` setb dc4 c4: ljmp c4x setb dc5 c5: ljmp c5x setb dc6 c6: ljmp c6x setb dc7 c7: ljmp c7x setb dc8 c8: ljmp c8x loop_101: ;serial routine checking setb p1.1 setb p1.4 setb p1.5 lcall delay_1 lcall delay_1 mov data_hi,#0 ; COUNT mov r1,#0fh s1: mov data_hi,#0 lcall send_char ;lcall delay_s ;mov a,data_hi ;clr C ``` ``` ;subb a,r1 ;jz slcon ;ljmp loc_fault_serial :slcon: setb p1.1 lcall delay 1 lcall delay_1 djnz r1,s1 ljmp loc_ok_serial send char: sbuf,r1 wait: ti,wait jnb ti clr clr p1.1 lcall delay_1 lcall delay_1 ret serial: ri clr acc push a,sbuf mov data hi,a mov acc pop ret ``` ``` ser_deci: ;*** ri,ser_rtn_i jnb serial ljmp ser rtn_i: ti clr ri clr ret delay s : mov r2, #0ffh s2: nop djnz r2,s2 ret loc_fault_serial: clr p1.5 setb pl.4 setb pl.1 lcall delay_1 setb p1.5 clr p1.4 setb pl.1 lcall delay_1 setb p1.5 setb pl.4 clr p1.1 lcall delay_1 mov a,90h ``` end The Central Processing Unit board, which is to be tested using the Test Jig, is the controller of the machine and has a number of peripherals. Each and every line of the PCB has to be tested for its functionality by using the test jig. Different testing methods have been designed and carried out with the help of the specialized nardware and software. The different modules to be tested are - Digital module - Analog Module - External RAM - Internal RAM - Serial Communication Now our aim is that the operator who is testing the CPU board need not have a deep Knowledge about the board and the peripherals in it but still should be able to operate The test jig. The operator other than comprehending the procedure to operate the jig, should also be able to report which peripheral on the CPU board is at fault when the error is reported on the front panel. The detailed view of the front panel is shown in the figure #### Description of the Display Panel: - The display panel has 16 Light Emitting Diodes (LED's) on the first row and is named L1 L16. This representation is for the Digital Outputs. - The second row has 16 corresponding switches named S1 S16. This representation is for the Digital Inputs. - Three switches S17, S18 and S19 are provided. These switches are selection switches, which indicate the module or the peripheral to be tested. - The two LED's Txd and Rxd, which are provided, indicate the end of transmission and the end of reception. - ➤ We have a rotary switch in order to feed a channel among CH0 CH7, in the analog module. - We have a 4\*3 matrix of LED's. The LED's E1, E2 and E3 indicate the OK/ERROR condition while the peripherals are being tested. The fourth LED in the first column is used to indicate the Power on or in other words the functioning of the jig. OK condition - 2 LED's among E1, E2 and E3 glow at a time. #### ERROR condition - E1, E2 and E3 glow alternately. - The second and the third column of LED's are used to indicate the DAC outputs. The extra column of green LED's that are indicated is for the future expansion if any. - A variable Potentiometer is provided in the display board below the variable switch for future development. - At the back panel, which is provided at the back of the test jig, we have a chord that is to be connected to 230 V AC mains. - We have the ON/OFF switch and a FUSE provision provided at the back panel. #### Steps to be followed while using the Test Jig: - The chord present in the back panel has to be connected to the 230 Volts AC supply and switched ON. - Now the power supply LED is ON indicating that the jig has its supply voltage necessary. - > POST Power On Self Test - Now as soon as the main switch is ON, the 16 LED's L1 L16 are checked for their functionality. This is a default routine that has been included in the software. - They glow for a second indicating they are OK and in working condition. If in case, any one of the LED's do not glow during the POST, it is an indication that the LED is not Ok by itself and there is no problem with the functionality of the jig. The LED has to be replaced to obtain the result. - Now after the POST, initially when the S17, S18 and S19 are in the combination 0-0-0, we have the flashing of the LED's. The flashing of the LED's E1, E2 and E3 shows that no module is selected. Again in this case too, we may use this flashing as a means to check for he working of the three LED's, if one of the LED's does not glow while the combination 0-0-0 is selected, then that indicates fault of the LED and not in the functionality of the Jig. - After the flash routine, we may now select the switches according to the module to be tested. The combinations are indicated below: | S17 | S18 | S19 | Module | |-----|-----|-----|----------| | 0 | 0 | 0 | Flashing | | | 0 | 0 | Internal | | 1 | | | RAM | | 0 | 1 | 0 | External | | U | | | RAM | | 1 | 1 | 0 | Digital | | 0 | 0 | 1 | Analog | | 1 | 0 | 1 | Serial | The various modules to be tested are indicated above. The procedure for testing of the various modules is given henceforth. #### Digital Module : - We first select the combination 1-1-0 in the switches S17, S18 and S19 in order to select the digital testing module. - 2. Now the E1, E2 and E3 indicate the selected combination. The orientation of the LED's and the switches can be shown using the figure below: 3. Now that we have selected the digital combination, we may give the Digital Inputs through the switches S1 – S16, and the corresponding outputs is shown in the LED's L1 – L16. If a corresponding LED does not glow when the switch is turned on, it indicated an error in either the Digital input or the Digital output module. The error can be identified. #### > Internal RAM: - 1. The combination for the switches S17, S18 and S19 1-0-0 is selected thereby Selecting the testing of the Internal RAM module. - 2. Checking of each one of the memory locations does the testing of the Internal RAM, and if an error in a particular location is found, then immediately the check is terminated and the error is displayed. The system will abort from the loop. - 3. The E1, E2 and E3 indicate the OK/ERROR condition. #### External RAM: - 1. The combination for the switches S17, S18 and S19 0-1-0 is selected thereby Selecting the testing of the External RAM module. - 2. Checking of each one of the memory locations does the testing of the External RAM, and if an error in a particular location is found, then immediately the check is terminated and the error is displayed. The system will abort from the loop. - 3. The LED's E1, E2 and E3 indicate the OK/ERROR condition. #### Analog Module: - The combination of S17, S18 and S19 switches 0-0-1 is selected thereby Selecting the testing of the Analog module. - 2. Select the Channel 0 Channel 7 in the Rotary switch provided. - 3. The corresponding channel 0 to channel 7 should be selected in the switches S1 S8. It should be noted that the selection of the channel in the Rotary switch and the selection of the channel in S1-S8 switches should be done simultaneously, if either one is not selected at a point of time or if there is a delay in the selection of either switches, the LED's E1, E2 and E3 will indicate an ERROR condition until the switches are selected. Care should be taken that the selection of switches is done attentively in order to avoid the error shown in the LED's E1, E2 and E3 mistaken for the error in the CPU board. During the testing of the Analog module, we display the digitized 12-bit value that is the output of the ADC in the 16 LED's that are provided in the Display board. We have split the representation of the digitized value into 4, each representing one digit between the 16 LED'S. So in the display that you see in L1 – L16 using the 8421 weighted codes, we may decode the value. 4. During the testing of the channels 0-7, it is not necessary to RESET to the Initial condition in order to test a subsequent channel. The software written Is compatible to test the channels online without resetting each time. #### 80C320 CPU DEBUGGER **Default check:** Power On Self Test (POST) #### **Testing Procedure:** #### Select the switches S17, S18 and S19 to test required module | S17 | S18 | S19 | Module | |-----|-----|-----|--------------| | 0 | 0 | 0 | Flash | | 1 | 0 | 0 | Internal RAM | | 0 | 1 | 0 | External RAM | | 1 | 1 | 0 | Digital | | 0 | 0 | 1 | Analog | | 1 | 0 | 1 | Serial Comm | #### For all routines status indicated by E1, E2 and E3 LED's OK condition - 2 LED's glow at a time ERROR condition- LED's glow alternately one at a time Digital Module : - 1. Select switches S17,S18 and S19. - 2. Check for Digital OUT LED's L1-L16 by Corresponding *Digital IN's* given through switches \$1-\$16 Analog Module : - 1. Select switches S17, S18 and S19. - 2. Select Rotary switch to required channel to be Tested ranging from *CH0-CH7*. - Select the switches S1-S8 for CH0- CH7. Check E1, E2 and E3 for Ok/Error condition. During the checking of the Analog Module, we also display the corresponding Digitized value of the channel being tested which is displayed in the LED's *L1-L16*. #### The Digitized values: | Analog values | Digitized values | |---------------|------------------| | 1.7 volts | 095C h | | 2.2 volts | 09C0 h | | 2.7 volts | 0A26 h | There were a number of hurdles we had to cross to complete this project. We learnt that in the practical field, we had to spend hours trying to identify the problem and then device means to solve it. A few of the significant ones we have mentioned below: - During the testing of the Power Supply board we fabricated, we encountered a short between a screw in the heat sink and the To3 package. We were not getting the required voltage because of this, it took some time to identify the cause and then we placed a non-conducting material between the heat sinks and the IC's. - Initially during the planning phase of the fabrication of PCB's, we started out as making the PCB's through Auto Routing and Using the Photo-Filming technique. It was taking a lot of time and then we thought of the alternative of drawing it manually and etching it. - During the testing phase of our software, we noticed that our Digital Module was not working. None of the 16 outputs were reflecting in the LED's. We were constantly checking and modifying our software, but after a detailed study we found that there was a connection missing in the CPU board that they had given us to test. When we included a short in the CPU board, the Digital module worked. - During the wiring phase, we noticed that we had shorts in the circuits to a very large extent when we had completed around 10% of the wiring. We rechecked the entire connections and found no fault. We then noticed that we had not used a sleeve at the connecting points. - While writing the software, the delay calculations that we had done were not practically getting implemented. For example if we have set a 1 ms delay, while testing the Jig we would not obtain this delay. So according to the practical requirement, we changed the delay by trial and error method. - (1) The parallel checking of the modules is not supported. (i.e) not more than one of the defined modules can be checked simultaneously. - (2) The analog module to be tested has to be represented by selecting a digital switch of port A. - (3) In the serial communication module it is not possible to test both the transmission and reception of data without PC link. Hence the serial communication module can be completed only after the system is made PC enabled. - (4) In each of the modules, only error conditions can be detected and the type of error cannot be spotted. For example an error in digital module may be any of the following kind. - Total port failure - Any discontinuity in the PCB route lining - Failure of the decoder to produce chip select signals so that the chip itself may not get the signals selected. - In both the internal and external memory modules the damaged memory locations cannot be identified. This is because the memories check loop is aborted once a damaged location is encountered. - The analog channel can be fed with a fixed voltage only and it cannot be varied. The system can be interfaced with the PC by connecting the serial port of the test jig with any serial port of the PC (LPJ ports). The selection of different modules can be given as commands. For this affront end (GUI) with necessary options has to be designed. Hence as the commands are given, each command is interpreted into the signals with specific standards and transmitted serially out of the PC through the serial port to the jig. Therefore the jig firmware has to sense the given command and switch to that particular module. Once the testing of the module is completed inside the jig, the results or the status of the peripherals tested has to be transmitted back to the PC. Hence all the operations of the jig can be made PC enabled through the serial link. Once the jig system is PC enabled, the following features can be added. - (1) Readable text messages about the status information can be displayed in the PC instead of LED indications. - (2) During the checking of a module comprising a few peripheral IC's, the operation of each peripheral unit can be tracked and the online information / status about each unit can be displayed as the process dynamically goes on. - (3) While checking of the memory module (both internal and external), the check loop is made to scan through the entire range of memory locations and at the end of the check routine, in case of error, a list of damaged locations may be displayed, so that, if possible the user may use the rest of the memory locations which are not damaged. - (4) The analog module can be tested for different levels of analog voltage inputs. The project "80C320 CPU Debugger" was a success. The working model of the Test Jig is being used at Premier Polytronics Limited, Coimbatore for real-time applications. The controller board for which the Test Jig has been designed is being used in many products. This project covers the testing of all the peripherals of the Controller board with inputs provided through switches and the defects, if any, are displayed by means of LED's. This Test Jig has considerably reduced the time involved in tracking errors in the peripherals of the controller board for smooth operation of the machines. This project can be extended to have a PC interface making the system more user-friendly and effective. The end result of this PC link can be the online tracking of the PCB's in the various customer areas thereby facilitating online checking. - "High- Speed Micro controller Data Book", Dallas Semiconductors Corporation, 1995 edition. - 2. "Linear Applications Data book", National Semiconductors Corporation, 2<sup>nd</sup> edition. - 3. Power Supply Circuits, Data Book", Texas Instruments, 1996 edition. - 4. "Industry Standard Analog IC's", SGS Thompson, 1st Edition, June 1989. - 5. "Micro controllers Data Book", Amtel Corporation, 3<sup>rd</sup> edition, May 1997. - 6. "Embedded Applications, Volume 2", Intel Corporation, 1995 edition. - 7. "Microprocessor and its Applications", Ramesh Goenkar, 1996 edition. - 8. "Linear Integrated Circuits and its Applications", Roy Chowdhery, 1995 edition. ## - FEATURES - Pin-compatible 80C32—Compatible - Standard 8051 instruction set - Three 16-bit timer/counters Four 8-bit I/O ports - 256 bytes' scratchpad RAM - Multiplexed address/data bus - Addresses 64KB ROM and 64KB RAM - High-speed architecture - 4 clocks/machine cycle (8032=12) Wasted cycles removed - Single-cycle instruction in 121 ns Runs DC to 33 MHz clock rates - Uses less power for equivalent work - Dual data pointer - Optional variable length MOVX to access fast slow RAM /peripherals - High integration controller includes: - Power-fail reset - Programmable Watchdog timer - Early-warning power-fail interrupt - Two full-duplex hardware serial ports - 13 total interrupt sources with six external - · Available in 40-pin DIP, 44-pin PLCC and TOFP ### DESCRIPTION microcontroller. Wasted clock and memory cycles have result, every 8051 instruction is executed between 1.5 tal. The DS80C320 offers a maximum crystal rate of 33 been removed using a redesigned processor core. As a speed. Typical applications will see a speed improve-MHz, resulting in apparent execution speeds of 82.5 and 3 times faster than the original for the same crystar ment of 2.5 times using the same code and same crys-The DS80C320 is a fast 80C31/80C32-compatible MHz (approximately 2.5X). ## PIN ASSIGNMENT counters, serial port, and I/O ports. In short, the DS80C320 is extremely familiar to 8051 users but pro-The DS60C320 provides several extras in addition to vides the speed of a 16-bit processor. åges of the standard 80C32 and offers the same timer/ DS80C320 also provides dual data pointers (DPTAs) to port, seven additional interrupts, programmable watchdog timer, power-fail interrupt and reset. The speed block data memory moves. It can also adjust tl.e speed of cff-chip data memory access to between two and nine machine cycles for flexibility in selecting greater speed. These include a second full hardware memory and peripherals. ORDERING INFORMATION | PART NUMBER | PACKAGE | MAX CLOCK SPEED | Tewaren | |---------------|---------------------|-----------------|------------------| | DS80C320-MCG | 40 pip plootin 010 | 200000 | JEMPER JRE RANGE | | | To Dissile Dif | 25 MHz | 0°C to +70°C | | DS80C320-QCG | 14-pin PLCC | 25 MHz | C. C. C. O.O | | DS80C320-ECG | 44-pin TQFP | 25 MH7 | 2-04-01-0-0 | | DS80C32C-MNG | 40 citacla oid | 7 | 2°0/+ 0t 2-0 | | 000000000 | to pin plastic Dir | 25 MHz | -40°C to +85°C | | USBUCSZU-UNG | 44-pin PLCC | 25 MHz | Ce30: of John | | DS80C320-ENG | 44-pin TQFP | 25 MH2 | 0.00 | | DS80C320-MCI | An original and An | 7 | 2,58+012-01- | | | 40-piil plastic DIP | 33 MHz | 0°C to +70°C | | DS80C320-QCL | 44-pin PLCC | 33 MH2 | 0001 | | DS80C320-ECL | 44-pin TOFP | 11100 | 7-0/+ 01-0 | | DSB0C320_MAN | | 33 MHZ | 0°C to +70°C | | Thill ACCOUNT | 40-pin plastic DIP | 33 MHz | -40°C to 196°C | | DS80C320-QNL | 44-pin PLCC | 33 MH2 | 0 504 00 00 | | DSB0C320_END | | 20 12 | 2°58+ 01 7-04- | | TOO OF THE | 44-pin IQFP | 33 MHz | 10°C of 0°C | | | | | | DS80C320 BLOCK DIAGRAM Figure 1 mary and overview. Detailed descriptions are available in the High-Speed Microcontroller User's Guide. timing diagrams are provided below in the electrical specifications. COMPARATIVE TIMING OF THE DS80C320 AND 80C32 Figure 2 DS80C320 TIMING SINGLE BYTE SINGLE CYCLE INSTRUCTION SINGLE BYTE SINGLE CYCLE INSTRUCTION 1 00x-1CK PORT 2 AD7-AD0 PSEN ALE XTAL1 PSEN ÄE STANDARD 80C32 TIMING PCfd 2 In this updated core, dummy memory cycles have been eliminated. In a conventional 80C32, machine cycles are generated by dividing the clock frequency by 12. In the DS80C320, the same machine cycle is performed in quency. Note that these are identical instructions. A comparison of the timing differences is shown in Figure 4 clocks. Thus the fastest instruction, 1 machine cycle, 2/The majority of instructions on the DS80C320 will see the full 3 to 1 speed improvement. Some instructions Is executed three times faster for the same crystal frewill get between 1.5 and 2.4 X improvement/Note that all instructions are faster than the original 80C51/Table 2 below shows a summary of the instruction set includring the speed. a 2.5 to 1 speed improvement. Individual programs will tions used. Speed sensitive applications would make However, the sheer number of 3 to 1 improved opcodes The numerical average of all opcodes is approximately be affected differently, depending on the actual instrucbined with 0.8 µm CMOS, the recult is a single cycle code: When these architecture improvements are comthe most use of instructions that are three times (aster. makes dramatic speed improvements likely for any instruction execution in 160 ns. The Dual Data Fornter feature also allows the user to eliminate wasted instructions when moving blocks of memory. INSTRUCTION SET SUMMARY All instructions in the DS80C320 perform the same functions as their 80C32 counterparts. Their affect on bits, flags, and other status functions is identical. However, the timing of each instruction is different. This For absolute timing of real-lime events, the timing of applies both in absolute and relative number of clocks.) software loops will need to be calculated using the table run at 4 clocks per increment cycle to take advantage of mountainon to operate as before. Timers can be set to The relative time of two instructions might be different in higher speed operation. efficient design. they required the same amount of time. In the the new architecture than it was previously. For example, in the original architecture, the "MOVX A, @DPTR" instruction and the "MOV direct, direct" instruction used two machine cycles or 24 oscillator cycles. Therefore, DS80C320, the MOVX instruction can be done in two machine cycles or cight oscillator cycles but the "MOV direct, direct" uses three machine cycles or 12 oscillator parts, they now have different execution times from cycles. While both are faster than their original countercerned with precise program timing should examine the cases, the DS80C320 uses one cycle for each byte. The user contiming of each instruction for familiarity with the changes. Note that a machine cycle now requires just Many instructions require only one cycle, but some four clocks, and provides one ALE pulse per cycle. require five. In the original architecture, all were one or each other. This is because in most wo cycles except for MUL and DIV. # VINSTRUCTION SET SUMMARY Table 2 Legends: Internal Register poin!ed-to by R0 or R1 2's complement offset byte 16-bit destination address 11-bit destination address Internal Register address direct bit-address Register R7-R0 (except MOVX) 16-bit constant 8-bit constant Accumulator #data 16 addr 16 addr 11 direct #data (a) Æ ē ξ | Color Colo | | | ! | | | | | | r Seleciable | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------|----------------|----------------|----------------------------|----------------|----------------|---------------------------------------------------| | 1 | | | | | | | es<br>8<br>12 | 21 02 05 | V & H, orect<br>V & Ri, #data<br>V DPTR, #data 16 | | 1 | | | | च | - | XCHD A, @Ri | 5 -1 | e - | V direct, #data<br>V G Ri, A | | 1 | | | | ю 4 | v | XCH A, @ Hi | l m | 01 0 | Vidirect, @ Ri | | 1 NV Chen 1 4 SEFBC 1 4 CPL CP | | | | → a | o | XCH A, Rn<br>XCH A, direct | به <u>د</u> | √ m | V direct1, direct2 | | 1 1 1 2 2 2 2 2 2 2 | | | | - ω | 2 | POP direct | თ, ი | 00 | V direct, A | | 1 | | <b>-</b> | | 9 80 | - 21 | PUSH direct | ო | 2 | V Rn. ≠data | | 1 | able speed MCVX instruction as described below | #Opcodes Speed Improvement | | 85-9 | | MOVX @DPTR. A | r sv | - 61 | W Rn. direct | | 1 | Notice above, an instruction cycle requires four clocks. Data memory (RAM) is accessed accessed | SPEED ADVANTAGE SIIMMABY | ····· | 8-36 | - | MOVX A, @DPTR | no = | CJ | ov A, ≃data<br>ov Rc. A | | 1 | crystal frequency and the actual instructions. As men- | . Selow. | | 8-36 | | 1:10VX A, @Ri | -1 | - | VA, GRI | | 1 2 5 INCRN | (ROM) is accessed at a fixed rate determined by the | Speed improvement stimmary is provided any system. The | ····· | ī 5 | | 1,10VC A, @A+PC | m | 63 | V A, airect | | NIC Rn | nection is shown in Figure 3. Timing diagrams are provided in the Electrical Specifications. Princip manner | the large total number that receive a 3 to 1 improvement assure a dramatic speed in contract. | | ç | - | A.OVCA @AADPTR | -1 | - | itructions:<br>)V A. Rn | | 1 | accessed using the multiplexed address/data bus on P0 and the MSR address on polytests. | than the original 80C32. While a system that empha- | | 4 | - | SIVIA A MANUS | | | to Transfer | | SETBC 2 SING Ring 1 4 NINC GRING 2 6 6 6 6 6 6 6 6 6 | bytes of scratchpad RAM. Off-chip memory is | tions. Of the 255 opcodes, 159 are three times frace. | | . 4 | | P.B.C. A | 12 | က | AL direct, #data | | SETBC 1 | The DS80C320 contains no on-chip ROM and 256 | tiple opcodes. There are 255 percent for the instructions have multiple opcodes. | | : 47 | - + | AR A | ю | 5 | RL direct, A | | NC GRN | MEMORY ACCESS | The table above shows the speed for each class of | | 4 4 | | HL A<br>RLC A | <b>1</b> ω | - 0 | RL A, =data | | SETBC 2 NNCRN | | | | 4 | | CPLA | σ, | ۰ ۲۵ | ال A, direct<br>الم محة: | | NO Greet 2 NIN Chin 1 4 No Greet 2 6 APIL C, bit 2 | | 7 | | 1 | ) <del>.</del> | CLRA | 4 | - | al A, Rn | | 1 | | cu m | | α <u>C</u> | vη | XRL direct, #data | ,<br>51 | n (n) | AL direct, #data | | 1 | . ຕ | - CV ( | | οο c | 01 0 | XBL direct A | ာတ | 2 2 | AL direct, A | | 1 | ကြေ | α | | 4 | - ( | XALA, @Ri | -) a | - 0 | ALA, #data | | 1 | 2 - | A+DPTR 1 | | - 60 | 8 | XRL A, direct | ω. | 7 | AL A, direct | | 2 8 INC Rn 1 4 | - 01 | en « | N | 4 | - | XBL A. Rn | 7 | - | VL A, Rn | | 2 8 INC Rn 1 4 ANL C, bit 2 8 3 1 4 ANL AB 1 2 8 ANL Addr. rel 3 1 1 4 ANL AB 1 2 ANL Addr. rel 3 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | C1 6 | | 1 | - | | | | ogical Instructions: | | 2 8 INC Rn 1 4 | <b>თ</b> ო | - | | 20 | | OA A | # co | - 01 | JBB A, ≇data | | NCRN | | ) <del></del> | · | 20 | - | MUL AB | ю <del>-</del> | ν - | UBB A. @Bi | | NCRN | m | L addr 16 3 | | 4 | - | DEC @F. | 4 0 | <del>-</del> c | UBB A direct | | 2 8 INCRN 1 4 SETBC 1 4 ANLC, bit 2 1 4 ORLC, bit 2 2 8 INC @Ri 1 4 ORLC, bit 2 2 8 ORLC, bit 2 1 4 ORC, bit 2 2 1 4 OCC, bit 2 2 2 8 OCC, bit 2 2 8 MOV C, bit 2 2 8 MOV bit, C 2 2 8 OCC, bit 2 2 8 MOV bit, C 2 2 1 4 OCC, R 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | c | | † 00 | 01 | DEC direct | 80 | 2 | DDC A, #data | | SETBC ANL C, bit 2 3 | | Program Branching | | 4. 4 | | DEC Ph | , 4 | · – | DDC A, GRI | | 2 9 INC Rn 1 4 SETBC 2 8 ANL C, bit 2 1 4 ORL C, bit 2 1 4 ORL C, bit 2 8 INC GRB, 1 4 ORL C, bit 2 1 4 ORL C, bit 2 1 4 MOV 3 | 1 0 | 2 | - | <br><u>~</u> . | | DEC A | t a. | - 2 | DDC A, direct | | 2 9 INC Rn 1 4 SETBC 2 8 ANI-C, bit 2 1 4 ONI-C, bit 2 1 4 ONI-C, bit 2 1 4 ONI-C, bit 2 1 4 ONI-C, bit 2 1 4 ONI-C, bit 2 1 4 ONI-C, bit 2 1 1 4 ONI-C, bit 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 7 | - | | 4 | <del>-</del> , | INC GH | ο 4 | v - | DDC A. Rn | | 2 9 INCRn 1 4 . SETBC 1 1 ANILO, bit 2 | CV CV | . 7 | | 80 | 2 | INC direct | 4 ( | ·- ( | OD A, GRI | | | વ વ વ | | | 4 | - | INC H | တ | 2 | (DD A, direct | - 3. I/O devices or registers - 4. Control logic - 5. Chip Select logic - 6. Bidirectional data bus - 7. Handshake signals and Interrupt logic الفريور بالرياسة أراأي الأعسا A programmable I/O device is programmed by writing a specific word, called the control word, according to the internal logic; its status can be verified by reading the status register. This I/O device can be expanded to include elements such as multiple I/O ports, counters, and parallel-to-serial registers. The programmable devices used in the Intel SKD-85 system—the 8155/8156, the 8355 (or 8755), and the 8279—are described in detail in the next sections. #### THE 8155/8156 AND 8355/8755 MULTIPURPOSE PROGRAMMABLE DEVICES The 8155 and the 8355 are two multipurpose programmable devices specifically designed to be compatible with the 8085 microprocessor. The ALE, $IO/\overline{M}$ , $\overline{RD}$ , and $\overline{WR}$ signals from the 8085 can be connected directly to these devices; this eliminates the need for external demultiplexing of the low-order bus AD7-AD0 and generation of the control signals such as MEMR, MEMW, IOR, and IOW. The 8155 includes 256 bytes of R/W memory, three I/O ports, and a timer. The 8156 is identical with the 8155, except that the 8156 requires Chip Enable (CE) active high. The 8355 includes 2K of ROM and two I/O ports. The 8755 is similar to the 8355, except that the 8755 is EPROM. The programmable I/O sections of these devices are illustrated in the following sections. #### 14.21 THE 8155/8156 PROGRAMMABLE I/O PORTS AND TIMER The 8155/8156 is a device with two sections: the first is 256 bytes of R/W memory, and the second is a programmable I/O. Functionally, these two sections can be viewed as two independent chips. The I/O section includes two 8-bit parallel I/O ports (A and B), one 6-bit port (C), and a timer (Figure 14.5). All the ports can be configured simply as input/ output ports. Ports A and B also can be programmed in the handshake mode, each port using three signals as handshake signals from port C. The timer is a 14-bit down-counter and has four modes. Pins PA, PB, and PC, shown in Figure 14.5, correspond to ports A? B, and C. and the internal and included eleganism of the edge and the parish oues is called ACK (Acute) is seen of its (second) airs cells: #### CONTROL LOGIC The control logic of the 8155 is specifically designed to eliminate the need for externally demultiplexing lines AD7-AD0 and generating separate control signals for memory and I/O. Figure 14.5 shows five control signals; all except the Chip Enable (CE) are input signals directly generated by the 8085. rwiczeńsar je staw s 5 18<sub>24</sub> 25 □ CE—Chip Enable: This is a master Chip Select signal connected to the decoded high- 8155 Pin Configuration and Block Diagram SOURCE: Intel Corporation, Embedded Microprocessors (Santa Clara, Calif.: Author, 1994), p. 1-31. it with charle bas rated floor of the research $\Box$ IO/M—When this signal is low, the memory section is selected, and when it is high, the I/O section (including timer) is selected. ារី ណីការណ៍ សំ សារវត្តិប្រកាស**នាសាសសារ**ិស្សាក្សា ស្នេចប្រកាស - ☐ ALE—Address Latch Enable: This signal latches the low-order address AD<sub>7</sub>-AD<sub>0</sub>, and edi- CE, and IO/M into the chip are an and are accessed and enumered. - □ RD and WR—These are control signals to read from and write into the chip registers and memory. - ☐ RESET—This is connected to RESET OUT of the 8085 and this resets the chip and initializes I/O ports as input: 21 Occasions root a supplement Oil server to 4. Read the state, register, if accessery, to verify the state to the HO portulate the time #### THE 8155 I/O PORTS la simple apprecadons un sup in a concessar; The I/O section of the 8155 includes a control register, three I/O ports, and two registers for the timer (Figure 14.6). The expanded block diagram of the I/O section (Figure 14.6) represents a typical programmable I/O, as discussed in Section 14.12. In that section, two address lines plus the Chip Select logic were used to determine port addresses. The 8155 I/O section requires three address lines—AD2 to AD0 (A2-A0 internally)—and the Chip Application Note 74 1ctioning Comparators luad of Independently 1139/LM239/LM339 family of devices is a monolithic independently functioning comparators designed to e needs for a medium speed, TTL compatible comfor industrial applications. Since no antisaturation are used on the output such as a Baker clamp or typically 0.5 nA. This makes the device ideal for applications where it is desired to switch a node to tive circuitry, the output leakage current in the OFF DUCTION T. M. Frederiksen shown in Figure 3. Current sources I<sub>3</sub> and I<sub>4</sub> are added to and Q4 to improve the slew rate of the input stage. Diodes help charge any parasitic capacitance at the emitters of Q, $\mathsf{D}_1$ and $\mathsf{D}_2$ are added to speed up the voltage swing at the emitters of Q<sub>1</sub> and Q<sub>2</sub> for large input voltage swings. on Input signal polarity. It can easily be seen that operation With both inputs at ground potential, the emitters of $\mathsf{O}_1$ and $\mathsf{Q}_4$ will be at one VBE above ground and the emitters of $\mathsf{Q}_2$ with an input common mode voltage of ground is possible. and Q<sub>3</sub> at 2 V<sub>BE</sub>. For switching action the base of Q<sub>5</sub> and $Q_{6}$ need only go to one VBE above ground and since $Q_{2}$ and Q3 can operate with zero volts collector to base, enough voltage is present at a zero volt common mode input to insure comparator action. The bases should not be however, to prevent forward biasing a substrate diode which would stop all comparator action and possibly damage the taken more than several hundred millivolts below ground, Figure 2 shows the comparator with the output stage added, Additional voltage gain is taken through $Q_7$ and $Q_8$ with the collector of Q<sub>8</sub> lett open to offer a wide variety of possible applications. The addition of a large pull-up resistor from the collector of Qa to either $\pm V_{CC}$ or any other supply up to 36V both increases the LM139 gain and makes possible output switching levels to match practically any application. Several outputs may be tied together to provide an ORing function or the pull-up resistor may be omitted entirely with the comparator then serving as a SPST switch to ground. device, if very large input currents were provided. atures include single supply, low voltage operation while leaving it totally unaffected in the OFF state. nput common mode range from ground up to ap- ctor so it may be used with a pull-up resistor and a output supply to give switching levels from any ely one voit below Vcc. The output is an uncommit- p to 36V down to a VCE SAT above ground (approx. sinking currents up to 15 mA. In addition It may be single pole switch to ground, leaving the switched flected while in the OFF state, Power dissipation ir comparators in the OFF state is typically 4 mW hows the basic input stage of one of the four rs of the LM139. Transistors O<sub>1</sub> through O<sub>4</sub> make Jarlington differential input stage with $\mathsf{Q}_{\mathsf{S}}$ and $\mathsf{Q}_{\mathsf{G}}$ give single-ended output from differential input s in gain. Any differential input at $Q_1$ and $Q_4$ will d causing Qe to switch OFF or ON depending gle 5V supply (1 mW/comparator). DESCRIPTION TUH/7385-3 Biasing for current sources 1, through 14 is shown in Figure 4. When power is first applied to the circuit, current flows through the JFET $\mathsf{O}_{13}$ to bias up diode $\mathsf{D}_{5}.$ This biases transistor Q<sub>12</sub> which turns ON transistors Q<sub>9</sub> and Q<sub>10</sub> by allowng a path to ground for their base and collector currents. FIGURE 3. Complete LM139 Comparator Circult TJH/7385-4 FIGURE 4. Current Source Blasing Circuit Current from the left hand collector of Qg flows through diodes D<sub>3</sub> and D<sub>4</sub> bringing up the base of Q<sub>11</sub> to 2 V<sub>BE</sub> above ground and the emitters of $O_{11}$ and $O_{12}$ to one $V_{BE},\, G_{12}$ will then turn OFF because its base emitter voltage goes to zero. This is the desired action because $Q_{\theta}$ and $Q_{10}$ are TL/H/7385-2 Output transistor $Q_{\theta}$ will sink up to 15 mA before the output put current sink capability may be boosted by the addition of ON voltage rises above several hundred miliivolts. The out- TL/H/7385-1 3URE 1. Basic LM139 Input Stage a discrete transistor at the output. FIGURE 2. Basic LM139 Comparator biased ON through Q11, D3 and D4 so Q12 is no longer needed. The "bias line" is now sitting at a VBE below + V<sub>CC</sub> which is the voltage needed to bias the remaining current sources in the LM139 which will have a constant bias regardless of $\pm V_{CC}$ fluctuations. The upper input common mode voltage is V<sub>CC</sub> minus the saturation voltage of the current sources (appoximately 100 mV) minus the 2 VBE of the input devices $Q_1$ and $Q_2$ (or $Q_3$ and $Q_4$ ). pull-up resistor should be chosen high enough so as to Figure 5 shows a basic comparator circuit for converting low level analog signals to a high level digital output. The output avoid excessive power dissipation yet low enough to supply enough drive to switch whatever load circuitry is used on the comparator output. Resistors R<sub>1</sub> and R<sub>2</sub> are used to set the input threshold trip voltage (VREF) at any value desired within the input common mode range of the comparator. # COMPARATORS WITH HYSTERESIS FIGURE 5. Basic Comparator Circuit TUH/7385-5 The circuit shown in Figure 5 suffers from one basic drawback in that if the input signal is a slowly varying low level signal, the comparator may be forced to stay within its linear region between the output high and low states for an undesireable length of time. If this happens, it runs the risk of oscillating since it is basically an uncompensated, high gain FIGURE 6. Comparator with Positive Feedback to Improve Switching Time shows a comparator with a small amount of positive feed. back. In order to insure proper comparator action, the components should be chosen as follows: RPULL:UP < PLOAD and R<sub>1</sub> > R<sub>PULL-UP</sub> This will insure that the comparator will always switch fully back. The amount of feedback is chosen arbitrarily to insure up to + Vcc and not be pulled down by the load or feed- proper switching with the particular type of input signal ייבי ווום ווואמוווות ווחחו מספי tower tribut trip vottage, VA2, is now defined by: reference input (V<sub>IN</sub> > V<sub>REF</sub>). This will drive the towards ground which in turn pulls VREF down Since VREF is actually the noninverting input to rator, it too will drive the output towards ground $V_{A2} = \frac{+ V_{CC} R_2 \| R_3}{R_1 + R_2 \| R_3}$ a fastest possible switching time regardless of ne input moves. If the input then travels down to same procedure will occur only in the opposite suring that the output will be driven hard towards teresis in the feedback loop of the comparator re use, however, than simply as an oscillation It can be made to function as a Schmitt trigger able trigger points. A typical circuit is shown in gain, the hysteresis is achieved by shifting the oltage at the positive input when the output voltnges state. This network requires only three res referenced to the positive supply + V<sub>CC</sub> of the This can be modeled as a resistive divider, R<sub>1</sub> ely connected to + V<sub>CC</sub> or ground, paralleling Re. To analyze this circuit, assume that the VA2 = R1 R2 + R1 R3 + R2 R3 + VCC R2 R3 We can then obtain an expression for R2 from equation (1) which gives The following design example is offered: ALOAD = 100 kn $V_{A1} = +10V$ Given: V+ = +15V $V_{A2} = +5V$ <u>8</u> When the input voltage, V<sub>IN</sub>, decreases to V<sub>A2</sub> or lower, the output will again switch high. The total hysteresis, AVA, pro- ල To insure that Vo will swing between + Vcc and ground, AVA A R1 R2 + R1 R3 + R2 R3 + Vcc R<sub>1</sub> R<sub>2</sub> $\Delta V_A = V_{A1} - V_{A2}$ or, subtracting equation 2 from equation 1 vided by this network is defined by: R<sub>PULL</sub>.υρ < 100 kΩ From equation (4) RPULL-UP < RLOAD To find: R1, R2, R3, RPULL-UP Solution: so let RPULL.UP = 3 KM ₹ RPULL-UP < RLOAD and R<sub>3</sub> > RPULL-UP $R_3 > 100 \, k\Omega$ R<sub>3</sub> > R<sub>LOAD</sub> $H_3 = 1 M\Omega$ From equation (5) so let Heavier loading on RPULL-UP (i.e. smaller values of $\mathsf{R}_3$ or RLOAD) simply reduces the value of the maximum output ing the value of VAt. For simplicity, we have assumed in the above equations that Vo high switches all the way up to voltage thereby reducing the amount of hysteresis by lower- 3, Vin, at the inverting input is less than VA. With e output will be high $(V_O = +V_{CC})$ . The upper tage, VA1, is defined by: ween +Vcc and ground with the third resistor, 10 - 5From equation (7) $n = \frac{\Delta V_A}{V_{A2}} = \frac{1}{1}$ R<sub>1</sub> = n R<sub>3</sub> and since this gives To find the resistor values needed for a given set of trip points, we first divide equation (3) by equation (2). This gives us the ratio: Ξ $V_{A1} = \frac{+ V_{CC} R_2 (R_1 + R_3)}{R_1 R_2 + R_1 R_3 + R_2 R_3}$ VA1 = (R1 | R3) + R2 The circuit shown in Figure 8 is a non-inverting comparator $A_2 = \frac{A_3 = 1 \text{ M}\Omega}{10} = 1 \text{ M}\Omega$ These are the values shown in Figure 7. From equation (8) <u>@</u> Ele /A2 1+ R<sub>3</sub> + R<sub>2</sub> ē Again for analysis, assume that the input voltage, V<sub>IN</sub>, is low output to switch, V<sub>IN</sub> must rise up to V<sub>IN 1</sub> where V<sub>IN 1</sub> is so that the output, Vo, is also low (Vo = GND). For the VREF as Vo changes between + V<sub>CC</sub> and ground. (9) + V<sub>CC</sub> - 1 $\mathsf{R}_2 = \frac{\mathsf{R}_1 \, \mathsf{I\!\!I} \, \mathsf{R}_3}{\mathsf{R}_3}$ he trip voltage, VA, at the positive input is shifted about 8 uvA = n 6 As soon as Vo switches to + Vcc, VA will step to a value VA = VIN + (VCC - VIN 1) R1 VIN 1 = VREF (R1 + R2) greater than VREF which is given by: 30 To make the comparator switch back to its low state (Vo = GND) VIN must go below VREF before VA will again equal VREF. This lower trip point is now given by: A<sub>1</sub> + R<sub>2</sub> The hysteresis for this circuit, AVIN, is the difference be-AVIN = VIN1 - VIN2 = tween VIN 1 and VIN 2 and is given by: Ē VIN 2 = VREF (R1 + R2) - VCC R1 VREF (R1 + R2) VREF (R1 + R2) - VCC R1 R $\Delta V_{IN} = \frac{V_{CC} R_1}{1}$ As a design example consider the following: ŏ (12) Again choose Rpull-UP < ALOAD to minimize loading, so To find: VREF, R1, R2 and R3 Given: RLOAD = 100 kn + V<sub>CC</sub> = 15V V<sub>IN 1</sub> ≈ 10V Vin 2 = 5V Solution: VIN = 7.5V RPULL-UP = 3 KA 10 - 5 $\frac{R_1}{R_2} = \frac{\Delta V_{IIV}}{V_{CC}}$ 5 Vaef = -/AEF = --3 B From equation (12) -rom equation (9) FIGURE 8. Non-Inverting Comparator with Hysteresis TL/H/7385-7 FIGURE 7, Inverting Comparator with Hysteresis NO HIGH + +