DS: [BX + SI] 10H\*DS ⇔ 10000 [BX] ⇔ +2000 [SI] ⇔ +3000 15000H – Effective address #### v. Relative based index: MOV AX, 5000[BX][SI] DS : [BX+SI+5000] 10H\*DS ⇔ 10000 [BX] ⇔ +2000 [SI] ⇔ +3000 +5000 1A000H - Effective address ### Pin Diagram of 8086: #### Signal description of 8086: - The 8086 is a 16-bit microprocessor. This microprocessor operates in single processor or multiprocessor configurations to achieve high performance. - > The pin configuration of 8086 is shown in the figure. Some of the pins serve a particular function in minimum mode (single processor mode) and others function in maximum mode (multiprocessor mode). #### The 8086 signals are categorized into 3 types: - 1. Common signals for both minimum mode and maximum mode. - 2. Special signals which are meant only for minimum mode - 3. Special signals which are meant only for maximum mode # Common Signals for both Minimum mode and Maximum mode: $AD_7 - AD_0$ : The address/ data bus lines are the multiplexed address data bus and contain the right most eight bit of memory address or data. The address and data bits are separated by using ALE signal. $AD_{15} - AD_8$ : The address/data bus lines compose the upper multiplexed address/data bus. This lines contain address bit $A_{15} - A_8$ or data bus $D_{15} - D_8$ . The address and data bits are separated by using ALE signal. $A_{19}/S_6 - A_{18}/S_3$ The address/status bus bits are multiplexed to provide address signals $A_{19} - A_{16}$ and also status bits $S_6 - S_3$ . The address bits are separated from the status bits using the ALE signals. The status bit $S_6$ is always a logic 0, bit $S_5$ indicates the condition of the interrupt flag bit. The $S_4$ and $S_3$ indicate which segment register is presently being used for memory access. $\overline{BHE}$ / $S_7$ The bus high enable (BHE) signal is used to indicate the transfer of data over the higher order $(D_{15} - D_8)$ data bus. It goes low for the data transfer over $D_{15} - D_8$ and is used to derive chip select of odd address memory bank or peripherals. | BHE | $A_0$ | Indication | |-----|-------|------------------------------------| | 0 | 0 | Whole word | | 0 | 1 | Upper byte from or to odd address | | 1 | 0 | Lower byte from or to even address | | 1 | 1 | None | RD : Read: whenever the read signal is at logic - 0, the data bus receives the data from the memory or I/O devices connected to the system - READY: This is the acknowledgement from the slow devices or memory that they have completed the data transfer operation. This signal is active high. - INTR: Interrupt Request: Interrupt request is used to request a hardware interrupt of INTR is held high when interrupt enable flag is set, the 8086 enters an interrupt acknowledgement cycle after the current instruction has completed its execution. - TEST: This input is tested by "WAIT" instruction. If the TEST input goes low; execution will continue. Else the processor remains in an idle state. - NMI- Non-maskable Interrupt: The non-maskable interrupt input is similar to INTR except that the NMI interrupt does not check for interrupt enable flag is at logic 1, i.e, NMI is not maskable internally by software. If NMI is activated, the interrupt input uses interrupt vector 2. - RESET: The reset input causes the microprocessor to reset itself. When 8086 reset, it restarts the execution from memory location FFFFOH. The reset signal is active high and must be active for at least four clock cycles. - CLK: Clock input: The clock input signal provides the basic timing input signal for processor and bus control operation. It is asymmetric square wave with 33% duty cycle. - Vcc (+5V): Power supply for the operation of the internal circuit - GND: Ground for the internal circuit - MN / MX : The minimum/maximum mode signal to select the mode of operation either in minimum or maximum mode configuration. Logic 1 indicates minimum mode. - Minimum mode Signals: The following signals are for minimum mode operation of 8086. - $M/\overline{IO}$ Memory/IO $M/\overline{IO}$ signal selects either memory operation or I/O operation. This line indicates that the microprocessor address bus contains either a memory address or an I/O port address. Signal high at this pin indicates a memory operation. This line is logically equivalent to $\overline{S_2}$ in maximum mode. - INTA Interrupt acknowledge: The interrupt acknowledge signal is a response to the INTR input signal. The INTA signal is normally used to gate the interrupt vector number onto the data bus in response to an interrupt request. - ALE- Address Latch Enable: This output signal indicates the availability of valid address on the address/data bus, and is connected to latch enable input of latches. - $DT/\overline{R}$ : Data transmit/Receive: This output signal is used to decide the direction of date flow through the bidirectional buffer. $DT/\overline{R}=1$ Indicates transmitting and $DT/\overline{R}=0$ indicates receiving the data. - DEN Data Enable: Data bus enable signal indicates the availability of valid data over the address/data lines. - WR Write: whenever the write signal is at logic 0, the data bus transmits the data to the memory or I/O devices connected to the system. - HOLD: The hold input request a direct memory access (DMA). If the hold signal is at logic 1, the micro process stops its normal execution and places its address, data and control bus at the high impedance state. HLDA: Hold acknowledgement indicates that 8086 has entered into the hold state. Maximum mode signal: The following signals are for maximum mode operation of 8086. $\overline{S}_2, \overline{S}_1, \overline{S}_0$ - Status lines: These are the status lines that reflect the type of operation being carried out by the processor. These status lines are encoded as follows | $\bar{S}_2$ | $\bar{S}_{_{1}}$ | $\overline{S}_0$ | Function | |-------------|------------------|------------------|-----------------------| | 0 | 0 | 0 | Interrupt Acknowledge | | 0 | 0 | 1 | Read I/O port | | 0 | 1 | O | Write I/O port | | 0 | 1 | 1 | Halt | | 1 | O | o | Code Access | | 1 | 0 | 1 | Read memory | | 1 | 1 | 0 | Write memory | | 1 | 1 | 1 | Passive (In active) | LOCK: The lock output is used to lock peripherals off the system, i.e, the other system bus masters will be prevented from gaining the system bus. $QS_1$ and $QS_0$ - Queue status: The queue status bits shows the status of the internal instruction queue. The encoding of these signals is as follows | QS <sub>1</sub> | $QS_0$ | Function | |-----------------|--------|-----------------------------| | 0 | 0 | No operation, queue is idle | | 0 | 1 | First byte of opcode | | 1 | 0 | Queue is empty | | 1 | 1 | Subsequent byte of opcode | RQ/GT1 and RQ/GT0- request/Grant: The request/grant pins are used by other local bus masters to force the processor to release the local bus at the end of the processors current bus cycle. These lines are bi-directional and are used to both request and grant a DMA operation. $\overline{RQ}/\overline{GT0}$ is having higher priority than $\overline{RQ}/\overline{GT1}$ ## 8086 Minimum mode system operation with timing diagrams: ➤ In a minimum mode 8086 system, the microprocessor 8086 is operated in minimum mode by strapping its MN/MX<sup>I</sup> pin to logic1. - In this mode, all the control signals are given out by the microprocessor chip itself. There is a single microprocessor in the minimum mode system. The remaining components in the system are latches, transreceivers, clock generator, memory and I/O devices. - Some type of chip selection logic may be required for selecting memory or I/O devices, depending upon the address map of the system. - > The general system organization is shown in below figure. Figure: Minimum mode 8086 system - > The latches are generally buffered output D-type flip-flops, like, 74LS373 or 8282. - They are used for separating the valid address from the multiplexed address/data signals and are controlled by the ALE signal generated by 8086. - Since it has 20 address lines and 16 data lines, the 8086 CPU requires three octal address latches and two octal data buffers for the complete address and data separation. - Transreceivers are the bidirectional buffers and sometimes they are called as data amplifiers. They are required to separate the valid data from the time multiplexed address/data signal. - > They are controlled by two signals, namely, DEN' and DT/R'. The DEN' signal indicates that the valid data is available on the data bus, while DT/R' indicates the direction of data, i.e. from or to the processor. - > The system contains memory for the monitor and users program storage. Usually, EPROMS are used for monitor storage, while RAMs for users program storage. - A system may contain I/O devices for communication with the processor as well as some special purpose I/O devices. - > The clock generator generates the clock from the crystal oscillator and then shapes it and divides to make it more precise so that it can be used as an accurate timing reference for the system. - The clock generator also synchronizes some external signals with the system clock. - The working of the minimum mode configuration system can be better described in terms of the timing diagrams rather than qualitatively describing the operations.