# Microcontroller Based Analog Signal Tester #### PROJECT REPORT Submitted by E. MALAR S. SUBATHRA N. SATHEESH KUMAR R. BABU Guided by Mrs. N. KALAIARASI. BE. IN PARTIAL FULFILMENT OF THE REQUIREMENTS FOR THE AWARD OF THE DEGREE OF BACHELOR OF ENGINEERING IN ELECTRICAL & ELECTRONICS ENGINEERING OF THE BHARATHIAR UNIVERSITY DEPARTMENT OF ELECTRICAL & ELECTRONICS ENGINEERING ## Kumaraguru College of Technology COIMBATORE - 641 006. ## DEPARTMENT OF ELECTRICAL AND ELECTRONICS ENGINEERING ## KUMARAGURU COLLEGE OF TECHNOLOGY **COIMBATORE -641 006** ## **CERTIFICATE** This is to certify that the report entitled #### Microcontroller Based Analog Signal Tester has been submitted by | 2.25 | | |------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mr./Ms. <u> </u> | State of the | | | | | In partial fulfilment for the | award of Bachelor of Engineering in | | Electrical and Electrical | onics Engineering Branch of | | Bharathiar Univers | ity, Coimbatore - 641 046. 4/5 (78 | | during the ac | ademic year 1997/98 | | $\sim$ | Dr. K. A. PALANERSMANNE, DEM Solvenger To | | 125000 | Professor and time: | | Guide | Department of Electrical and Decision is togeness of Head of the Department . Kumaragura College of recomment. | | | Colembatics 60 (for | | Date : > [4] C | | | Certified that the candidate was example | mined by us in the project work Viva-Voce | | Examination held on | and the University Register Number | | was | | | | | | • | | | | | | Internal Examiner | External Examiner | ## **PR-MIER** #### **CERTIFICATE** This is to certify that the following students of KUMARAGURU COLLEGE OF TECHNOLOGY, Coimbatore, of Electrical & Electronics Engineering - E. Malar - S. Subathra - N. Satheesh kumar - R. Babu had undertaken their project entitled "Microcontroller Based Analog Signal Tester", from September '97 to March '98 at our industry and have successfully completed it. Their performance during the period was found to be good. We wish them all success. Place: Coimbatore Date: 24.03.98 A.G. Raghunath Project Manager #### **Industry Seal** Premier Polytronics Limited 304, TRICHY ROAD SINGANALI UR FOST COIMBATORE-641 005. #### ACKNOWLEDGEMENT We record our sincere thanks and profound gratitude to our beloved lecturer Mrs.N.KALAIARASI B.E., M.I.S.T.E., who helped and inspired us right from the time of inception to completion of the project. We are elated to record our heartiest indebtedness to our Professor and Head of the Department of Electrical and Electronics Engineering Dr.K.A.PALANISWAMY M.Sc., (Engg.), Ph.D., M.I.S.T.E., C.Eng.(I), F.I.E., for his valuable help and encouragement during this project. We have great pleasure in expressing our gratitude to the Principal Dr.S.SUBRAMANIAN M.Sc.,(Engg.), Ph.D., S.M.IEEE...for this valuable encouragement. We acknowledge with gratitude, M/s PREMIER POLYTRONICS LTD., Coimbatore, for having sponsored our project and providing all the facilities to do the project. We are thankful to Mr.A.G.RAGHUNATH, PROJECT MANAGER - R&D, Premier Polytronics Ltd., for motivating us to do the project and helping us a lot with constant encouragement. We are also indebted to Mr.M.DEVENDRAN. ASSITANT ENGINEER - R&D, Premier Polytronics Ltd., for his immense help. We also wish to acknowledge our sincere thanks to all the **staff members** of the ELECTRICAL AND ELECTRONICS ENGINEERING DEPARTMENT for their valuable help. We are very much thankful to our friends for having helped us in many ways during the course of the project. #### SYNOPSIS Quality management and market leadership are the primary motto of current industrial scenario. Digital technology has paved way for developing methods to produce elegant products by which quality assurance of products can be guaranteed. This method of quality assurance is extended to reduce time span and fatigue of workers, as time and energy are two non - renewable resources of mankind. This project elucidates one such test- jig for the YARN QUALITY MONITOR. Yarn Quality Monitor is a textile machinery which continuously monitors the quality of yarn. This jig is designed and fabricated for L1 module of this Yarn Quality Monitor which collects the data regarding the quality of yarn and test to achieve the required quality. Our ANALOG SIGNAL TESTER being Microcontroller based uses 80C32 Microcontroller (ROMless Version) and has an efficient software which test this PCB at a high speed. Thus the commercial Yarn Quality Monitor in large numbers can be easily tested using this Analog Signal Tester. ## **CONTENTS** PAGE NO. | CERTIF | ICA | TE | | |--------|-----|--------------------------------------|----| | ACKNO | WL | EDGEMENT | | | SYNOP | SIS | | | | CONTE | NTS | | ч | | | | | | | CHAPT | ER- | 1 | | | | 1. | INTRODUCTION | ·: | | | 1.1 | INTRODUCTION TO YARN QUALITY MONITOR | 2 | | | 1.2 | L1 MODULE DESCRIPTION | 3 | | CHAPT | ER- | 2 | | | | 2. | HARDWARE DESCRIPTION | | | | 2.1 | 8279 PROGRAMMABLE KEYBOARD DISPLAY | | | | | INTERFACE | | | | 2.2 | DECODER | Ž) | | | 2.3 | MICROCONTROLLER | 8 | | | 2.4 | LATCH | ÷. | | | 2.5 | EPROM | 10 | | | 2.6 | STATIC RAM | 11 | | | | | PAGE NO. | |------|------|-------------------------------|----------| | | 2.7 | VOLTAGE COMPARATOR | 12 | | | 2.8 | WATCH DOG TIMER | 12 | | | 2.9 | DIGITAL CARD | 12 | | | 2.10 | POWER SUPPLY | 13 | | | 2.11 | LOGIC DIAGRAM DESCRIPTION | 13 | | | 2.12 | TESTING PROCEDURE | 14 | | | | | | | CHAP | TER- | -3 | | | | 3. | 8032 DESCRIPTION | 19 | | | 3.1 | INTRODUCTION | 19 | | | 3.2 | HARDWARE FEATURES OF 8032 CPU | 20 | | | 3.3 | INTERRUPTS | 24 | | | 3.4 | PORT DETAILS | 27 | | | 3.5 | SERIAL INTERFACE | 28 | | | | | | | CHAP | TER- | -4 | | | | 4. | DIGITAL CARD DESCRIPTION | 33 | | | 4.1 | INTRODUCTION | 33 | | | 4.2 | 80C196 DESCRIPTION | 33 | | | 4.3 | SERIAL PORT | 37 | | | 11 | A/D CONVERTER | 38 | | | | PAGE NO. | |---------|-------------------------------|----------| | 4.5 | EXTERNAL MEMORY | 39 | | 4.6 | GAIN LATCHES | 39 | | 4.7 | 7 DIGITAL TO ANALOG CONVERTER | 49 | | | | | | CHAPTER | R-5 | | | 5. | SOFTWARE | 42 | | 5.1 | 1 ALGORITHM | 42 | | 5.2 | 2 FLOW CHART | 44 | | 5.3 | 3 PROGRAM | 50 | | | | | | CHAPTE | R-6 | | | 6. | CONCLUSION | 62 | | | | | | REFERE | NCES | | | APPEND | IX . | | . #### **CHAPTER-1** #### 1.INTRODUCTION ANALOG SIGNAL TESTER is basically a testing instrument. This is used to test the PCB of the YARN QUALITY MONITOR. The PCB to be tested has eight similar channels. Hence a testing equipment designed for one channel can be used for all eight modules. The modules to be tested is selected using the corresponding latch. This system consist of electronic circuits like keyboard display interface, decoder, latch etc., microcontroller and a keyboard display card. Through the keyboard the input parameters such as voltage, gain and the channel to be tested are fed in. The keyboard display interface feeds the data to the digital card through 8032 microcontroller. The digital card which is used for serial communication receives the data, selects the channel to be tested and sets the voltage and gain correspondingly. The output signal from the PCB is verified and the result is displayed accordingly. ## 1.1INTRODUCTION TO YARN QUALITY MONITOR The process of yarn making consists of converting a stock of fibre into yarn. During conversion forming a long strand of aligned fibres is called as SLIVER. Sliver is twisted to form yarn. This Yarn Quality Monitor is placed in the stage of conversion of sliver to yarn. This is used to monitor the quality of the yarn. Yarn Quality Monitor consists of the following four modules. - 1. L0 Module - 2. L1 Module - 3. L2 Module - 4. L3 Module #### LO MODULE: L0 Module is a sensor module. It consists of capacitive sensors to sense the quality of the yarn. #### L1 MODULE: L1 Module does the data collection and processing. It collects the output of the L0 Module as data and processes it. #### L2 MODULE: L2 Module displays the processed output of L1 Module. The quality of the yarn is displayed at various instants. #### L3 MODULE: L3 Module is used to interface the yarn quality monitor to personal computer. A personal computer can control 15 such yarn quality monitors. Out of this four Modules the complete processing of the data is done by L1 Module. Hence this plays a vital role in determining the quality of the yarn. Failure of any components in this Module leads to drastic errors. To eradicate this problem the performance of this Module has to be tested initially. #### 1.2 L1 MODULE DESCRIPTION: This module has eight similar channels of analog circuits. A single channel can be divided in to the following three stages. - 1. Offset Null Stage - 2. Gain Stage - 3. Clipper Stage #### **OFFSET NULL STAGE:** It consists of an opamp operating in differential mode. In differential mode the output of opamp is the difference of the two input signals. The inputs to the opamp are from a sensor and a DAC. In any opamp the output offset voltage is the voltage at the output with no input signals applied. If this is not nullified, this gets added up with the actual output. To nullify the output offset voltage following procedure is adopted. - The output of the opamp is read with the input points grounded i.e., the input from the sensor and DAC is grounded. - The DAC is set to the value of the output obtained. By this the accumulation of error voltage is eliminated. #### **GAIN STAGE:** This stage amplifies the output signal of the offset null stage. As the input from the sensor is in the range of millivolts, any change in the yarn quality cannot be determined accurately. Therefore this weak signal should be amplified appropriately. Gain for which the signals should be can be varied by the user, through microcontroller and latches. #### **CLIPPER STAGE:** Microcontroller can read only the signals of voltage ranging from 0 - 5V. Any signal beyond this limit is excluded. To avoid this, any signal which is below 0V is grounded through diode D1 and the signals above 5V is directed to Vref through diode D2. Thus only the signals from 0 - 5V is allowed to enter microcontroller. The circuit diagram of the L1 module is shown in figure 1.1. HOLD BLOCK DIACRAM OF LI MODULE #### CHAPTER - 2 #### HARDWARE DESCRIPTION ## 2.1 THE 8279 PROGRAMMABLE KEYBOARD/DISPLAY INTERFACE: It is a keyboard display interface. It is used to interface the keyboard and seven segment display to 8032. The keyboard segment of 8279 can be connected to a 16-contact key matrix through scan and return lines. The channel to be tested, voltage and the gain are fed in through the keyboard in the following format. | С | X1 | G | X2 | V | Х3 | |---|----|---|----|---|----------| | | | | | | <u> </u> | C : Channel X1 : Numbers from 0 - 7 (Channel number) G : Gain X2 : Numerical value of gain V : Voltage X3 : Numerical value of voltage. This data is stored in the FIFO RAM of 8279 to be read by 8032. The output data to be displayed from microcontroller is stored in display RAM. This is then displayed in the six character, seven segment display. #### 2.2 DECODER [74LS138]: This is a 3-8 bit decoder. This is employed in interfacing the Keyboard Display interface (8279) with 80C32. The decoder is a logic circuit that identifies each combination of the signals present at its input. The 74LS138 has three input lines and eight active low output lines. It requires three enable inputs. Two are active low and one is active high. All three enable lines should be activated so that the device can function as a decoder. The address lines A13, A14, A15 of the microcontroller are the input lines to the decoder1. The memory map of RAM ranges from 0000H to 7FFFH. For various combinations of A13, A14 and A15 the RAM is selected. The decoder circuit diagram is shown in fig 2.3. Decoder2 is used to select 8279. The address lines A9, A10, A11 are used as input lines. The memory map of 8279 ranges from E400H to E5FFH. The output of the decoder is connected to the chip select pins of RAM and 8279. When chip select is low, the output lines go into the high impedance state. Then the 8279 or RAM is activated. ## 2.3 MICROCONTROLLER [ 80C32 ]: The purpose of this chip is to execute the users program instruction by executing a series of its microinstructions there by controlling data transfer and all functions from computed results. The microcontroller has two 16 bit timers. The timers are versatile and can be used for A/D conversion, pulse width measurement and frequency counting. They can also act as counters. Signa pulses from transducers like phototransistors could be conventionally counted. The UART in 8032 enables it to transmit and receive serial data from other devices like CRT terminal, computer and printer. Two interrupts are allowed from external sources. There is a free I/O port available in 8032 in addition to three other ports. But 8032 uses these ports for external memory since it has no in-built EPROM or ROM. Nevertheless it saves a lot of hardware. Moreover any bit of a port can be read by the software or toggled or processed. The microcontroller serves as a bit processor, because it has instructions to deal with a bit and thus can do Boolean logic functions more conveniently. The 8032 has a low power mode in which its internal RAM and registers can be retained with low battery power. ## 2.4 LATCH [ 74LS573 ] : The latch is employed to demultiplex the address/data iines. During transfer of data from memory to the controller, the higher order address remains on the bus. However the lower order address bits will be lost after the first T-state. Hence the need for address to be latched and used for identifying the memory address. When the ALE goes high, the latch is transparent i.e., the output changes according to the input. When ALE is low, the lower order address is latched until the next ALE and the output of the latch represents the lower order address bus (A0-A7) after the latching operation. #### 2.5 EPROM [ 27512 ]: Erasable programmable read only memory is a type of memory which can be reprogrammed again and again simply by erasing it subjecting it to ultraviolet rays. #### Programming the EPROM: The programming tool used for loading the EPROM is PC-UPROG.UPROG system is designed with 40 pin socket that supports most devices. PC-UPROG is a convenient programming tool for all kinds of programmable devices. PC-UPROG uses the popular IBM and IBM compatible desk top computer as its host system for data and algorithm storage while actual programming is under control of the hardware pulse generators and D/A converter of the PC-UPROG system. PC-UPROG is very user friendly, no special knowledge of programmable devices are required. All the operations are menu driven and displayed in clear, easy to understand English text. #### **Erasing the EPROM:** Erasure of the EPROM begins to occur when the chip is exposed to light with wavelengths shorter than approximately 4000 Angstroms. Since sunlight and fluorescent have wavelengths in this range, exposure to these light sources over an extended time ( about 1 week in sunlight, or 3 years in room level fluorescent light ) could cause inadvertent erasure. If an application subjects the device of this type of exposure, it is suggested that an opaque label be placed over the window. The recommended erasure procedure is exposure to ultraviolet light (at 2537Angstroms) to an integrated dose of atleast 15WSecs/sq.cm. Exposing the EPROM to an ultraviolet lamp of 12,000 mW/sq.cm rating for 20 to 30mins, at a distance of about 1 inch, should be sufficient. Erasure leaves the array in all 1's state. ## 2.6 STATIC RAM [ MCM 62256 / 63256 ] : It is a read-write memory i.e., a static RAM. A static RAM is essentially a matrix of flipflops. Therefore one can write a new data word in RAM location at any time by applying the word to the flipflop data inputs. Here the EPROM and RAM are employed as external memory to the controller. #### 2.7 VOLTAGE COMPARATOR [7705]: Voltage comparator is used to protect the controller from over voltage and under voltage levels of the supply voltage. The comparator monitors the supply voltage and compares it with a reference. If the voltage drops or rises above $V_{\text{ref}}$ , then a hardware reset will be initiated. #### 2.8 WATCH DOG TIMER: Watch dog timer is a missing pulse detector. It provides a means to recover from a software upset. When the watch dog timer is enabled, it will initiate a hardware reset. So the software should clear it every 64K state times. The clearing pulses are monitored. If the pulses are missed until the gets overflowed, it pulls down the reset pin resetting the 8032 and all other devices tied to the reset line. #### 2.9 DIGITAL CARD: This card consists of 80C196 microcontroller, DACs, latches, RAMs and EPROMs. The latches used here to set gain for the channel to be tested. The DACs are used to convert the digital input from 3032 to analog signal. RAMs and EPROMs are used as external memories for 80C196. 80C196 is operated in mode 1,(i.e) asynchronous mode. This digital card serves as serial communication port between 8032 card and the PCB to be tested. #### 2.10 POWER SUPPLY: The power supply for all IC's is given from the +5V of the regulated supply. These IC's can tolerate the fluctuations within certain limits. These limits are fixed by the voltage monitoring IC. The power supply diagram is shown in fig 2.2. #### 2.11 Logic Diagram Description: The circuit designed is to interface the keyboard and display unit with that of the digital card. The operation of interfacing is Microcontroller based. 80C32 Microcontroller is used for this purpose. 80C32 has only 128 bytes of data memory on chip and it has no program memory. But 80C32 can address 64 KB of RAM and 34 KB of program memory (EPROM) externally. The program to be executed is loaded in 27512 EPROM, as it has 64 KB of memory. For temperary data storage we need 32 KB of RAM. This is done by 63256 RAM. 8279 keyboard display interface is used to interface keyboard display card with that of 80C32 Microcontroller. 74LS573 3-8 8 bit decoders are used to select 63256 (RAM) and 8279 chips. The active low chip select line to the EPROM is grounded to make it available always. The data and address lines are shared by different chips. The lower order address lines and data lines are multiplexed. For this purpose a tatch is used. An octal bidirectional transceiver or buffer (74LS245) is used as temporary storage of data. Since bidirectional it can transfer data from Microcontroller to EPROM or RAM or vice versa. Chip 1232 is used to reset the hardware externally. Supply to all the chips is provided using a 7705 voltage comparator. This provides 5 V of supply. Connector pins are provided to interface this board with keyboard display card and digital card. The keyboard used here is 4 X 4 matrix keyboard. Six characters can be displayed using seven segment display. The PCB for this circuit is designed and fabricated. The logic diagram is shown in fig.2.1. #### 2.12 TESTING PROCEDURE: The PCB to be tested is interfaced with the digital card and 80C32 microcontroller board. The channel to be selected the testing voltage and the gain are fed as inputs through the keyboard display care which is directly linked to the 80C32 board. The 8279 keyboard display interface scans the keyed in data and stores in FIFO RAM temporarily. This data is transferred to 80C32 microcontroller which then passes this data to digital card through serial communication port. The entire program to perform this process is loaded in the EPROM. RAM is used for temporary storage of datas during processing. The digital board receives the input data through the serial I/O port. Then the digital card selects the particular channel and sets the testing voltage and gain. The gain settings are done through the gain latches in the digital board. The DAC feeds the voltage to be set to the non-inverting terminal of the OP-AMP in the PCB which is to be tested. The output voltage from the PCB is fed to the digital card. This analog signal is converted into digital by the inbuilt analog to digital converter in 80C196 microcontroller. This microcontroller checks whether the output is corresponding to the input. Based on the performance it then transmits the result to the 80C32 microcontroller through serial I/O port. The data received is in the form of ASCII code which is then converted into display code by the microcontroller. The output whether the channel works or not is displayed in the keyboard display card. Hence a particular channel in the PCB can be tested as per above procedure. The next channel can be selected and tested successively. The general block diagram is shown in fig.2.4. FIG 2.1 LOGIC DIAGRAM FIG 2.2 POWER CIRCUIT DIAGRAM FIG 2.3 DECODER CIRCUIT DIAGRAM ۴. #### **CHAPTER - 3** #### 8032 DESCRIPTION #### 3.1 INTRODUCTION: SUPPLY Single 5V operation with power down mode for saving internal RAM memory. INTERNAL MEMORY 128 bytes of register memory on chip, four banks of eight registers have special functions, two registers have additional indexing capability in each bank . MEMORY 64 KB program memory, switchable in 4K banks. 64 KB data memory, fully addressable. CLOCK TIME 1 microsecond instruction cycle time with 12MHZ crystal. Two external interrupts, two level priority, level or edge triggerable, two timer interrupts, one UART interrupt. **PORTS** One 8-bit I/O port, bit addressable, one UART port high speed programmable, two counter inputs could be used for gating timers or counters. Two multimode 16bit (8bit) timers/counters. ALU Binary or decimal arithmetic, Boolean bit for control logic programs, hardware 8-bit multiply and divide in 4 microsecs, parity computation, overflow detection. The block diagram is shown in the fig. 3.1 #### 3.2 HARDWARE FEATURES OF 8032 CPU: #### REGISTERS: Registers are small memories within the CPU. Registers are one part of control section. Like memory storage units, they consist of sinary cells and have address that distinguish them. The number of registers is very small however, data may be saved in a register until the program requires it. The registers are distinguished as follows: #### **ACCUMULATOR:** The accumulator is a eight bit register that is a part of the arithmetic logic unit (ALU). This register is the focus of all accumulator instructions that include arithmetic, logic, store and I/O instructions. The result of an operation is also stored in the accumulator which is also identified as register A. #### PROGRAM COUNTER (PC): The register is a memory pointer. Memory locations have sixteen bit address. The microcontroller uses this register to sequence the execution of instructions. The microcontroller uses this register to sequence the execution of instructions. The function of the program counter is to point to the memory address from which the next byte has to be fetched. When a byte is being fetched the program counter is incremented by one point to the next memory location. The 8032 program counter is 16 - bits wide and can access upto 64KB of program or data memory. #### FLAG REGISTER: The processor flags are combined in one status word (PSM) | CY AC FO RS1 RS0 OV X P | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |-------------------------|----|----|----|-----|-----|----|----|----|--| | | CY | AC | FO | RS1 | RS0 | OV | Х | Р | | CY: Carry flag AC : Auxiliary carry flag F0: Indicator RS1 : Register bank RS0 : Register bank OV : Overflow flag X : Don't care Parity flag #### STACK POINTER (SP): The stack pointer is also a 16-bit register used as a memory pointer. It points to a memory location in the R/W memory, called the stack which is defined by loading a sixteen bit address in the stack pointer. The stack is also within the RAM only. The stack pointer points to the location where the stack operations has to be done. Stack fills upward from there. Reset defaults the stack pointer to 08, pushing and popping of register / memory location can be done with one byte of instruction. #### **SERIAL DATA BUFFER:** The serial data buffer is actually two separate registers. When data is moved to SBUF, it goes to the transmit buffer where it is held for serial transmission (Moving a byte to SBUF is what initiates transmission). When data is moved from SBUF, it comes from the receive buffer. During serial reception the incoming bits are clocked into a separate shift register. When reception of a frame is complete and if various other conditions are satisfied, received data bits are transferred from the shift register to the receive buffer. The shift register is then ready to commence reception of a second frame, while the frame already received awaits servicing. #### **CONTROL AND STATUS REGISTERS:** Special Function Registers IP(Interrupt Priority). IE(Interrupt Enable), TMOD(Timer / Counter Mode), TCON(Timer / Counter Control), SCON(Serial Control) and PCON(Power Control) contain control and status bits for the interrupt system, the timers and the serial port. #### STACK: Data is pushed in to the stack or popped out of the stack on the LIFO basis. The stack can be located anywhere in the RAM memory. The stack pointer maintains the address of the last byte entered into the stack and is decremented everytime data is pushed into the stack and incremented each time data is popped out of the stack. The stack pointer is always incremented or decremented by two bytes. #### **ARITHMETIC LOGIC UNIT:** The ALU consists of the accumulator, the flag register and some temporary register that are accessible to the user. Arithmetic, logic and rotate operations are performed by the ALU. #### INTERNAL TIMERS / COUNTERS: There are two timers, timer1 and timer0. Actually, two 16-bit registers are used, which incremented one by one, either by a tick of the timer clock or by a count pulse at pins T0 and T1. If a 12MHz crystal is used, each tick is one microsecond. Thus a timer register can fill up to 65536 clock ticks. Longer time delays can be arranged by using the timer repeatedly in a software loop. As a counter, the same could accumulate pulses at frequencies from DC to 500MHz, with 16-bit precision. The timer could be operated in four modes. #### 3.3 INTERRUPTS: The 8032 provides five interrupt sources, each of which can be programmed to one of the two priority levels. The five interrupt sources are listed below. | Source | Description | |-------------|--------------------------------------------------| | INT O | External request from P3.2 pin. | | Timer 0 | Overflow request Timer 0 activates interrupt | | | request flag TF0 | | INT 1 | External request from P3.3 pin. | | Timer 1 | Overflow from Timer 1 activates interrupt | | | request flag TF1. | | Serial Port | Completion of transmission or reception of | | | one serial frame activates request flag TI or RI | | | respectively. | Each source can be individually enabled or disabled by setting or clearing a bit in special function register IE. IE: MSB LSB | EA | Х | Х | ES | ET1 | EX1 | ET0 | EX0 | | |----|---|---|----|-----|-----|-----|-----|--| | | | | | | | | L | | EA : Enable all. ES : Enable serial port control bit. ET0, ET1 : Enable timer 0 and timer 1 control bit EX0, EX1 : Enable external interrupts 0 or 1 Since there is more than one interrupt, priority is given to them. Set or clear five bits of the IP register to make the priority high or low respectively. IP: MSB LSB | ſ | | | PS | PT1 | PX1 | PT0 | PX0 | 1 | |---|------|-------------|----|-----|-----|-----|-----|---| | | <br> | <del></del> | | | | | | | PS : Serial port priority control bit. PT0, PT1 : Timer interrupts PX0, PX1 : External interrupts Each interrupt has a vector address to which the program branches. In the monitor program, long jump instructions are given to take the interrupt service routines at the addresses given below: | Source | Address | |----------------------|---------| | External Interrupt | 0003H | | Timer 0 Overflow | 000BH | | External Interrupt 1 | 0013H | | Timer 1 Overflow | 001BH | | Serial Port | 0023H | Execution proceeds from that address until the RET1 instruction is encountered. #### 3.4 PORT DETAILS: #### PORT 0: Port 0 is a 8 bit open drain bi-directional I/O port. Port 0 pins that have 1's written to them float, and in that state can be used as night impedance inputs. Port 0 is also the multiplexed low order address and data bus during access to external program and data memory. Port 0 also receives the code bytes during programming the EPROM parts, and outputs the code bytes during program verification of the ROM and EPROM parts. External pull-ups are required during program verification. #### PORT 1: Port 1 is an 8-bit bi-directional I/O port with external pull-ups. The port 1 output can sink /source 4 LS TTL inputs. Port 1 pins have 1's written to them are pulled high by the external pull-ups and that state can be used as inputs. As inputs, port 1 pins that are externally being pulled low will source current because of the internal pull-ups. #### PORT 2: Port 2 is an 8-bit bi-directional I/O port with internal pull-up. The port 2 output buffers can sink/source 4 LS TTL inputs. Port 2 pins that have 1's written to them are pulled high by the internal pull-ups and in that state can be used as inputs. Port 2 also receives the higher order address bits during programming of the EPROM parts and during program verification of the EPROM parts. Port 2 emits the higher order address byte during access to external data memory that use 16-bit address. #### PORT 3: Port 3 is a 8-bit bi-directional I/O port with internal pull-up. The port 3 output buffers can sink /source 4 LS TTL inputs. Port 3 pins that have 1's written to them are pulled high by the internal pull-ups, and in that state it can be used as inputs. Port 3 pins that are externally being pulled low will source current because of the pull-ups. Port 3 also serves the functions of various special features of the 8032 as listed below | PORT PIN | ALTERNATIVE FUNCTION | |----------|--------------------------------| | P 3.0 | RXD (Serial input port) | | P 3.1 | TXD (Serial output port) | | P 3.2 | INT0 (External interrupt 0) | | P 3.3 | INT1 (External interrupt 1) | | P 3.4 | T0 (Timer 0 external input) | | P 3.5 | T1 (Timer 1 external input) | | P 3.6 | WR (External data memory write | | | strobe) | | P 3.7 | RD (External data mmeory read | | | strobe) | ## 3.5 SERIAL INTERFACE: The serial port is full duplex, meaning it can transmit and receive simultaneously. It is also receive buffered, meaning it can commence reception of a second byte before a previously received byte has been read from the receive register. The serial port registers are both accessed at Special Function Register serial buffer (SBUF). A write to SBUF loads the transmit register and a read access a physically separate receive register. The serial port can operate in 4 modes as follows: - MODE 0: Serial data enters and exits through RXD. TXD outputs the shift clock. 8-bits are transmitted / received : 8 data bits (LSB first). The baud rate is fixed at 1/12 the oscillator frequency. - MODE 1: 10 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first), and a stop bit(1). On receive, the stop bit goes into RB8 in Special Function Register SCON. The baud rate is variable. - MODE 2: 11 bits are transmitted (through TXD) or received (through RXD): a start bit (0), 8 data bits (LSB first), a programmable 9<sup>th</sup> data bit, and a stop bit (1). On transmit, the 9<sup>th</sup> data bit (TB8) can be assigned the value of 0 or 1. With nominal software overhead, TB8 can be made a parity bit. On receive, the 9<sup>th</sup> data bit goes into RB8 in Special Function Register SCON, and the stop bit is ignored. The baud rate is programmable to either 1/32 or 1/64 the oscillator frequency. - MODE 3: 11 bits are transmitted (through TXD) or received (through RXD):a start bit (0), 8 data bits (LSB first), a programmable 9<sup>th</sup> data bit, and a stop bit (1). #### **SERIAL PORT CONTROL REGISTER:** Special Function Register SCON is used to define the operating modes and control certain functions of the serial port. It also receives the 9<sup>th</sup> data bit (RB8), and contains the transmit and receive interrupt flags (Ti and RI). The register is as shown below: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | |-----|-----|-----|-----|-----|-----|----|----| | SM0 | SM1 | SM2 | REN | TB8 | RB8 | T1 | R1 | Where SM0 and SM1 specify the port mode, as follows: | SM1 | SM1 | Mode | Description | Baud rate | |-----|-----|------|----------------|-------------| | 0 | 0 | 0 | shift register | f osc. / 12 | | 0 | 1 | 1 | 8-bit UART | variable | | 1 | 0 | 2 | 9-bit UART | f osc. / 64 | | | | | | 0.7 | | | | | | f osc. / 32 | | 1 | 1 | 3 | 9-bit UART | variable | - SM2 enables the multiprocessor communication feature in modes 2 and 3. - REN enables serial reception. - TB8 is the 9<sup>th</sup> data bit that will be transmitted in modes 2 and 3. - RB8 in modes 2 and 3, is the 9<sup>th</sup> data bit that was received. - TI is transmit interrupt flag. - RI is receive interrupt flag. FIG 3.1 INTERNAL ARCHITECTURE OF 8032 ## CHAPTER - 4 ## DIGITAL CARD DESCRIPTION #### 4.1 INTRODUCTION: The Digital card used for serial communication is previously used by the industry for the same purpose. The main part of the digital card is a 80C196 microcontroller supported by two EPROMs (odd and even), two RAMs and gain latches. #### 4.2 80C196 DESCRIPTION: The 80C196 is a 16-bit microcontroller. There are five peripherals on the 80C196KB: The Pulse Width Modulated output (PWM), timers, high speed I/O units, serial port and A/D converter. Out of the five peripherals serial port and A/D converter are used here. SUPPLY Single 5V operation with power down mode for saving internal RAM memory. MEMORY SPACE 64K Bytes of memory space is available for program or data memory. Locations 0000H through 90FFH and 1FFFH through 2080H are used for special purposes. All other locations can be used for either program or data storage or for memory mapped peripherals. INTERNAL TIMING Internal operation of the 80C196 KB is based on the crystal or external oscillator frequency divided by 2 .Every 2 oscillator periods is referred to as a state time, the basic time measurement for all 80C196 KB. With a 12MHZ oscillator the state time is 167 ns. **PORTS** Five 8-bit I/O ports. Port0 is an input port also used as analog input for A/D convertor. Port1 and Port2 are quasi-bidirectional, input and output ports. Port3 and Port4 are open drain bidirectional ports. RALU Most calculations performed by 80C196 takes place in RALU. The RALU contains a 17-bit ALL, the program status word (PSW), the program counter (PC), a loop counter and three temporary registers. All of these registers are 16-bit or 17-bit wide. Some of the registers have the ability to perform simple operations to off-load the ALU. The internal architecture of 80C196 microcontroller is shown in Fig. 4.1 #### SYSTEM BUS: There are several modes of system bus operation on the 80C196KB. The standard bus mode uses a 16-bit multiplexed address/data bus. Other bus modes include an 8-bit mode and a mode in which the bus size can dynamically be switched between 8- bits and 16-bits. #### PROGRAM STATUS WORD: PSW is a collection of Boolean flag which retain information concerning the state of the user's program. There are 2 bytes in the PSW: the actual status word and the low byte of the interrupt mask. PSW can be saved in the system stack with a single instruction PUSH F and restore in a POP F instruction. Only the interrupt section of the PSW can be accessed directly. There is no SFR for the PSW status bits. | MSB | | | | | | | LSB | | | |-----|---|---------------|----|---|---|---|-----|--|--| | Z | N | V | VT | С | Х | I | ST | | | | Z | | Zero fla | g | | | | | | | | N | | Negative flag | | | | | | | | V Overflow flag VT Overflow trap flag C Carry flag X Reserved Interrupt disable bit ST Set to indicate that during a right shift a 1 has been shifted first into the carry flag. #### INTERRUPTS: 80C196 microcontroller supports 28 sources of interrupts. These sources are gathered into 15 vectors plus special vectors NMI,TRAP and UNIMPLEMENTED opcodes. #### NMI: The external NMI pin generates an unmaskable interrupt for implementation of critical interrupt routines. #### TRAP: It is useful in the development of custom software debuggers or generation of software interrupts. The TRAP instruction prevents the acknowledgement of interrupts until after execution of the next instruction. #### **UNIMPLEMENTED OPCODE:** It generates an interrupt when unimplemented opcodes are executed. This provides software recovery from random execution during hardware and software failures. ## 4.3 SERIAL PORT: Serial port on 80C196KB has one synchronous and three asynchronous modes. #### Serial Port Modes: Mode 0: Mode 0 is a synchronous mode which is commonly used for shift register based I/O expansion. In this mode the TXD pin outputs a set of 8 pulses while the RXD pin either transmits or receives data. Data is transferred 8 bits at a time with LSB first. In this mode the serial port expands the I/O capability of the 80C196 KB by simply adding shift registers. Mode 1: Mode1 is the standard asynchronous communication mode. The data frame used in this mode consists of 10 bits; a start bit (0),8 data bits(LSB first),and a stop bit(1),if parity is enabled by setting SP\_CON.2, and even parity bit is sent instead of the 8<sup>th</sup> data bit and parity is checked on reception. Mode 2: Mode2 is the asynchronous 9<sup>th</sup> bit recognition mode. This mode is commonly used with mode3 for multiprocessor communications. The transmission frame in this mode consists of 11 bits; one start bit, 9 data bit and one stop bit.9<sup>th</sup> bit in data is a programmable one. Mode 3: It is the asynchronous 9 bit mode. The data frame of this mode is same as that of mode 2. The transmission difference between mode2 and mode3 is that parity can be enabled (PEN=1) and cause the 9<sup>th</sup> data bit to take even parity value. The TB 8 bit can still be used if parity is not enabled (PEN=0). In mode3 a reception always causes an interrupt regardless of the state of the 9<sup>th</sup> bit. 9<sup>th</sup> bit is stored if PEN=0 and can be read in bit RB8. If PEN=1 then RB8 becomes receive parity error flag. #### 4.4 A/D CONVERTER Analog inputs to the 80C196KB system are handled by the A/D converter system. The system has an 8-channel multiplexer, a sample and hold, and a 10-bit successive approximation A/D converter. Conversions can performed on one of 8 channels, the input of which share with port 0. A conversion can be done in 91 state times. The A/D converter can cause an interrupt on completing the conversion. So by using this interrupt we can read the result in the interrupt service routine if required. Otherwise we can read the result using a polling method. #### 4.5 EXTERNAL MEMORY: Using EPROMs & RAMs: Since 80C196 is a 16-bit microcontroller it needs two 8-bit EPROMs to perform word size operations. One EPROMs is called the Odd EPROM and the other is called the Even EPROM. The 8-bits of Odd EPROM is used as MSB of a word. The 8-bits of Even EPROM and 8-bits of Odd EPROM are together parallelly fed into the microcontrol or for processing. Similarly two RAMs are used, one for 8-bits (MSB) and other for rest 8-bits (LSB) storage. #### 4.6 GAIN LATCHES: There are five gain latches used here. Each latch has eight output lines. For one channel five output lines are used. When the input for a particular channel is given the five output lines of the corresponding channel are latched and the gain input to the channel is set. The block diagram for the digital card is shown in figure 4.1. ## 4.7 DIGITAL TO ANALOG CONVERTER: The inbuilt DAC in 80C196 can be used only for six channels and can be operated in unipolar mode alone. But we need eight output lines of DAC for eight channels. Therefore we go in for external DACs which can be operated in bipolar mode. The DACs used here are voltage output DACs. FIGHT BLOCK DIAGRAM OF DIGITAL CARD #### CHAPTER - 5 ## SOFTWARE #### 5.1 INTRODUCTION: This software is essential to initiate the various processes that are necessary for testing the PCB. An efficient assembly level program is written which makes the hardware function works successfully. Program memory allocated externally to the microcontroller has a memory capacity of 64KB and it is used to store the program to be executed. #### 5.2 ALGORITHM: - 1. Memory allocation to various chips are done. - The 8032 Microcontroller and 8279 keyboard display interface are initialized. - 3. Check whether any key is pressed using the program status word. If pressed, read the data else wait until any key is pressed. - 4. The character read corresponds to the position of the key in the keyboard along with the status of the control and shift lines. Control and shift lines are always maintained high. Out of the six remaining bits, three bits indicate the row of the pressed key and three bits indicate the column. This data format is converted into original form by the keyboard lookup tables. - 5. The data recorded is currently displayed and simultaneously transferred to the digital board through serial input/output port. - 6. The datas from 80C196 Microcontroller are received after the completion of processing by the 80C32 Microcontroller. - 7. The data received is converted to display format from ASCII code. - 8. The result is displayed in the seven segment display as PASS or FAIL. ``` ; HARDWARE SPECIFICATIONS AND DESIGN DETAILS ***************** 00000H TO CFFFFH MAPPING PROGRAM MEMORY 64KB ; EPROM TO OFFFH MAPPING H00000 EXTERNL MEMORY 32KB ;SRAM TO 09FFFH 08000Н MAPPING 08KB EXTERNL MEMORY ; NVRAM OE400H TO OE5FFH MAPPING --DO-- ____ ;8279 DESIGNATED FOR WATCH DOG PULSE OUTPUT P1.2 ; PORT ; HIGHEST PRIORITY ****************** ; INTERNAL RAM LOCATIONS FOR BYTE AND WORD VARIABLES 033H ;STARTING DISPLAN EOU OP 0 ;LOCATION-18t Dir 034H ;2nd DIGIT EQU OP I 035H ;3rd DIGIT EQU OP 2 ;4th DIGIT 036Н OP_3 EQU 037H ;5th DIGIT EQU OP 4 038H ;6th DIGIT EQU OP 5 ;TEMPORARY RAM 039H EQU TMP 0 ;LOCATIONS 03AH EQU TMP 1 040H EQU DBUF1 IADR 041H EQU DBUF2 IADR 042H DBUF3_IADR EQU 043H EQU DBUF4 IADR 044H EQU DBUF5 IADR 045H EQU TEMPO ADDR 046H EQU BLUEO ADDR 047H EQU BLUE1 ADDR 048H EQU BLUE2 ADDR 049H EQU BLUE3 ADDR 04AH EQU BLUE4_ADDR 04BH EQU BLUE5 ADDR 04CH EQU BLUE6 ADDR ; CONSTANT DATA DECLARATIONS ;TIMER I LOADING VALUE 0F3R EQU BAUD FACTOR ; FOR 2400 BAUD RATE ;TIMERO 50 THOUSAN. OBOH EQU TIMERO LO_COUNT ;MICRO SECONDO PACTOR ``` | TIMERO_HI_COUNT | r EQU | 03CH | ;TIMERO 50 THOOSAND<br>;MICRO SECONDS FARTER | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------------------------------|----------------------------------------------------------------------|--|--|--|--|--| | TIMER2_LO_COUNT | r EQU | 0B0H | ;TIMER 2 FOR ONE ALP TE<br>;TIME COUNTER | | | | | | | TIMER2_HI_COUN | r EQU | 03CH | ;TIMER 2 FOR ONE BUNGTE ;TIME COUNTER | | | | | | | BLANK_CODE | EQU<br>EQU | 0FFH<br>020H | ;DATA FOR BLANKING<br>;THE DISPLAY | | | | | | | ZERO_CODE<br>PCON | EQU<br>DATA | 000H<br>087H | , | | | | | | | ; PERIPHERAL'S | LOCATION DE | EFINITIONS | ************************** | | | | | | | COURT OF THE PORT | n: | ZAOIH · COMMA | ND & CONTRL REC. ADDRESS<br>REG. ADDRESS | | | | | | | ;&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$&\$ | | | | | | | | | | ;&\$&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& | <b>୫୫୫୫୫୫୫</b> ୫୫୫୫ | \$&&&&&&&&&&&&& | <b>&amp;&amp;&amp;&amp;&amp;&amp;&amp;&amp;&amp;</b> && <b>&amp;</b> | | | | | | | KEY_DISP_MODE PGM_CLOCK FIFO_RAM DISP_RAM_READ DISP_RAM_WRITE CLEAR_DISP | | 000H<br>03AH<br>050H<br>070H<br>090H<br>0DFH | | | | | | | | ; ୧୯୯୯ ଓ ୯୯୯ | | | | | | | | | | KEY_TBLADR | | EQU | 42000 | | | | | | | KEY_TBLCODE | | EQU | 4020H | | | | | | | KY_RTRNADDR | | EQU | 4054H | | | | | | | DISP_TBLADR | | EQU | 4050H | | | | | | | ;^^^^^ | .^^^^^^ | ^^^^^ | | | | | | | | ORG 00<br>LJMP SI | )H<br>CART | | | | | | | | | ORG 1E | 311 | | | | | | | | ``` RETI 23H ORG RETI 100H ORG ;starting location of the program START: BLANK DISPLAY LCALL VOM OP 0, #OFFH OP 1, #0FFH MOV OP_2,#0FFH MOV OP_3,#0FFH VOM OP 4,#0FFH MOV OP 5, #0FFH VOM INIT 8279 CALL R2,#06H MOV P1.2 CPL KEY DISP LOO: CALL P1.\overline{2} CPL R2, #00H, LOO CJNE R2,#06H MOV OP 0, #OFFH MOV OP_1,#0FFH MOV OP_2,#0FFH VOM Pl.2 CPL OP 3,#0FFH MOV OP 4,#0FFH OP 5,#0FFH MOV MOV P1.2 CPL 001 JMP KEY DISP: ********************** P1.2 CPL DPTR, #CMND 8279 MOV A, @DPTR XVOM ACC.4, RD FIFO JNB P1. 2 CPL ``` RTRN: RET ``` RD FIFO: A, #07H ANL P1.2 CPL JZ RTRN DPTR, #CMND_8279 VOM A,#040H VOM @DPTR,A XVOM DPTR, #DATA 8279 MOV P1.2 CPL A,@DPTR MOVX TEMPO ADDR, A VOM KEY LOOK LCALL CALL DISP LOOK DISP ENTRY CODE CALL F1.2 CPL RET KEY LOOK: ; THIS SUBROUTINE COMPARES THE FIFO DATA WITH THE LOOKUE ; TABLE AND RETURN THE DATA IN KEY_RTRNADDR LOCATION. IF THE ; VALUE NOT AVAILABLE IN LOOK_UP TABLE THEN RETURNS DATA OFFH ******************** P1.2 DPTR, #KEY TBLADR VOM DO CMPR: A, #00H MOV A,@A+DPTR MOVC A, TEMPO ADDR, NEXT CMPR CJNE P1.2 CPL A,#020H VOM A,@A+DPTR MOVC DPTR, #KY_RTRNADDR MOV @DPTR,A XVOM TEMPO ADDR,A MOV E2,#06H,AL1 CJNE BLUE1_ADDR, TEMPO_ADDR MOV P1.2 CPL \LambdaL6 JMP R2,#05H,AL2 CJNE AL1: BLUE2 ADDR, TEMPO ADDR VOM \Lambda L6 JMP P1 .2 CPL R2,#04H,AL3 AL2: CJNE BLUE3 ADDR, TEMPO ADDR MOV Ab6 JMP R2,#03H,AL4 CJNE AL3: BLUE4 ADDR, TEMPO ADDR MOV P1.2 CPL AL6 JMP 53 ``` ``` R2, #02H, AL5 CJNE AL4: BLUE5 ADDR, TEMPO_ADDR VOM JMP AL6 R2,#01H,AL6 CJNE AL5: P1.2 CPL BLUE6 ADDR, TEMPO ADDR VOM RET AL6: NEXT CMPR: DPTR INC A,#80H MOV P1.2 CPL A,@A+DPTR MOVC A,#OFFH,DO CMPR CJNE DPTR, #KY_RTRNADDR MOV @DPTR,A MOVX P1.2 CPL RET ********************** DISP LOOK: ; COMPARE THE DATA AVAILABLE IN TEMPO_ADDR WITH DISPLAY LOOK ; UP TABLE AND RETURNS THE CORRESPONDING SEGMENT DATA IN ;TEMPO ADDR P1.2 CPL ;START WITH 000H FOR MOV R3, #ZERO_CODE ; COMPARING DPTR, #DISP_TBLADR ;LOOK UP TABLE STARTING MOV ; ADDRESS TO FOOK: A, TEMPO ADDR VOM CJNE A, #20H, NO BLANK CPL P1.2 MOV \Lambda, \#BLANK TEMPO ADDR, A VOM RET NO BLANK: A, TEMPO ADDR VOM A,#3FH ANL CPL P1.2 C CLR SUBB A, R3 ; IF NOT EQUAL TO THEN NEXT_LOOK JNZ ; INCREMENT R3 AND CHECK ;FOR 009H ``` ``` ;OFFSET FOR DISP TBLADR A, #ZERO CODE VOM ; LOCATION ;GET THE SEGMENT DATA FROM MOVC A, @A+DPTR ; DISPLAY TABLE TEMPO ADDR, A VOM P1.2 CPL R2, #005H, RT1 CJNE TMP 0, TEMP0 ADDR VOM RET RT1: NEXT_LOOK: ; NEXT DISPLAY SEGMENT DPTR INC P1.2 CPL ;R3 = R3 + 1 UP TO COSE R3 INC CJNE R3, #027H, DO LOOK JIF R3=OAR THEN RETURN BLANK IN TEMPO ADDE TEMPO_ADDR, #BLANK MOV RET · 集相元素依赖文法表表文表演者表示者表表文的意义表示文章表示人类表示文章表示文章的文章或文章或文章表示文章 DISP ENTRY CODE: ; DISPLAY THE CORRESPONDING PRESSED KEY P1.2 CPL R2,#006H,K1 CJNE MOV OP 0, TEMPO ADDR К6 JMP CJNE R2,#005H,K2 K1: P1.2 CPL OP_1,TEMPO_ADDR VOM Κб JMP CJNE R2, #004H, K3 K2: OP 2, TEMPO ADDR VOM P1.2 CPL К6 JMP K3: CJNE R2,#003H,K4 OP_3,TEMPO_ADDR MOV P1.2 CPL Κő JMP R2,#002H,K5 CJNE K4: OP 4, TEMPO ADDR MOV P1.2 CPL Κ6 JMP R2,#001H,K6 CJNE K5: OP 5, TEMPO ADDR VOM P1.2 CPL ``` ``` LCALL OUT_SEGMENT DJNZ R2,LOOP SERIAL COMM LCALL P1.2 CPL RET LOOP: OUT SEGMENT: ************ ; THIS SUBROUTINE DISPLAYS 5 DIGIT DATA AVAILABLE IN ; DISPLAY BUFFER ADDRESS LOCATIONS TO 8279 & INITIALISE ; WRITE DISPLAY RAM ADDRESS OF 8279 P1.2 CPL DPTR, #CMND 8279 MOV A,#090H MOV @DPTR,A XVOM DPTR, #DATA 8279 MOV P1.2 CPL A, OP 0 VOM 9DPTR,A XVOM A, OP_1 MOV @DPTR,A MOVX A,OP Z VOM P1.2 CPL @DPTR,A XVOM A,OP_3 MOV @DPTR, A XVOM VOM \Lambda, OP 4 gorrR,A MOVX P1.2 CPL A, OP 5 MOV @DPTR,A MOVX RET ********************* ORG KEY TBLADR ************************* OC3H, OC2H, OCAH, OD2H, OC1H, OC9H, OD1H; 0,1,2,3,4,5,6 DB OC4H, OCCH, OD4H, OCBH, OD3H, ODAH, ODBH DB ;7,8,9,DP,ENTER,F1,F2 BLANK ``` K6: OFFH DB ``` ORG KEY TBLCODE 000н,001н,002н,003н,004н,005н,006н ;0,1,2,3,1,1,4 DB. 007H,008H,009H,013H,011H,017E,026H DB ;7,8,9,0P,ENTER,F1,F2 ORG DISP TBLADR ;7 SEGMENT CODE FOR '0';00 0C0H DB ;7 SEGMENT CODE FOR '1';01 DB OF9H ;7 SEGMENT CODE FOR '2';02 DB 0A4H ;7 SEGMENT CODE FOR '3';03 OBOH DB ;7 SEGMENT CODE FOR '4';04 099H DB ;7 SEGMENT CODE FOR '5';05 DB 092H ;7 SEGMENT CODE FOR '6':06 082H DΒ ;7 SEGMENT CODE FOR '7';07 OF8H DB ;7 SEGMENT CODE FOR '8';08 DΒ H080 ;7 SEGMENT CODE FOR '9';09 090H DΒ ;7 SEGMENT CODE FOR 'C';0A 0C6H DВ ;7 SEGMENT CODE FOR 'A';0B ;ENTER ÐΒ И880 ;7 SEGMENT CODE FOR 'G';0C 0C2H DB. ;7 SEGMENT CODE FOR 'V';0D 0C1H DΒ ; 7 SEGMENT CODE FOR 'E'; 0E 086H DΒ ;7 SEGMENT CODE FOR 'F';0F 08EH DB ;7 SEGMENT CODE FOR 'B';10 083E DB ;7 SEGMENT CODE FOR 'A';11 088H DВ ;7 SEGMENT CODE FOR 'I';12 0F9H DB ;7 SEGMENT CODE FOR 'C';13 0C6H DB ;7 SEGMENT CODE FOR 'L';14 0C7H DB. ;7 SEGMENT CODE FOR 'M';15 0EAH DB. ;7 SEGMENT CODE FOR 'N';16 0ABH 1013 ;7 SEGMENT CODE FOR 'G';17 0C2H DB ;7 SEGMENT CODE FOR 'P';18 08CH DB ;7 SEGMENT CODE FOR 'R';19 0AFH DΒ ; 7 SEGMENT CODE FOR 'S'; 1A DB 092H ;7 SEGMENT CODE FOR 'T';1B 087H DΒ ;7 SEGMENT CODE FOR 'U';10 OC1H DΒ ;7 SEGMENT CODE FOR 'V';1D 0A1H DB ;7 SEGMENT CODE FOR 'W';1E 0E2H DB ;7 SEGMENT CODE FOR 'Y';1F 091H DB ;7 SEGMENT CODE FOR ' ';20 FOR SPACE OFFH DB ;7 SEGMENT CODE FOR '_';21 FOR HYPHEN DB OF7H ;7 SEGMENT CODE FOR '\overline{L}';22 0C7H DB ;7 SEGMENT CODE FOR 'M';23 0EAH DB ;7 SEGMENT CODE FOR 'N';24 0ABH DB ``` ``` ;7 SEGMENT CODE FOR 'G';25 DB ;7 SEGMENT CODE FOR 'V';26 OC1H DΒ SERIAL_COMM: SP,#60H VOM PSW, #00H MOV P1.2 CPL TMOD, #020H MOV SCON, #050H MOV PCON, #080H VOM P1.2 CPL TL1,#OF3H MOV TH1,#0F3H MOV P1.2 CPL ΤΙ CLR RI CLR TR1 SETB EΑ SETB P1.2 CPL A, BLUE1_ADDR VOM A,#030H ADD SBUF, A MOV L1: P1.2 CPL TI,L1 JNB TI CLR P1.2 CPL A, BLUE2 ADDR VOM A,#030H ADD SBUF, A MOV L2: P1.2 CPL TH, LE JNB 1.1 CLR 21.2 CPL A, BLUES AUDR MOV A,#030H ADD SBUE, A MOV L3: P1.2 CPL TI,L3 JNB ΤI CLR P1.2 CPL A, BLUE4 ADDR VOM A,#030H ADD SBUF, A MOV ``` OC2H ``` L4: P1.2 CPL TI, L4 JNB TI CLR P1.2 CPL A, BLUE5_ADDR VOM A,#030H ADD SBUF, A VOM L5: CPL P1.2 TI,L5 JNB Τſ CLR P1.2 CPL A, BLUE6_ADDR MOV A,#030H ADD SBUF, A VOM P1.2 CPL L6: TI, L6 JNB TI CLR P1.2 CPL L9: RI,L9 JNB A, SBUF VOM RΙ CLR P1.2 CPL A,#031H,L10 CJNE DISP PASS CALL RET L10: P1.2 CPL A, #032H, L11 CJNE DISP_FAIL CALL RET L11: DISP_PASS: P1.2 CPL DBUF1_TADR, #08CH VOM DBUF2 IADR, #088H VOM DBUF3_IADR,#092H DBUF4_IADR,#092H VOM VOM DBUF5 IADR, TMP_0 MOV P1.2 CPL BLUEO ADDR,#CC6H VOM SEGMENT_DISP LCALL ``` RET ``` DISP FAIL: P1.2 CPL DBUF1 IADR, #08EH MOV DBUF2 IADR, #088H MOV DBUF3 IADR, #0F9H VOM DBUF4_IADR, #0C7H VOM CPL P1.2 DBUF5 IADR, TMP_0 VOM BLUEO ADDR, #0C6H MOV SEGMENT DISP LCALL RET SEGMENT DISP: P1.2 CPL DPTR, #CMND 8279 VOM A,#090H MOV @DPTR, A MOVX P1.2 CPL DPTR, #DATA 8279 VOM MOV A, BLUEO ADDR XVOM @DPTR,A A, DBUF5 IADR MOV @DPTR,A MOVX P1.2 CPL A, DBUF1_IADR MOV @DPTR,A MOVX A, DBUF2 IADR MOV @DPTR.A MOVX P1.2 CPL A, DBUF3 _ IADR VOM @DPTR,A MOVX VOM A, DBUF4 IADR @DPTR,A XVOM P1.2 CPL RET ***************** INIT 8279: ****************** ;This is to initialise the 8279 for 8char, right entry, encoded ; key board mode ********************** DPTR, #CMND 8279 MOV A,#000H ; KBRD - DISP MODE VOM @DPTR,A MOVX CPL P1.2 ; PRGM CLOCK A,#3AH MOV MOVX @DPTR,A ;FIFO RAM A,#50H MOV ``` ``` @DPTR, A XVOM P1.2 CPL ; READ DISPLAY RAM ADDRESS MOV A,#70H @DPTR,A XVOM P1.2 CPL ;WRITE DISPLAY RAM ADDRESS A,#90H MOV XVOM @DPTR,A P1.2 CPL A,#ODFH ;CLEAR MODE VOM @DPTR,A MOVX R7,#0FFH MOV DDD P1.2 CPL R7,DDD DJNZ MOV R7,#06H DPTR, #DATA 8279 ; purposely blank th MOV ;displays A,#OFFH VOM DO OUT: @DPTR,A XVOM R7,00 00T DJNZ RET ************************************ ******************* BLANK DISPLAY: ; THIS ROUTINE FOR BLANK ALL DIGITS ***************** DPTR, #CMND 8279 VOM A, #090H MOV @DPTR,A XVOM DPTR, #DATA 8279 VOM A,#OFFH VOM @DPTR,A MOVX @DPTR,A XVOM @DPTR,A MOVX @DPTR,A XVOM @DPTR,A XVOM @DPTR,A MOVX RET *********************************** END ``` #### CHAPTER - 6 ## CONCLUSION In this project a microcontroller based Analog signal tester, to test a PCB of the Yarn Quality Monitor has been designed and fabricated. This Analog Signal Tester is employed in the industry for regular use. The tester is very fast and accurate in its performance. This method has considerably decreased the time span required for the entire testing sequence in to few minutes and there by conserves the precious of time. The visual display reduces the fatigue of the worker and makes his work easy. # FURTHER DEVELOPMENT: - As this project tests the entire channel at a time, this can be improved to test each and every component individually. - A testing method which interfaces the PCB to be tested to the personal computer can be developed. ## REFERENCES - D.Roy Choudhury, Shail Jain, "Linear Integrated Circuits", Wiley Eastern Ltd., New Age International Ltd., New Delhi, 1984. - 2. "Intel 8-bit Embedded Controller Handbook ",1986. - Ramesh .S. Goankar, "Microprocessor Architecture, Programming and applications", Wiley Eastern Ltd., New Age International Ltd., New Delhi, 2<sup>nd</sup> Edition, 1987. - 4. "National Semiconductors Data Acquisition Data Book",1993. - 5. "Intel Memory Components Handbook", 1987. - Doughlas V.Hall, "Microprocessors and Interfacing Programming and Hardware", McGraw-Hill International Editions, Newyork, 1988. # 8279/8279-5 PROGRAMMABLE KEYBOARD/DISPLAY INTERFACE - Simuitaneous Keyboard Display Operations - Scannad Kayboard Mode - Scanned Sensor Mode - a Strobed Input Entry Mode - B 8-Character Keyboard FIFO - g 2-Key Lockout or N-Key Rollover with Contact Debounce - a Dual 8- or 16-Numerical Display - s Single 16-Character Display - s Right or Laft Entry 16-Byte Display BAG - a Mode Programmable from CPU - a Programmable Scan Timing - m Interrupt Output on Key Entry - Available in EXPRESS - —Standard Temperature Rango - —Extended Temperature Rango The Intel® 8279 is a general purpose programmable keyboard and display I/O interface device designed for use with Intel\* microprocessors. The keyboard portion can provide a scanned interface to a 64-contact key matrix. The keyboard portion will also interface to an array of sensors or a strobed interface keyboard, such as the hall effect and ferrite variety. Key depressions can be 2-key lockout or N-key rollover. Keyboard entries are debounced and strobed in an 8-character FIFO. If more than 8 characters are entered, overrun status is set. Key entries set the interrupt output The display portion provides a scanned display interface for LED, incandescent, and other popular display technologies. Both numeric and alphanumeric segment displays may be used as well as simple indicators. The 8279 has 16x8 display RAM which can be organized into dual 16x4. The RAM can be loaded or interrogated by the CPU, 8oth right entry, calculator and left entry typewriter display formats are possible. Both read and write of the display RAM can be done with auto-increment of the display RAM address. ### HARDWARE DESCRIPTION The 8279 is packaged in a 40 pin OIP. The following is a functional description of each pin. Yable 1. Pin Descriptions | | T., | | |-----------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Symbol | Pin | | | <del></del> | 8 | Bi-directional data bus: All data | | D8 <sub>0</sub> -D8 <sub>7</sub> | 5 | and commands between the CPU | | | | and the 8279 are transmitted on | | } | 1 | these lines. | | CLK | 1 | Clock; Clock from system used to | | | 1 | generate internal timing. | | RESET | 1 | Reset: A high signal on this pin resets the 8279. After being reset the 8279 is placed in the following mode: 1) 16 8-bit character display—left entry. 2) Encoded scan keyboard—2 | | | | key lockout. | | | | Along with this the program clock prescaler is set to 31. | | cs | 1 | Chip Select: A low on this pin en-<br>ables the interface functions to<br>receive or transmit. | | 40 | :<br> <br> | Buffer Address: A high on this line indicates the signals in or out are interpreted as a command or status. A low indicates that they are data. | | RD, WA | 2 | Input/Output Read and Write:<br>These signals enable the data | | | | buffers to either send data to the external bus or receive it from the external bus. | | IRG | 1 | Interrupt Request: In a key-<br>board mode, the interrupt line is<br>high when there is data in the | | | | FIFO/Sensor RAM, The interrupt line goes low with each FIFO/ | | | i l | Sensor RAM read and returns : high if there is still information in | | | | the RAM. In a sensor mode, the | | | | interrupt line goes high whenever | | | | a change in a sensor is detected. | | V <sub>SS</sub> , V <sub>CC</sub> | 2 | Ground and power supply pins. | | SL <sub>0</sub> -SL <sub>3</sub> | 4 | Scan Lines: Scan lines which are | | | | used to scan the key switch or<br>sensor matrix and thet display<br>digits. These lines can be either<br>encoded (1 of 16) or decoded (1<br>of 4). | | RL <sub>0</sub> -RL <sub>7</sub> | | Return Line: Return line inputs which are connected to the scan lines through the keys or sensor switches. They have active internal pullups to keep them high until a switch closure pulls one low. They also serve as an 8-bit input in the Strobed Input mode. | | Symbol | Pin<br>No. | Name and Function | |----------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SHIFT | 1 | Shift: The shift input status is stored along with the key position on key closure in the Scanned Keyboard modes, it has an active internal pullup to keep it high until a switch closure pulls it low. | | CNTL/STB | 1 | Control/Strobed Input Mode: For keyboard modes this line is used as a control input and stored like status on a key closure. The line is also the strobe line that enters the data into the FIFO in the Strobed Input mode. (Rising Edge), It has an active internal pullup to keep it high until a switch closure pulls it low. | | OUT A <sub>0</sub> -OUT A <sub>3</sub><br>OUT B <sub>0</sub> -OUT B <sub>3</sub> | 4 4 | Outputs: These two ports are the outputs for the 16 x 4 usplay refresh registers. The data from these outputs is synchronized to the scan lines (SL <sub>2</sub> -SL <sub>3</sub> ) for multiplexed digit displays. The two 4 bit ports may be planked independently. These two ports may also be considered as one 8 bit port. | | 857 | 1 | Blank Display: This output is used to blank the display coring digit switching or try a display blanking community. | ### FUNCTIONAL DESCRIPTION Since data input and display are an integral part of many microprocessor designs, the system designer needs an interface that can control these functions without placing a large load on the CPU. The 8279 provides this function for 8-bit microprocessors. The 8279 has two sections: keyboard and display. The keyboard section can interface to regular typewriter style keyboards or random toggle or thumb switches. The display section drives alphanumeric displays or a bank of indicator lights. Thus the CPU is relieved from scanning the keyboard or refreshing the display. The 8279 is designed to directly connect to the microprocessor bus. The CPU can program all operating modes for the 8279. These modes include: ### Input Modes - Scanned Keyboard with encoded (8 x 8 key keyboard) or decoded (4 x 8 key keyboard) scan lines. A key depression generates a 6-bit encoding of key position. Position and shift and control status are stored in the FIFO. Keys are automatically debounced with 2-key lockout or N-key rollover. - Scanned Sensor Matrix with encoded (8 x 8 matrix switches) or decoded (4 x 8 matrix switches) scan lines. Ke status (open or closed) stored in RAM addressable by CPU. - Strobed Input Data on return lines during control line strobe is transferred to FIFO. ### Output Modes - 8 or 16 character multiplexed displays that can be organized as dual 4-bit or single.8-bit (B<sub>0</sub> = D<sub>0</sub>, A<sub>3</sub> = D<sub>7</sub>). - Right entry or left entry display formats. Other features of the 8279 include: - Mode programming from the CPU. - Clock Prescaler - Interrupt output to signal CPU when there is keyboard or sensor data available. - An 8 byte FIFO to store keyboard information. - 16 byte internal Display RAM for display refresh. This RAM can also be read by the CPU. ## PRINCIPLES OF OPERATION The following is a description of the major elements of the 8279 Programmable Keyboard/Display interface device. Refer to the block diagram in Figure 3. ## VO Control and Data Buffers The I/O control section uses the $\overline{CS}$ , Ao, $\overline{RD}$ and $\overline{WR}$ lines to control data flow to and from the various internal registers and buffers. Air data flow to and from the 8279 is enabled by $\overline{CS}$ . The character of the information, given or desired by the CPU, is identified by Ao. A logic one means the information is a command or status. A logic zero means the information is data. $\overline{RD}$ and $\overline{WR}$ determine the direction of data flow through the Data Buffers. The Data Buffers are bi-directional buffers that connect the informal bus to the external bus. When the chip is not selected $(\overline{CS} = 1)$ , the devices are in a high impedance state. The drivers input during $\overline{WR} \bullet \overline{CS}$ and out; at during $\overline{RD} \bullet \overline{CS}$ . ## Control and Timing Registers and Timing Control These registers store the keyboard and display modes and other operating conditions programmed by the CPU. The modes are programmed by presenting the proper command on the data lines with $A_0=1$ and then sending a WR. The command is latched on the rising edge of WR. Figure 3. Internal Black Diagram The command is then decoded and the appropriate function is set. The timing control contains the basic timing counter chain. The first counter is a ÷ N prescaler that can be programmed to yield an internal frequency of 100 kHz which gives a 5.1 ms keyboard scan time and a 10.3 ms debounce time. The other counters divide down the basic internal frequency to provide the proper key scan, row scan, keyboard matrix scan, and display scan times. #### Scan Counter The scan counter has two modes. In the encoded mode, the counter provides a binary count that must be externally decoded to provide the scan lines for the keyboard and display. In the decoded mode, the scan counter decodes the least significant 2 bits and provides a decoded 1 of 4 scan. Note than when the keyboard is in decoded scan, so is the display. This means that only the first 4 characters in the Display RAM are displayed. In the encoded mode, the scan lines are active high outputs. In the decoded mode, the scan lines are active low outputs. ## Return Buffers and Keyboard Debounce and Control The 8 return tines are buffered and latched by the Return Buffers. In the keyboard mode, these lines are scanned, looking for key closures in that row. If the debounce circuit detects a closed switch, it waits about 10 msec to check if the switch remains closed. If it does, the address of the switch in the matrix plus the status of SHIFT and CONTROL are transferred to the FIFO. In the scanned Sensor Matrix modes, the contents of the return lines is directly transferred to the corresponding row of the Sensor RAM (FIFO) each key scan time. In Strobed input mode, the contents of the return lines are transferred to the FIFO on the rising edge of the CNTL/STB tir a pulse. ### FIFO/Sensor RAM and Status This block is a dual function 8 x 8 RAM. In Keyboard or Strobed Input modes, it is a FIFO. Each new entry is written into successive RAM positions and each is then read in order of entry. FIFO status keeps track of the number of characters in the FIFO and whether it is full or empty. Too many reads or writes will be recognized as an error. The status can be read by an RD with CS low and Ao high. The status-logic also provides an IRO signal when the FIFO is not empty. In Scanned Sensor Matrix mode, the memory is a Sensor RAM. Each row of the Sensor RAM is loaded with the status of the corresponding row of sensor in the sensor matrix. In this mode, IRO is high it a change in a sensor is delected. ### Display Address Registers and Display RAM The Display Address Registers hold the address of the word currently being written or read by the CPU and the two 4-bit hibbies being displayed. The read/write addresses are programmed by CPU command. They also can be set to auto increment after each read or write. The Display RAM can be directly read by the CPU after the correct mode and address is set. The addresses for the A and B hibbles are intomatically updated by the 8279 to match data entry by the CPU. The A and B hibbles can be entered independently or as one word, according to the mode that is set by the CPU. Data entry to the display can be set to either left or right entry. See Interface Considerations for details. ### SOFTWARE OPERATION #### 8279 commands The following commands program the 8279 operating modes. The commands are sent on the Data Bus with $\widetilde{\rm OS}$ low and $|{\rm Ag}|$ high and are leaded to the 8278 on the rising edge of $\widetilde{\rm Vid}$ . ### Keyboard/Display Mode Sat | * | MS | 3 | | | | | | LSE | |-------|----|---|---|---|----|---|---|-----| | Code: | 0 | 0 | 0 | D | D, | К | Κ | Χ | Where DD is the Display Mode and KKK is the Keyboard Mode ### DD - 0 0 8 8-bit character display Ceft entry - 0 1 16 8-bit character display Left entry\* - 0 8 8-bit character display Right entry - 1 1 16 3-bit character display Right entry For description of right and left entry, see interface Considerations. Note that when decoded scan is set in keyboard mode, the display is reduced to 4 characters independent of display mode set. ### KKK - 0 0 0 Encoded Scan Keyboard 2 Key Lockout\* - 0 0 1 Decoded Scan Keyboard 2-Key Lockout - 0 1 0 Encoded Scan Keyboard N-Key Rollover - 0 1 1 Decoded Scan Keyboard N-Key Rollover - 1 0 0 Encoded Scan Sensor Maurix - 1 0 1 Decoded Scan Sensor Matrix: - 1 1 0 Strobed Input, Encoded Display Scan - 1 1 T Strobed Input, Decoded Display Scool ### Program Clock Code: 0 0 1 P P P P All timing and multiplexing signals for the 3279 are generated by an internal prescaler. This prescaler divides the external clock (pin 3) by a programmable integer. Bits PPPPP determine the value of this integer which ranges from 2 to 31. Choosing a divisor that yields 100 kHz will give the specified scan and debounce times. For instance, if Pin 3 of the 8279 is being clocked by a 2 MHz signal, PPPPP should be set to 10100 to divide the clock by 20 to yield the proper 100 kHz sparating frequency. ### Road FIFC/Sensor RAM | Cods: | 0 | 1 | 0 | اۂ | X | A | AA | X = ರೀ.೧೪ <b>೧</b> ೭೧೩ | |-------|---|---|-----|----|---|---|----|------------------------| | | | - | L . | | | _ | | | The CPU sets up the 8279 for a read of the FIFO/Sensor RAM by first writing this command. In the Scan Key- Default after reset. board Mode, the Auto-Increment flag (Al) and the RAM address bits (AAA) are irrelevant. The 8279 will automatically drive the data bus for each subsequent read ( $A_0 = 0$ ) in the same sequence in which the data first entered the FIFO. All subsequent reads will be from the FIFO until another command is issued." In the Sensor Matrix Mode, the RAM address bits AAA select one of the 8 rows of the Sensor RAM. If the Al flagis set (Al = 1), each successive read will be from the subsequent row of the sensor RAM. ### Read Display RAM 0 1 1 AI A Α A Code: The CPU sets up the 8279 for a read of the Display RAM by first writing this command. The address bits AAAA selectione of the 16 rows of the Display RAM. If the Al flag is set (Al = 1), this row address will be incremented after each following read or write to the Display RAM. Since the same counter is used for both reading and writing, this command sets the next read or write address and the sense of the Auto-Increment mode for both operations. ### Write Display RAM 1 0 0 A1 A A A A Code: The CPU sets up the 8279 for a write to the Display RAM by first writing this command. After writing the command with $A_0 = 1$ , all subsequent writes with $A_0 = 0$ will be to the Display RAM. The addressing and Auto-Increment functions are identical to those for the Read Display RAM. However, this command does not affect the source of subsequent Data Reads; the CPU will read from whichever RAM (Olsplay or FIFO/Sensor) which was last specified. If, indeed, the Display RAM was last specified, the Write Display RAM will, nevertheless, change the next Read location. ### Display Write Inhibit/Blanking В 8L BL IW IW X Code: The IW Bits can be used to mask nibble A and nibble 8 in applications requiring separate 4-bit display ports. By setting the IW flag (IW=1) for one of the ports, the port becomes marked so that entries to the Display RAM from the CPU do not affect that port. Thus, if each nibble is input to a BCD decoder, the CPU may write a digit to the Display RAM without affecting the other digit being displayed, it is important to note that bit B<sub>0</sub> corresponds to bit Do on the CPU bus, and that bit A3 corresponds to If the user wishes to blank the display, the BL flags are available for each nibble. The last Clear command issued determines the code to be used as a "blank." This code defaults to all zeros after a reset. Note that both BL flags must be set to blank a display formatted with a single 8-bit port. #### Clear O CD CD CD CF CA Code: The Co bits are available in this command to clear all rows of the Display RAM to a selectable blanking code as follows: During the time the Display RAM is being cleared (~160 µs). — Enable clear display when = 1 (or by CA = 1) it may not be written to. The most significant bit of the FIFO status word is set during this time. When the O.splay RAM becomes available again, it aut matically resets. If the $C_{\rm F}$ bit is asserted ( $C_{\rm F}=1$ ), the PIFO status is cleared and the interrupt output line is reast. Also, the Sensor RAM pointer is set to row 9. $C_A$ , the Clear All bit, has the combined effect in $C_B$ and $C_{\text{F}}$ It uses the $C_{\text{D}}$ clearing code on the Display RAM and also clears FIFO status. Furthermore, it mayn of ronices the internal timing chain. ### End Interrupt/Error Moda Set TTTTEXXXXXX X = Dun't care Code For the sensor matrix modes this command lowers the IRQ line and enables further writing into RAM. (The IRQ line would have been raised upon the detection of a change in a sensor value. This would have also inhibited further writing into the RAM until reset). For the N-key rollover mode — if the E bit is programmed to "1" the chip will operate in the special Error mode. (For further details, see Interface Considerations Section.) ### Status Word The status word contains the FIFO status, error, and display unavailable signals. This word is read by the CPU when Ao is high and CS and RD are low. See Interface Considerations for more detail on status word. ### Data Read Data is read when Ao. CS and RD are all low. The source of the data is specified by the Read FIFO or Read Display commands. The trailing edge of AD will cause in Haddress of the RAM being read to be incremented if the Auto-Increment flag is set. FIFO reads always in ordine of fif no error occurs) independent of Al ### Data Write Data that is written with Ao, OS and WA low is always written to the Display RAM. The address is specified by the latest Read Display or Write Display communic Autoincrementing on the rising edge of WR ondurs if Aliset by the latest display command ### INTERFACE CONSIDERATIONS ### Scanned Keyboard Mode, 2-Key Lockout There are three possible combinations of conditions that can occur during debounce scanning. When a key is depressed, the debounce logic is set. Other depressed keys are looked for during the next two scans. If none are encountered, it is a single key depression and the key position is entered into the FIFO along with the status of CNTL and SHIFT lines. If the FIFO was empty, IRQ will be set to signal the CPU that there is an entry in the FIFO. If the FIFO was full, the key will not be entered and the error flag wiff be set. If another closed switch is encountered, no entry to the FIFO can occur. If all other keys are released before this one, then it will be entered to the FIFO. If this key is released before any other, it will be entirely ignored. A key is entered to the FIFO only once per depression, no matter how many keys were pressed along with it or in what order they were released. If two keys are depressed within the debounce cycle, it is a simultaneous depression. Neither key will be recognized until one key remains depressed alone. The last key will be treated as a single key depression. ### Scanned Keyboard Mode, N-Key Rollover With N-key Rollover each key depression is treated independently from all others. When a key is depressed, the debounce circuit waits 2 keyboard scans and then checks to see if the key is still down. If it is, the key is entered into the FIFO. Any number of keys can be depressed and another can be recognized and entered into the FIFO. If a simultaneous depression occurs, the keys are recognized and entered according to the order the keyboard scan found them. ## Scanned Kayboard — Special Error Modes For N-key rollover mode the user can program a special error mode. This is done by the "End Interrupt/Error Mode Set" command. The debounce cycle and key-validity check are as in normal N-key mode. If during a single debounce cycle, two keys are found depressed, this is considered a simultaneous multiple depression, and sets an error flag. This flag will prevent any further writing into the FIFO and will set interrupt (if not yet set). The error flag could be read in this mode by reading the FIFO STATUS word. (See "FIFO STATUS" for further details.) The error flag is reset by sending the normal CLEAR command with Crimina. ### Sensor Matrix Mode The status of the sensor switch is inputted directly to the Sensor RAM. In this way the Sensor RAM keeps an image of the state of the switches in the sensor matrix. Although debouncing is not provided, this mode has the advantage that the CPU knows how long the sensor was closed and when it was released. A keyboard mode can only indicate a validated closure. To make the software easier, the designer should functionally group the sensors by row since this is the format in which the CPU will read them. In Sensor Matrix mode, the debounce logic is inhibited. The IRQ line goes high if any sensor value change is \_detected at the end of a sensor matrix scan. The IRQ line is cleared by the first data read operation if the Autoincrement flag is set to zero, or by the End interrupt command if the Auto-Increment flag is set to one. . Note: Multiple changes in the matrix Addressed by (SLo-3 = 0) may cause multiple interrupts. (SLo = 0 in the Decoded Mode). Reset may cause the 8279 to see multiple changes. #### Data Format In the Scanned Keyboard mode, the character entered into the FIFO corresponds to the position of the switch in the keyboard plus the status of the CNTL and SHIFT lines (non-inverted). CNTL is the MSB of the character and SHIFT is the next most significant bit. The next three bits are from the scan counter and indicate the row the key was found in. The last three bits are from the scolumn counter and indicate to which return line the key was connected. | MSB | | LSS | |------------|------|------------------| | CNTL SHIFT | SCAN | RETURN | | | 1 | LARO DATA FORMAT | In Strobed input mode, the data is also entered to the FIFO from the return lines. The data is entered by the rising edge of a CNTL/STB line pulse. Data can come from another encoded keyboard or simple switch matrix. The return lines can also be used as a general purpose strobed input. ### Display ### Left Entry Left Entry mode is the simplest display format in that each display position directly corresponds to a byte (or nibble) in the Display RAM. Address 0 in the RAM is the left-most display character and address 15 (or address 7 in 8 character display) is the right most display character. Entering characters from position zero causes the display to fill from the left. The 17th (9th) character is entered back in the left most position and filling again proceeds from there. | 1st entry | 0 1 Display RAM Address | |------------|----------------------------------| | 2nd entry | 0 1 14 15 | | 16th entry | 0 1 14 15 | | 17th entry | 0 1 14 13 | | 18th entry | 0 1 14 15 | | | LEFT ENTRY MODE (AUTO INCREMENT) | ### Right Entry Right entry is the method used by most electronic calculators. The first entry is placed in the right most display character. The next entry is also placed in the right most character after the display is shifted left one character. The left most character is shifted off the end and is lost. Note that now the display position and register address do not correspond. Consequently, entering a character to an arbitrary position in the Auto Increment mode may have unexpected results. Entry starting at Display RAM address 0 with sequential entry is recommended. ### Auto Increment In the Left Entry mode, Auto Incrementing causes the address where the CPU will next write to be incremented by one and the character appears in the next location. With non-Auto incrementing the entry is both to the same RAM address and display position. Entry to an arbitrary address in the Auto Increment mode has no undesirable side effects and the result is predictable: | 1st entry | 0 1 2 3 4 5 6 7 Display RAM Address | |-----------|-----------------------------------------| | | 0 1 2 3 4 5 6 7 | | 2nd entry | 1 2 | | | 0 1 2 3 4 5 6 7 | | Command | 1 2 | | 10010101 | Enter next at Location 5 Auto Increment | | | 0 1 2 3 4 5 6 7 | | 3rd entry | 1 2 3 | | | 0 1 2 3 4 5 6 7 | | Ath entry | 1 2 3 4 | | • | LEFT ENTRY MODE<br>(AUTO INCHEMENT) | In the Right Entry mode, Auto Incrementing and nonincrementing have the same effect as in the belt Entry excupt if the address sequence is interrapted Starting at an arbitrary location operates as shown below: 0 1 2 3 4 5 6 7-4- Display Command 10010101 RIGHT ENTRY MODE (AUTO INCREMENT) Entry appears to be from the initial entry point. #### 8/16 Character Display Formats If the display mode is set to an 8 character display, the on duty-cycle is double what it would be for a 16 character display (e.g., 5.1 ms scan time for 8 characters vs. 10.3 ms for 15 characters with 100 kHz internal frequency). #### G. FIFO Sistus FIFO status is used in the Keyboard and Strobed Input modes to indicate the number of characters in the FIFO and to indicate whether an error has occurred. There are two types of errors possible: overrun and underrun. Overrun occurs when the entry of another character into a full FIFO is attempted. Underrun occurs when the CPU tries to read an empty FIFO. The FIFO status word also has a bit to indicate that the Display RAM was unavailable because a Clear Display or Clear All command had not completed its clearing operation. In a Sensor Matrix mode, a bit is set in the FIFO states word to indicate that at least one sensor clusure indication is contained in the Sensor RAM. in Special Error Mode the S/E bit is showing the error flag and serves as an indication to whether a simultaneous multiple closure error has occurred. Figure 4. System Block Diagram ## MCS®-51 8-BIT CONTROL-ORIENTED MICROCOMPUTERS 8031/8051 8031AH/8051AH 8032AH/8052AH 8751H/8751H-12 - # High Performance HMOS Process - m Internal Timers/Event Counters - 2-Level Interrupt Priority Structure - 32 I/O Lines (Four 8-Bit Ports) - m 64K Program Memory Space - Boolean Processor - Bit-Addressable RAM - Programmable Full Duplex Serial Channel - 111 Instructions (64 Single-Cycle) - 64K Data Memory Space ## ■ Security Feature Protects EPROM Parts Against Software Piracy The MCS\*-51 products are optimized for control applications. Byte-processing and numerical operations on small data structures are facilitated by a variety of fast addressing modes for accessing the internal RAM. The instruction set provides a convenient menu of 8-bit arithmetic instructions, including multiply and divide in structions. Extensive on-chip support is provided for one-bit variables as a separate data type, allowing direct bit manipulation and testing in control and logic systems that require Boolean processing. | | Internal f | Memory | | | |-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------| | Davies | Program | Oata | Timers/<br>Event Counters | interrupts . | | 8052AH<br>8051AH<br>8051AH<br>8032AH<br>8031AH<br>8031<br>8751H<br>8751H-12 | 8K × 8 ROM<br>4K × 8 ROM<br>4K × 8 ROM<br>none<br>none<br>none<br>4K × 8 EPROM<br>4K × 8 EPROM | 256 × 8 RAM<br>128 × 8 RAM<br>128 × 8 RAM<br>256 × 8 RAM<br>128 × 8 RAM<br>128 × 8 RAM<br>128 × 8 RAM<br>128 × 8 RAM<br>128 × 8 RAM | 3 x 16-8it<br>2 x 16-8it<br>2 x 16-8it<br>3 x 16-8it<br>2 x 16-8it<br>2 x 16-8it<br>2 x 16-8it<br>2 x 16-8it | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | The 8751H is an EPROM version of the 8051AH; that is, the on-chip Program Memory can be electrically programmed, and can be erased by exposure to ultraviolet light. It is fully compatible with its predecessor, the 8751-8, but incorporates two new features: a Program Memory Security bit that can be used to protect the EPROM against unauthorized read-out, and a programmable baud rate modification bit (SMOD). SMOD is not present in the 8751H-12. Figure 1. MCS\*-51 Block Diagram ### PIN DESCRIPTIONS VCC Supply voltage. **VSS** Circuit ground. ### Port 0 Port 0 is an 8-bit open drain bidirectional I/O port. As an output port each pin can sink 8 LS TTL inputs. Port 0 pins that have 1s written to them tloat, and in that state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external Program and Data Memory. In this application it uses strong internal pullups when emitting 1s, and can source and sink 8 LS TTL inputs. Port 0 also receives the code bytes during programming of the EPROM parts, and outputs the code bytes during program verification of the ROM and EPROM parts. External pullups are required during program verification. 1.43 % September of the second for the second second ζ, ## Port 1 Port 1 is an 8-bit bidirectional I/O port with internal pullups. The Port 1 output buffers can sink/source 4 LS TTL inputs. Port 1 pins that have 1s written to them are pulled high by the internal pullups, and in that state can be used as inputs, As inputs, Port 1 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups. Port 1 also receives the low-order address bytes during programming of the EPROM parts and during program verification of the ROM and SPROW parts. Figure 2. MCS\*-51 Pin Connections In the 8032AH and 8052AH, Port 1 pins P1.0 and P1.1 also serve the T2 and T2EX functions, respectively. ### Port 2 Port 2 is an 8-bit bidirectional I/O port with Internal pullups. The Port 2 output buffers can sink/source 4 LS TTL inputs. Port 2 pins that have 1s written to them are pulled high by the Internal pullups, and in that state can be used as inputs. As inputs, Port 2 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups. Port 2 emits the high-order address byte during fetches from external Program Memory and during accesses to external Data Memory that use 16-bit addresses (MOVX @DPTR). In this application it uses strong internal pullups when emitting 1s. During accesses to external Data Memory that use 8-bit addresses (MOVX @Ri), Port 2 emits the contents of the P2 Special Function Register. Port 2 also receives the high-order address bits during programming of the EPROM parts and during program verification of the ROM and EPROM parts. #### Port 3 Port 3 is an 8-bit bidifectional I/O port with internal pullups. The Port 3 output buffers can sink/source 4 LS TTL inputs. Port 3 pins that have 1s written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the pullups. Port-3 also serves the functions of various special features of the MCS-51 Family, as listed below: | Port Pin | Alternative Function | | |--------------|--------------------------------|--| | P3.0 | RXD (serial input port) | | | P3.1 | TXD (serial output port) | | | P3.2 | INTO (external interrupt 0) | | | P3.3 | INT1 (external interrupt 1) | | | P3.4 | T0 (Timer 0 external input) | | | P3.5 | T1 (Timer 1 external input) | | | P3.5<br>P3.6 | WA (external data memory write | | | 7 0.0 | strobe) | | | P3.7 | AD (external data memory rood | | | 1 3.7 | strobe) | | ### **RST** Reset input. A high on this pin for two machine cycles while the oscillator is running resets the device. ### ALE/PROG Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory, ALE can drive 8 LS TTL inputs. This pin is also the program pulse input (PROG) during programming of the EPROM parts. In normal operation ALE is emitted at a constant rate of 1/4 the oscillator frequency, and may be used for external timing or clocking purposes. Note, however, that one ALE pulse is skipped during each access to external Data Memory. ### PSEN Program Store Enable is the read strobe to external Program Memory. PSEN can drive 8 LS TTL inputs. When the device is executing code from external Program Memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external Data Memory. ### **EA**/VPP External Access enable EA must be externally held low in order to enable any MCS-51 device to fetch code from external Program Memory locations 0 to 0FFFH (0 to 1FFFH, in the 8032AH and 8052AH). Note, however, that if the Security Bit in the EPROW devices is programmed, the device will not faich code from any location in external Program Memory. This pin also receives the 21V programming supply voltage (VPP) during programming of the EPROM parts. ### XTAL1 Input to the inverting oscillator amplifier. ### XTAL2 Output from the inverting oscillator amplifier. ### **OSCILLATOR CHARACTERISTICS** XTAL1 and XTAL2 are the input and output, respectively, of an inverting amplifier which can be configured for use as an on-chip oscillator, as shown in Figure 3. Either a quartz crystal or ceramic resonator may be used. More detailed information concerning the use of the on-chip oscillator is available in Application Note AP-155, "Oscillators for Microcontrollers." To drive the device from an external clock source, XTAL1 should be grounded, while XTAL2 is driven, as shown in Figure 4. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the Data Shaat must be observed. Figure 3. Oscillator Connections Figure 4. External Drive Configuration ## MCM63258 ## Product Preview ### 256K BIT READ ONLY MEMORY The MCM83256 is a MOS mask programmable byte-organized Read Only Memory (ROM). The MCM63256 is organized as 32,768 bytes of 8 bits and is fabricated using Motorola's high performance N-channel silicon gate technology (HMOS). This device is designed to provide maximum circuit density and reliability with highest possible performance while maintaining low power dissipation and wide operating margins and remaining fully compatible with TTL inputs and outputs. The active level of the Chip Enable and the Output Enable, along with the memory contents, are defined by the user. The Chip Enable input deselects the output and puts the chip in a power-down mode. - Single ± 10%"+5 Volt Power Supply - Fully Static Periphery No Clocking Required on Chip Enable - · Automatic Power Down - Power Dissipation 100 mA Active (Maximum) (Unloaded) - 15 mA Standby (Maximum) - Current Surge Suppression When Powering Up Device - Program Layer Late in Process for Quick Turnaround Time - e 160 ns Maximum Access from Address and Chip Enable - 28-Pin JEDEC Standard Package and Pinout ### ADDITIONAL FEATURE Address (A14) is User Selectable for Either Pin 27 or Pin 1 ### HMOS (N-CHANNEL, SILICON GATE) 32,768×8 BIT READ ONLY MEMORY ### PIN ASSIGNMENT | N/C[ | To V | ಚಿತ್ರಗಳು | |------------|------|--------------| | A12 ( | 2 | 27 ] 7:14 | | A7 [ | 3 | 26 DA13 | | A6 [ | 4 | 25 ] 28 | | A\$ ( | 5 | \$477.40 | | A4 [ | 6 | 23 TA11 | | A3 [ | 7 | :: J | | A2 [ | 1 | 21 DA10 | | A1[ | 9 | 20 🏳 🖡 | | AQ [ | 10 | 19 JG7 | | $\infty$ [ | 11 | 18 🖸 🗆 | | 01[ | 12 | 17 🛚 🗅 🖰 🖰 5 | | 02 [ | 13 | 15 🖸 🗀 | | ٧ss¤ | 14 | 15 DO3 | | | | | | PIN NAMES | | | | | |-----------|--------------------|--|--|--| | AD-A14 | Address | | | | | r- | , Chip Enative | | | | | ð | Output Enable | | | | | 00:07 | . Dare Output | | | | | YCC. | + 5 V Power Supply | | | | | VSS | Ground | | | | | 33 | | | | | This pocument contains information on a product underdevelopment. Motorola reserves the right to change or discontinue this product without notice. ## 256 CBIT (32,768 x 8) CMOS STATIC RANDOM ACCESS MEMORY WITH DATA RETENTION AND LOW POWER The Fujitsu M8 84256 is a 32,768-word by 8-bit static random access mainory fabricated with a CMOS silicon gate process. The memory utilizes asynchronouse circuitry and may be maintained in any state for an indefinite period of time. All pins are TTL compatible, and a single +5 volts power supply is required. The MB 84256 is ideally suited for use in microprocesser systems and other applications where fast access time and ease of use are required. All devices offer the advantages of low power dissipation, low cost and high performance. 32,768 x 8 bits Organization: Fast access time: 100 ns max. (MB 84256-10/10L/10LL) 120 ns max. (MB 84256-12/12L/12LL) 150 ns max. (MB 84256-15/15L/15LL) • Completely static operation: No clock required TTL compatible inputs/outputs Three-state outputs Single +5V power supply, ±10% tolerance Low power standby: CMOS level: .5.5 mW·max. (MB 84256-10/12/15) 0.55 mW max. (MB 84256-10L/10LL/12L/12LL/ 15L/15LL) 16.5 mW max. (MB 84256-10/10L/10LL/12/12L/12LL/ TTL level: 15/15L/15LL) e Data retention: 2.0V Standard 28-pin DIP (600 mil) (Suffix: -P) Standard 28-pin Bend-type Plastic Flat Package (450 mil) (Suffix: -PF) Standard 32-pad LCC (Suffix: -CV) ## ABSOLUTE MAXIMUM RATINGS (500 NOTE) | Rating | | Symbol | Value | Unit | | |------------------------------|---------|--------|------------------------------|----------|--| | Supply Voltage | | Vcc | -0.5 to +7.0 | ٧ | | | Input Voltage | | VIN | -0.5 to V <sub>CC</sub> +0.5 | ٧ | | | Output Voltage | | Vour | -0.5 to V <sub>CC</sub> +0.5 | <u>v</u> | | | Temperature Under Bias | | Tulas | -10 to +85 | °c | | | Storage<br>Temperature Range | CERAMIC | | -65 to +150 | °c | | | | PLASTIC | TSTG | -40 to +125 | | | ## 27512 512K (64K x 8) PRODUCTION AND UV ERASABLE PROM - Software Carrier Capability - 170 ns Maximum Access Time - E Two-Line Control - **z** int<sub>e</sub>ligent identifier™ Mode Automated Programming Operations - ☐ Low Power — 125 mA max. Active - 40 mA max. Standby - ន Inteligent Programming ារ Algorithm - m Available in 28-Pin Cerdip (See packaging spec order ≠231369) m TTL Compatible The Intel 27512 is a 5V-only, 524,288-bit ultraviolet Erasable and Electrically Programmable Read Only Merilory (EPROM) organized as 64K words by 8 bits. This ensures compatibility with high-performance microprocessors, such as the Intel 8 MHz iAPX 286, allowing full speed operation without the addition of performance-degrading WAIT states. The 27512 is also directly compatible with Intel's 8051 family of microcontrollors. The 27512 enables implementation of new, advanced systems with firmware intensive architectures. The combination of the 27512's high-density, cost-effective EPROM storage, and new advanced microprocessors having megabyte addressing capability provides designers with opportunities to engineer user-friendly, high-reliability, high-performance systems. The 27512's large storage capability of 64 K-bytes enables it to function as a high-density software carrier. Entire operating systems, diagnostics, high-level language programs and specialized application software can reside in a 27512 EPROM directly on a system's memory bus. This permits immediate microprocessor access and execution of software and oliminates the need for time-consuming disk accesses and downloads. Two-line control and JEDEC-approved, 28-pin packaging are standard features of all Intel high-density EPROMs. This assures easy microprocessor interfacing and minimum design efforts when upgrading, adding, or choosing between nonvolatile memory alternatives. The 27512 is manufactured using Intel's advanced HMOS \*II-E technology. \*HMOS is a patented process of Intel Corporation. Figure 1. Biock Diagram 231068- ### Pin Names | . A <sub>0</sub> -A <sub>15</sub> | Addresses | |-----------------------------------|--------------------| | Œ | Chip Enable | | ŌĒ/Vpp | Outputs Enable/Vpp | | O <sub>0</sub> -O <sub>7</sub> | Outputs | | D.U. | Don't Use | | 27513 | 27254<br>270254<br>870258 | 27 128<br>27 128A | 2764<br>2764A<br>27084<br>87084 | |--------------------------------|---------------------------|-------------------|---------------------------------| | DU. | Vpp | Vpp | Vpe | | A 12 | A., | A12 | A12 | | A, | A., | A <sub>7</sub> | Az | | 4, | - 44 | A <sub>4</sub> | <b>~</b> | | 45 | ٨, | A4 | 45 | | A <sub>4</sub> | A <sub>4</sub> | A, | A | | A3 | ٨ | ٨٦ | Ag | | A2 | ٨, | A <sub>2</sub> | A <sub>2</sub> | | A, | ۸, | A <sub>1</sub> | A <sub>1</sub> | | 40 | - √₀ | A0 | <b>~</b> ₀ | | 00/00 | o₀ . | ್ಯ | C <sub>0</sub> | | D <sub>1</sub> /O <sub>3</sub> | 01 | 0, | 0, | | 07 | O <sub>2</sub> | O₂ | O <sub>2</sub> | | Gnd | Gnd | Gnd | Gnd | | | • | | | |--------------|------------|----------------------|----| | | 27512 | 2 | | | | | | | | A15 C | | 21 □ 7∞ | | | 4,2 □ | <b>1</b> 2 | 27 🏳 A <sub>14</sub> | | | <b>≯</b> 7 □ | 3 | 29 D A13 | | | 4, 0 | | 25 🗀 🔩 | | | تا کم | 5 | 24 77 49 | | | A4 [ | E | 23 711 | | | A3 🗆 | 7 | 22 3 OE / Vpg | | | ^2 □ | 5 | 2: 🗀 A10 | | | ۸, ⊏ | 9 | 20,∃č[ | | | | 10 | 12 07 | ٠. | | 0, ⊏ | 11 | ार 🔁 📞 | | | 0, ⊂ | 17 | 17 🗀 03 | | | ᅆᇃᄄ | | 15 🗖 0, | | | сно⊏ | 14 | 15 🗀 03 | | | | | 231088-2 | | | 2784A<br>2784A<br>27084<br>87084 | 27128<br>27128A | 27256<br>270258<br>870256 | 27515 | |----------------------------------|------------------|---------------------------|------------------------| | Vας | Yuc | Væ | V <sub>C</sub> C<br>₩E | | 220 | 2.271 | A <sub>14</sub> | 1 | | N.C. | 412 | *·3 | F A-1 | | ^e . | A-6 | ٨. | ** | | to . | A <sub>4</sub> | *. | 1.0 | | A11 | A11 [ | Α : | A | | ÇE . | ्ट | FF. | ** -,- | | A <sub>10</sub> ! | Aso | A - 17 | A . | | CENCLES ; | 76 | CTALLS. | 7.5 | | c, i | $O_{I}$ | C) - | *** | | c. | Ce . | Cs. | €. | | C <sub>5</sub> | O <sub>2</sub> ; | O <sub>5</sub> | ್ಯತ್ತ | | ٥. ا | ا ٥٠ | C. | , G. | | 03 | O <sub>3</sub> : | Cr. | 100 | Figure 2. Pin Configurations ## EXTENDED TEMPERATURE (EXPRESS) EPROMs The Intel EXPRESS EPROM family is a series of electrically programmable read only memories which have received additional processing to enhance product characteristics. EXPRESS processing is available for several densities of EPROM, allowing the choice of appropriate memory size to match system applications. EXPRESS EPROM products are available with 168 ±8 hours, 125°C dynamic burninusing Intel's standard bias configuration. This process exceeds or meets most industry specifications of burn-in. The standard EXPRESS EPROM operating temperature range is 0°C to 70°C. Extended operating temperature range (~40°C to +85°C) EXPRESS products are available. Like all Intel EPROMs, the EXPRESS EPROM family is inspected to 0.1% electrical AQL. This may allow the user to reduce or eliminate incoming inspection testing. ### EXPRESS EPROM PRODUCT FAMILY ### PRODUCT DEFINITIONS | Type | Operating temperature | Burn-m 125 C (711) | |------|-----------------------|--------------------| | a | 0°C to +70°C | 168 ±8 | | Τ - | -40°C to +85°C | None | | L- | -40°C to +85°C | 165 ± 8 | | | Q<br>T<br>L | T -40°C to +85°C | ### EXPRESS OPTIONS ### 27512 VERSIONS | Packaging Options | | | |--------------------|---------|--| | Speed Versions | Cerdlp | | | -170V05 | a | | | -200V05, -200V10 | Q, L | | | -STD, -25, -250V10 | O, T, L | | | -3, -30 | Q, T, L | | ## 74LS245 Transceiver Octal Transceiver (3-State) Product Specification ### Logic Products ### **FEATURES** - Octal bidirectional bus interface - 3-State buffer outputs - PNP inputs for reduced loading - Hysteresis on all Data inputs ### DESCRIPTION The 'LS245 is an octal transcoiver featuring non-inverting 3-State bus compatible outputs in both send and receive directions. The outputs are all capable of sinking 24mA and sourcing up to 15mA, producing very good capacitive drive characteristics. The device features a Ohip Enable (CE) input for easy cascadng and a Send/Receive (S/R) input for prection control. All data inputs have hysteresis built in to minimize AC noise effects. | | TYPICAL PROPAGATION | TYPICAL SUPPLY CURRENT | ; | |---------|---------------------|------------------------|---| | TYPE | DELAY | (TOTAL) | ; | | 74LS245 | 8ns | 58mA | | ### ORDERING CODE | ONDENING CODE | COMMERCIAL BANGE | |----------------|----------------------------------------------| | PACKAGES | $V_{CC} = 5V + 5\%(T_A = 0\%C + 0) + 7.0\%C$ | | Plastic D'P | K.241.82450 | | Plastic SOL-20 | N74ES245D | ### NOTE: For information regarding devices processed to Michary Specifications, see the Legentics Michary 1999 and Data Manual. ## INPUT AND OUTPUT LOADING AND FAN-OUT TABLE | PINS | <br>DESCRIPTION | 7410 | |------|-----------------|----------------------| | Ali | <br>Imputs | 18.50 | | Al | <br>Outgoals | i parties<br>i santa | | | | | Where a 74US unit load (USo) is 20pA by and -0.4mA is ### PIN CONFIGURATION ### LOGIC SYMBOL ### LOGIC SYMBOL (IEEE/IEC)