### **System Buses** Ch 3

Computer Function Interconnection Structures **Bus Interconnection PCI Bus** 

9/18/2003 Copyright Teemu Kerola 2003

9/18/2003



#### I/O control

- CPU executes instructions and with those instructions guides I/O modules
  - control and data registers in I/O modules
  - I/O modules give feedback to CPU with control and data registers, but only when CPU is reading them!



#### I/O Control

• Interrrupts allow I/O modules to give feedback to CPU even when CPU is doing something else



• DMA allows I/O modules to access memory without CPU's help

9/18/2003 Copyright Teemu Kerola 2003

#### von Neumann Bottleneck



- All components communicate via system bus
- Each component has its own inputs/outputs
  - System bus must support them all

Fig. 3.16

9/18/2003 Copyright Teemu Kerola 2003

#### System Bus

- 50-100 lines (wires)
  - address
  - data
  - control
  - other: power, ground, clock
- Performance
  - bandwidth, how many bits per sec?

(väyläkapasiteetti)

- propagation delay?

(päästä päähän viive)

9/18/2003 Copyright Teemu Kerola 2003

#### **Bus Configurations**

- · One bus alone
  - might be very long
    - · large end-to-end signal time
  - serious von Neumann bottleneck
  - all devices use similar speeds
  - slowest device determines speed used
- Hierarchy of buses
  - can maximize speed for limited access
    - · closer to CPU
  - lower speed general access I/O
    - · further away from CPU

9/18/2003

Copyright Teemu Kerola 2003







### Synchronous timing

- · All same speed devices
- · All synchronized with a clock signal
- Slowest device determines speed
- · Can make assumptions on when some other device will do something, or how fast it will do it "Do this in next cycle!"

- 1 or 2 clock cycles to do it?

9/18/2003

- data will be ready to read in 1 cycle
- written data stored in 1 cycle (Fig. 3.19 (a) [Stal99])

How to read timing diagrams: Fig. 3.27 (Fig. 3.26 [Stal99]) Copyright Teemu Kerola 2003

#### Asynchronous timing

- No need to have same speed devices
- Timing determined with change of signal levels - signaling may happen only at predetermined times
- Synchronize with signals (wires) "Do this in when

you can, please. - "read", "write", "ack", ... Let me know, when you are done"

- · Speed determined by devices in action
  - not by all devices that are or could be connected!
- Can *not* make assumptions on when some other device will do something

Fig. 3.20 (Fig. 3.19 (b) [Stal99])

12

9/18/2003 Copyright Teemu Kerola 2003

#### Bus Design Features (cont)

- Bus width
  - address, data
- Data transfer types
  - read, write
- write Fig. 3.21 (Fig. 3.20 [Stal99])
  - multiplexed & non-multiplexed operations
  - read-modify-write
    - E.g., for indivisible increments (concurrency control method for multiprocessor environments)
  - read-after-write
    - E.g., for check that write succeeds (multiproc. env.)
  - block
    - · long delay for interrupt handling?

9/18/2003

Copyright Teemu Kerola 2003

13

15

17

# Example Bus: Industry Standard Architecture (ISA, or PC-AT)

- · Bus type: dedicated
- · Arbitration method: single bus master
- · Timing: asynchronous
  - own 8.33 MHz clock,
  - 15.9 MBps max data rate, 5.3 MBps in practice
- Bus width: address 32, data 16
- Data transfer type
  - read, write, read block, write block

9/18/2003

Copyright Teemu Kerola 2003

Example: Peripheral Component Interconnect (PCI) Bus

- Bus type: multiplexed
- Arbitration method: centralised arbiter
- Timing: synchronous, own 33 MHz clock
  - 2.122 Gbps (265 MBps) max data rate
- Bus width: address/data 32 (64), signal 17
- Data transfer type
  - read, write, read block, write block
- Max 16 slots (devices)

9/18/2003

Copyright Teemu Kerola 2003

### **PCI** Configurations

Copyright Teemu Kerola 2003

Hierarchy

9/18/2003

Fig. 3.22

(Fig. 3.21 [Stal99])

- Bridge to internal/system bus allows them to be faster (with different bus protocol)
- Bridge to expansion buses allows them to slower (with different bus protocol)

PCI card: 49 Mandatory Signals (6)



14

- 32 pins for address/data, time multiplexed
   1 parity pin
- 4 pins for command type/byte enable
   E.g., 0110/1111 = memory read/all 4 bytes
- 2 system pins: clock, reset
- 6 transaction timing & coordination pins
- 2 arbitration pins (not shared with other devices!) to PCI bus arbiter: REQ, GNT
- 2 error pins: parity, system

9/18/2003 Copyright Teemu Kerola 2003

9/18/2003

Copyright Teemu Kerola 2003

18

## PCI Bus 51 Optional Signals (4)

- · Request interrupt pins (4 pins for each dev)
- · Cache support pins (2) for snoopy cache protocols



19

21

- · 32 pins for additional multiplexed address/data
  - plus 7 control/parity pins
- 5 test pins
- · 1 pin for locking the bus for multiple transactions
- (may have extra pin to select 66/33 MHz clock)

9/18/2003 Copyright Teemu Kerola 2003

#### PCI Bus Transaction (4)

- Bus activity is in separate transactions
- Each transaction preceded by arbitration

Fig. 3.24 (Fig. 3.23 [Stal99])

- central arbiter (e.g., First-In-First-Out)
- determines initiator/master for transaction
- · Transaction is executed
- Bus is marked "ready" for next transaction

9/18/2003 Copyright Teemu Kerola 2003 20

#### PCI Transaction Types (5)

- Interrupt Acknowledge
  - READ interrupt parameter (e.g., subtype) for interrupt handler
- · Special Cycle
  - broadcast message to many targets
- · Configuration Read/Write
  - Read/Update (Write) device configuration data
- · Dual Address Cycle
  - use 64 bit addresses in this transaction
- · I/O or memory read/write
  - one or multiple words, cache line

9/18/2003 Copyright Teemu Kerola 2003











## PCI Express New Bus to Replace PCI

- Code name "Arapahoe" or 3GIO
- Prevent bus bottleneck between fast CPU and memory of the future

   Armacker World Crown http://www.pcisig.com
- Arapahoe Work Group
- . .
- Compaq, Dell, IBM, Intel, Microsoft, ....
- Will replace PCI as industry standard
- late 2003? low-end 2004? high-end 2005?PCI devices will work with PCI Express
- Speedup (E.g.) 64x as compared to std PCI
  - 16 GB/s with 32 lanes vs. 264 MB/s
- Scalable capacity per device (pin count, speed)

9/18/2003 Copyright Teemu Kerola 2003

-- End of Chapter 3: System Buses -
(PCI card - connectors also on other side, some pins not used by this card)

9/18/2003 Copyright Teemu Kerola 2003 28