# **PCI Bus & Devices**

By Jitesh Verma

| Pin | Side B   | Side A    | Comments                                                             |
|-----|----------|-----------|----------------------------------------------------------------------|
| 1   | -12 V    | TRST#     |                                                                      |
| 2   |          | +12 V     | JTAG port pins                                                       |
| 3   | Ground   |           | (optional)                                                           |
| 4   | TDO      | TDI       |                                                                      |
| 5   | +5 V     | +5 V      |                                                                      |
| 6   | +5 V     | INTA#     |                                                                      |
| 7   | INTB#    | INTC#     | Interrupt pins (open-drain)                                          |
| 8   | INTD#    | +5 V      | ,                                                                    |
| 9   | PRSNT1#  | Reserved  | Pulled low to<br>indicate 7.5 or 25<br>W power<br>required           |
| 10  | Reserved | IOPWR     | +5 V or +3.3 V                                                       |
| 11  | PRSNT2#  | Reserved  | Pulled low to<br>indicate 7.5 or 15<br>W power<br>required           |
| 12  | Ground   | Ground    | Key notch for                                                        |
| 13  | Ground   | Ground    | 3.3 V-capable cards                                                  |
| 14  | Reserved | 3.3 V aux | Standby<br>power (optional)                                          |
| 15  | Ground   |           | Bus reset                                                            |
| 16  |          | IOPWR     | 33/66 MHz clock                                                      |
| 17  | Ground   | GNT#      | Bus grant from motherboard to card                                   |
| 18  | REQ#     | Ground    | Bus request from card to motherboard                                 |
| 19  | IOPWR    | PME#      | Power management event (optional) 3.3 V, open drain, active low.[19] |



| 20 | AD[31]   | AD[30] |                  |
|----|----------|--------|------------------|
| 21 | AD[29]   | +3.3 V |                  |
| 22 | Ground   | AD[28] |                  |
| 23 | AD[27]   | AD[26] |                  |
| 24 | AD[25]   | Ground |                  |
| 25 | +3.3 V   | AD[24] |                  |
| 26 | C/BE[3]# | IDSEL  | Address/data     |
| 27 | AD[23]   | +3.3 V | bus (upper half) |
| 28 | Ground   | AD[22] |                  |
| 29 | AD[21]   | AD[20] |                  |
| 30 | AD[19]   | Ground |                  |
| 31 | +3.3 V   | AD[18] |                  |
| 32 | AD[17]   | AD[16] |                  |
| 33 | C/BE[2]# | +3.3 V |                  |

| 34 | Ground  |        | FRAME# |       | Bus<br>transfer in<br>progress                                     |
|----|---------|--------|--------|-------|--------------------------------------------------------------------|
| 35 | IRDY#   |        | Ground |       | Initiator ready                                                    |
| 36 | +3.3 V  |        | TRDY#  |       | Target ready                                                       |
| 37 | DEVSEL# |        | Ground |       | Target selected                                                    |
| 38 | PCIXCAP | Ground | STOP#  |       | PCI-<br>X capable<br>; Target<br>requests<br>halt                  |
| 39 | LOCK#   |        | +3.3 V |       | Locked<br>transactio<br>n                                          |
| 40 | PERR#   |        | SMBCLK | SDONE | Parity<br>error; SM<br>Bus clock<br>or Snoop<br>done<br>(obsolete) |
| 41 | +3.3 V  |        | SMBDAT | SBO#  | SMBus<br>data<br>or Snoop<br>backoff<br>(obsolete)                 |
| 42 | SERR#   |        | Ground |       | System error                                                       |
| 43 | +3.     | 3 V    | PAR    |       | Even<br>parity over<br>AD[31:00]<br>and<br>C/BE[3:0]<br>#          |



| 44 | C/BE[1]# |        | AD[15]   |                                                                  |
|----|----------|--------|----------|------------------------------------------------------------------|
| 45 | AD[14]   |        | +3.3 V   |                                                                  |
| 46 | Ground   |        | AD[13]   | Address/dat                                                      |
| 47 | AD       | [12]   | AD[11]   | a bus<br>(higher half)                                           |
| 48 | AD       | [10]   | Ground   |                                                                  |
| 49 | M66EN    | Ground | AD[09]   |                                                                  |
| 50 | Gro      | und    | Ground   | Key notch                                                        |
| 51 | Ground   |        | Ground   | for 5 V-<br>capable<br>cards                                     |
| 52 | AD       | [80]   | C/BE[0]# |                                                                  |
| 53 | AD       | [07]   | +3.3 V   |                                                                  |
| 54 | +3.      | 3 V    | AD[06]   | Address/dat                                                      |
| 55 | AD[05]   |        | AD[04]   | a bus (lower                                                     |
| 56 | AD       | [03]   | Ground   | half)                                                            |
| 57 | Gro      | und    | AD[02]   |                                                                  |
| 58 | AD[01]   |        | AD[00]   |                                                                  |
| 59 | IOPWR    |        | IOPWR    |                                                                  |
| 60 | ACK64#   |        | REQ64#   | For 64-bit<br>extension;<br>no connect<br>for 32-bit<br>devices. |
| 61 | +5 V     |        | +5 V     |                                                                  |
| 62 | +5 V     |        | +5 V     |                                                                  |



### 32-bit PCI connector pinout – Legend

| Ground pin        | Zero volt reference                                          |
|-------------------|--------------------------------------------------------------|
| Power pin         | Supplies power to the PCI card                               |
| Output pin        | Driven by the PCI card, received by the motherboard          |
| Initiator output  | Driven by the master/initiator, received by the target       |
| I/O signal        | May be driven by initiator or target, depending on operation |
| Target output     | Driven by the target, received by the initiator/master       |
| Input             | Driven by the motherboard, received by the PCI card          |
| <u>Open drain</u> | May be pulled low and/or sensed by multiple cards            |
| Reserved          | Not presently used, do not connect                           |

### PCI Card (PCI Slave Device – for Desktops)



## **Host PCI Slots (On Desktops)**



### **Mini PCI Card (For Laptops)**



## Mini PCI Slots (On Laptops)











### **Processor Address Spaces**

- Processor Memory Address Space
- Processor I/O Address Space

### **Processor Address Space Selection**



### **PCI Address Spaces**

- PCI Memory Address Space
- PCI I/O Address Space
- PCI Configuration Space

## **PCI Configuration Space**

| 31                               | 1 1615 0               |                   |                | !     |
|----------------------------------|------------------------|-------------------|----------------|-------|
| Device ID                        |                        | <b>V</b> endor ID |                | 0 0 h |
| Status                           |                        | Comman d          |                | 04h   |
|                                  | Class Code             |                   | Revision ID    | 08h   |
| BIST                             | Header Type            | Lat. Timer        | Cache Line S.  | 0 Ch  |
|                                  |                        |                   |                | 10h   |
|                                  |                        |                   |                | 1 4h  |
|                                  | Base Address Registers |                   |                |       |
|                                  |                        |                   |                |       |
|                                  |                        |                   |                |       |
|                                  |                        |                   |                | 24h   |
|                                  | Cardbus CIS Pointer    |                   |                |       |
| Subsystem ID Subsystem Vendor ID |                        | <b>V</b> endor ID | 2.Ch           |       |
| Expansion ROM Base Address       |                        |                   |                | 30h   |
| Reserved                         |                        |                   | Cap. Pointer   | 34h   |
| Reserved                         |                        |                   | 38h            |       |
| Max Lat.                         | Min Gnt.               | Interrupt Pin     | Interrupt Line | 3Ch   |

### PCI Config Space – Base Address Register (BAR)

| Bits             | Description     | Values                                                |  |  |
|------------------|-----------------|-------------------------------------------------------|--|--|
| For all PCI BARs |                 |                                                       |  |  |
| 0                | Region Type     | 0 = Memory<br>1 = I/O                                 |  |  |
|                  | For Memory BARs |                                                       |  |  |
| 2-1              | Locatable       | 0 = any 32-bit<br>1 = < 1 <u>MB</u><br>2 = any 64-bit |  |  |
| 3                | Prefetchable    | 0 = no<br>1 = yes                                     |  |  |
| 31-4             | Base Address    | naturally 16-byte aligned                             |  |  |
| For I/O BARs     |                 |                                                       |  |  |
| 1                | Reserved        |                                                       |  |  |
| 31-2             | Base Address    | naturally 4-byte aligned                              |  |  |

PCI Config Space & Memory / IO Segments (Functional Register Sets)



PCI Config Space & Memory / IO Segment 0 (Functional Register Set 0)



#### **PCI** References

- 1) <a href="https://en.wikipedia.org/wiki/Peripheral\_Component\_Interconnect">https://en.wikipedia.org/wiki/Peripheral\_Component\_Interconnect</a>
- 2) <a href="https://en.wikipedia.org/wiki/PCI\_configuration\_space">https://en.wikipedia.org/wiki/PCI\_configuration\_space</a>