# **Unit 2:**

### **Bus Cycles and System Architecture**

# Initialization

### Initialization

- After a signal on the RESET pin, certain registers of 80386 are set to predefined values.
- These values are adequate to enable execution of a bootstrap program.

### **Processor State after RESET**

- Contents of EAX depends on results power-up self test
- Self-test may be requested externally by assertion of BUSY# at the end of RESET (EAX=0 if the 80386 passed the test, else 80386 unit is faulty)
- If self-test is not requested , EAX is undefined
- DX holds a component identifier and revision number (DH=3, indicates 80386, DL=unique identifier of the revision level)



### Processor State after RESET

• Control Register 0 (CR0) contains





# State of flags and other registers

The remaining registers and flags are set as follows:

| EFLAGS      | 5     | = 00 | 000002H |
|-------------|-------|------|---------|
| IP          |       | = 00 | 00FFF0H |
| CS select   | or    | = 00 | OH      |
| DS select   | or    | = 00 | 000H    |
| ES select   | or    | = 00 | 00H     |
| SS selected | or    | = 00 | 00H     |
| FS select   | or    | = 00 | 00H     |
| GS select   | or    | = 00 | 00H     |
| IDTR:       |       |      |         |
|             | base  | = 0  |         |
|             | limit | = 03 | FFH     |

All registers not mentioned above are undefined.

### Functional Pin Diagram



# Pin Description Table

| Symbol                          | bol Type Name and Function |                                                                                                                                                                                                 |  |
|---------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CLK2                            | 1                          | CLK2 provides the fundamental timing for the Intel386 DX.                                                                                                                                       |  |
| D <sub>31</sub> -D <sub>0</sub> | 1/0                        | DATA BUS inputs data during memory, I/O and interrupt acknowledg<br>read cycles and outputs data during memory and I/O write cycles.                                                            |  |
| A31-A2                          | 0                          | ADDRESS BUS outputs physical memory or port I/O addresses.                                                                                                                                      |  |
| BE0#-BE3#                       | 0                          | BYTE ENABLES indicate which data bytes of the data bus take part in<br>a bus cycle.                                                                                                             |  |
| W/R#                            | 0                          | WRITE/READ is a bus cycle definition pin that distinguishes write<br>cycles from read cycles.                                                                                                   |  |
| D/C#                            | 0                          | DATA/CONTROL is a bus cycle definition pin that distinguishes dat<br>cycles, either memory or I/O, from control cycles which are: interrup<br>acknowledge, halt, and instruction fetching.      |  |
| M/IO#                           | 0                          | MEMORY I/O is a bus cycle definition pin that distinguishes memo<br>cycles from input/output cycles.                                                                                            |  |
| LOCK#                           | 0                          | BUS LOCK is a bus cycle definition pin that indicates that othe<br>system bus masters are denied access to the system bus while it<br>active.                                                   |  |
| ADS#                            | 0                          | ADDRESS STATUS indicates that a valid bus cycle definition an address (W/R#, D/C#, M/IO#, BE0#, BE1#, BE2#, BE3# an A <sub>31</sub> -A <sub>2</sub> ) are being driven at the Intel386 DX pins. |  |
| NA#                             | 11                         | NEXT ADDRESS is used to request address pipelining.                                                                                                                                             |  |
| READY #                         | 11                         | BUS READY terminates the bus cycle.                                                                                                                                                             |  |
| BS16#                           |                            | BUS SIZE 16 input allows direct connection of 32-bit and 16-bit data buses.                                                                                                                     |  |
| HOLD                            | 11                         | BUS HOLD REQUEST input allows another bus master to request<br>control of the local bus.                                                                                                        |  |

# Pin Description Table (Cont...)

| Symbol          | Туре | Name and Function                                                                                                                                                                    |  |
|-----------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| HLDA            | 0    | BUS HOLD ACKNOWLEDGE output indicates that the Intel386 DX has surrendered control of its local bus to another bus master.                                                           |  |
| BUSY #          | L.   | BUSY signals a busy condition from a processor extension.                                                                                                                            |  |
| ERROR#          |      | ERROR signals an error condition from a processor extension.                                                                                                                         |  |
| PEREQ           | I    | PROCESSOR EXTENSION REQUEST indicates that the processo<br>extension has data to be transferred by the Intel386 DX.                                                                  |  |
| INTR            | I    | INTERRUPT REQUEST is a maskable input that signals the Intel38<br>DX to suspend execution of the current program and execute a<br>interrupt acknowledge function.                    |  |
| NMI             | l    | NON-MASKABLE INTERRUPT REQUEST is a non-maskable input<br>that signals the Intel386 DX to suspend execution of the current<br>program and execute an interrupt acknowledge function. |  |
| RESET           | E.   | RESET suspends any operation in progress and places the Intel38<br>DX in a known reset state. See Interrupt Signals for additional<br>information.                                   |  |
| N/C             |      | NO CONNECT should always remain unconnected. Connection of<br>N/C pin may cause the processor to malfunction or be incompatible<br>with future steppings of the Intel386 DX.         |  |
| Vcc             | l.   | SYSTEM POWER provides the +5V nominal D.C. supply input.                                                                                                                             |  |
| V <sub>SS</sub> | I    | SYSTEM GROUND provides 0V connection from which all inputs and<br>outputs are measured.                                                                                              |  |

# I/O Addressing

The 80386 allows input/output to be performed in either of two ways:

- a. By means of a separate I/O address space (using specific I/O instructions)
- b. By means of memory-mapped I/O (using generalpurpose operand manipulation instructions )

### Separate I/O address space (An Isolated I/O)

- $\checkmark$  I/O devices treated separately from memory.
  - Hardware and software architecture of 8088/8086 support separate memory I/O address space.
- Can be accessed as either byte-wide or word-wide.
- Can be treated as either independent byte-wide I/O ports or word-wide I/O ports.
- ✓ Page 0:
  - Certain I/O instructions can only perform operations to ports in this part of the address range.
  - Other I/O instructions can input/output data for ports anywhere in the address space.

| FFFF   | Port 65 535       |      |
|--------|-------------------|------|
|        | I/O address space |      |
| 00FF   | Port 255          |      |
| ( 00FE | Port 254          |      |
|        |                   |      |
|        |                   |      |
|        |                   |      |
| 0004   | Port 4            |      |
| 0003   | Port 3            |      |
| 0002   | Port 2            | Port |
| 0001   | Port 1            |      |
| 0000   | Port 0            | Por  |
|        |                   | 1    |

Page 0

Port 1 (16 bit port)

Port 0 (16 bit port)

### Separate I/O address space (An Isolated I/O)



#### Advantages: -

- 1 MByte memory address space is available for use with memory.
- Special instructions have been provided in the instruction set of 8088/8086 to perform isolated I/O input and output operations.
- These instructions have been tailored to maximize I/O performance.

### Disadvantages: -

All input and output data transfers must take place between AL or AX register and the I/O port

11

Page 0

# Memory-mapped I/O

### I/O devices is placed in memory address space of the microcomputer.

- The memory address space is assigned to I/O devices.
- MPU looks at the I/O port as though it is a storage location in memory.
- Make use of instructions that affect data in memory rather than special input/output instructions.



12

# Memory-mapped I/O



#### Advantages:

- Many more instructions and addressing modes are available to perform I/O operations.
- ✓ I/O transfers can now take place between I/O port and internal registers other than just AL/AX.

### <u>Disadvantages:</u>

- Memory instructions tend to execute slower than those specifically designed for isolated I/O.
- Part of the memory address space is lost

# I/O Instructions

There are two classes of I/O instruction:

1. Those that transfer a single item (byte, word, or doubleword) located in a register.

2. Those that transfer strings of items (strings of bytes, words, or doublewords) located in memory.

These are known as "string I/O instructions" or "block I/O instructions".

### Register I/O Instructions

- The I/O instructions IN and OUT are provided to move data between I/O ports and the EAX (32-bit I/O), the AX (I6-bit I/O), or AL (8-bit I/O) general registers.
- IN and OUT instructions addresses I/O ports either directly, with the address of one of up to 256 port

| Mnemonic | Meaning                       | Format       | Operation                        |
|----------|-------------------------------|--------------|----------------------------------|
| IN       | Input direct                  | IN Acc, Prt  | (Acc) ← (Port)<br>Acc = AL or AX |
|          | Input indirect<br>(variable)  | IN Acc, DX   | (Acc) ← ((DX))                   |
| OUT      | Output direct                 | OUT Prt, Acc | (Port) ← (Acc)                   |
|          | Output indirect<br>(variable) | OUT DX, Acc  | ((DX)) ← (Acc)                   |

## Block I/O Instructions

- The block (or string) I/O instructions INS and OUTS move blocks of data between I/O ports and memory space.
- Block I/O instructions use the DX register to specify the address of a port in the I/O address space.
- Block I/O instructions use either SI or DI to designate the source or destination memory address.
- For each transfer, SI or DI are automatically either incremented or decremented as specified by the direction bit in the flags register.

### **Read and Write Cycles**

- Data transfers occur as a result of bus cycles, classified as read or write cycles.
- Two choices of address timing are dynamically selectable: non-pipelined, or pipelined.
- After a bus idle state, the processor always uses non-pipelined address timing.
- However, the NA# (Next Address) input may be asserted to select pipelined address timing for the next bus cycle.

- When pipelining is selected and the Intel386 DX has a bus request pending internally, the address and definition of the next cycle is made available even before the current bus cycle is acknowledged by READY#.
- Terminating a read cycle or write cycle, like any bus cycle, requires acknowledging the cycle by asserting the READY# input.
- Until acknowledged, the processor inserts wait states



## Non-pipelined read & write cycles

- At the end of the second bus state within the bus cycle, READY# is sampled
- If asserted the bus cycle terminates
- Else the cycle continues another bus state (a wait state) and READY# is sampled again at the end of that state.
- This continues indefinitely until the cycle is acknowledged by READY# asserted.

19

# Unit 2: Bus Cycles and System Architecture

# System Architecture

# Systems Registers

- EFLAGS
- Memory Management Registers
- Control Registers
- Debug Registers
- Test Registers

# Systems Registers

### ✓ <u>EFLAGS</u>

- Memory Management Registers
- Control Registers
- Debug Registers
- Test Registers





NOTE

0 OR 1 INDICATES INTEL RESERVED. DO NOT DEFINE.

System Flags of EFLAG REGISTER

# Systems Registers

- EFLAGS
- ✓ <u>Memory Management Registers</u>
- Control Registers
- Debug Registers
- Test Registers

# Memory-Management Registers

- Four registers of the 80386 locate the data structures that control segmented memory management:
  - ✓ GDTR Global Descriptor Table Register
  - ✓ LDTR Local Descriptor Table Register
- These registers point to the segment descriptor tables GDT and LDT.
- IDTR Interrupt Descriptor Table Register This register points to a table of entry points for interrupt handlers (the IDT).
- TR Task Register

This register points to the information needed by the processor to define the current task.

# Systems Registers

- EFLAGS
- Memory Management Registers
- ✓ <u>Control Registers</u>
- Debug Registers
- Test Registers





# Systems Registers

- EFLAGS
- Memory Management Registers
- Control Registers
- ✓ <u>Debug Registers</u>
- Test Registers

# Debug Registers

- Six registers: to control debug features
- Accessed by variants of the MOV instruction
- debug registers are privileged resources

### **Registers are:**

- Debug Address Registers (DRO-DR3)
- ✓ Debug Status Register (DR6)
- Debug Control Register (DR7)



NOTE: O MEANS INTEL INTEL RESERVED. DO NOT DEFINE.

# Systems Registers

- EFLAGS
- Memory Management Registers
- Control Registers
- Debug Registers

### ✓ <u>Test Registers</u>

30



- Two test registers are provided for the purpose of testing.
- TR6 is the test command register, and TR7 is the test data register.
- The test registers are privileged resources; in protected mode, the MOV instructions that access them can only be executed at privilege level 0



### The Test Command Register (TR6)

- C: Command bit, two commands: '0'- write entries into the TLB and '1' perform TLB lookups
- Linear Address:
  - on a TLB write command, a TLB entry is allocated to this linear address and the rest of that TLB entry is set as per the values of TR7 & TR6
  - ✓ on a TLB lookup command, the TLB is interrogated as per this value and if one and only one TLB entry matches, the rest of the fields of TR6 & TR7 are set from the matching TLB entry.

- V: The Valid bit for this TLB entry. The TLB uses the valid bit to identify entries that contain valid data. Entries of the TLB that have not been assigned values have zero in the valid bit. All valid bits can be cleared by writing to CR3.
- D, D#: The dirty bit for/from the TLB entry
- U, U#: The U/S bit for/from the TLB entry
- W, W#: The R/W bit for/from the TLB entry

| x | <b>X</b> # | Effect during TLB Lookup | Value of bit X<br>after TLB Write |
|---|------------|--------------------------|-----------------------------------|
| 0 | 0          | (undefined)              | (undefined)                       |
| 0 | 1          | Match if X=0             | Bit X becomes 0                   |
| 1 | 0          | Match if X=1             | Bit X becomes 1                   |
| 1 | 1          | (undefined)              | (undefined)                       |

#### Meaning of D, U, and W Bit Pairs

# The Test Data Register (TR7)

Holds data read from or data to be written to the TLB

- **Physical Address:** This is the data field of the TLB. On a write to the TLB, the TLB entry allocated to the linear address in TR6 is set to this value. On a TLB lookup, if HT is set, the data field (physical address) from the TLB is read out to this field. If HT is not set, this field is undefined.
- **HT:** For a TLB lookup, the HT bit indicates whether the lookup was a hit (HT <- 1) or a miss (HT <- 0). For a TLB write, HT must be set to 1.
- **REP:** For a TLB write, selects which of four associative blocks of the TLB is to be written. For a TLB read, if HT is set, REP reports in which of the four associative blocks the tag was found; if HT is not set, REP is undefined.

## **Test Operations**

### ✓ To write a TLB entry

- Move a doubleword to TR7 that contains the desired physical address, HT, and REP values. HT must contain 1. REP must point to the associative block in which to place the entry
- Move a doubleword to TR6 that contains the appropriate linear address, and values for V, D, U, and W. Be sure C=0 for "write" command.

### ✓ To look up (read) a TLB entry

- Move a doubleword to TR6 that contains the appropriate linear address and attributes. Be sure C = 1 for "lookup" command
- Store TR 7. If the HT bit in TR 7 indicates a hit, then the other values reveal the TLB contents. If HT indicates a miss, then the other values in TR 7 are indeterminate

### Systems Instructions

### **1. Verification of pointer parameters:**

- ARPL Adjust RPL
- LAR Load Access Rights
- LSL Load Segment Limit
- VERR Verify for Reading
- VERW Verify for Writing

### 2. Addressing descriptor tables:

- LLDT Load LDT Register
- SLDT Store LDT Register
- LGDT Load GDT Register
- SGDT Store GDT Register

### 3. Multitasking:

- LTR Load Task Register
- STR Store Task Register
- 4. Coprocessing and Multiprocessing :
  - CLTS Clear Task-Switched Flag
  - ESC Escape instructions
  - WAIT Wait until Coprocessor not Busy
  - LOCK Assert Bus-Lock Signal

## Systems Instructions

### **5. Input and Output :**

- IN Input
- OUT Output INS Input String
- OUTS Output String

### 7. Debugging :

• MOV — Move to and from debug registers

### 8. TLB testing :

• MOV — Move to and from test registers

#### 6. Interrupt control :

- CLI Clear Interrupt-Enable Flag
- STI Set Interrupt-Enable Flag
- LIDT Load IDT Register
- SIDT Store IDT Register

### 9. System Control:

- SMSW Set MSW
- LMSW Load MSW
- HLT Halt Processor
- MOV Move to and from control registers