

OPTi Inc. 888 Tasman Drive Milpitas, CA 95035 (408) 486-8000 Fax: (408) 486-8001

# **Application Note (OPTi Confidential)**

Product Name: Viper Xpress+ Chipset

Title: BIOS Programming Guide

Date:

January 16, 1997

## Scope

This document outlines the recommended procedure for programming the internal registers of the Viper Xpress+ Chipset. It is intended to be a reference for a BIOS developer using the Viper Xpress+ Chipset in a PC design. This document classifies the internal registers of the Viper Xpress+ Chipset based on the subsystems that they control.

### Discussion

#### **BIOS Settings**

Given below is a chipset specific illustrative flow chart that a BIOS needs to follow to program the chipset registers.

Tables 1 through 4 provide the register settings required of the chipset that the BIOS should ensure in order for the system to boot. These are fail safe boot values.

#### Figure 1 Boot Setting



OPTi Inc. makes no representations or warranties with respect to the design and documentation herein described and especially disclaims any implied warranties of merchantability or fitness for any particular purpose. Further, OPTi Inc. reserves the right to revise the design and associated documentation and to make changes from time to time in the content without obligation of OPTi Inc. to notify any person of such revisions or changes.

#### Table 1 82C579 Fail Safe Boot Values

| Loc. | Value                |
|------|----------------------|
|      | DV0<br>egister Space |
| 00h  | 45h                  |
| 01h  | 10h                  |
| 02h  | 69h                  |
| 03h  | C5h                  |
| 04h  | 07h                  |
| 05h  | 00h                  |
| 06h  | 80h                  |
| 07h  | 02h                  |
| 08h  | 10h                  |
| 09h  | 00h                  |
| 0Ah  | 00h                  |
| 0Bh  | 06h                  |
| 0Ch  | 00h                  |
| 0Dh  | 00h                  |
| 0Eh  | 00h                  |
| 0Fh  | 00h                  |
| 10h  | 00h                  |
| 11h  | 00h                  |
| 12h  | 00h                  |
| 13h  | 00h                  |
| 14h  | 00h                  |
| 15h  | 00h                  |
| 16h  | 00h                  |
| 17h  | 00h                  |
| 18h  | 00h                  |
| 19h  | 00h                  |
| 1Ah  | 00h                  |
| 1Bh  | 00h                  |
| 1Ch  | 00h                  |
| 1Dh  | 00h                  |
| 1Eh  | 00h                  |
| 1Fh  | 00h                  |
| 20h  | 00h                  |
| 21h  | 00h                  |

| Loc.               | Value |
|--------------------|-------|
| 22h                | 00h   |
| 23h                | 00h   |
| 24h                | 00h   |
| 25h                | 00h   |
| 26h                | 00h   |
| 27h                | 00h   |
| 28h                | 00h   |
| 29h                | 00h   |
| 2Ah                | 00h   |
| 2Bh                | 00h   |
| 2Ch                | 00h   |
| 2Dh                | 00h   |
| 2Eh                | 00h   |
| 2Fh                | 00h   |
| 30h                | 00h   |
| 31h                | 00h   |
| 32h                | 00h   |
| 33h                | 00h   |
| 34h                | 00h   |
| 35h                | 00h   |
| 36h                | 00h   |
| 37h                | 00h   |
| 38h                | 00h   |
| 39h                | 00h   |
| 3Ah                | 00h   |
| 3Bh                | 00h   |
| 3Ch                | 00h   |
| 3Dh                | 00h   |
| 3Eh                | 00h   |
| 3Fh                | 00h   |
| 40h                | 00h   |
| 41h                | 00h   |
| 42h                | 00h   |
| 43h                | 20h   |
| 44h <sup>(1)</sup> | 01h   |
| 45h                | 00h   |
|                    |       |

| 1                  |                    |  |
|--------------------|--------------------|--|
| Loc.               | Value              |  |
| 46h                | 00h                |  |
| 47h                | 00h                |  |
| 48h                | 00h                |  |
| 49h                | 00h                |  |
| 4Ah                | 00h                |  |
| 4Bh                | 00h                |  |
| 4Ch                | 40h <sup>(2)</sup> |  |
| 4Dh                | 00h                |  |
| 4Eh                | 00h                |  |
| 4Fh                | 00h                |  |
| SYSCFG             |                    |  |
|                    | gister Space       |  |
| 00h                | 00h                |  |
| 01h                | 00h                |  |
| 02h                | 00                 |  |
| 03h                | 00h                |  |
| 04h                | 00h                |  |
| 05h                | 00h                |  |
| 06h                | 00h                |  |
| 07h                | 00h                |  |
| 08h                | 00h                |  |
| 09h                | 00h                |  |
| 0Ah                | 00h                |  |
| 0Bh                | 00h                |  |
| 0Ch                | 00h                |  |
| 0Dh                | 00h                |  |
| 0Eh                | 00h                |  |
| 0Fh                | 00h                |  |
| 10h                | 00h                |  |
| 11h                | 00h                |  |
| 12h                | 00h                |  |
| 13h                | 80h                |  |
| 14h <sup>(1)</sup> | 80h                |  |
| 15h                | 00h                |  |
| 16h                | 00h                |  |
| 471                | 0.01               |  |

17h

00h

| Loc. | Value |
|------|-------|
| 18h  | 00h   |
| 19h  | 88h   |
| 1Ah  | 00h   |
| 1Bh  | 00h   |
| 1Ch  | 00h   |
| 1Dh  | 00h   |
| 1Eh  | 08h   |
| 1Fh  | 02h   |
| 20h  | 8Ah   |
| 21h  | 01h   |
| 22h  | 00h   |
| 23h  | 00h   |
| 24h  | 00h   |
| 25h  | 00h   |
| 26h  | 00h   |
| 27h  | 06h   |
| 28h  | 00h   |
| 29h  | 00h   |
| 2Ah  | 01h   |
| 2Bh  | 00h   |
| 2Ch  | 00h   |
| 2Dh  | 00h   |
| 2Eh  | 00h   |
| 2Fh  | 00h   |

 SYSCFG 14h must be written first followed by PCIDV0 44h[1]. It is important that PCIDV0 44h-47h is always a 32-bit write and in a tight sequence code.

(2) If L2 cache is being used in the system, 4Eh[6] should be set to 1.



#### Table 2 82C578 Fail Safe Boot Values

| Loc. | Value                |
|------|----------------------|
|      | DV1<br>egister Space |
| 00h  | 45h                  |
| 01h  | 10h                  |
| 02h  | 68h                  |
| 03h  | C5h                  |
| 04h  | 07h                  |
| 05h  | 00h                  |
| 06h  | 80h                  |
| 07h  | 02h                  |
| 08h  | 10h                  |
| 09h  | 00h                  |
| 0Ah  | 01h                  |
| 0Bh  | 06h                  |
| 0Ch  | 00                   |
| 0Dh  | 00                   |
| 0Eh  | 00h                  |
| 0Fh  | 00h                  |
| 10h  | 00h                  |
| 11h  | 00h                  |
| 12h  | 00h                  |
| 13h  | 00h                  |
| 14h  | 00h                  |
| 15h  | 00h                  |
| 16h  | 00h                  |
| 17h  | 00h                  |
| 18h  | 00h                  |
| 19h  | 00h                  |
| 1Ah  | 00h                  |
| 1Bh  | 00h                  |
| 1Ch  | 00h                  |
| 1Dh  | 00h                  |
| 1Eh  | 00h                  |
| 1Fh  | 00h                  |
| 20h  | 00h                  |
| 21h  | 00h                  |
| 22h  | 00h                  |

| Loc. | Value |
|------|-------|
| 23h  | 00h   |
| 24h  | 00h   |
| 25h  | 00h   |
| 26h  | 00h   |
| 27h  | 00h   |
| 28h  | 00h   |
| 29h  | 00h   |
| 2Ah  | 00h   |
| 2Bh  | 00h   |
| 2Ch  | 00h   |
| 2Dh  | 00h   |
| 2Eh  | 00h   |
| 2Fh  | 00h   |
| 30h  | 00h   |
| 31h  | 00h   |
| 32h  | 00h   |
| 33h  | 00h   |
| 34h  | 00h   |
| 35h  | 00h   |
| 36h  | 00h   |
| 37h  | 00h   |
| 38h  | 00h   |
| 39h  | 00h   |
| 3Ah  | 00h   |
| 3Bh  | 00h   |
| 3Ch  | 00h   |
| 3Dh  | 00h   |
| 3Eh  | 00h   |
| 3Fh  | 00h   |
| 40h  | 00h   |
| 41h  | 00h   |
| 42h  | 00h   |
| 43h  | 00h   |
| 44h  | 00h   |
| 45h  | 00h   |
| 46h  | 06h   |
| 47h  | 00h   |

| Loc.                         | Value |
|------------------------------|-------|
| 48h                          | 00h   |
| 49h                          | 00h   |
| 4Ah                          | 00h   |
| 4Bh                          | 00h   |
| 4Ch                          | 00h   |
| 4Dh                          | 00h   |
| 4Eh                          | 00h   |
| 4Fh                          | 00h   |
| 50h                          | 00h   |
| 51h                          | 00h   |
| 52h                          | 00h   |
| 53h                          | 00h   |
| 54h                          | 00h   |
| 55h                          | 02h   |
| 56h                          | 00h   |
| 57h                          | 00h   |
| 58h                          | 00h   |
| 59h                          | 00h   |
| 5Ah                          | 00h   |
| 5Bh                          | 00h   |
| 5Ch                          | 00h   |
| 5Dh                          | 00h   |
| 5Eh                          | 00h   |
| 5Fh                          | C0h   |
| 60h                          | 00h   |
| 61h                          | 00h   |
| 62h                          | 00h   |
| 63h-FCh                      | 00h   |
| FDh                          | xxh   |
| FEh                          | xxh   |
| FFh                          | xxh   |
| SYSCFG<br>Pwr Mgmt Registers |       |
| E0h                          | 00h   |
| E1h                          | 00h   |
| E2h                          | 00h   |
| E3h                          | 00h   |
|                              |       |

| Loc. | Value |
|------|-------|
| E4h  | 00h   |
| E5h  | 00h   |
| E6h  | 00h   |
| E7h  | 00h   |
| E8h  | 00h   |
| E9h  | 00h   |
| EAh  | 01h   |
| EBh  | 01h   |
| ECh  | 01h   |
| EDh  | 00h   |
| EEh  | 00h   |
| EFh  | 00h   |
| F0h  | 00h   |
| F1h  | 00h   |
| F2h  | 00h   |
| F3h  | 00h   |
| F4h  | 00h   |
| F5h  | 00h   |
| F6h  | 00h   |
| F7h  | 00h   |
| F8h  | 00h   |
| F9h  | 00h   |
| FAh  | 00h   |
| FBh  | 00h   |
| FCh  | 00h   |
| FDh  | 00h   |
| FEh  | 00h   |
| FFh  | 10h   |



### Table 3 Register Boot Values without Deep Buffers

| Loc. | Value                              |  |
|------|------------------------------------|--|
|      | SYSCFG<br>Sys Cntrl Register Space |  |
| 00h  | 00h                                |  |
| 01h  | DDh                                |  |
| 02h  | 03h                                |  |
| 03h  | EEh                                |  |
| 04h  | 05h                                |  |
| 05h  | 00h                                |  |
| 06h  | 15h                                |  |
| 07h  | xxh                                |  |
| 08h  | 6Ah                                |  |
| 09h  | 00h                                |  |
| 0Ah  | 00h                                |  |
| 0Bh  | 00h                                |  |
| 0Ch  | 40h                                |  |
| 0Dh  | 02h                                |  |
| 0Eh  | 43h                                |  |
| 0Fh  | 24h                                |  |
| 10h  | 83h                                |  |
| 11h  | 08h                                |  |
| 12h  | 00h                                |  |
| 13h  | 83h                                |  |
| 14h  | 80h                                |  |
| 15h  | A1h                                |  |
| 16h  | A4h                                |  |
| 17h  | 02h                                |  |
| 18h  | 50h                                |  |
| 19h  | 00h                                |  |
| 1Ah  | 00h                                |  |
| 1Bh  | 00h                                |  |
| 1Ch  | 00h                                |  |
| 1Dh  | 20h                                |  |
| 1Eh  | CCh                                |  |
| 1Fh  | 02h                                |  |
| 20h  | 8Fh                                |  |
| 21h  | 03h                                |  |

|               | Leep Barro    |
|---------------|---------------|
| Loc.          | Value         |
| 22h           | 00h           |
| 23h           | 06h           |
| 24h           | 00h           |
| 25h           | 00h           |
| 26h           | 00h           |
| 27h           | 00h           |
| 28h           | 00h           |
| 29h           | 00h           |
| 2Ah           | 01h           |
| 2Bh           | 00h           |
| 2Ch           | 00h           |
| 2Dh           | 00h           |
| 2Eh           | 40h           |
| 2Fh           | 00h           |
| PCI           | DV0           |
| PCI Config Re | egister Space |
| 80000000h     | C5691045h     |
| 80000004h     | 02800007h     |
| 8000008h      | 06000010h     |
| 8000000Ch     | 00000000h     |
| 80000010h     | 00000000h     |
| 80000014h     | 00000000h     |
| 80000018h     | 00000000h     |
| 8000001Ch     | 00000000h     |
| 80000020h     | 00000000h     |
| 80000024h     | 00000000h     |
| 80000028h     | 00000000h     |
| 8000002Ch     | 00000000h     |
| 80000030h     | 00000000h     |
| 80000034h     | 00000000h     |
| 80000038h     | 00000000h     |
| 8000003Ch     | 00000000h     |
| 80000040h     | 20000000h     |
| 80000044h     | 0000007h      |
| 80000048h     | 00000000h     |
| 8000004Ch     | 00000000h     |

| Loc.         | Value         |
|--------------|---------------|
| 80000050h    | 00000000h     |
| 80000054h    | 00000000h     |
| 80000058h    | 00000000h     |
| 8000005Ch    | 00000000h     |
| 80000060h    | 00000000h     |
| 80000064h    | 00000000h     |
| 8000068h     | 00000000h     |
| 8000006Ch    | 00000000h     |
| 80000070h    | 00000000h     |
| 80000074h    | 00000000h     |
| 80000078h    | 00000000h     |
| 8000007Ch    | 00000000h     |
| PCI          | DV1           |
| PCI Config R | egister Space |
| 80000800h    | C5681045h     |
| 80000804h    | 92800107h     |
| 80000808h    | 06010010h     |
| 8000080ch    | 00800000h     |
| 80000810h    | 00000000h     |
| 80000814h    | 00000000h     |
| 80000818h    | 00000000h     |
| 8000081Ch    | 00000000h     |
| 80000820h    | 00000000h     |
| 80000824h    | 00000000h     |
| 80000828h    | 00000000h     |
| 8000082Ch    | 00000000h     |
| 80000830h    | 00000000h     |
| 80000834h    | 00000000h     |
| 80000838h    | 00000000h     |
| 8000083Ch    | 00000000h     |
| 80000840h    | 20000000h     |
| 80000844h    | 40060001h     |
| 80000848h    | C0000000h     |
| 8000084Ch    | 40000000h     |
| 80000850h    | 0004C000h     |
| 80000854h    | 000000D0h     |

| Loc.      | Value     |
|-----------|-----------|
| 80000858h | 00000000h |
| 8000085Ch | 00000000h |
| 80000860h | 00000000h |
| 80000864h | 00000000h |
| 80000868h | 00000000h |
| 8000086Ch | 00000000h |
| 80000870h | 00000000h |
| 80000874h | 00000000h |
| 80000878h | 00000000h |
| 8000087Ch | 00000000h |



#### Table 4 Register Boot Values with Deep Buffers

| Loc.                | Value               |
|---------------------|---------------------|
| SYS<br>Sys Cntrl Re | CFG<br>gister Space |
| 00h                 | 00h                 |
| 01h                 | DDh                 |
| 02h                 | 03h                 |
| 03h                 | EEh                 |
| 04h                 | 05h                 |
| 05h                 | 00h                 |
| 06h                 | 15h                 |
| 07h                 | xxh                 |
| 08h                 | 6Ah                 |
| 09h                 | 00h                 |
| 0Ah                 | 00h                 |
| 0Bh                 | 00h                 |
| 0Ch                 | 40h                 |
| 0Dh                 | 02h                 |
| 0Eh                 | 43h                 |
| 0Fh                 | 24h                 |
| 10h                 | 83h                 |
| 11h                 | 08h                 |
| 12h                 | 00h                 |
| 13h                 | 83h                 |
| 14h                 | 80h                 |
| 15h                 | A1h                 |
| 16h                 | A4h                 |
| 17h                 | 02h                 |
| 18h                 | 50h                 |
| 19h                 | 00h                 |
| 1Ah                 | 00h                 |
| 1Bh                 | 00h                 |
| 1Ch                 | 00h                 |
| 1Dh                 | 20h                 |
| 1Eh                 | CCh                 |
| 1Fh                 | 02h                 |
| l                   |                     |

| lues with De                                                                                                                                                                           | ep Dulleis                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Loc.                                                                                                                                                                                   | Value                                                                                                                                                                                                                                                                                                                                                                                              |
| 20h                                                                                                                                                                                    | 8Fh                                                                                                                                                                                                                                                                                                                                                                                                |
| 21h                                                                                                                                                                                    | 03h                                                                                                                                                                                                                                                                                                                                                                                                |
| 22h                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 23h                                                                                                                                                                                    | 06h                                                                                                                                                                                                                                                                                                                                                                                                |
| 24h                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 25h                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 26h                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 27h                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 28h                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 29h                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 2Ah                                                                                                                                                                                    | 0Dh                                                                                                                                                                                                                                                                                                                                                                                                |
| 2Bh                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 2Ch                                                                                                                                                                                    | 21h                                                                                                                                                                                                                                                                                                                                                                                                |
| 2Dh                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
| 2Eh                                                                                                                                                                                    | 48h                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2Fh                                                                                                                                                                                    | 00h                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                        | DV0                                                                                                                                                                                                                                                                                                                                                                                                |
| PCI                                                                                                                                                                                    | DV0                                                                                                                                                                                                                                                                                                                                                                                                |
| PCII<br>PCI Config Re                                                                                                                                                                  | DV0<br>egister Space                                                                                                                                                                                                                                                                                                                                                                               |
| PCII<br>PCI Config Re<br>80000000h                                                                                                                                                     | DV0<br>egister Space<br>C5691045h                                                                                                                                                                                                                                                                                                                                                                  |
| PCII<br>PCI Config Re<br>80000000h<br>80000004h                                                                                                                                        | <b>DV0</b><br>egister Space<br>C5691045h<br>02800007h                                                                                                                                                                                                                                                                                                                                              |
| PCI<br>PCI Config Rd<br>80000000h<br>80000004h<br>80000008h                                                                                                                            | DV0<br>egister Space<br>C5691045h<br>02800007h<br>06000010h                                                                                                                                                                                                                                                                                                                                        |
| PCI<br>PCI Config Re<br>80000000h<br>80000004h<br>80000008h<br>8000000Ch                                                                                                               | DV0<br>egister Space<br>C5691045h<br>02800007h<br>06000010h<br>00000000h                                                                                                                                                                                                                                                                                                                           |
| PCI<br>PCI Config Rd<br>80000000h<br>80000004h<br>80000008h<br>8000000Ch<br>80000010h                                                                                                  | DV0<br>egister Space<br>C5691045h<br>02800007h<br>06000010h<br>00000000h<br>00000000h                                                                                                                                                                                                                                                                                                              |
| PCI<br>PCI Config Re<br>80000000h<br>80000008h<br>80000000Ch<br>80000010h<br>80000014h                                                                                                 | DV0<br>egister Space<br>C5691045h<br>02800007h<br>06000010h<br>00000000h<br>00000000h                                                                                                                                                                                                                                                                                                              |
| PCI<br>PCI Config Rd<br>80000000h<br>80000004h<br>800000008h<br>80000000Ch<br>80000010h<br>80000014h<br>80000018h                                                                      | DV0<br>egister Space<br>C5691045h<br>02800007h<br>06000010h<br>00000000h<br>00000000h<br>0000000h                                                                                                                                                                                                                                                                                                  |
| PCI<br>PCI Config Re<br>80000000h<br>80000008h<br>80000008h<br>800000000                                                                                                               | DV0           Degister Space           C5691045h           02800007h           06000010h           00000000h           00000000h           00000000h           00000000h           00000000h           00000000h           00000000h                                                                                                                                                               |
| PCI<br>PCI Config Rd<br>80000000h<br>80000004h<br>800000000h<br>80000010h<br>80000010h<br>80000014h<br>80000018h<br>8000001Ch<br>80000020h                                             | DV0           egister Space           C5691045h           02800007h           06000010h           00000000h           00000000h           00000000h           00000000h           00000000h           00000000h           00000000h           00000000h           00000000h                                                                                                                        |
| PCII<br>PCI Config Rd<br>80000000h<br>80000008h<br>8000000Ch<br>80000010h<br>80000014h<br>80000018h<br>8000001Ch<br>80000020h<br>80000024h                                             | DV0           egister Space           C5691045h           02800007h           06000010h           00000000h                                                                                                    |
| PCI<br>PCI Config Re<br>80000000h<br>80000004h<br>800000000<br>80000010h<br>80000010h<br>80000014h<br>80000018h<br>80000010h<br>80000020h<br>80000020h<br>80000028h                    | DV0           gister Space           C5691045h           02800007h           06000010h           00000000h                                         |
| PCII<br>PCI Config Rd<br>80000000h<br>80000004h<br>800000000h<br>80000010h<br>80000014h<br>80000018h<br>8000001Ch<br>80000020h<br>80000024h<br>80000028h<br>8000002Ch                  | DV0           gister Space           C5691045h           02800007h           06000010h           00000000h           00000000h |
| PCI Config Re<br>80000000h<br>80000004h<br>80000008h<br>8000000Ch<br>80000010h<br>80000014h<br>80000014h<br>80000018h<br>8000001Ch<br>80000020h<br>80000020h<br>8000002Ch<br>8000002Ch | DV0           gister Space           C5691045h           02800007h           06000010h           00000000h           00000000h |

| 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                       |                                                                                                                                              |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Loc.                                                                                                                                                                                  | Value                                                                                                                                        |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000040h                                                                                                                                                                             | 20000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000044h                                                                                                                                                                             | 20003071h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000048h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8000004Ch                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000050h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000054h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000058h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8000005Ch                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000060h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000064h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000068h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8000006Ch                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000070h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000074h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 80000078h                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8000007Ch                                                                                                                                                                             | 00000000h                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | PCIDV1<br>PCI Config Register Space                                                                                                                                                   |                                                                                                                                              |  |  |  |  |  |
| e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | -                                                                                                                                                                                     |                                                                                                                                              |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                     |                                                                                                                                              |  |  |  |  |  |
| h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | PCI Config R                                                                                                                                                                          | egister Space                                                                                                                                |  |  |  |  |  |
| h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCI Config R<br>80000800h                                                                                                                                                             | C5681045h                                                                                                                                    |  |  |  |  |  |
| h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCI Config R<br>80000800h<br>80000804h                                                                                                                                                | egister Space<br>C5681045h<br>92800107h                                                                                                      |  |  |  |  |  |
| h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PCI Config R<br>80000800h<br>80000804h<br>80000808h                                                                                                                                   | egister Space<br>C5681045h<br>92800107h<br>06010010h                                                                                         |  |  |  |  |  |
| h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PCI Config R<br>80000800h<br>80000804h<br>80000808h<br>8000080Ch                                                                                                                      | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h                                                                            |  |  |  |  |  |
| h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCI Config R<br>80000800h<br>80000804h<br>80000808h<br>8000080Ch<br>80000810h                                                                                                         | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h                                                               |  |  |  |  |  |
| h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCI Config R<br>80000800h<br>80000804h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h                                                                                            | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h                                                               |  |  |  |  |  |
| h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCI Config R<br>80000800h<br>80000808h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h<br>80000818h                                                                               | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>00000000h                                                  |  |  |  |  |  |
| h<br>h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PCI Config R<br>80000800h<br>80000804h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h<br>80000818h<br>8000081Ch                                                                  | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>0000000h<br>0000000h                                       |  |  |  |  |  |
| h<br>h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PCI Config R<br>80000800h<br>80000808h<br>80000808h<br>8000080Ch<br>80000810h<br>80000818h<br>8000081Ch<br>80000820h                                                                  | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>00000000h<br>0000000h                                      |  |  |  |  |  |
| <b>e</b> h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h  h <p< td=""><td>PCI Config R<br/>80000800h<br/>80000804h<br/>80000808h<br/>8000080Ch<br/>80000810h<br/>80000814h<br/>80000818h<br/>8000081Ch<br/>80000820h<br/>80000820h</td><td>egister Space<br/>C5681045h<br/>92800107h<br/>06010010h<br/>00800000h<br/>00000000h<br/>00000000h<br/>0000000h<br/>0000000h</td></p<> | PCI Config R<br>80000800h<br>80000804h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h<br>80000818h<br>8000081Ch<br>80000820h<br>80000820h                                        | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>00000000h<br>0000000h<br>0000000h                          |  |  |  |  |  |
| h<br>h<br>h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PCI Config R<br>80000800h<br>80000808h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h<br>80000818h<br>8000081Ch<br>80000820h<br>80000824h<br>80000828h                           | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>00000000h<br>00000000h<br>0000000h<br>0000000h             |  |  |  |  |  |
| h<br>h<br>h<br>h<br>h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PCI Config R<br>80000800h<br>80000804h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h<br>80000818h<br>8000081Ch<br>80000820h<br>80000824h<br>80000828h<br>8000082Ch              | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>00000000h<br>00000000h<br>0000000h<br>0000000h             |  |  |  |  |  |
| h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PCI Config R<br>80000800h<br>80000804h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h<br>80000818h<br>8000081Ch<br>80000820h<br>80000822h<br>8000082Ch<br>8000082Ch              | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>00000000h<br>00000000h<br>0000000h<br>0000000h<br>0000000h |  |  |  |  |  |
| h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | PCI Config R<br>80000800h<br>80000808h<br>80000808h<br>8000080Ch<br>80000810h<br>80000814h<br>80000818h<br>8000081Ch<br>80000820h<br>80000820h<br>80000828h<br>8000082Ch<br>80000830h | egister Space<br>C5681045h<br>92800107h<br>06010010h<br>00800000h<br>00000000h<br>00000000h<br>00000000h<br>00000000                         |  |  |  |  |  |

| Loc.      | Value     |
|-----------|-----------|
| 80000840h | 20000000h |
| 80000844h | 40060001h |
| 80000848h | C0000000h |
| 8000084Ch | 40000000h |
| 80000850h | 0004C000h |
| 80000854h | 000000D0h |
| 80000858h | 00000000h |
| 8000085Ch | 00000000h |
| 80000860h | 00000000h |
| 80000864h | 00000000h |
| 80000868h | 00000000h |
| 8000086Ch | 00000000h |
| 80000870h | 00000000h |
| 80000874h | 00000000h |
| 80000878h | 00000000h |
| 8000087Ch | 00000000h |



#### Pin Muxing in the Viper Xpress+ Chipset

The Viper Xpress+ Chipset allows a great amount of flexibility to enable the system designer to tailor the design optimally to meet requirements. The BIOS programmer should obtain the hardware muxing information from the board designer to program the pin muxing registers. These values should be programmed once and should not be changed during warm resets. Globally, the designer can program two bits in the 82C578 to enable a group of pins to take on different functions or can individually program bits to assign the desired functionality on a pin-by-pin basis. Table 5 shows the group-wise pin programming option and Table 6 shows the register bits used in pin programming (pin- and group-wise).

#### Table 5 82C578 Group-Wise Register Programmable Pins

|         | PCIDV1 44h[1:0] |        |          |          |  |  |  |  |
|---------|-----------------|--------|----------|----------|--|--|--|--|
| Pin No. | 00              | 01     | 10       | 11       |  |  |  |  |
| 141     | PIRQ2#          | PIRQ2# | GPCS0##  | PIRQ2#   |  |  |  |  |
| 143     | PIRQ3#          | PIRQ3# | EPMI2#   | PIRQ3#   |  |  |  |  |
| 108     | DACK0#          | DACK0# | EDACK0   | EDACK0   |  |  |  |  |
| 109     | DACK1#          | DACK1# | EDACK1   | EDACK1   |  |  |  |  |
| 110     | DACK2#          | DACK2# | EDACKEN# | EDACKEN# |  |  |  |  |
| 111     | DACK3#          | DACK3# | EDACK2   | EDACK2   |  |  |  |  |

Note: The group-wise pin functionality of these pins will always be overridden by the pin-wise programmability.

#### Table 6 82C578 Pin Functionality Programming Register Bits

| 7                                             | 6 | 5      | 4                                                                                                                                                | 3                  | 2      | 1 | 0                                                    |  |
|-----------------------------------------------|---|--------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------|---|------------------------------------------------------|--|
| PCIDV1 41h Keyboard Control Register - Byte 1 |   |        |                                                                                                                                                  |                    |        |   |                                                      |  |
|                                               |   |        | Keyboard<br>emulation:<br>0 = Enable -<br>Pin 12<br>functions<br>as A20M#<br>output<br>1 = Disable -<br>Pin 12<br>functions<br>as KBRST<br>input |                    |        |   |                                                      |  |
| PCIDV1 42h                                    |   | Interr | rupt Edge/Level (                                                                                                                                | Control Register - | Byte 0 |   | Default = 00h                                        |  |
|                                               |   |        |                                                                                                                                                  |                    |        |   | Pin 122<br>functionality:<br>0 = DREQ6<br>1 = EPMI0# |  |



| 7                                                                               | 6                           | 5                                                                                               | 4                                                                                                                                             | 3                                                                       | 2                                                       | 1                                                                           | 0                            |
|---------------------------------------------------------------------------------|-----------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------|
| PCIDV1 44h                                                                      |                             | ·                                                                                               | Pin Functionality                                                                                                                             | Register 1 - By                                                         | te O                                                    |                                                                             | Default = 00h                |
| Pin 111 fur                                                                     | nctionality:(1)             | Pin 109 fun                                                                                     | ctionality:(2)                                                                                                                                | Pin 108 f                                                               | unctionality:                                           | DACK/PI                                                                     | RQ[3:2]#                     |
| 0X = Controlled                                                                 | by bits [1:0]               | 0X = Controlled b                                                                               | by bits [1:0]                                                                                                                                 | 0X = Controlled                                                         | by bits [1:0]                                           | group-wise p                                                                | 0                            |
| 10 = DACK7#                                                                     |                             | 10 = DACK6#                                                                                     |                                                                                                                                               | 10 = DACK5#                                                             |                                                         | pin functionalities:                                                        |                              |
| 11 = Reserved                                                                   |                             | 11 = Reserved                                                                                   |                                                                                                                                               | 11 = Reserved                                                           |                                                         | 00 = Explicit DACK[3:0]#,                                                   |                              |
| If set to 10, the setting on bits [1:0<br>will not affect the functionality tha |                             | If set to 10, the se<br>will not affect the                                                     |                                                                                                                                               |                                                                         |                                                         | PIRQ[3:2]#<br>01 = Explicit DACK[7:5,3,1,0]#,                               |                              |
| this pin takes on                                                               |                             | this pin takes on.                                                                              |                                                                                                                                               | ality that                                                              |                                                         | GPCS0#, P                                                                   |                              |
|                                                                                 |                             |                                                                                                 |                                                                                                                                               |                                                                         |                                                         | 10 = Encoded EI<br>EDACKEN#                                                 |                              |
|                                                                                 |                             |                                                                                                 |                                                                                                                                               |                                                                         |                                                         | 11 = Encoded EI<br>EDACKEN#                                                 | DACK[2:0],<br>\$, PIRQ[3:2]# |
|                                                                                 |                             |                                                                                                 |                                                                                                                                               |                                                                         |                                                         | Pin-wise, the se fror overridden by GF<br>EPMI[x]#, and D/<br>DACK3#, DACK1 | PCS[x]#,<br>ACK[7:5]# (for   |
| (1) Pin 111 can                                                                 | take on the followi         | I<br>ng functionalities -                                                                       | DACK3#. EDACK                                                                                                                                 | (2. or DACK7#. E                                                        | ACK3# and EDAC                                          |                                                                             | ,                            |
|                                                                                 |                             | mable with DACK                                                                                 |                                                                                                                                               | ,                                                                       |                                                         | 3 - 1                                                                       | , ,                          |
|                                                                                 |                             | ng functionalities -<br>programmable with                                                       |                                                                                                                                               | (1, or DACK6#. [                                                        | ACK1# and EDAC                                          | CK1 are group-wise                                                          | e programmable               |
| PCIDV1 45h                                                                      |                             | I                                                                                               | Pin Functionality                                                                                                                             | Register 1 - By                                                         | te 1                                                    |                                                                             | Default = 00                 |
|                                                                                 |                             | Pin 143                                                                                         | Pin 141                                                                                                                                       | Pin 140 f                                                               | unctionality:                                           | Pin 139 fu                                                                  | nctionality:                 |
|                                                                                 |                             | functionality:(1)                                                                               | functionality:                                                                                                                                | 00 = PIR0                                                               | Q1#                                                     | 00 = PIRQ                                                                   | 0#                           |
|                                                                                 |                             | If PCIDV1                                                                                       | This bit deter-                                                                                                                               | 01 = IRQ                                                                | )                                                       | 01 = EPMI                                                                   | 1#                           |
|                                                                                 |                             | 51h[4] = 0:                                                                                     | mines the                                                                                                                                     | 1X = Res                                                                | erved                                                   | 1X = Rese                                                                   | rved                         |
|                                                                                 |                             | 0 = Controlled<br>by PCIDV1                                                                     | group-wise<br>functionality of<br>the PIRQ2#+                                                                                                 |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | 44h[1:0]                                                                                        | GPCS0#. These                                                                                                                                 |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | 1 = EPMI2#                                                                                      | two functional-                                                                                                                               |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | (If this bit is set                                                                             | ities are group-                                                                                                                              |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | and 51h[4] = 0,                                                                                 | wise program-                                                                                                                                 |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | pin 143 takes                                                                                   | mable.                                                                                                                                        |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | on the EPMI2#                                                                                   | 0 = Controlled                                                                                                                                |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | functionality                                                                                   | by PCIDV1                                                                                                                                     |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | regardless of                                                                                   | 44h[1:0]                                                                                                                                      |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | the setting of                                                                                  |                                                                                                                                               |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             |                                                                                                 | and                                                                                                                                           |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             | 44h[1:0])                                                                                       | and<br>PCIDV1                                                                                                                                 |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             |                                                                                                 | PCIDV1                                                                                                                                        |                                                                         |                                                         |                                                                             |                              |
|                                                                                 |                             |                                                                                                 |                                                                                                                                               |                                                                         |                                                         |                                                                             |                              |
| (1) This nin can                                                                | take on any of the          | 44h[1:0])                                                                                       | PCIDV1<br>51h[3] = 0<br>1 = Reserved                                                                                                          | S1# or EPMI2#                                                           | PIRO3# and GPC                                          | S1# functionalities                                                         | are aroun-wise               |
|                                                                                 |                             | 44h[1:0])                                                                                       | PCIDV1<br>51h[3] = 0<br>1 = Reserved<br>ies - PIRQ3#, GPC                                                                                     |                                                                         | PIRQ3# and GPC<br>2#.                                   | S1# functionalities                                                         | are group-wise               |
| programmab                                                                      |                             | 44h[1:0])<br>these functionaliti<br>functionalities are                                         | PCIDV1<br>51h[3] = 0<br>1 = Reserved<br>ies - PIRQ3#, GPC                                                                                     | mable with EPMI                                                         | 2#.                                                     | S1# functionalities                                                         | are group-wise               |
| programmab<br>PCIDV1 48h                                                        |                             | 44h[1:0])<br>these functionaliti<br>functionalities are                                         | PCIDV1<br>51h[3] = 0<br>1 = Reserved<br>es - PIRQ3#, GPC<br>pin-wise programm                                                                 | mable with EPMI<br>Register 2 - By                                      | 2#.                                                     | S1# functionalities                                                         |                              |
| programmab<br>PCIDV1 48h<br>Pin 120 fu                                          | Inctionality:               | 44h[1:0])<br>these functionaliti<br>functionalities are<br>I<br>Pin 117 fu                      | PCIDV1<br>51h[3] = 0<br>1 = Reserved<br>es - PIRQ3#, GPC<br>pin-wise programm<br>Pin Functionality<br>nctionality:                            | nable with EPMI<br>Register 2 - By<br>Pin 116 f                         | 2#.<br>te 0<br>unctionality:                            | S1# functionalities                                                         |                              |
| programmab<br>PCIDV1 48h<br>Pin 120 fu<br>00 = DREC                             | Inctionality:               | 44h[1:0])<br>these functionaliti<br>functionalities are<br>Pin 117 fu<br>00 = DREC              | PCIDV1<br>51h[3] = 0<br>1 = Reserved<br>es - PIRQ3#, GPC<br>pin-wise programm<br>Pin Functionality<br>nctionality:                            | nable with EPMI<br>Register 2 - By<br>Pin 116 f<br>00 = DRE             | 2#.<br><b>te 0</b><br>unctionality:<br>Q0               | S1# functionalities                                                         |                              |
| PCIDV1 48h<br>Pin 120 fu<br>00 = DRE0<br>01 = DRE0                              | Inctionality:<br>Q3<br>Q3/7 | 44h[1:0])<br>these functionaliti<br>functionalities are<br>Pin 117 fu<br>00 = DREC<br>01 = DREC | PCIDV1<br>51h[3] = 0<br>1 = Reserved<br>les - PIRQ3#, GPC<br>pin-wise programm<br>Pin Functionality<br>nctionality:<br>Q1<br>Q1/6             | nable with EPMI<br>Register 2 - By<br>Pin 116 f<br>00 = DRE<br>01 = DRE | 2#.<br>te 0<br>unctionality:<br>Q0<br>Q0/5              | S1# functionalities                                                         |                              |
| PCIDV1 48h<br>Pin 120 fu<br>00 = DREC                                           | Inctionality:<br>Q3<br>Q7   | 44h[1:0])<br>these functionaliti<br>functionalities are<br>Pin 117 fu<br>00 = DREC              | PCIDV1<br>51h[3] = 0<br>1 = Reserved<br>les - PIRQ3#, GPC<br>pin-wise program<br><b>Pin Functionality</b><br>nctionality:<br>21<br>21/6<br>26 | nable with EPMI<br>Register 2 - By<br>Pin 116 f<br>00 = DRE             | 2#.<br><b>te 0</b><br>unctionality:<br>Q0<br>Q0/5<br>Q5 | S1# functionalities                                                         |                              |

#### Table 6 82C578 Pin Functionality Programming Register Bits (cont.)



| Table 6 | 82C578 Pin | Functionality | Programming | <b>Register Bits</b> | (cont.) |
|---------|------------|---------------|-------------|----------------------|---------|
|---------|------------|---------------|-------------|----------------------|---------|

| 7                                                                                                                                                                                                                                              | 6                                                     | 5                                                                                        | 4                                                                                   | 3                                                                                         | 2                                                    | 1                                                                                                                                                                                                          | 0             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Pin 136<br>functionality:<br>0 = IRQ15<br>1 = Reserved                                                                                                                                                                                         | Pin 134 fu<br>0X = IRQ1:<br>10 = MPIR<br>11 = Reser   | Q2#/3#                                                                                   | Pin 132<br>functionality:<br>0 = IRQ10<br>1 = MIRQ10/12                             | Pin 128<br>functionality:<br>0 = IRQ6<br>1 = MPIRQ0#/<br>1#<br>Also see<br>PCIDV1 53h[7]. | Pin 126<br>functionality:<br>0 = IRQ4<br>1 = MIRQ4/6 | Pin 123 fui<br>00 = DREC<br>01 = EPMI<br>1X = Reser                                                                                                                                                        | 27<br>3#      |
| PCIDV1 4Fh                                                                                                                                                                                                                                     |                                                       | Mi                                                                                       | scellaneous Con                                                                     | trol Register - By                                                                        | /te 1                                                |                                                                                                                                                                                                            | Default = 00I |
| Pin 112<br>functionality:<br>0 = DACK5#<br>(also see<br>PCIDV1<br>44h[1:0])<br>1 = PPWRL#<br>+PPWRL2                                                                                                                                           |                                                       |                                                                                          |                                                                                     |                                                                                           |                                                      | Pin 113<br>functionality:<br>0 = Controlled<br>by PCIDV1<br>44h[1:0]<br>1 = GPCS2#<br>If set to 1, the<br>PCIDV1<br>44h[1:0] setting<br>will not affect<br>the functionality<br>that this pin<br>takes on. |               |
| PCIDV1 51h                                                                                                                                                                                                                                     |                                                       | Inte                                                                                     | errupt Trigger Co                                                                   | ntrol Register - E                                                                        | Syte 1                                               |                                                                                                                                                                                                            | Default = 00  |
| Pin 104<br>functionality:<br>0 = 32KHz<br>1 = PREQ3#<br>Also see<br>PCIDV1 5Eh[6].                                                                                                                                                             | Pin 90<br>functionality:<br>0 = ZEROWS#<br>1 = PGNT3# | Pin 110<br>functionality:<br>0 = DACK2#<br>1 = GPCS2#<br>Also see<br>PCIDV1<br>44h[1:0]. | Pin 143<br>functionality:<br>0 = PIRQ3#<br>1 = GPCS1#<br>Also see<br>PCIDV1 45h[5]. | Pin 141<br>functionality:<br>0 = PIRQ2#<br>1 = GPCS0#                                     |                                                      |                                                                                                                                                                                                            |               |
| PCIDV1 53h                                                                                                                                                                                                                                     |                                                       | Interru                                                                                  | upt Multiplexing                                                                    | Control Register                                                                          | - Byte 1                                             |                                                                                                                                                                                                            | Default = 00  |
| Pin<br>functionality:<br>0 = Pin #:<br>125 = IRQ3<br>127 = IRQ5<br>128 = IRQ6<br>129 = IRQ7<br>131 = IRQ9<br>133 = IRQ11<br>1 = Pin #:<br>125 = MIRQ3/5<br>127 = MIRQ7/9<br>128 = MIRQ11/<br>15<br>129 = EPMI1#<br>131 = EPMI2#<br>133 = GMIRQ | Pin 146<br>functionality:<br>0 = PREQ2#<br>1 = EPMI0# |                                                                                          |                                                                                     |                                                                                           |                                                      |                                                                                                                                                                                                            |               |
| PCIDV1 55h                                                                                                                                                                                                                                     |                                                       |                                                                                          | PCI Master Contr                                                                    | al Degister - But                                                                         |                                                      |                                                                                                                                                                                                            | Default = 00  |



| 7                                                                                                                                                                                                                                | 6                                                                                                                                                                                                                | 5                                                                                   | 4                                                                                                                                                           | 3                                                                                | 2          | 1            | 0                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------|--------------|------------------------------|
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     | SERIRQ# mux-                                                                                                                                                |                                                                                  |            |              |                              |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     | ing on Pin 1:                                                                                                                                               |                                                                                  |            |              |                              |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     | 0 = Disable                                                                                                                                                 |                                                                                  |            |              |                              |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     | $1 = Enable^{(1)}$                                                                                                                                          |                                                                                  |            |              |                              |
| (1) Also these I                                                                                                                                                                                                                 | PCIDV1 register bit                                                                                                                                                                                              | s must be set: 5                                                                    | 4h[4] = 1, 59h[3] = 0                                                                                                                                       | , and 5Fh[4] = 0.                                                                |            |              |                              |
| PCIDV1 59h                                                                                                                                                                                                                       |                                                                                                                                                                                                                  |                                                                                     | Pin Function                                                                                                                                                | ality Register 3                                                                 |            |              | Default = 00h                |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             | EPMI0# mux-                                                                      |            |              | Pin 106                      |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             | ing on Pin 1:                                                                    |            |              | functionality:               |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             | 0 = Disable                                                                      |            |              | 0 = RTCRD#                   |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             | $1 = Enable^{(1)}$                                                               |            |              | 1 = PGNT3#                   |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | For SDACK2#                  |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | function on this             |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | pin, see                     |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | PCIDV1 5Eh[6].               |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | For PCI soft                 |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | reset genera-                |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | tion through<br>RTCRD#, see  |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              |                              |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              |                              |
|                                                                                                                                                                                                                                  |                                                                                                                                                                                                                  |                                                                                     |                                                                                                                                                             |                                                                                  |            |              | PCIDV1 61h[7]<br>and 62h[7]. |
| (1) Also these I                                                                                                                                                                                                                 | PCIDV1 register bit                                                                                                                                                                                              | s must he set: 5                                                                    | 4b[4] = 1.55b[4] = 0                                                                                                                                        | and $5Eb[4] = 0$                                                                 |            |              | and 62h[7].                  |
|                                                                                                                                                                                                                                  | PCIDV1 register bits                                                                                                                                                                                             | s must be set: 5                                                                    | 4h[4] = 1, 55h[4] = 0                                                                                                                                       |                                                                                  |            |              | and 62h[7].                  |
| PCIDV1 5Eh                                                                                                                                                                                                                       |                                                                                                                                                                                                                  | s must be set: 5                                                                    |                                                                                                                                                             | , and 5Fh[4] = 0.<br>Control Register                                            |            |              | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/                                                                                                                                                                                                              | SDRQ/                                                                                                                                                                                                            | s must be set: 5                                                                    |                                                                                                                                                             |                                                                                  |            |              | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-                                                                                                                                                                                              | SDRQ/<br>SDACK# func-                                                                                                                                                                                            | s must be set: 5                                                                    |                                                                                                                                                             |                                                                                  |            |              | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins                                                                                                                                                                             | SDRQ/<br>SDACK# func-<br>tions on pins                                                                                                                                                                           | s must be set: 5                                                                    |                                                                                                                                                             |                                                                                  |            |              | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:                                                                                                                                                             | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:                                                                                                                                                           | s must be set: 5                                                                    |                                                                                                                                                             |                                                                                  |            |              | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable                                                                                                                                              | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable                                                                                                                                            | s must be set: 5                                                                    |                                                                                                                                                             |                                                                                  |            |              | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup>                                                                                                                 | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>) 1 = Enable <sup>(2)</sup>                                                                                                             |                                                                                     | Steerable DRQ                                                                                                                                               | Control Register                                                                 |            |              |                              |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 func-                                                                                            | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a                                                                                          | nd pin 107 funct                                                                    |                                                                                                                                                             | Control Register                                                                 | V1 60h[4]. | n[0].        | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 func<br>(2) Pin 104 func                                                                         | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a                                                                                          | nd pin 107 funct                                                                    | Steerable DRQ<br>tions as SDACK1#. /                                                                                                                        | Control Register<br>Also refer to PCID                                           | V1 60h[4]. | n[0].        | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 fund<br>(2) Pin 104 fund<br>PCIDV1 5Fh                                                           | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a<br>ctions as SDRQ2 a                                                                     | nd pin 107 funct                                                                    | Steerable DRQ<br>tions as SDACK1#. /<br>tions as SDACK2#. /<br>Steerable IRQ                                                                                | Control Register                                                                 | V1 60h[4]. | h[O].        | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 fund<br>(2) Pin 104 fund<br>PCIDV1 5Fh<br>Pin 52                                                 | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a<br>ctions as SDRQ2 a                                                                     | nd pin 107 funct<br>nd pin 106 funct<br>nd pin 106 funct                            | Steerable DRQ<br>tions as SDACK1#. /<br>tions as SDACK2#. /<br>Steerable IRQ<br>SERIRQ# mux-                                                                | Control Register<br>Also refer to PCID                                           | V1 60h[4]. | h[0].        | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 fund<br>(2) Pin 104 fund<br>PCIDV1 5Fh<br>Pin 52<br>functionality:                               | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a<br>ctions as SDRQ2 a<br>Pin 154 fu<br>00 = Reser                                         | nd pin 107 funct<br>nd pin 106 funct<br>nctionality:<br>rved                        | Steerable DRQ<br>tions as SDACK1#. A<br>tions as SDACK2#. A<br>Steerable IRQ<br>SERIRQ# mux-<br>ing on Pin 1:                                               | Control Register<br>Also refer to PCID                                           | V1 60h[4]. | h[0].        | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 fund<br>(2) Pin 104 fund<br>PCIDV1 5Fh<br>Pin 52<br>functionality:<br>0 = Reserved               | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a<br>ctions as SDRQ2 a<br>Pin 154 fu<br>00 = Reset<br>01 = Reset                           | nd pin 107 funct<br>nd pin 106 funct<br>nctionality:<br>rved<br>rved                | Steerable DRQ<br>tions as SDACK1#. /<br>tions as SDACK2#. /<br>Steerable IRQ (<br>SERIRQ# mux-<br>ing on Pin 1:<br>0 = Disable                              | Control Register<br>Also refer to PCID                                           | V1 60h[4]. | n[0].        | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 fund<br>(2) Pin 104 fund<br>PCIDV1 5Fh<br>Pin 52<br>functionality:                               | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a<br>ctions as SDRQ2 a<br>Pin 154 fu<br>00 = Reset<br>01 = Reset<br>10 = MSGS              | nd pin 107 funct<br>nd pin 106 funct<br>nctionality:<br>rved<br>rved<br>S2N         | Steerable DRQ<br>tions as SDACK1#. A<br>tions as SDACK2#. A<br>Steerable IRQ<br>SERIRQ# mux-<br>ing on Pin 1:                                               | Control Register<br>Also refer to PCID                                           | V1 60h[4]. | <u>h[0].</u> | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 fund<br>(2) Pin 104 fund<br>PCIDV1 5Fh<br>Pin 52<br>functionality:<br>0 = Reserved<br>1 = MSGN2S | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a<br>ctions as SDRQ2 a<br>Pin 154 fu<br>00 = Reset<br>01 = Reset<br>10 = MSGS<br>11 = USBC | nd pin 107 funct<br>nd pin 106 funct<br>nctionality:<br>rved<br>rved<br>S2N<br>GNT# | Steerable DRQ<br>itions as SDACK1#. A<br>itions as SDACK2#. A<br>Steerable IRQ<br>SERIRQ# mux-<br>ing on Pin 1:<br>0 = Disable<br>1 = Enable <sup>(1)</sup> | Control Register<br>Also refer to PCID<br>Also refer to PCID<br>Control Register | V1 60h[4]. | ۵[O].        | and 62h[7].                  |
| PCIDV1 5Eh<br>SDRQ/<br>SDACK# func-<br>tions on pins<br>105 and 107:<br>0 = Disable<br>1 = Enable <sup>(1)</sup><br>(1) Pin 105 fund<br>(2) Pin 104 fund<br>PCIDV1 5Fh<br>Pin 52<br>functionality:<br>0 = Reserved<br>1 = MSGN2S | SDRQ/<br>SDACK# func-<br>tions on pins<br>104 and 106:<br>0 = Disable<br>1 = Enable <sup>(2)</sup><br>ctions as SDRQ1 a<br>ctions as SDRQ2 a<br>Pin 154 fu<br>00 = Reset<br>01 = Reset<br>10 = MSGS<br>11 = USBC | nd pin 107 funct<br>nd pin 106 funct<br>nctionality:<br>rved<br>rved<br>S2N<br>GNT# | Steerable DRQ<br>tions as SDACK1#. /<br>tions as SDACK2#. /<br>Steerable IRQ (<br>SERIRQ# mux-<br>ing on Pin 1:<br>0 = Disable                              | Control Register<br>Also refer to PCID<br>Also refer to PCID<br>Control Register | V1 60h[4]. | <u> </u>     | and 62h[7].                  |

### Table 6 82C578 Pin Functionality Programming Register Bits (cont.)



| 7                                                                                                                                            | 6 | 5        | 4                                                                                                                                                                             | 3                                                                                                                                           | 2                           | 1               | 0             |
|----------------------------------------------------------------------------------------------------------------------------------------------|---|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------|---------------|
|                                                                                                                                              |   | <u>.</u> | Pins 105 and<br>107<br>functionality:<br>0 = RTCAS+<br>SDRQ1 on<br>pin 105 and<br>RTCWR#+<br>SDACK1#<br>on pin 107<br>1 = PREQ4#<br>on pin 105<br>and<br>PGNT4#<br>on pin 107 |                                                                                                                                             | <u> </u>                    | <u> </u>        |               |
| PCIDV1 61h                                                                                                                                   |   |          | PCI Reset Co                                                                                                                                                                  | ontrol Register                                                                                                                             |                             |                 | Default = 00h |
| PCI soft reset<br>generation<br>through<br>RTCRD#:<br>0 = No action<br>1 = Generate a<br>100µs PCI<br>reset pulse<br>if PCIDV1<br>62h[7] = 0 |   |          |                                                                                                                                                                               | USBGNT# thru<br>RTCWR#<br>(pin 107):<br>0 = Enabled<br>only if<br>PCIDV1<br>5Fh[7] = 1<br>1 = Disable (no<br>USBGNT#<br>functional-<br>ity) | SERIRQ#/F<br>00 = No BFLOCI | s will override |               |
| PCIDV1 62h                                                                                                                                   |   |          | Emulation Co                                                                                                                                                                  | ontrol Register                                                                                                                             |                             |                 | Default = 00h |
| Pin<br>functionality:<br>0 = PCIRES#<br>enable<br>1 = PCIRES#<br>disable                                                                     |   |          |                                                                                                                                                                               |                                                                                                                                             |                             |                 |               |



| 7                                                  | 6                                       | 5                                  | 4        | 3            | 2                                 | 1 | 0             |
|----------------------------------------------------|-----------------------------------------|------------------------------------|----------|--------------|-----------------------------------|---|---------------|
| SYSCFG 26h                                         |                                         | ·                                  | ISA Cont | rol Register |                                   |   | Default = 00h |
|                                                    |                                         |                                    |          |              | USBGNT#:                          |   |               |
|                                                    |                                         |                                    |          |              | 0 = Through<br>messaging          |   |               |
|                                                    |                                         |                                    |          |              | protocol<br>1 = Through<br>pin 58 |   |               |
| SYSCFG 2Dh Bank-wise EDO Timing Selection Register |                                         |                                    |          |              |                                   |   |               |
| DIRTYI pin<br>(pin 158) mux:                       |                                         |                                    |          |              |                                   |   |               |
| 0 = MREF#<br>(MCACHE)                              |                                         |                                    |          |              |                                   |   |               |
| 1 = NVMCS                                          |                                         |                                    |          |              |                                   |   |               |
| SYSCFG 2Eh                                         |                                         |                                    | PCI Mast | er Register  |                                   |   | Default = 00h |
| BFLOCK pin<br>(pin 177)<br>control:                | Pin 102<br>functionality:<br>0 = USBCLK | MSGN2S/<br>MSGS2N bus<br>enabling: |          |              |                                   |   |               |
| 0 = Disable<br>1 = Enable                          | 1 = REFRESH#                            | -                                  |          |              |                                   |   |               |

#### Table 7 82C579 Pin Functionality Programming Register Bits

#### **DRAM Subsystem**

After a power-on reset when the BIOS attempts to configure the DRAM subsystem, the registers that affect the DRAM subsystem are located in the 82C579. All the registers that control the DRAM subsystem are accessed by the 22h, 24h indexing scheme (to access the System Control Register Space - SYSCFG).

The Viper Xpress+ Chipset supports up to six banks of DRAM. Given below is a step-by-step procedure for initializing the DRAM subsystem of the chipset. Table 8 shows the registers associated with configuration of the DRAM subsystem.

#### Step 1

Program SYSCFG 13h[7] = 1. This will enable the Viper Xpress+ Chipset to fully decode the incoming address.

#### Step 2

The BIOS should then program the size of each DRAM bank to be the maximum size before it determines the exact size of memory in each bank.

| SYSCFG   | Logical Bank Addressed |
|----------|------------------------|
| 13h[2:0] | Logical Bank 0         |
| 13h[6:4] | Logical Bank 1         |
| 14h[2:0] | Logical Bank 2         |
| 14h[6:4] | Logical Bank 3         |
| 19h[2:0] | Logical Bank 4         |
| 19h[6:4] | Logical Bank 5         |



#### Notes:

- A. SYSCFG 19h[7] and 19h[3] should be set to 1 before starting DRAM sizing.
- B. The maximum DRAM size setting in each register is 16Mx72 which corresponds to a 3-bit binary code of "111".

Table 8 DRAM Configuration Registers

E. Above all, the L1 and L2 caches must be disabled when the DRAM subsystem is being initialized.

#### Step 3

Size Logical Banks 0 through 5 and program the appropriate 3-bit binary code in the appropriate registers.

| 7                                                                                                                                                                | 6             | 5                    | 4             | 3                                                                                                                                                                                                                                               | 2 | 1                    | 0             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------|---------------|
| SYSCFG 13h                                                                                                                                                       |               |                      | Memory Decode | Control Register                                                                                                                                                                                                                                | 1 |                      | Default = 00h |
| Memory decode<br>select:<br>This bit must<br>be set to 1 for<br>full decode<br>(maximum flexi-<br>bility in choos-<br>ing different<br>DRAM configu-<br>rations) |               | (x72 101<br>(x72 110 |               | SMRAM:<br>0 = Disable<br>1 = Enable                                                                                                                                                                                                             |   | (x72 101<br>(x72 110 |               |
| SYSCFG 14h                                                                                                                                                       |               |                      | Memory Decode | Control Register                                                                                                                                                                                                                                | 2 |                      | Default = 00h |
| 82C576 mode:<br>0 = Normal<br>mode<br>1 = Clocked<br>mode<br>(Must = 1 for<br>EDO timing)                                                                        |               | (x72 101<br>(x72 110 | · · · ·       | SMRAM<br>control:<br>Inactive<br>SMIACT#:<br>0 = Disable<br>SMRAM<br>1 = Enable<br>SMRAM <sup>(1)</sup><br>Active<br>SMIACT#:<br>0 = Enable<br>SMRAM for<br>both Code<br>and Data <sup>(1)</sup><br>1 = Enable<br>SMRAM for<br>Code only<br>(1) |   | (x72 101<br>(x72 110 | ```           |
| (1) If SYSCFG 1                                                                                                                                                  | 3h[3] is set. |                      |               |                                                                                                                                                                                                                                                 | 1 |                      |               |
| SYSCFG 19h                                                                                                                                                       |               |                      | Memory Decode | Control Register                                                                                                                                                                                                                                | 3 |                      | Default = 00h |
| Reserved:<br>Must be written<br>to 1.                                                                                                                            |               | (x72 101<br>(x72 110 | · ,           | Reserved:<br>Must be written<br>to 1.                                                                                                                                                                                                           |   | (x72 101<br>(x72 110 | . ,           |



#### EDO DRAM Auto Detection

This section of the document explains the mechanism used to automatically detect EDO DRAM SIMMs located on the motherboard by the Viper Xpress+ Chipset.

# Detection between WE# controlled EDO DRAMs and Fast Page Mode DRAMs

Differentiating between these two type of DRAMs is a little bit more complex because FP Mode DRAMs specified at 70ns, could perform better than their rating and thus may even work with tighter timing. A second factor that makes the detection complex is the large capacitive load presented by the DRAM on the MD bus. This capacitive load manifests itself in the form of large discharge times, thereby retaining the last driven value on the bus for long periods of time.

A solution to this problem is to latch data into the chipset after a significantly large time after the CAS has been pulled high. Also an attempt could be made to generate a conflict on the bus, thereby discharging the bus and then attempting to read back the data present on the MD bus.

When SYSCFG 1Fh[6] (in the 82C579) is set to "1" it puts the Viper Xpress+ Chipset in the Mode of EDO DRAM detection. This will cause a quad-word to be read in 4 $\mu$ s. When bit 6 is set, setting bit 7 to a "1" will cause a conflict to be generated at about 2 $\mu$ s, if necessary.

An algorithm is given below to use this feature and detect the type of DRAM used on the board. Refer to

#### Size the first bank

1. Set SYSCFG 1Fh[6] = 1.

- 2. Set SYSCFG 1Fh[7] = 1. This step needs to be done only if the user desires to create a conflict on the bus.
- 3. Write a known pattern to a pre-determined location in DRAM.
- 4. Write a second different pattern to a second pre-determined location in the DRAM.
- 5. Read back data from the first pre-determined location in DRAM.
- 6. Read back data from second pre-determined location.
- If data read back is the same as the data written to the first pre-determined location, then the DRAM SIMMs are WE# EDO SIMMs, otherwise they are Fast Page Mode DRAM SIMMs.
- Set SYSCFG 1Ch[2] = 1 if Bank 0 = EDO Set SYSCFG 1Ch[2] = 0 if Bank 0 = FP DRAM

...... Set SYSCFG 1Ch[7] = 1 if Bank 5 = EDO Set SYSCFG 1Ch[7] = 0 if Bank 5 = FP DRAM

9. Repeat for all banks.

.....

**Note:** While EDO auto detection is in progress, hidden refresh should be disabled.

# Table 9 Register Bits Associated with EDO DRAM Auto Detection

| 7                                                                                     | 6                                                   | 5 | 4            | 3                | 2 | 1 | 0             |
|---------------------------------------------------------------------------------------|-----------------------------------------------------|---|--------------|------------------|---|---|---------------|
| SYSCFG 1Ch                                                                            |                                                     |   |              | Default = 00h    |   |   |               |
| Each bit is set to<br>to Bank 0 and bi<br>0 = Sta<br>1 = ED                           |                                                     |   |              |                  |   |   |               |
| SYSCFG 1Fh                                                                            |                                                     |   | EDO Timing C | Control Register |   |   | Default = 00h |
| 0 = Normal<br>1 = Generate<br>conflict dur-<br>ing EDO<br>detection<br>(bit 6 set) if | 0 = Normal<br>(fast page<br>mode)<br>1 = Detect EDO |   |              |                  |   |   |               |



#### Shadowing the ROM Area

The BIOS needs to shadow the F0000 area so that the BIOS code can execute out of local memory. Given below is an algorithm to achieve this and shows the 82C578 and 82C579 associated register bits.

- The BIOS should set PCIDV1 4Bh[7:6] = 00. This enables generation of the ROMCS# by the 82C578 whenever the address is in the F0000 segment.
- The BIOS should then set SYSCFG 06h[3:2] = 10. This causes all reads to the F0000 segment to go across the PCI bus while all writes will be performed on the DRAM.
- 4. The BIOS should then copy the contents of the ROM in the F0000 segment to DRAM.
- 5. The BIOS should set PCIDV1 4Bh[7:6] = 11. This disables generation of the ROMCS# by the 82C578 whenever the address is in the F0000 segment.
- The BIOS should then set register SYSCFG 06h[3:2] = 11. This causes all reads and writes to be performed on the DRAM.

| Table 10 | Register Bits | Associated with | <b>ROM Shadowing</b> |
|----------|---------------|-----------------|----------------------|
|----------|---------------|-----------------|----------------------|

| 7                                                                                                                                     | 6                                                                                                                                                                                                                                                           | 5                                                                                                                        | 4                                                                                                                                       | 3                                                                                                                                                                                            | 2                                                                                                                | 1                                                                                                                      | 0                                                                              |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|
| PCIDV1 4Bh                                                                                                                            |                                                                                                                                                                                                                                                             | RO                                                                                                                       | MCS# Range Co                                                                                                                           | ntrol Register - B                                                                                                                                                                           | yte 1                                                                                                            |                                                                                                                        | Default = 00h                                                                  |  |  |  |
| ROMCS# for<br>FFFF8000h-<br>FFFFFFFh<br>segment:<br>0 = Enable<br>1 = Disable                                                         | ROMCS# for<br>FFFF0000h-<br>FFFF7FFFh<br>segment:<br>0 = Enable<br>1 = Disable                                                                                                                                                                              | ROMCS# for<br>FFFE8000h-<br>FFFEFFFh<br>segment:<br>0 = Disable<br>1 = Enable                                            | ROMCS# for<br>FFFE0000h-<br>FFFE7FFFh<br>segment:<br>0 = Disable<br>1 = Enable                                                          | ROMCS# for<br>FFFD8000h-ROMCS# for<br>FFFD000h-FFFD8000h-<br>FFFD7FFFhFFFD7FFFh<br>segment:0 = Disable0 = Disable1 = Enable1 = Enable                                                        |                                                                                                                  | ROMCS# for<br>FFFC8000h-<br>FFFCFFFh<br>segment:<br>0 = Disable<br>1 = Enable                                          | ROMCS# for<br>FFFC0000h-<br>FFFC7FFFh<br>segment:<br>0 = Disable<br>1 = Enable |  |  |  |
| SYSCFG 06h     Shadow RAM Control Register 3     Default = 00h                                                                        |                                                                                                                                                                                                                                                             |                                                                                                                          |                                                                                                                                         |                                                                                                                                                                                              |                                                                                                                  |                                                                                                                        |                                                                                |  |  |  |
| DRAM hole<br>in system<br>memory from<br>80000h-<br>9FFFh: <sup>(1)</sup><br>0 = No hole in<br>memory<br>1 = Enable hole<br>in memory | Wait state addi-<br>tion for PCI<br>master<br>snooping:<br>0 = Do not add<br>a wait state<br>for the<br>cycle<br>access fin-<br>ish to do the<br>snooping<br>1 = Add a wait<br>state for the<br>cycle<br>access to<br>finish and<br>then do the<br>snooping | C0000h-<br>C7FFFh<br>cacheability:<br>0 = Not<br>Cacheable<br>in L1 and L2<br>(L1 dis-<br>abled by<br>SY SCFG<br>08h[0]) | F0000h-<br>FFFFh<br>cacheability:<br>0 = Not<br>Cacheable<br>1 = Cacheable<br>in L1 and L2<br>(L1 dis-<br>abled by<br>SYSCFG<br>08h[0]) | F0000h-<br>read/write<br>00 = Read/write I<br>01 = Read from I<br>PCI<br>10 = Read from F<br>DRAM<br>11 = Read/write I<br>If SYSCFG 04h[2<br>E0000h-EFFFFh<br>trol should have f<br>as this. | PCI bus<br>DRAM / write to<br>PCI / write to<br>DRAM<br>PCI = 1, then the<br>read/write con-<br>the same setting | E0000h-<br>read/write<br>00 = Read/write I<br>01 = Read from I<br>PCI<br>10 = Read from F<br>DRAM<br>11 = Read/write I | e control:<br>PCI bus<br>DRAM / write to<br>PCI / write to<br>DRAM             |  |  |  |



#### **PCI Bus Master IDE Configuration Requirements**

The system IDE controller configuration is done by the BIOS in two phases. The first phase takes place when the devices on the PCI bus are initialized. During this phase, the BIOS assigns interrupts and sets the level of the interrupts. The second phase of configuring the IDE controller takes place when the features in the system are enabled. During this phase, the IDE controller is configured for optimum performance based on the drives installed in the system. This is when the timing of the IDE controller is programmed into the internal registers of the controller.

The following section includes the tasks that are done by the BIOS during both of these phases. The BIOS is required to separate the two phases based on the guidelines provided above.

In order to optimize the PCI IDE Module for both DMA and PIO operations, the following steps are expected to be fulfilled by the system BIOS:

- 1. Enable the PCI IDE Module: PCIDV1 4Fh[6] = 1.
- Configure the PCI IDE Module through Mechanism #1 as Bus #0, Device #1, and Function #1. Also set SYSCFG FFh[4] = 1 (82C578).
- Detect the PCI bus frequency and record it into IDE I/O Address 1F5h[0]. For a synchronous PCI Viper Xpress+ system, the PCI bus frequency equals the system bus frequency divided by two.

If a 25MHz PCI bus is detected, a 1 should be written into the IDE I/O Address 1F5h[0] and 01 should be written into PCIDV1 47h[5:4] for the proper ISA clock divisor as well.

If the Viper Xpress+ system is configured for an asynchronous PCI clocking scheme, there is no need to perform this checking since an external 33MHz (power-up default) is feeding into the IDE module.

- 4. The default IDE ownership at PCIIDE 40h[4] should be set to 1. This allows the multiplexed ISA/IDE bus always park to the IDE Module.
- 5. The 32-byte read prefetch FIFO should be enabled by setting PCIIDE 40h[5] = 1.
- 6. Concurrent refresh and IDE cycles should be enabled by setting PCIDV1 52h[0] = 1.
- 7. PCI IDE one wait state reads for primary and secondary channels should be enabled at IDE I/O Address 1F3h[4].
- Read prefetch for primary and secondary channels should be enabled at IDE I/O Address 1F6h[6] and 176h[6] accordingly.
- 9. Enable master capability at PCIIDE 04h[2]. Once mastering is enabled, set PCIDV1 54h[7:4] = Fh.
- 10. Assign value for bus master IDE base address at PCIIDE 20h-23h.
- Depending on the capabilities of the system's hard drives and the PCI bus frequency, setup the IDE timings accordingly. The applicable SET\_FEATURES commands (i.e., Flow Control Enable) should be issued to the corresponding IDE drives as well.
- If no device is in the primary slave (Drive 1) location, set the command pulse and recovery time (1F0h/1F1h, Index-1) to correspond to PIO Mode 0.
- If no device is in the secondary master (Drive 0) location or slave (Drive 1) location, set the command pulse and recovery time (170h/171h, Index-0 and 170h/171h, Index-1) to correspond to PIO Mode 0.

#### Table 11 PCI Bus Master IDE Configuration Associated Register Bits

|            |                                                               | 0    |                                       | 0                |          |   |               |  |  |  |  |
|------------|---------------------------------------------------------------|------|---------------------------------------|------------------|----------|---|---------------|--|--|--|--|
| 7          | 6                                                             | 5    | 4                                     | 3                | 2        | 1 | 0             |  |  |  |  |
| PCIDV1 4Fh | CIDV1 4Fh Miscellaneous Control Register - Byte 1             |      |                                       |                  |          |   |               |  |  |  |  |
|            | IDE<br>functionality<br>support:<br>0 = Disable<br>1 = Enable |      |                                       |                  |          |   |               |  |  |  |  |
| SYSCFG FFh |                                                               | Gene | ral Purpose Chip                      | Select Control R | Register |   | Default = 00h |  |  |  |  |
|            |                                                               |      | Reserved:<br>Must be written<br>to 1. |                  |          |   |               |  |  |  |  |



|                 |   | r IDE Configura            |                                | -                |          |   |                                    |
|-----------------|---|----------------------------|--------------------------------|------------------|----------|---|------------------------------------|
| 7               | 6 | 5                          | 4                              | 3                | 2        | 1 | 0                                  |
| I/O Address 1F5 | h |                            | Strap I                        | Register         |          | I | Default = xxh                      |
|                 |   |                            |                                |                  |          |   | PCI CLK speed:                     |
|                 |   |                            |                                |                  |          |   | 0 = 33MHz<br>1 = 25MHz             |
|                 |   |                            |                                |                  |          |   | 1 = 2311112                        |
| PCIDV1 47h      |   |                            | Cycle Control R                | egister 1 - Byte | 1        |   | Default = 00h                      |
|                 |   |                            | uency select:                  |                  |          |   |                                    |
|                 |   | 00 = LC                    |                                |                  |          |   |                                    |
|                 |   | 10 = LC<br>01 = LC         |                                |                  |          |   |                                    |
|                 |   | 11 = LC                    |                                |                  |          |   |                                    |
| PCIIDE 40h      |   |                            | IDE Initialization             | Control Registe  | er       |   | Default = 00h                      |
|                 |   | Enhanced                   | Reserved:                      |                  |          |   |                                    |
|                 |   | slave:                     | Must be written                |                  |          |   |                                    |
|                 |   | 0 = 82C621A-               | to 1.                          |                  |          |   |                                    |
|                 |   | compatible<br>mode, uses   |                                |                  |          |   |                                    |
|                 |   | a 16-byte                  |                                |                  |          |   |                                    |
|                 |   | FIFO in                    |                                |                  |          |   |                                    |
|                 |   | PIO Mode                   |                                |                  |          |   |                                    |
|                 |   | 1 = Enhanced<br>mode, uses |                                |                  |          |   |                                    |
|                 |   | a 32-byte                  |                                |                  |          |   |                                    |
|                 |   | FIFO in                    |                                |                  |          |   |                                    |
|                 |   | PIO Mode                   |                                |                  |          |   |                                    |
| PCIDV1 52h      |   | Interru                    | upt Multiplexing (             | Control Register | - Byte 0 |   | Default = 00h                      |
|                 |   |                            |                                |                  |          |   | Concurrent<br>refresh and          |
|                 |   |                            |                                |                  |          |   | IDE cycle:                         |
|                 |   |                            |                                |                  |          |   | 0 = Disable                        |
|                 |   |                            |                                |                  |          |   | 1 = Enable                         |
|                 |   |                            |                                |                  |          |   | ISA devices that                   |
|                 |   |                            |                                |                  |          |   | rely on accu-<br>rate refresh      |
|                 |   |                            |                                |                  |          |   | addresses for                      |
|                 |   |                            |                                |                  |          |   | proper opera-                      |
|                 |   |                            |                                |                  |          |   | tion should dis-<br>able this bit. |
|                 |   |                            |                                |                  |          |   |                                    |
| I/O Address 1F3 | h |                            | 1                              | Register         |          |   | Default = xxh                      |
|                 |   |                            | Enable one<br>wait state read: |                  |          |   |                                    |
|                 |   |                            | 0 = 2  WS                      |                  |          |   |                                    |
|                 |   |                            | minimum                        |                  |          |   |                                    |
|                 |   |                            | 1 = 1 WS                       |                  |          |   |                                    |
|                 |   |                            | minimum for<br>data reads      |                  |          |   |                                    |
|                 |   |                            | data reads                     |                  |          |   |                                    |

### Table 11 PCI Bus Master IDE Configuration Associated Register Bits



#### 7 6 5 4 3 2 0 1 I/O Address 1F6h **Miscellaneous Register** Default = xxh Read prefetch: 0 = Disable1 = Enable I/O Address 176h **Miscellaneous Register** Default = xxh Read prefetch: 0 = Disable 1 = Enable PCIIDE 04h Command Register - Byte 0 Default = 4xh **IDE** controller becomes a PCI master to generate PCI accesses: 0 = Disable 1 = Enable Note: This bit must be explicitly programmed. PCIDV1 54h PCI Master Control Register - Byte 0 Default = 00h PCI master PCI master PCI master/IDE New AHOLD write X-1-1-1: read X-1-1-1: concurrence: protocol: 0 = Disable 0 = Disable 0 = Disable 0 = Disable1 = Enable 1 = Enable 1 = Enable 1 = Enable (use HREQ (Also see PCIIDE 42h[4] to latch and [2]) AHOLD) PCIIDE 20h-23h **Bus Master IDE Base Address Register** Default = 01000080h This register is the I/O base address indicator for the Bus Master IDE Registers. The address block has a size of 16 bytes. Bits [31:0] correspond to: 20h = [7:0], 21h = [15:8], 22h = [23:16], 23h = [31:24]. - Bits [3:0] are read-only and default to 0001. - Bits [31:4] are writable. I/O Address 1F0h, Index-1 Read Cycle Timing Register-B<sup>(1)</sup> Default = xxh Read pulse width: Read recovery time: The value programmed in this register plus one determines the DRD# The value programmed in this register plus two determines the recovery time between the end of DRD# and the next DA[2:0]/DCSx# being pulse width in LCLKs (for a 16-bit read from the IDE Data Register).<sup>(2)</sup> presented (after a 16-bit read from the IDE Data Register), measured in LCLKs.<sup>(2)</sup> (1) Read Cycle Timing Register-B shares the I/O address with Read Cycle Timing Register-A, indexed by 1F6h[0]. It controls the read cycle timing of the IDE Data Register for the drive not selected by 1F3h[3:2] if 1F3h[7] = 1. (2) See Table 14 or Table 15 (of this document).





| Table 11 PCI Bus Master                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | IDE Configura                            | tion Associat                  | ted Register B                                                                | its                                                          |                                       |                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------|---------------------------------------|
| 7 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 5                                        | 4                              | 3                                                                             | 2                                                            | 1                                     | 0                                     |
| I/O Address 1F1h, Index-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          | Write Cycle Tin                | ning Register-B <sup>(1)</sup>                                                |                                                              |                                       | Default = xxh                         |
| The value programmed in this regis<br>pulse width in LCLKs (for a 16-bit v<br>(1) Write Cycle Timing Register-B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | write from the IDE<br>shares the I/O add | Data Register). <sup>(2)</sup> |                                                                               | mmed in this regis<br>the end of DWR#<br>a 16-bit write from | and the next DA[2<br>the IDE Data Reg | 2:0]/DCSx# being<br>gister), measured |
| timing of the IDE Data Registe<br>(2) See Table 14 or Table 15 (of the second seco    |                                          | selected by 1F3h[              | 3:2] if 1F3h[7] = 1.                                                          |                                                              |                                       |                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                          |                                |                                                                               |                                                              |                                       |                                       |
| I/O Address 170h, Index-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          | Read Cycle Tin                 | ning Register-A <sup>(1)</sup>                                                |                                                              |                                       | Default = xxh                         |
| Read pu<br>The value programmed in this regis<br>pulse width in LCLKs (for a 16-bit r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                          |                                | The value programery time between presented (after a in LCLKs. <sup>(2)</sup> | mmed in this regis<br>the end of DRD#                        | and the next DA[2                     | 2:0]/DCSx# being                      |
| <ol> <li>Read Cycle Timing Register-A<br/>timing of the IDE Data Registe</li> <li>See Table 14 or Table 15 (of the second se</li></ol> | r for the drive sele                     |                                |                                                                               | ter-B, indexed by                                            | 176h[0]. It control                   | s the read cycle                      |
| I/O Address 171h, Index-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          | Write Cycle Tin                | ning Register-A <sup>(1)</sup>                                                |                                                              |                                       | Default = xxh                         |
| The value programmed in this regis<br>pulse width in LCLKs (for a 16-bit v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                          |                                | The value programery time between presented (after a in LCLKs. <sup>(2)</sup> | mmed in this regis<br>the end of DWR#                        | and the next DA[2                     | 2:0]/DCSx#being                       |
| <ol> <li>Write Cycle Timing Register-A<br/>timing of the IDE Data Registe</li> <li>See Table 14 or Table 15 (of the second s</li></ol> | r for the drive sele                     |                                |                                                                               | er-B, indexed by                                             | 176h[0]. It control                   | s the write cycle                     |
| I/O Address 170h, Index-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          | Read Cycle Tin                 | ning Register-B <sup>(1)</sup>                                                |                                                              |                                       | Default = xxh                         |
| Read pu<br>The value programmed in this regis<br>pulse width in LCLKs (for a 16-bit r<br>(1) Read Cycle Timing Register-B<br>timing of the IDE Data Registe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | shares the I/O add                       | Data Register). <sup>(2)</sup> |                                                                               | mmed in this regis<br>the end of DRD#<br>a 16-bit read from  | and the next DA[2<br>the IDE Data Reg | 2:0]/DCSx# being<br>gister), measured |
| (2) See Table 14 or Table 15 (of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | his document).                           |                                |                                                                               |                                                              |                                       |                                       |
| I/O Address 171h, Index-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                          | Write Cycle Tin                | ning Register-B <sup>(1)</sup>                                                |                                                              |                                       | Default = xxh                         |
| Write pu<br>The value programmed in this regis<br>pulse width in LCLKs (for a 16-bit v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | •                                        |                                | The value programery time between presented (after a in LCLKs. <sup>(2)</sup> | mmed in this regis<br>the end of DWR#                        | and the next DA[2                     | 2:0]/DCSx#being                       |
| <ol> <li>Write Cycle Timing Register-B<br/>timing of the IDE Data Registe</li> <li>See Table 14 or Table 15 (of the second s</li></ol> | r for the drive not s                    |                                |                                                                               | er-A, indexed by                                             | 176h[0]. It control                   | s the write cycle                     |



#### **Programming PCI Bus Master IDE Timing**

The power-up default of the IDE module is PIO Mode 0 for all four IDE devices. However, any of the IDE devices can be programmed up to PIO Mode 3. In addition, there are four sets of registers (two sets for each channel) that allow specific timings to be programmed on a "per-device" basis, see Table 12. These register sets are shared by the DMA and PIO operations. With the IDENTIFY\_DRIVE command information, the BIOS can optimize the IDE timing for each drive individually by programming these registers.

Any combination of hard drives or ATAPI devices may be connected to the two channels of the IDE module in a fourdrive configuration. For each channel, both sets of registers and the power-up default can be used to control any devices in the channel. See Table 13 for details. Table 14 and Table 15 show the timing and recommended register settings for various IDE modes defined in the Enhanced IDE Specifications. They include PIO transfer, Single-Word DMA transfer, and Multi-Word DMA transfer modes. The actual cycle time equals the sum of actual command active time and actual command inactive (command recovery and address setup) time. These three timing requirements shall be met. In some cases, the minimum cycle time requirement is greater than the sum of the command pulse and command recovery time. This means either the command active (command pulse) time, or command inactive (command recovery and address setup) time can be lengthened to ensure that the minimum cycle times are met.

Figure 2 is a flow chart that describes how to program the primary channel of the MIDE interface. For the secondary channel, a similar procedure can be done by changing all the indexes from 1Fxh to 17xh.

#### Table 12 Registers for Programming IDE Timing

| Name                                     | Address             |                                         |  |  |  |  |
|------------------------------------------|---------------------|-----------------------------------------|--|--|--|--|
| Timing Registers-A for Primary Channel   | 1F0h/1F1h - Index-0 | 1F3h, 1F5h, and 1F6h are shared by both |  |  |  |  |
| Timing Registers-B for Primary Channel   | 1F0h/1F1h - Index-1 | indexes                                 |  |  |  |  |
| Timing Registers-A for Secondary Channel | 170h/171h - Index-0 | 173h, 175h, and 176h are shared by both |  |  |  |  |
| Timing Registers-B for Secondary Channel | 170h/171h - Index-1 | indexes                                 |  |  |  |  |

#### Table 13 REGTIMx Programming Options

| REGTIM0<br>1F3h[2]/173h[2] | REGTIM1<br>1F3h[3]/173h[3] | REGTIM2<br>1F3h[7]/173h[7] | Master/Drive 0<br>Controlled by: | Slave/Drive 1<br>Controlled by: |
|----------------------------|----------------------------|----------------------------|----------------------------------|---------------------------------|
| 1(1)                       | 0                          | 1                          | Index-0                          | Index-1                         |
| 0                          | 1                          | 1                          | Index-1                          | Index-0                         |
| 0                          | 0                          | 1                          | Index-1                          | Index-1                         |
| 1                          | 0                          | 0                          | Index-0                          | Default <sup>(2)</sup>          |
| 0                          | 1                          | 0                          | Default <sup>(2)</sup>           | Index-0                         |
| 0                          | 0                          | 0                          | Default <sup>(2)</sup>           | Default <sup>(2)</sup>          |
| 1                          | 1                          | Х                          | Index-0                          | Index-0                         |

(1) Recommended configuration

(2) Refer to PCIIDE 40h[1:0]



#### Table 14 16-Bit Timing Parameters with 33/30MHz PCI Bus

|                                                               |                                           | IDE Transfer Modes |     |     |     |     |     |                         |     |     |                          |                                                                                                           |     |
|---------------------------------------------------------------|-------------------------------------------|--------------------|-----|-----|-----|-----|-----|-------------------------|-----|-----|--------------------------|-----------------------------------------------------------------------------------------------------------|-----|
| Parameter:                                                    |                                           | PIO Modes          |     |     |     |     |     | Multi-Word DMA<br>Modes |     |     | Single-Word DMA<br>Modes |                                                                                                           |     |
| Register Bits                                                 | Dimension                                 | 0                  | 1   | 2   | 3   | 4   | 5   | 0                       | 1   | 2   | 0                        | 1                                                                                                         | 2   |
| Address Setup:                                                | Bit values in hex                         | 2                  | 1   | 1   | 1   | 0   | 0   | 0                       | 0   | 0   | 0                        | 0                                                                                                         | 0   |
| 1F6h/176h[5:4]                                                | Timing in LCLKs <sup>(1)</sup>            | 3                  | 2   | 2   | 2   | 1   | 1   | 1                       | 1   | 1   | 1                        | 1                                                                                                         | 1   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | 70                 | 50  | 30  | 30  | 25  | N/S | N/A                     | N/A | N/A | N/A                      | N/A                                                                                                       | N/A |
| R/W Command Pulse:<br>1F0h/170h/1F1h/<br>171h[7:4], Index-0/1 | Bit values in hex                         | 5                  | 4   | 3   | 2   | 2   | 2   | 7                       | 2   | 2   | F                        | 8                                                                                                         | 4   |
|                                                               | Timing in LCLKs <sup>(1)</sup>            | 6                  | 5   | 4   | 3   | 3   | 3   | 8                       | 3   | 3   | 16                       | 9                                                                                                         | 5   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | 165                | 125 | 100 | 80  | 70  | N/S | 215                     | 80  | 70  | 480                      | 240                                                                                                       | 120 |
| R/W Recovery Time:                                            | Bit values in hex                         | 9                  | 4   | 0   | 0   | 0   | 0   | 6                       | 0   | 0   | D                        | 4                                                                                                         | 0   |
| 1F0h/170h/1F1h/<br>171h[3:0], Index-0/1                       | Timing in LCLKs <sup>(1)</sup>            | 11                 | 6   | 2   | 1   | 0   | 0   | 8                       | 1   | 0   | 15                       | 6                                                                                                         | 2   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | N/S                | N/S | N/S | 70  | 25  | N/S | 215                     | 50  | 25  | NS                       | Modes           1           0           1           N/A           8           9           240           4 | NS  |
| Enhanced Mode:<br>PCIIDE 43h [7:6],<br>[5:4], [3:2], or [1:0] | Bit values in hex                         | 0                  | 0   | 0   | 1   | 2   | 2   | 0                       | 1   | 2   | 0                        | 0                                                                                                         | 0   |
| DRDY:                                                         | Bit values in hex                         | 0                  | 0   | 0   | 0   | 0   | 0   | 0                       | 0   | 0   | 0                        | 0                                                                                                         | 0   |
| 1F6h/176h[3:1]                                                | Timing in LCLKs <sup>(1)</sup>            | 2                  | 2   | 2   | 2   | 2   | 2   | 2                       | 2   | 2   | 2                        | 2                                                                                                         | 2   |
| Cycle Time                                                    | Timing in LCLKs                           | 20                 | 13  | 8   | 6   | 5   | 4   | 17                      | 5   | 4   | 32                       | 16                                                                                                        | 8   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | 600                | 383 | 240 | 180 | 120 | N/S | 480                     | 150 | 120 | 960                      | 480                                                                                                       | 240 |

N/S = Not Specified, N/A = Not Applicable

(1) The actual timing (in LCLKs) that will be generated by the IDE controller if the recommended bit values in hex are programmed.

(2) The timing (in ns) as specified in the Enhanced IDE Specification.

N/S = Not Specified, N/A = Not Applicable



| Table 15 | 16-Bit Timing Parameters with 25MHz PCI Bus |
|----------|---------------------------------------------|
|----------|---------------------------------------------|

|                                                               |                                           | IDE Transfer Modes |     |     |     |     |      |                         |     |     |                          |     |     |
|---------------------------------------------------------------|-------------------------------------------|--------------------|-----|-----|-----|-----|------|-------------------------|-----|-----|--------------------------|-----|-----|
| Parameter:                                                    |                                           | PIO Modes          |     |     |     |     | Mult | Multi-Word DMA<br>Modes |     |     | Single-Word DMA<br>Modes |     |     |
| Register Bits                                                 | Dimension                                 | 0                  | 1   | 2   | 3   | 4   | 5    | 0                       | 1   | 2   | 0                        | 1   | 2   |
| Address Setup:                                                | Bit values in hex                         | 1                  | 1   | 0   | 0   | 0   | 0    | 0                       | 0   | 0   | 0                        | 0   | 0   |
| 1F6h/176h[5:4]                                                | Timing in LCLKs <sup>(1)</sup>            | 2                  | 2   | 1   | 1   | 1   | 1    | 1                       | 1   | 1   | 1                        | 1   | 1   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | 70                 | 50  | 30  | 30  | 25  | N/S  | N/A                     | N/A | N/A | N/A                      | N/A | N/A |
| R/W Command Pulse:                                            | Bit values in hex                         | 4                  | 3   | 2   | 2   | 1   | 1    | 5                       | 2   | 1   | D                        | 6   | 3   |
| 1F0h/170h/1F1h/<br>171h[7:4], Index-0/1                       | Timing in LCLKs <sup>(1)</sup>            | 5                  | 4   | 3   | 3   | 2   | 2    | 6                       | 3   | 2   | 13                       | 7   | 4   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | 165                | 125 | 100 | 80  | 70  | N/S  | 215                     | 80  | 70  | 480                      | 240 | 120 |
| R/W Recovery Time:                                            | Bit values in hex                         | 6                  | 2   | 0   | 0   | 0   | 0    | 4                       | 0   | 0   | 8                        | 2   | 0   |
| 1F0h/170h/1F1h/<br>171h[3:0], Index-0/1                       | Timing in LCLKs <sup>(1)</sup>            | 8                  | 4   | 2   | 1   | 0   | 0    | 6                       | 1   | 0   | 10                       | 4   | 1   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | N/S                | N/S | N/S | 70  | 25  | N/S  | 215                     | 50  | 25  | NS                       | NS  | NS  |
| Enhanced Mode:<br>PCIIDE 43h [7:6],<br>[5:4], [3:2], or [1:0] | Bit values in hex                         | 0                  | 0   | 0   | 1   | 2   | 2    | 0                       | 1   | 2   | 0                        | 0   | 1   |
| DRDY:<br>1F6h/176h[3:1]                                       | Bit values in hex                         | 0                  | 0   | 0   | 0   | 0   | 0    | 0                       | 0   | 0   | 0                        | 0   | 0   |
|                                                               | Timing in LCLKs <sup>(1)</sup>            | 2                  | 2   | 2   | 2   | 2   | 2    | 2                       | 2   | 2   | 2                        | 2   | 2   |
| Cycle Time                                                    | Timing in LCLKs                           | 15                 | 10  | 6   | 5   | 4   | 3    | 13                      | 4   | 3   | 24                       | 12  | 6   |
|                                                               | Enhanced IDE<br>Spec in ns <sup>(2)</sup> | 600                | 383 | 240 | 180 | 120 | N/S  | 480                     | 150 | 120 | 960                      | 480 | 240 |

(1) The actual timing (in LCLKs) that will be generated by the MIDE Module if the recommended bit values in hex are programmed.

(2) The timing (in ns) as specified in the Enhanced IDE Specification.



#### Table 16 IDE Interrupt Routing Chart

|                       |                       | 820                                        | 578 PCI Coi       | nfiguration F          | Register Sett            | ing                       | Interrupt Controller   |                        |                       |                       |
|-----------------------|-----------------------|--------------------------------------------|-------------------|------------------------|--------------------------|---------------------------|------------------------|------------------------|-----------------------|-----------------------|
| Functions             |                       | PCI Bus<br>Intrf,<br>Dev = 01h<br>Func = 0 |                   | IDE M<br>Dev :<br>Fund |                          |                           | 82C578 Inte            | errupt Input           | IDE Interrupts Output |                       |
| IDE Modes             |                       | 4Fh[6]                                     | 04h[0]            | 40h[3]                 | 40h[2]                   | 09h[3:0]                  | Pin 135 <sup>(1)</sup> | Pin 136 <sup>(1)</sup> | Primary               | Secondary             |
| Primary               | Secondary             | IDE Module<br>Enable                       | IDE I/O<br>Enable | 2nd IDE<br>Disable     | Native<br>Mode<br>Enable | Native/<br>Legacy<br>Mode | IRQ14 or<br>DINT0      | IRQ15 or<br>DINT1      | 8259 or<br>PCI INCT   | 8259 or<br>PCI INCT   |
| Disable               |                       | 0                                          | PCI Config.       | Register Sp            | ace cannot b             | e accessed                | ISA IRQ14              | ISA IRQ15              | N/A                   | N/A                   |
| DISC                  | able                  | 1                                          | 0                 | х                      | х                        | XXXX                      | ISA INQ 14             |                        | 19/74                 | IN/A                  |
| Legacy <sup>(2)</sup> | Disable               | 1                                          | 1                 | 1                      | 0                        | xxxx                      | DINT0                  | ISA IRQ15              | 8259 IRQ14            | N/A                   |
| Legacy                | Disable               | 1                                          | 1                 | 1                      | 1                        | xx10                      | DINTO                  |                        |                       |                       |
| Native                | Disable               | 1                                          | 1                 | 1                      | 1                        | xx11                      | DINT0                  | ISA IRQ15              | PIRQ3# <sup>(3)</sup> | N/A                   |
| Legacy <sup>(2)</sup> | Native                | 1                                          | 1                 | 0                      | 1                        | 1110                      | DINT0                  | DINT1                  | 8259 IRQ14            | PIRQ3# <sup>(3)</sup> |
| Native                | Legacy <sup>(2)</sup> | 1                                          | 1                 | 0                      | 1                        | 1011                      | DINT0                  | DINT1                  | PIRQ3# <sup>(3)</sup> | 8259 IRQ15            |
| (2)                   | 1                     | 1                                          | 0                 | 0                      | XXXX                     | DINT0                     | DINT1                  | 8259 IRQ14 82          | 9250 IP015            |                       |
| Legacy <sup>(2)</sup> | Legacy <sup>(2)</sup> | 1                                          | 1                 | 0                      | 1                        | 1010                      | DINTO                  | DINTI                  | 0233 INQ14            | 0200 110010           |
| Native                | Native                | 1                                          | 1                 | 0                      | 1                        | 1111                      | DINT0                  | DINT1                  | PIRQ3# <sup>(3)</sup> | PIRQ3# <sup>(3)</sup> |

1. The ISA IRQ14 (ISA IRQ15) will not be available to the ISA bus if the on-board primary (secondary) IDE is enabled.

2. The 8259 IRQ14 (8259 IRQ15) will not be available for PIRQ[3:0]# if the on-board primary (secondary) IDE is enabled.

3. In Native mode, IDE interrupts are shared with PIRQ3# from the PCI bus. It is routed in the same way as PIRQ3# to the interrupt controller and is controlled by PCIDV1 40h[11:9], 42h[7:1], and 50h[7:6] of the 82C578 (Device #01h, Function #0). Using this mode requires that the IDE device's Interrupt Service Routine support interrupt sharing.



# **OPTi Confidential**

#### Figure 2 IDE Interface Primary Channel Programming Flow Chart



#### **Programming and Drive Placement Tips:**

- Ensure that IDE I/O Address 1F6h[0] (176h[0] in the Secondary channel) is set to 0 whenever accessing Timing Registers-A. It is a common mistake that after accessing Timing Registers-B, this bit is not reset to 0 by the BIOS. An error happens after a soft reset (those bits will not be reset during a soft reset). The BIOS wants to reload the timing sets to both Timing Registers-A and -B. It would actually write to Timing Registers-B twice.
- 2. The address setup and recovery time are shared by the two IDE devices on the same channel at 1F6h[5:1]. If these two devices are not in the same mode, slower address setup and recovery time should be programmed to ensure proper timings on the slower drive. Under this assumption, two drives should be placed on the separate channels in a two-drive system. In a multiple-drive system, place slower drives on one channel and faster drives on the other channel.
- If no IDE hard drives are in the primary slave, secondary master location or slave location, set only the command pulse and recovery time (1F0h/1F1h, Index-1, 170h/ 171h, Index-0 and 170h/171h, Index-1) to correspond to PIO Mode 0. This is to ensure proper timing for an ATAPI CD-ROM that may be in any of these locations.



915-2000-067 Revision: 1.0

#### System Configuration

This section of the document will discuss configuration of the I/Os in the Viper Xpress+ Chipset.

#### **Cache Sizing Programming Guide**

The following tasks need to be completed in order to size the cache subsystem.

- 1. Performing cache tag test
- 2. Single bank cache SRAM devices detection

If a usable cache SRAM device is detected, then the cache needs to be sized. The following are valid cache sizes for the Viper Xpress+ Chipset.

- 256KB total cache size
- 512KB total cache size
- 1MB total cache size
- 2MB total cache size

The following is a flow diagram of the Viper Xpress+ Chipset cache sizing program.





#### **PCI Interrupt Routing**

The registers that affect the assignment of interrupts in the Viper Xpress+ chipset are located in the 82C578. The registers that affect the assignment are PCIDV1 40h, 41h and 50h.

Table 17 Interrupt Assignment / Control

| PCI<br>Interrupt | PCIDV1           | Bit Values/Triggered<br>IRQ                              |
|------------------|------------------|----------------------------------------------------------|
| PIRQ0#           | 40h[2:0]         | 000 = IRQx                                               |
| PIRQ1#           | 40h[5:3]         | 001 = IRQ5<br>010 = IRQ9                                 |
| PIRQ2#           | 40h[7:6], 41h[0] | 011 = IRQ10                                              |
| PIRQ3#           | 41h[3:1]         | 100 = IRQ11<br>101 = IRQ12<br>110 = IRQ14<br>111 = IRQ15 |

**Note:** The bits provided above control the interrupt routing only when the bits are programmed to a value different from 000. In the event that the bits are programmed to 000 for a given PIRQx#, then the routing of that interrupt is controlled by PCIDV1 50h. That mapping scheme is provided in Table 18.

Table 18 Enhanced Interrupt Assignment / Control

| PCI<br>Interrupt | PCIDV1   | Bit Values/Triggered IRQ |
|------------------|----------|--------------------------|
| PIRQ0#           | 50h[1:0] | 00 = Disable             |
| PIRQ1#           | 50h[3:2] | 01 = IRQ3<br>10 = IRQ4   |
| PIRQ2#           | 50h[5:4] | 11 = IRQ7                |
| PIRQ3#           | 50h[7:6] |                          |

#### Interrupt Sensing

Whenever PCI interrupts are routed to ISA interrupts, the interrupt needs to become level-triggered instead of edge-triggered. The only exception is the IDE interrupt (IRQ14). Table 19 lists the register bits that affect the interrupt trigger mechanism and the associated interrupt.

| ISA Interrupt | PCIDV1 | Bit Value           |
|---------------|--------|---------------------|
| IRQ3          | 51h[2] | 0 = Edge-triggered  |
| IRQ4          | 51h[1] | 1 = Level-triggered |
| IRQ5          | 42h[1] |                     |
| IRQ6          | 52h[7] |                     |
| IRQ7          | 51h[0] |                     |
| IRQ9          | 42h[2] |                     |
| IRQ10         | 42h[3] |                     |
| IRQ11         | 42h[4] |                     |
| IRQ12         | 42h[5] |                     |
| IRQ14         | 42h[6] |                     |
| IRQ15         | 42h[7] |                     |

Table 19 Interrupt Level Assignment



Page 25 of 27

#### **Enabling Features in the Viper Xpress+ Silicon**

All features listed in this section of the document should be turned on by the BIOS while enabling the advanced features in the system. Where indicated, the BIOS needs to follow the order specified while turning on these features.

- Note: Make sure writes to registers PCIDV0 44h-47h are always 32-bit writes. No memory access should be allowed in between configuration writes.
- CPU address pipelining
  - SYSCFG 08h[2] = 1
- PCI pre-snoop
  - The BIOS should turn on SYSCFG 0Fh[7] first and then turn on SYSCFG 16h[3]. This order should be maintained. As long as this order is maintained no other ordering with regard to the other features needs to be followed.
- Page miss posted write
  - SYSCFG 11h[2] = 1
- Hidden refresh (82C568)
   PCIDV1 47h[6] = 1
- Programming wait states during PCI master transfers
  - Enhanced Mode PCI master read:
    - PCIDV0 44h[1] = 1 PCIDV1 54h[6] = 1
    - = Controlled by SYSCFG 20h[1:0]
    - SYSCFG 20h[1:0] 01 = X-3-3-3 10 = X-2-2-2 11 = X-1-1-1
  - Enhanced Mode PCI master write: PCIDV0 44h[2] = 1 PCIDV1 54h[7] = 1
    - = Controlled SYSCFG 20h[3:2]
    - SYSCFG 20h[3:2] 01 = X-3-3-3 10 = X-2-2-2 11 = X-1-1-1
- **Note:** It is highly recommended to program X-1-1-1 transfers for PCI masters

- CPU-to-DRAM FIFO
  - Enable (Sequence must be followed)
    - SYSCFG 01h[2] = 1 (CAS width for DRAM write 2 CLK)
    - SYSCFG 02h[0] = 1 (CAS precharge 1 CLK)
    - SYSCFG 02h[1] = 1 (DRAM posted writes if already enabled this bit will be set to 1)
    - SYSCFG 2Ch[1:0] = 11 (Generate BOFF when FIFO full)
    - PCIDV0 44h[4] = 1
    - PCIDV0 45h[1] = 1
  - Disable Follow reverse sequence.
     Note: If DRAM post write already enabled there is no need to disable it when turning off this feature. Similarly for CAS width and precharge.
- PCI-to-DRAM FIFO
  - Enable/Disable (Sequence must be followed)
    - SYSCFG 20h[3:0] = 0Fh (PCI X-1-1-1 enable)
    - PCIDV0 47h[5] = 1
    - PCIDV0 44h[2:1] = 00
    - PCIDV0 44h[6:5] =
      - 00 Disable read/write FIFO
      - 01 Disable read/Enable write FIFO
      - 10 Enable read/Disable write FIFO
      - 11 Enable read/write FIFO
    - SYSCFG 2Ah[3:2] = 11 (bit 2 enables reads burst) (bit 3 enables write burst)
- CPU-to-PCI FIFO
  - Enable (Sequence must be followed)
    - SYSCFG 15h[5:4] = 01 (if PCI posted writes are already enabled, this bit will be set to either 01, 10 or 11)
    - PCIDV0 44h[7] = 1
    - SYSCFG 2Eh[3] = 1
  - **Disable** Follow reverse sequence. **Note:** If PCI post write already enabled do not disable it when turning off this feature.
- EDO 5-2-2-2 timing
  - Enable (Sequence must be followed)
    - Turn on EDO functionality
    - SYSCFG 1Dh[4] = 1 (Turns on 7-2-2-2)
    - SYSCFG 1Fh[4] = 1 (Turns on 6-2-2-2)
    - SYSCFG 26h[3] = 1
    - SYSCFG 2Dh[6] = 1
    - SYSCFG 2Dh[5:0] = Set for EDO bank detected (5-2-2-2)



# **OPTi Confidential**

- Self Refresh
  - Enable
    - SYSCFG 27h[2:0] =
    - 100 if ext clock is 66MHz
    - 101 if ext clock is 60MHz
    - 110 if ext clock is 50MHz
    - 111 if ext clock is 40MHz - PCIDV1 54h[0] = 1
  - Disable
    - PCIDV1 54h[0] = 0
    - SYSCFG 27h[2:0] = 000
- Note: It is recommended to turn on self refresh and turn off hidden refresh.
- CPU to Sync SRAM 3-1-1-1 pipelining
  - Enable (Sequence must be followed)
    - SYSCFG 10h[5] = 1
    - SYSCFG 04h[3] = 1
- Fast NA (3 CLK single cycle writes)
  - Enable (Sequence must be followed)
    - Ensure SYSCFG 0Ch[6] =1
    - <u>No L2 cache:</u> SYSCFG 0Eh[2] = 1
    - <u>L2 cache enabled</u> SYSCFG 27h[4] = 1 SYSCFG 0Fh[4] = 1 PCIDV1 55h[1] = 1 PCIDV0 42h[0] = 1 SYSCFG 0Eh[2] = 1
- Buffer DMA
  - ISA Retry SYSCFG 55h[1] = 1 SYSCFG 1Eh[3] = 1 SYSCFG 26h[6] = 1 SYSCFG 22h[4] = 1
- SDRAM
  - Read around SYSCFG 2Ch[4] = 1 PCIDV0 44h[13:12] = 11
  - SDRAM timing
    - 9-1-1-1 SYSCFG 1Fh[4] = 0 SYSCFG 1Dh[4] = 1 PCIDV0 54h[5:0] = 111111
    - 8-1-1-1 SYSCFG 1Fh[4] = 0 SYSCFG 1Dh[4] = 1 PCIDV0 54h[5:0] = 000000

- 7-1-1-1
  - SYSCFG 1Fh[4] = 1 SYSCFG 1Dh[4] = 1
  - PCIDV0 54h[5:0] = 000000
- SDRAM pipeline
  - X-1-1-1/2-1-1-1 pipeline setup for EDO SYSCFG 00h[6] = 1 SYSCFG29h[7] = 1
  - X-1-1/5-1-1-1 pipeline setup for EDO

**Note:** For all SDRAM-based systems, the following bits need to be set:

PCIDV0 48h[4] = 1, PCIDV0 48h[3] = 0, PCIDV0 48h[3] = 0, PCIDV0 4Eh[6] = 0PCIDV0 4Eh[5] = 1PCIDV0 55h[7] = 1PCIDV0 55h[6] = 1

### Deep Buffer Programming

The following sequence should be used when enabling deep buffers.

- 1. CPU-to-PCI
- 2. CPU-to-DRAM
- 3. PCI-to-DRAM

Also the enabling of deep buffers with respect to the entire BIOS, the following sequence is recommended.

- 1. The three deep buffers can be enabled just before giving control to boot block to start the OS.
- 2. When deep buffers are enabled and Ctrl+Alt+Del key is pressed (soft boot), the BIOS must disable all the three deep buffers in the reverse order of enabling after giving sufficient time (250 CPU clock time at least) to allow flushing of buffered data from the buffers. Again just before giving control to boot block, they should be enabled.
- 3. All the deep buffer enabling/disabling code must be a tight sequence code without any DRAM or non-configuration PCI cycles in-between.



**Application Note**