ADM-XRC

PCI Mezzanine Card

User Guide

Version 1.3



1

Copyright © 2001 Alpha Data Parallel Systems Ltd. All rights reserved.

This publication is protected by Copyright Law, with all rights reserved. No part of this publication may be reproduced, in any shape or form, without prior written consent from Alpha Data Parallel Systems Limited.

Alpha Data Parallel Systems Ltd. 58 Timber Bush Edinburgh EH6 6QH Scotland UK Phone: +44 (0) 131 555 0303

Fax: +44 (0) 131 555 0505 Fax: +44 (0) 131 555 0728 Email: support@alphadata.co.uk

Copyright © 2001 Alpha Data Parallel Systems Ltd. All rights reserved.

This publication is protected by Copyright Law, with all rights reserved. No part of this publication may be reproduced, in any shape or form, without prior written consent from Alpha Data Parallel Systems Limited.

## Table of Contents

| 1. Introd  | uction                                       | 1  |
|------------|----------------------------------------------|----|
| 1.1. S     | pecifications                                | 1  |
| 2. Install | ation                                        | 2  |
| 2.1. N     | otherboard requirements                      | 2  |
|            | andling instructions                         |    |
| 2.3. Ir    | stalling the ADM-XRC onto a PMC motherboard  | 2  |
| 2.4. Ir    | stalling the ADM-XRC if fitted to an ADC-PMC | 2  |
| 3. PCI B   | us Interface                                 | 3  |
| 4. ADM-2   | XRC Local Bus Architecture                   | 4  |
| 4.1. C     | haracteristics of Address Spaces             | 4  |
| 4.2. L     | ocal Control Registers                       | 5  |
| 4.2.1.     | FCON Register                                | 5  |
|            | CCON Register                                |    |
|            | ICON Registers                               |    |
|            | PSTAT Register                               |    |
| 4.2.5.     | SelectMAP Register                           | 7  |
| 5. FPGA    | Operation                                    |    |
| 5.1. C     | lock Distribution                            | 8  |
| 5.2. lr    | put Clocks                                   | 8  |
|            | utput Clocks                                 |    |
| 5.4. L     | ocal Bus                                     | 9  |
|            | ynchronous SRAM                              |    |
|            | ser I/O Front Panel Variant                  |    |
| 5.7. U     | ser I/O PMC Pn4 Variant                      | 13 |
|            | juring the FPGA                              |    |
|            | electMAP Operation                           |    |
|            | itstream Issues                              |    |
| 7. Interru | ıpts                                         | 15 |
|            | Memory                                       |    |
|            | CI9080 Initialisation                        |    |
|            | CI Registers                                 |    |
|            | ocal Configuration Registers                 |    |
|            | Mode/Arbitration Register                    |    |
| 9.2.2.     | Big/Little Endian Descriptor Register        |    |
| 9.2.3.     |                                              |    |
| 9.2.4.     |                                              |    |
| 9.2.5.     | DM Config/IO Register                        |    |
| 9.2.6.     |                                              |    |
| 9.3. R     | untime Registers                             |    |
| 9.3.1.     | Interrupt Control/Status Register            | 26 |
| 9.3.2.     |                                              |    |
| 10. EEF    | PROM Contents                                |    |
| -          | GA Pins                                      |    |
| 11.1.      | Clocks                                       |    |
| 11.2.      | Local Bus                                    |    |
| 11.3.      | SSRAM Bank 0                                 |    |
| 11.4.      | SSRAM Bank 1                                 |    |
| 11.5.      | SSRAM Bank 2                                 |    |
| -          |                                              | -  |

| 11.6. | SSRAM Bank 3 | .3 | 7 | , |
|-------|--------------|----|---|---|
|-------|--------------|----|---|---|

## 1. Introduction

The ADM-XRC is a high performance PCI Mezzanine Card (PMC) format device designed for supporting development of applications using the Virtex series of FPGA's from Xilinx.



## 1.1. Specifications

The ADM-XRC supports high performance PCI operation without the need to integrate proprietary cores into the FPGA. A PLX PCI9080 provides a rich set of PCI resources including two high speed DMA controllers that can achieve rates of 120Mbytes/sec.

- ?? Physically conformant to IEEE P1386 Common Mezzanine Card standard
- ?? High performance PCI and DMA controllers
- ?? Local bus speeds of up to 40MHz
- ?? Four banks of 256kx36 SSRAM, Synchronous burst or ZBT
- ?? Up to 512kx36 bits ZBT supported
- ?? User clock programmable between 0.5MHz and 100MHz
- ?? User 68 pin front panel connector with 34 free I/O
- ?? Supports 3.3V and 5V PCI signalling levels (VI/O)

# 2. Installation

This chapter explains how to install the ADM-XRC onto a PMC motherboard.

## 2.1. Motherboard requirements

The ADM-XRC must be installed in a PMC motherboard which supplies 3.3V power to the PMC connectors. Ensure that the motherboard satisfies this requirement before powering it up.

The ADM-XRC supports both 3.3V and 5V PCI signalling levels (VI/O).

## 2.2. Handling instructions

Observe precautions for preventing damage to components by electrostatic discharge. Personnel handling the board should take SSD precautions. Avoid flexing the board.

## 2.3. Installing the ADM-XRC onto a PMC motherboard

# Note: This operation should not be performed while the PMC motherboard is powered up.

The ADM-XRC must be secured to the PMC motherboard using M2.5 screws in the four holes provided. The PMC bezel through which the I/O connector protrudes should be flush with the front panel of the PMC motherboard.

## 2.4. Installing the ADM-XRC if fitted to an ADC-PMC

The ADM-XRC can be supplied for use in standard PC systems fitted to an ADC-PMC carrier board. The ADC-PMC can support up to two ADC-PMC cards whilst maintaining host PC PCI compatibility. There are no links or jumpers to set on the ADC-PMC. All that is required for installation is a 5V PCI slot that has enough space to accommodate the full-length card. It should be noted that the ADC-PMC uses a standard bridge to provide a secondary PCI bus for the ADM-XRC and that some older BIOS code does not set up these devices correctly. Please ensure you have the latest version of BIOS appropriate for your machine. The ADC-PMC requires only 5V from the host PC.

# 3. PCI Bus Interface

The PCI bus is implemented in a PLX PCI9080 and is configured with settings as described later in this document to simplify the integration of user applications in the FPGA.

| Config. |                                     |                                          |       |        |      |       |       |       |
|---------|-------------------------------------|------------------------------------------|-------|--------|------|-------|-------|-------|
| Offset  | 31                                  | 24                                       | 23    | 16     | 15   | 8     | 7     | 0     |
| 00      |                                     | Devi                                     | ce ID |        |      | Vendo | or ID |       |
|         |                                     |                                          | 40)   |        |      |       | 44)   |       |
|         |                                     |                                          | 80)   |        |      |       | B5)   |       |
| 04      |                                     |                                          | tus   |        |      | Comr  | nand  |       |
| 08      | Class                               | Code                                     |       |        |      |       | Revis | ionID |
| 0C      | BI                                  | ST                                       | Heade | rType  | Lat. | Timer | Cache | Line  |
| 10      |                                     | PCI BAR0                                 |       |        |      |       |       |       |
|         |                                     | (PLX Internal Registers/Memory)          |       |        |      |       |       |       |
| 14      |                                     |                                          |       | PCI    |      |       |       |       |
|         |                                     | (PLX Internal Registers/IO)              |       |        |      |       |       |       |
| 18      |                                     | PCI BAR2                                 |       |        |      |       |       |       |
|         | (Local Bus FPGA)                    |                                          |       |        |      |       |       |       |
| 1C      | PCI BAR3                            |                                          |       |        |      |       |       |       |
|         | (Local Bus Control/Flash/SelectMap) |                                          |       |        |      |       |       |       |
| 20      | PCI BAR4                            |                                          |       |        |      |       |       |       |
|         | (Not used)                          |                                          |       |        |      |       |       |       |
| 24      | PCI BAR5                            |                                          |       |        |      |       |       |       |
|         | (Not used)                          |                                          |       |        |      |       |       |       |
| 28      |                                     |                                          |       | CIS Po |      |       | ,     |       |
| 2C      | Subsystem ID Subsystem Vendor ID    |                                          |       |        |      |       |       |       |
| 30      | P                                   | PCI Base Address for Local Expansion ROM |       |        |      |       |       | М     |
| 34      |                                     |                                          |       | Rese   | rved |       |       |       |
| 38      |                                     |                                          |       | Rese   | rved |       |       |       |
| 3C      | Max La                              | at                                       | Min G | nt     | Int. | Pin   | Int.  | Line  |

The PCI configuration space of the ADM-XRC is shown below.

The PCI9080 uses the first two Bar's to provide access to its internal registers both via memory accesses and I/O accesses. Either BAR may be used by the host.

BAR 2 provides access to a 4Mbyte space for use by the FPGA and must be accessed only when a valid FPGA configuration is loaded that can respond correctly to local bus access.

BAR 3 provides access to the local control registers and the flash memory.

# 4. ADM-XRC Local Bus Architecture

It is useful to refer to the PLX PCI9080 user manual for information on the operation of the local bus and how address spaces map to the BAR's in PCI configuration space. The first two BAR's decode memory and I/O ranges for the PCI9080 internal registers.

There are two BAR's (at offsets 0x18 and 0x1C) that map the two main local bus address spaces, S0 and S1. In the ADM-XRC, S0 is a 4Mbyte memory address space, 32 bits wide and is available for the user to access the FPGA and for local bus control registers. S1 maps in a 4Mbyte memory address space, 8 bits wide for access to the flash and FPGA SelectMap port.



The PCI9080 can be programmed to support 8, 16 or 32 bit local bus widths and this feature is used to match with the device widths fitted on the ADM-XRC. Other than programming the BAR's with values determined by the host system, no other programming of the PCI9080 is required in order to access the local bus registers and devices.

## 4.1. Characteristics of Address Spaces

| Space | Size | Width | Burst | Prefetch | Burst Term | Local Offset |
|-------|------|-------|-------|----------|------------|--------------|
| S0    | 4MB  | 32    | yes   | yes      | yes        | 0x00000000   |
| S1    | 4MB  | 8     | no    | no       | n/a        | 0x00800000   |

From the PCI side of the PCI9080, transfers to either space may be 8, 16 or 32 bit in width and of any length. The PCI9080 breaks up transfers to suit the address space on the local bus whilst respecting the characteristics outlined above.

## 4.2. Local Control Registers

The local bus control registers are implemented in a CPLD attached to the PCI9080 local bus. The map of these registers is shown below.

| S1+offset | Write     | Read      |
|-----------|-----------|-----------|
| 0         | FCON      | FSTAT     |
| 1         | CCON      | CSTAT     |
| 2         | IMSET     | IMSTAT    |
| 3         | IMCLR     | IMSTAT    |
| 4         | ICON      | ISTAT     |
| 5         | PCON      | PSTAT     |
| 6         | MBZ       | RAX       |
| 7         | MBZ       | RAX       |
| 8-15      | SelectMap | SelectMap |

Registers that are not implemented are marked Must Be Zero (MBZ) and Read As Don't Care (RAX). The same applies for bits within implemented registers that are not used or reserved.

## 4.2.1. FCON Register

The FPGA can be configured by the host system using the SelectMap port on the target device. Before this can be achieved, the FPGA must be initialised to an erased state. Asserting PROG and then releasing it will start the initialisation process. The INIT bit is only valid whilst the device is not configured, indicated by a zero in DONE. After configuration, the INIT pin becomes a user I/O pin and has no further function on the ADM-XRC. In this case the place and route program sets the INIT pin to an input with a weak pull down thus resulting in INIT appearing set.

|       | 7   | 6   | 5   | 4   | 3   | 2    | 1    | 0    |   |
|-------|-----|-----|-----|-----|-----|------|------|------|---|
| FCON  | MBZ | MBZ | MBZ | MBZ | MBZ | MBZ  | INIT | PROG | W |
| FSTAT | RAX | RAX | RAX | RAX | RAX | DONE | INIT | PROG | R |

| FCON<br>PROG | Function (W0/1 is write value, R is when read)<br>W0 - Release PROGRAM to the FPGA |
|--------------|------------------------------------------------------------------------------------|
|              | W1 - Asserts PROGRAM pin on the target FPGA                                        |
|              | RX - Indicates state of FCON[PROG]                                                 |
| INIT         | W0 - Has no effect on FPGA INIT pin                                                |
|              | W1 - Asserts INIT pin to FPGA to postpone configuration                            |
|              | R0 - FPGA has no error                                                             |
|              | R1 - FPGA has asserted INIT                                                        |
| DONE         | R0 - FPGA is not configured or is being configured                                 |
|              | R1 - FPGA is successfully configured                                               |

## 4.2.2. CCON Register

The CCON register controls access to the ICD2061 clock generator. The range of frequencies supported is between 25 and 40 MHz. Although the ADM-ARC can operate at frequencies less than 25MHz, the CLKDLL circuits in the FPGA will not. The maximum frequency of the PCI9080 local bus is 40MHZ.

Refer to the ICD2061A data sheet for further information on determining clock generator settings.

|       | 7   | 6   | 5   | 4      | 3      | 2       | 1       | 0      |   |
|-------|-----|-----|-----|--------|--------|---------|---------|--------|---|
| CCON  | MBZ | MBZ | MBZ | MBZ    | INTCLK | FEATCLK | DATA/S1 | CLK/S0 | W |
| CSTAT | RAX | RAX | RAX | SERERR | INTCLK | FEATCLK | DATA/S1 | CLK/S0 | R |

| FCON    | Function (W0/1 is write value, R is when read) |
|---------|------------------------------------------------|
| CLK     | W0/1 Drives clock signal to ICD2061            |
|         | Determines S0 when static                      |
| DATA    | W0/1 Drives data signal to ICD2061             |
|         | Determines S1 when static                      |
| FEATCLK | W0 - Do not use                                |
| INTCLK  | W0 - Do not use                                |

The ICD2061 is programmed using CLK and DATA bits to form manchester encoded sequences. Each sequence consists of a 5 bit unlock preamble followed by a 24 bit data word all of which must be programmed within 10ms from the start of the first bit. If programming is not completed within this time, the ICD2061 will assert SERERR and ignore the remainder of the sequence. When the ICD2061 is not being programmed, S1 and S0 select the internal VCLK programming register.

## 4.2.3. ICON Registers

The ICON registers consist of a mask register and an interrupt status register. The mask register can be set or cleared by writing to IMSET or IMCLR with a bit mask. The ADM-XRC only supports one interrupt from the local bus and is masked, set or cleared using bit 0. On reset the mask bits are set disabling local bus interrupts.

|        | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0     |   |
|--------|-----|-----|-----|-----|-----|-----|-----|-------|---|
| IMSET  | MBZ | FINTM | W |
| IMCLR  | MBZ | FINTM | W |
| IMSTAT | RAX | FINTM | R |

The ICON register contains the status of the interrupt from the FPGA. This bit can be read independently of the state of the FINTM mask bit. To clear the FINT interrupt reported in ISTAT, write the corresponding bit in ICON.

|       | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0    |   |
|-------|-----|-----|-----|-----|-----|-----|-----|------|---|
| ICON  | MBZ | FINT | W |
| ISTAT | RAX | FINT | R |

#### 4.2.4. PSTAT Register

The PSTAT register presents information about the power supply to the Virtex device. The ADM-XRC generates power for the FPGA core from 5V, using a switch mode supply circuit that outputs two signals to indicate over-temperature and accuracy.

| 7     6     5     4     3     2     1     0       PSTAT     RAX     RAX     RAX     RAX     RAX     PTEMP     PGOOD     R | _ |       |     |     |     |     |     |     |       |       |   |
|---------------------------------------------------------------------------------------------------------------------------|---|-------|-----|-----|-----|-----|-----|-----|-------|-------|---|
| PSTAT RAX RAX RAX RAX RAX RAX PTEMP PGOOD R                                                                               |   |       | 7   | 6   | 5   | 4   | 3   | 2   | 1     | 0     |   |
|                                                                                                                           | F | PSTAT | RAX | RAX | RAX | RAX | RAX | RAX | PTEMP | PGOOD | R |

| PGOOD | R0 - PSU is out of range               |
|-------|----------------------------------------|
|       | R1 - PSU is within +/- 10%             |
| PTEMP | R0 - PSU has shutdown (thermal detect) |
|       | R1 - PSU is within operating range     |

#### 4.2.5. SelectMAP Register

The ADM-XRC supports only SelectMAP download of configuration data to the Virtex FPGA. The SelectMAP register is a write only port (in the current ADM-XRC) that is written with configuration information.

|           | 7                         | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |
|-----------|---------------------------|---|---|---|---|---|---|---|---|
| SelectMap | p Configuration Data Byte |   |   |   |   |   |   |   | W |

#### NOTE. Do not write to the SelectMAP register whilst DONE is set.

# 5. FPGA Operation

The following sections describe the operation of the FPGA in terms of the resources that are available. Where pin numbers are not mentioned, these can be found the constraints file for the V1000, supplied with the example FPGA design. Please refer to the application notes supplied in the installation directory for examples of working designs and guidelines.

## 5.1. Clock Distribution

The ADM-XRC uses the PLX PCI9080 local bus to provide a synchronous data transfer interface and all devices attached to the PCI9080 run at the local bus clock rate.

The VCLK output from the ICD2061 provides the local bus clock and by default runs at 28.5MHz. The VCLK output can be determined by three registers in the ICD2061, selected by the S1/S0 bits in the CCON register. It is recommended that alterations to VCLK use REG1 or REG2 to set the new value so that on reset the VCLK output selects REG0 when S1/S0 are reset.



## 5.2. Input Clocks

There are two primary clock inputs to the FPGA, both from the programmable clock generator. The MCLK signal from the clock generator is used only by the FPGA. It is therefore free for use by logic in the FPGA.

The VCLK signal from the clock generator is the local bus clock, used by the FPGA, PLX PCI9080 and a support CPLD. In addition, this clock is routed to the FPGA CCLK pin to enable SelectMap configuration at local bus speed.

Both MCLK and VCLK can be programmed between 400kHz and 100MHz.

A restriction on VCLK is that it must not exceed 40MHz,the maximum speed of the PCI9080, and should not be lower than 25MHz for reliable CLKDLL operation.

VCLK is input to the FPGA on GCK3 (pin A17) and should be used to drive a Virtex CLKDLL circuit which aligns the internal FPGA clock to the local bus clock. The circuit below demonstrates how to align the internal clock of the FPGA to the local bus clock. The output of the BUFG is available to all flip-flops in the design.



MCLK is input to the FPGA on GCK1 (pin AJ17) and can be used for any purpose within the FPGA.

## 5.3. Output Clocks

The FPGA is responsible for providing clocks to the SRAM's and also for aligning its internal global clock with the local bus clock. To do this requires the use of Virtex CLKDLL's that are specifically designed for the purpose of minimising skew between external and internal clock domains.

The R0\_R2CLK and R1\_R3CLK should each be slaved to the FPGA clock on the output of the BUFG in the above diagram. The feedback for the SRAM CLKDLL should come form R2\_CLK. The same applies for R1\_R3CLK and R3\_CLK.

NOTE. There are issues arising from the use of CLKDLL modules in some service packs for 2.1i software. Please ensure that the latest service pack has been applied to your system.

## 5.4. Local Bus

The local bus of the ADM-XRC uses the PCI9080 to provide a nonmultiplexed address and data capability with synchronous speeds of up to 40MHz, independent of PCI operation. Whilst the local bus is capable of achieving near PCI performance, it is much simpler to interface with than PCI. The ADM-XRC routes most of the local bus signals to the FPGA and devotes an entire address space to the FPGA.

The signals provided are :-

| Signal   | Active | Direction | Purpose                                |
|----------|--------|-----------|----------------------------------------|
| LA[23:2] | high   | IN        | Address                                |
| LBE[3:0} | low    | IN        | Address/byte enables                   |
| LD[31:0] | high   | BIDIR     | Data Bus                               |
| LWRITE   | high   | IN        | Write cycle when true, read when false |
| LBLASTL  | low    | IN        | End of burst                           |

| LADSL       | low  | IN      | Address / data start                |
|-------------|------|---------|-------------------------------------|
| LBTERML     | low  | OUT/TRI | Burst terminate                     |
| LREADYIL    | low  | OUT/TRI | Accepts/completes data transfer     |
| LDREQL[1:0] | low  | OUT     | Request DMA transfer                |
| LDACKL[1:0] | low  | IN      | DMA transfer acknowledge            |
| LEOTL[1:0]  | low  | OUT     | Terminate current DMA transfer      |
| LINTIL      | low  | OUT     | Interrupt (via CPLD)                |
| FHOLD       | high | OUT     | Reserved for future use             |
| FHOLDA      | high | IN      | Reserved for future use             |
| LRESETOL    | low  | IN      | Reset from PLX and PCI              |
| LCLKA       | high | IN      | Local bus clock (VCLK from ICD2061) |

The local bus provides 4Mbytes of address space for the FPGA to use for whatever purpose is desired by the application. LA[23:21]=000 should be used to determine when the FPGA is being accessed.

Example Verilog code demonstrates how to interface to the local bus and provide access to the SSRAM's for test purposes. User applications can define how the address space allocated to the FPGA is mapped to the local bus and may or may not provide access to the SRAM memory.

## 5.5. Synchronous SRAM

The four banks of synchronous SRAM are identical in device type and FPGA interface. The devices fitted as standard are Micron MT55L256L36FT-10 which are 256Kx36 bits flow through synchronous burst type with 10ns access time.

The pins are allocated to support synchronous burst or ZBT SRAM and each bank provides the following interface

| FPGA Pin    | Active | Туре  | Function                         |
|-------------|--------|-------|----------------------------------|
| Rn_D[35:0]  | high   | Bidir | Data Bus                         |
| Rn_A[16:0]  | high   | OUT   | Address Bus                      |
| Rn_WEL[3:0] | low    | OUT   | Byte enables [35,31:24] [32,7:0] |
| Rn_GWEL     | low    | OUT   | Global write enable              |
| Rn_OEL      | low    | OUT   | Output enable                    |
| Rn_CEL      | low    | OUT   | Chip enable                      |
| Rn_ADVL     | low    | OUT   | SYNC: ADSC function              |
|             |        |       | ZBT: ADV (advance)function       |
| Rn_C2L      | low    | OUT   | SYNC: ADV (advance) function     |
|             |        |       | ZBT: no function                 |
| Rn_CKEL     | low    | OUT   | SYNC: Synchronous write enable   |
|             |        |       | ZBT: Clock enable                |
| R0_R2CLK    | high   | OUT   | Clock to SRAM 0 and SRAM 2       |
| R2_CLK      | HIGH   | IN    | Feedback for CLKDLL              |
| R1_R3CLK    | high   | OUT   | Clock to SRAM 1 and SRAM 3       |
| R3_CLK      | HIGH   | IN    | Feedback for CLKDLL              |

## 5.6. User I/O Front Panel Variant

User I/O is presented on a 68 way miniature D connector (of SCSI-2 style) with interleaved signal and ground pairs as shown below.



| Pin | Pin                                                                                                                                                                                                                   | Signal                                                                                                                      |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 1   | 35                                                                                                                                                                                                                    | USER[0]                                                                                                                     |
| 2   | 36                                                                                                                                                                                                                    | USER[1]                                                                                                                     |
| 3   | 37                                                                                                                                                                                                                    | USER[2]                                                                                                                     |
| 4   | 38                                                                                                                                                                                                                    | USER[3]                                                                                                                     |
| 5   | 39                                                                                                                                                                                                                    | USER[4]                                                                                                                     |
| 6   | 40                                                                                                                                                                                                                    | USER[5]                                                                                                                     |
| 7   | 41                                                                                                                                                                                                                    | USER[6]                                                                                                                     |
| 8   | 42                                                                                                                                                                                                                    | USER[7]                                                                                                                     |
| 9   | 42                                                                                                                                                                                                                    | USER[8]                                                                                                                     |
| 10  | 44                                                                                                                                                                                                                    | USER[9]                                                                                                                     |
| 11  | 45                                                                                                                                                                                                                    | USER[10]                                                                                                                    |
| 12  | 46                                                                                                                                                                                                                    | USER[11]                                                                                                                    |
| 13  | 47                                                                                                                                                                                                                    | USER[12]                                                                                                                    |
| 14  | 48                                                                                                                                                                                                                    | USER[13]                                                                                                                    |
| 15  | 49                                                                                                                                                                                                                    | USER[14]                                                                                                                    |
| 16  | 50                                                                                                                                                                                                                    | USER[15]                                                                                                                    |
| 17  | 51                                                                                                                                                                                                                    | USER[16]                                                                                                                    |
| 18  | 52                                                                                                                                                                                                                    | USER[17]                                                                                                                    |
| 19  | 53                                                                                                                                                                                                                    | USER[18]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[19]                                                                                                                    |
| 21  | -                                                                                                                                                                                                                     | USER[20]                                                                                                                    |
| 22  | 56                                                                                                                                                                                                                    | USER[21]                                                                                                                    |
| 23  | 57                                                                                                                                                                                                                    | USER[22]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[23]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[24]                                                                                                                    |
| -   |                                                                                                                                                                                                                       | USER[25]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[26]                                                                                                                    |
|     | -                                                                                                                                                                                                                     | USER[27]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[28]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[29]                                                                                                                    |
|     | -                                                                                                                                                                                                                     | USER[30]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[31]                                                                                                                    |
| -   |                                                                                                                                                                                                                       | USER[32]                                                                                                                    |
|     |                                                                                                                                                                                                                       | USER[33]                                                                                                                    |
|     | 1         2         3         4         5         6         7         8         9         10         11         12         13         14         15         16         17         18         19         20         21 | 135236337438539640741842942104411451246134714481549165017511852195320542155225623572458255926602761286229633064316532663367 |

## 5.7. User I/O PMC Pn4 Variant

User I/O is presented on the User Connector Pn4 via a standard 64-way PMC connector. This should be routed via a suitable CMC compliant motherboard to an external I/O adapter.



| Signal   | Pn4 Pin | Pn4 Pin | Signal   |
|----------|---------|---------|----------|
| USER[0]  | 1       | 2       | USER[1]  |
| USER[2]  | 3       | 4       | USER[3]  |
| USER[4]  | 5       | 6       | GND      |
| USER[5]  | 7       | 8       | USER[6]  |
| USER[7]  | 9       | 10      | USER[8]  |
| USER[8]  | 11      | 12      | USER[10] |
| USER[11] | 13      | 14      | USER[12] |
| USER[13] | 15      | 16      | USER[14] |
| GND      | 17      | 18      | USER[15] |
| USER[16] | 19      | 20      | USER[17] |
| USER[18] | 21      | 22      | USER[19] |
| USER[20] | 23      | 24      | USER[21] |
| USER[22] | 25      | 26      | USER[23] |
| USER[24] | 27      | 28      | GND      |
| USER[25] | 29      | 30      | USER[26] |
| GND      | 31      | 32      | GND      |
| USER[27] | 33      | 34      | USER[28] |
| USER[29] | 35      | 36      | USER[30] |
| GND      | 37      | 38      | USER[31] |
| USER[32] | 39      | 40      | USER[33] |
| USER[34] | 41      | 42      | USER[35] |
| USER[36] | 43      | 44      | USER[37] |
| USER[38] | 45      | 46      | USER[39] |
| USER[40] | 47      | 48      | USER[41] |
| USER[42] | 49      | 50      | GND      |
| USER[43] | 51      | 52      | USER[44] |
| USER[45] | 53      | 54      | USER[46] |
| USER[47] | 55      | 56      | USER[48] |
| USER[49] | 57      | 58      | USER[50] |
| GND      | 59      | 60      | GND      |
| USER[51] | 61      | 62      | USER[52] |
| GND      | 63      | 64      | GND      |

# 6. Configuring the FPGA

The Virtex FPGA family support a mode of configuration referred to as SelectMAP. The ADM-XRC uses the local bus clock to synchronise byte loading through the SelectMAp interface and is thus limited to a maximum of 40Mbytes/sec.

## 6.1. SelectMAP Operation

Before the FPGA can be configured using SelectMap, the FPGA must be in a state where it is ready to accept data. This can be confirmed by the following process :-

- 1. Assert PROG and INIT, hold for 20 usec.
- 2. Release PROG and INIT, wait for 50usec
- 3. Check that INIT is not set.

If INIT is clear then configuration can proceed.

Configuration is a simple process and requires the entire bitstream to be written to the SelectMap register. At the end of the process, DONE should be high. If DONE is not high and INIT is set then an error has occurred and will probably be due to an invalid bitstream. Note that INIT is not valid when DONE is set as it becomes a user I/O after configuration and is pulled low (active) by default.

#### 6.2. Bitstream Issues

The bitstream produced by the **bitgen** program is stored in a **design.bit** file and is suitable for use with the download cables produced by Xilinx. The driver for the ADM-XRC loads this file and determines the location of the binary bitstream data within it. This data is not suitable for writing directly to the SelectMap registers as it is bit reversed. The driver performs this bit reversal on each byte before download to the FPGA.

Files generated by the **promgen** program and stored in **mcs** format for example are not bit reversed but the resulting file is around three times larger than the binary **design.bit** file.

## 7. Interrupts

The PCI9080 can provide a number of interrupts from internal sources as well as from the local bus. The FPGA can interrupt the host system by asserting the LINTIL (active low) signal and keeping it asserted until the source of the interrupt is cleared. See the ICON registers on how to mask and respond to local bus interrupts.

## 8. Flash Memory

The flash memory is implemented by an Atmel AT49F008A device with 1Mbyte capacity. The device is sectored as shown :-



The flash memory is located is Space 1 (S1) at offset 0x200000-0x2FFFFF. The device can be written or read without restriction and is available at all times. The flash device is connected to the local bus reset signal to allow the device to resume normal operation if the system hangs during a programming sequence.

The Atmel device is easy to program and erase and has practically no timing constraints. Each byte must be written individually but with the advantage of 10usec typical programming time.

The following sequences are required for programming the flash device.

|              | Сус  | le 1 | Сус  | :le 2 | Сус  | :le 3 | Сус    | le 4 | Сус  | le 5 | Сус  | :le 6 |
|--------------|------|------|------|-------|------|-------|--------|------|------|------|------|-------|
| COMMAND      | Addr | Data | Addr | Data  | Addr | Data  | Addr   | Data | Addr | Data | Addr | Data  |
| Chip Erase   | 5555 | AA   | 2AAA | 55    | 5555 | 80    | 5555   | AA   | 2AAA | 55   | 5555 | 10    |
| Sector Erase | 5555 | AA   | 2AAA | 55    | 5555 | 80    | 5555   | AA   | 2AAA | 55   | SA   | 30    |
| Byte Program | 5555 | AA   | 2AAA | 55    | 5555 | A0    | addres | byte |      |      |      |       |
|              |      |      |      |       |      |       | S      | -    |      |      |      |       |
| Boot Lockout | 5555 | AA   | 2AAA | 55    | 5555 | 80    | 5555   | AA   | 2AAA | 55   | 5555 | 40    |
| Product ID   | 5555 | AA   | 2AAA | 55    | 5555 | 90    |        |      |      |      |      |       |
| Leave ID     | 5555 | AA   | 2AAA | 55    | 5555 | F0    |        |      |      |      |      |       |
| Leave ID     | XXXX | F0   |      |       |      |       |        |      |      |      |      |       |

The erased state of the device is that all locations contain 0xFF;

The ADM-XRC is capable of loading the FPGA from flash on power up or reset and will load the bitstream from the main memory section starting at 0x8001. This is to avoid any problem with the boot block which, if locked out, cannot be unlocked without removing the flash device from the PCB. The byte at location 0x8000 should be programmed with bit 0 = 0 (all other bits are ignored) to enable the load sequence otherwise the assumption is the flash is blank and should not be used.

The following fragment of 'C' code demonstrates how to write a byte with value 0x77 to the flash at location 0x1234.

UCHAR \*Flash;

| Flash = S1 + 0x200000; | // | S1 points to the start of space 1 |
|------------------------|----|-----------------------------------|
| Flash[0x5555] = 0xAA;  | // | First cycle                       |
| Flash[0x2AAA] = 0x55;  | // | Second cycle                      |
| Flash[0x5555] = 0xA0;  | // | Enter programming mode            |
| Flash[0x1234] = 0x77;  | // | Write byte                        |
| Wait(50);              | // | Wait for 50 usec worst case       |

Instead of the wait, the device may be polled to check for programming completion. The simplest method is to read the flash device and compare the result with the data just written. Whilst programming is in progress, D7 is the complement of the data written.

## 9. PLX PCI9080 Initialisation

The PCI9080 is configured at power-up and reset by a serial EEPROM attached to it. This device is configured at the factory with settings to suit the standard operation of the ADM-XRC. For the values in the EEPROM, see the following chapter.

After reset, the PCI9080 loads initial settings for PCI and other registers from the EEPROM. The following sections show the PCI9080 registers after booting on a system with a PCI BIOS. The screen shots were produced by PLXMON98 on a WIN95 machine. PLXMON98 for WINNT and WIN95 is available from PLX Technology or its distributors.

## 9.1. PCI Registers

The PCI9080 PCI registers are accessed in PCI configuration space primarily during system boot to configure resources requested by the ADM-XRC.

| PCI Registers       |                |              |                      |             | ×            |
|---------------------|----------------|--------------|----------------------|-------------|--------------|
| Vendor ID           | (00h) 10B5     |              | Device ID            | (02h) 9080  |              |
| Command             | (04h) 0007     |              | Status               | (06h) 0280  |              |
| Revision ID         | (08h) 02       |              | Class Code           | (09h) 06800 | 0            |
| Cache Line Size     | (0Ch) 08       |              | Latency Timer        | (0Dh) 40    |              |
| Header Type         | (0Eh) 00       |              | Build-In Self Test   | (0Fh) 00    | EIST         |
| Base Address 0      | (10h) E9001000 | 🗖 1/0 🛛 🤇    | • 32 O 1 MB - О      | 64 🗖 1      | Prefetchable |
| Base Address 1      | (14h) 0000D001 | ☑ 1/0 (      | • 32 <b>О</b> 1 МВ С | 64 🗖 1      | Prefetchable |
| Base Address 2      | (18h) E8C00000 | E 1/0 🤇      | • 32 <b>О</b> 1 МВ С | 64 🗖 1      | Prefetchable |
| Base Address 3      | (1Ch) E8800000 | 🗖 1/0 – 🤇    | • 32 <b>О</b> 1 МВ С | 64 🗖 I      | Prefetchable |
| Base Address 4      | (20h) 00000000 | □ 1/0      ( | • 32 <b>О</b> 1 МВ С | 64 🗖 1      | Prefetchable |
| Base Address 5      | (24h) 00000000 | 🗖 1/0 – 🤇    | 32 О 1 MB С          | ) 64 🛛 🗖 ।  | Prefetchable |
| CardBus CIS Pointer | (28h) 00000000 |              |                      |             |              |
| Sub Vendor ID       | (2Ch) 4144     |              | SubSystem ID         | (2Eh) 0040  |              |
| Expansion ROM       | (30h) 00000000 | 🗖 Addres     | s Decode Enable      |             |              |
| Interrupt Line      | (3Ch) 0A       |              | Interrupt Pin        | (3Dh) 01    |              |
| Minimum Grant       | (3Eh) 00       |              | Max Latency          | (3Fh) 00    |              |
|                     |                |              |                      | Close       | Refresh      |

The main points to note are that the device and vendor ID's are 9080/10B5 and the command register is set for memory and I/O access.

BAR0(10h) is allocated to 32 bit memory space and is used for access to all of the PCI9080 control registers. BAR1(14h) is allocated to I/O space and is used for the same purpose as BAR1.

BAR2 defines the PCI9080 Local Bus address range Space 0 (S0) and is allocated to 32 bit memory space. BAR3 maps a similar amount to BAR2 and is used for access to Space 1 (S1).

It is important to note that as far as PCI space is concerned, there is no difference between S0 and S1. The Local Bus registers define the operation of these spaces.

## 9.2. Local Configuration Registers

The PCI9080 Local Bus provides two main address spaces through which accesses to local bus resources can be made. As described earlier, S0 is a 4Mbyte space that is 32 bits wide, allocated to the FPGA. S1 is also a 4Mbyte space and is allocated to the flash prom and control registers. The Local Configuration registers are shown below in summary with more detailed descriptions following them.

| Local Configuration |       |          | ×                                                                       |
|---------------------|-------|----------|-------------------------------------------------------------------------|
| Local0 Range        | (00h) | FFC00000 | Map into PCI Memory Space 💌 Encode in 32 bit PCI Space 💌 🗖 Prefetchable |
|                     |       |          | Size in byte: 4,194,304                                                 |
| Local0 Remap        | (04h) | 00000001 | Direct Slave Enabled                                                    |
| Local Arbitration   | (08h) | 03000000 | Mode / Arbitration                                                      |
| Endian Descriptor   | (0Ch) | 00000000 | Endian Descriptor                                                       |
| Exp. ROM Range      | (10h) | 00000000 | Rom Size in byte: 0                                                     |
| Exp. ROM Remap      | (14h) | 00000000 | Delay 0 🗖 BREQ Enable 🗖 BREQ Timer-Resolution                           |
| Region0 Descriptor  | (18h) | 433C00C3 | Space 0 / Exp ROM                                                       |
| Local DM Range      | (1Ch) | 00000000 | Size in byte: 0                                                         |
| Local DM Mem Base   | (20h) | 00000000 |                                                                         |
| Local DM 10 Base    | (24h) | 00000000 |                                                                         |
| DM PCI Remap        | (28h) | 00000000 | Details                                                                 |
| DM Config IO Addr   | (2Ch) | 00000000 | DM Config ID Addr                                                       |
| Local1 Range        | (F0h) | FFC00000 | Map into PCI Memory Space 💌 Encode in 32 bit PCI Space 💌 🗖 Prefetchable |
|                     |       |          | Size in byte: 4,194,304                                                 |
| Local1 Remap        | (F4h) | 00800001 | Direct Slave Enabled                                                    |
| Region1 Descriptor  | (F8h) | 00000240 | Space 1                                                                 |
|                     |       |          | (Close ) Refresh                                                        |

## 9.2.1. Mode/Arbitration Register

The Mode/Arbitration Register is usually set by the EEPROM initialisation and left unaltered after boot.

| Mode / Arbitration Register (08h)                                                                                                                                                                                                                                                                                                                                                                                                                                       | ×                                                                                                                                                                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Local Bus Latency Timer Enable</li> <li>Local Bus Pause Timer Enable</li> <li>Local Bus BREQ Enable</li> <li>Local Bus Direct Slave Give up Bus Mc</li> <li>Direct Slave LLOCKo# Enable</li> <li>PCI Request Mode</li> <li>PCI Rev 2.1 Mode</li> <li>PCI Read No Write Mode</li> <li>PCI Read With Write Flush Mode</li> <li>Gate the Local Bus Latency Timer with BR</li> <li>PCI Read No Flush Mode</li> <li>Subsystem ID and Subsystem Vendor ID</li> </ul> | Local Bus Latency 00<br>Local Bus Pause Timer 00<br>DMA Channel Priority<br>© Rotational priority scheme<br>© Channel 0 has priority<br>© Channel 1 has priority |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | OK Cancel                                                                                                                                                        |

The **PCI Rev 2.1 Mode** pin sets the behaviour of the PCI9080 to conform to PCI revision 2.1 with regard to posted transactions.

The **PCI Read No Write Mode** bit is set to cause PCI writes to the PCI9080 to retry whilst a posted read is pending. This is a known workaround in REV 3 silicon.

## 9.2.2. Big/Little Endian Descriptor Register

This register can be used to force big endian mode for various transfers. The ADM-XRC does not perform any endian conversions by default.



## 9.2.3. Region 0 Descriptor

The Region 0 Descriptor describes the attributes of Local Bus Space 0. It can be seen that 32 bit local bus width is selected and that ready must be generated by the target space. In this case, Space 0 is allocated to the FPGA so all accesses to Space 0 must be acknowledged by the FPGA.

The BTERM bit is set which means that bursts of greater the four LWORD's are permitted. This also means that the FPGA can break a burst transfer into smaller lengths by asserting BTERM. No wait states are generated by the PCI9080 for Space 0 - all wait states are determined by the FPGA.

The Expansion ROM Space is not currently used in the ADM-XRC. The Extra Long Load from Serial EEPROM bit is set to indicate that a long load did occur during the EEPROM read cycle. The length of the EEPROM load is determined by the contents of the EEPROM.

| Region 0 Descriptor (18h)                                                                                                                                        | ×                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| Memory Space 0<br>Bus Width<br>8 bit 16 bit 32 bit<br>Internal Wait State 0<br>Ready Input Enabled<br>BTERM# Input enabled<br>Prefetch Disabled<br>Burst Enabled | Expansion ROM Space<br>Bus Width          |
| <ul> <li>Read Prefetch Count Enabled</li> <li>Extra Long Load from Serial EEPROM</li> <li>Direct Slave Write</li> <li>Target Retry Delay</li> </ul>              | Prefetch Count 0<br>(Status)<br>OK Cancel |

#### Notes.

- 1. The bus width of memory space 0 is set to 32 bits by default. As this region is totally under control of the FPGA, it may be changed. It is the responsibility of the FPGA designer to take this into account.
- 2. The Extra Long Load from Serial EEPROM bit indicates that the extended EEPROM load was performed. This is required to set up Space 1 and some other registers.
- 3. Expansion ROM Space is not implemented in the ADM-XRC and should not be altered.

## 9.2.4. Direct Master PCI Remap Register

This register is for Local Bus initiated PCI Bus transactions (Direct Master) and is not used in the ADM-XRC.

| DM PCI Remap Register (28h)                                                                                                                                                                      | ×                                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| Read Prefetch Size<br>Continous<br>Up to 4 Lwords<br>Up to 8 Lwords<br>Up to 8 Lwords<br>Up tp 16 Lwords                                                                                         | Write Delay<br>No delay<br>Delay 4 PCI clock<br>Delay 8 PCI clock<br>Delay 16 PCI clocl |
| <ul> <li>DM Mem. Access Enable</li> <li>DM IO Access Enabled</li> <li>LLOCK# Input Enabled</li> <li>DM PCI Read Mode</li> <li>Write and Invalidate Mode</li> <li>DM Prefetch Limitted</li> </ul> | Almost Full 0<br>PCI Remap 0000                                                         |
| Select IO Remap                                                                                                                                                                                  | OK Cancel                                                                               |

## 9.2.5. DM Config/IO Register

The DM (Direct Master) Config/IO register is used for controlling configuration cycles on the PCI bus. It is not used in the ADM-XRC.

| DM Config/IO (2Ch)                    | × |
|---------------------------------------|---|
| Configuration Type<br>Type 0 O Type 1 |   |
| Register Number 00                    |   |
| Function Number 00                    |   |
| Device Number 00                      |   |
| Bus Number 00                         |   |
| Configuration Enabled                 |   |
| OK Cancel                             | ] |

## 9.2.6. Region 1 Descriptor

The Region 1 Descriptor describes the attributes of Local Bus Space 1. It can be seen that 8 bit local bus width is selected and that ready must be generated by the target space. Burst transfers are not enabled in this space to avoid any side effects of prefetching from control and /or FPGA configuration registers.

Space 1 maps the flash memory, control registers and FPGA SelectMAP port.



Notes.

- 1. Do not enable burst for this region as it may cause side effects that will stop FPGA loading and readback.
- 2. Internal wait states should always be 0.
- 3. Bus width is always 8 bit.

## 9.3. Runtime Registers

The runtime registers group together mailboxes, control and status registers. The only registers applicable to the ADM-XRC in this group are the INTCSR register at offset 68h and CNTRL at offset 6Ch.

| Runtime Registers                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                     | ×                  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Mailbox Registers<br>Mailbox Register 0 (78h) 00F90000<br>Mailbox Register 1 (7Ch) 00000150<br>Mailbox Register 2 (48h) 00000000<br>Mailbox Register 3 (4Ch) 00000000<br>Mailbox Register 4 (50h) 00000000<br>Mailbox Register 5 (54h) 00000000 | Doorbell and Control RegistersPCI to LOC Doorbell Reg(60h)00000000LOC to PCI Doorbell Reg(64h)00000000Interrupt Ctrl/Status Reg(68h)0F010100EEPROM, PCI, User IO(6Ch)9801767EPCI Permanent Config ID(70h)908010B5PCI Permanent Revision(74h)0000003 | Details<br>Details |
| Mailbox Register 6 (58h) 00000000<br>Mailbox Register 7 (5Ch) 00000000                                                                                                                                                                          | Close                                                                                                                                                                                                                                               | Refresh            |

It should be noted that Mailbox 0 and 1 can be set to initial values using the EEPROM.

## 9.3.1. Interrupt Control/Status Register

In order to for a PCI host processor to receive interrupts from the many sources in the PCI9080, the appropriate enable bits in the INTCSR must be set.

| Control       Status         Enable Local Bus LSERR#       PCI Doorbell Interrupt Active         Generate PCI Bus SERR#       PCI Abort Interrupt Active         Mailbox Interrupt Enabled       DMA CH0 Interrupt Active         PCI Doorbell Interrupt Enabled       DMA CH0 Interrupt Active         PCI Abort Interrupt Enabled       DMA CH0 Interrupt Active         PCI Abort Interrupt Enabled       DMA CH0 Interrupt Active         PCI Local Interrupt Enabled       DMA CH0 During Master/T arget Abort         PCI Local Interrupt Enabled       DMA CH1 During Master/T arget Abort         Maibox CH0 Interrupt Enabled       DMA CH1 During Master/T arget Abort         PCI Wrote Data to Mailbox 0       PCI Wrote Data to Mailbox 1         PCI Wrote Data to Mailbox 3       PCI Wrote data to Mailbox 3 | Interrupt Control/Status Register (68h)                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Control<br>Enable Local Bus LSERR#<br>Enable LESRR# When PCI Parity Error<br>Generate PCI Bus SERR#<br>Mailbox Interrupt Enabled<br>PCI Interrupt Enabled<br>PCI Doorbell Interrupt Enabled<br>PCI Abort Interrupt Enabled<br>PCI Local Interrupt Enabled<br>Retry Abort Enabled<br>Encal Interrupt Output Enabled<br>Local Doorbell Interrupt Enabled | <ul> <li>PCI Doorbell Interrupt Active</li> <li>PCI Abort Interrupt Active</li> <li>Local Interrupt Active</li> <li>Local Doorbell Interrupt Active</li> <li>DMA CH0 Interrupt Active</li> <li>DMA CH1 Interrupt Active</li> <li>BIST Interrupt Active</li> <li>DM During Master/Target Abort</li> <li>DMA CH0 During Master/Target Abort</li> <li>DMA CH1 During Master/Target Abort</li> <li>DMA CH1 During Master/Target Abort</li> <li>DMA CH1 During Master/Target Abort</li> <li>PCI Wrote Data to Mailbox 0</li> <li>PCI Wrote Data to Mailbox 2</li> <li>PCI Wrote data to Mailbox 3</li> </ul> |

Notes.

- 1. Refer to the PLX user manual for the actual register format.
- 2. Clearing a bit in this register does not remove the interrupting source, it simply masks it.

## 9.3.2. EEPROM, PCI, User IO

This register is known as CNTRL and reports information about the state of the EEPROM interface, DMA transfer codes and general purpose input and output bits.

| EEPROM, PCI, User IO (6Ch)                                                                                                       | ×                                                                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCI Read Cmd Code for DMA E<br>PCI Write Cmd Code for DMA 7<br>PCI Mem Read Cmd Code for DM 6<br>PCI Mem Write Cmd Code for DM 7 | <ul> <li>General Purpose Output</li> <li>Serial EEPROM Clock</li> <li>Serial EEPROM Chip Select</li> <li>Write Bit to Serial EEPROM</li> <li>Reload Configuration Registers</li> <li>PCI Adapter Software Reset</li> </ul> |
| <ul> <li>General Purpose Input</li> <li>✓ Read Serial EEPROM Data Bit</li> <li>✓ Serial EEPROM Present</li> </ul>                | Cancel                                                                                                                                                                                                                     |

#### Notes.

- 1. A fault with the EEPROM or if the EEPROM is blank will result in the **Serial EEPROM Present** bit being cleared.
- 2. This register can be used to write and read the EEPROM for initial programming or to perform changes to the initialisation code.

# 10. EEPROM Contents

| Offset | Value | Register | Description                                                          |
|--------|-------|----------|----------------------------------------------------------------------|
| 0      | 10B5  |          | Device ID                                                            |
| 2      | 9080  |          | Vendor ID                                                            |
| 4      | 0680  |          | Class Code                                                           |
| 6      | 0002  |          | Class Code / Revision                                                |
| 8      | 0000  |          | Maximum Latency / Minimum Grant                                      |
| A      | 01FF  |          | Interrupt Pin / Interrupt Line Routing                               |
| С      | 0000  |          | MSW Mailbox 0                                                        |
| E      | 4144  |          | LSW Mailbox 0                                                        |
| 10     | 0000  |          | MSW Mailbox 1                                                        |
| 12     | 0150  |          | LSW Mailbox 1                                                        |
| 14     | FFC0  | LAS0RR   | MSW of Range for PCI to Local Address Space 0                        |
| 16     | 0000  |          | LSW of Range for PCI to Local Address Space 0                        |
| 18     | 0000  | LAS0BA   | MSW of Local Base Address (Remap) for PCI to Local Address Space 0   |
| 1A     | 0001  |          | LSW of Local Base Address (Remap) for PCI to Local Address Space 0   |
| 1C     | 0300  | MARBR    | MSW of Local Arbitration Register                                    |
| 1E     | 0000  |          | LSW of Local Arbitration Register                                    |
| 20     | 0000  | BIGEND   | MSW of Local Bus Big/Little Endian Descriptor Register               |
| 22     | 0000  |          | LSW of Local Bus Big/Little Endian Descriptor Register               |
| 24     | 0000  | EROMRR   | MSW of Range for PCI to Local Expansion ROM                          |
| 26     | 0000  |          | LSW of Range for PCI to Local Expansion ROM                          |
| 28     | 0000  | EROMBA   | MSW of Local Base Address (Remap) for PCI to Local Expansion ROM     |
| 2A     | 0000  |          | LSW of Local Base Address (Remap) for PCI to Local Expansion ROM     |
| 2C     | 433C  | LBRD0    | MSW of Bus Region Descriptors for PCI to Local Accesses              |
| 2E     | 00C3  |          | LSW of Bus Region Descriptors for PCI to Local Accesses              |
| 30     | 0000  | DMRR     | MSW of range for Direct Master to PCI                                |
| 32     | 0000  |          | LSW of range for Direct Master to PCI                                |
| 34     | 0000  | DMLBAM   | MSW of Local Base Address for Direct Master to PCI Memory            |
| 36     | 0000  |          | LSW of Local Base Address for Direct Master to PCI Memory            |
| 38     | 0000  | DMLBAI   | MSW of Local Bus Address for Direct Master to PCI I/O                |
| ЗA     | 0000  |          | LSW of Local Bus Address for Direct Master to PCI I/O                |
| 3C     | 0000  | DMPBAM   | MSW of PCI Base Address (Remap) for Direct Master to PCI             |
| 3E     | 0000  |          | LSW of PCI Base Address (Remap) for Direct Master to PCI             |
| 40     | 0000  | DMCFGA   | MSW of PCI Configuration Address Reg for Direct Master to PCI IO/CFG |
| 42     | 0000  |          | LSW of PCI Configuration Address Reg for Direct Master to PCI IO/CFG |
| 44     | 0040  |          | Subsystem ID                                                         |
| 46     | 4144  |          | Subsystem Vendor ID                                                  |
| 48     | FFC0  | LAS1RR   | MSW of Range for PCI to Local Address Space 1 (1MB)                  |
| 4A     | 0000  |          | LSW of Range for PCI to Local Address Space 1 (1MB)                  |
| 4C     | 0080  | LAS1BA   | MSW of Local Base Address (Remap) for PCI to Local Address Space 1   |
| 4E     | 0001  |          | LSW of Local Base Address (Remap) for PCI to Local Address Space 1   |
| 50     | 0000  | LBRD1    | MSW of Bus Region Descriptors (Space 1) for PCI to local accesses    |
| 52     | 3400  |          | LSW of Bus Region Descriptors (Space 1) for PCI to local accesses    |
| 54     | 0000  | PCIERBAR | MSW of PCI Base Address for local expansion ROM                      |
| 56     | 0000  |          | LSW of PCI Base Address for local expansion ROM                      |

# 11. FPGA Pins

## 11.1. Clocks

#Local bus clock NET "LCLKA" LOC = "A17";

#SRAM 0 and 2 Clock NET "R0R2CLK" LOC = "C18";

#SRAM 0 and 2 Feedback NET "R2\_CLK" LOC = "D17";

#SRAM 1 and 3 Clock NET "R1R3CLK" LOC = "AN17";

#SRAM 1 and 3 Feedback NET "R3\_CLK" LOC = "AL17";

## 11.2. Local Bus

```
NET "LD<31>" LOC = "H31";
NET "LD<30>" LOC = "K29";
NET "LD<29>" LOC = "H32";
NET "LD<28>" LOC = "J31":
NET "LD<27>" LOC = "K30";
NET "LD<26>" LOC = "H33";
NET "LD<25>" LOC = "L29";
NET "LD<24>" LOC = "K31":
NET "LD<23>" LOC = "L30";
NET "LD<22>" LOC = "J33";
NET "LD<21>" LOC = "M29";
NET "LD<20>" LOC = "L31":
NET "LD<19>" LOC = "M30";
NET "LD<18>" LOC = "L32";
NET "LD<17>" LOC = "M31";
NET "LD<16>" LOC = "L33";
NET "LD<15>" LOC = "N30";
NET "LD<14>" LOC = "N31";
NET "LD<13>" LOC = "M32";
NET "LD<12>" LOC = "P29";
NET "LD<11>" LOC = "P30";
NET "LD<10>" LOC = "P31";
NET "LD<9>" LOC = "P32";
NET "LD<8>" LOC = "R29":
NET "LD<7>" LOC = "R30";
NET "LD<6>" LOC = "R31";
```

```
NET "LD<5>" LOC = "R33";
NET "LD<4>" LOC = "T31";
NET "LD<3>" LOC = "T29";
NET "LD<2>" LOC = "T30":
NET "LD<1>" LOC = "T32";
NET "LD<0>" LOC = "U31";
NET "LA<23>" LOC = "D28";
NET "LA<22>" LOC = "C30";
NET "LA<21>" LOC = "D29":
NET "LA<20>" LOC = "E28":
NET "LA<19>" LOC = "D30"
NET "LA<18>" LOC = "F29";
NET "LA<17>" LOC = "D31":
NET "LA<16>" LOC = "F30":
NET "LA<15>" LOC = "C33":
NET "LA<14>" LOC = "G29";
NET "LA<13>" LOC = "E31":
NET "LA<12>" LOC = "D32"
NET "LA<11>" LOC = "G30";
NET "LA<10>" LOC = "F31"
NET "LA<9>" LOC = "H29";
NET "LA<8>" LOC = "E32";
NET "LA<7>" LOC = "E33":
NET "LA<6>" LOC = "G31";
NET "LA<5>" LOC = "J29":
NET "LA<4>" LOC = "F33";
NET "LA<3>" LOC = "G32":
NET "LA<2>" LOC = "J30";
NET "LBE<3>" LOC = "D27";
NET "LBE<2>" LOC = "B30";
NET "LBE<1>" LOC = "C29":
NET "LBE<0>" LOC = "AL18";
NET "LADSL" LOC = "C28":
NET "LWRITE" LOC = "E26";
NET "LDACKL<1>" LOC = "D26":
NET "LDACKL<0>" LOC = "B29":
NET "LBLASTL" LOC = "C27":
NET "LBTERML" LOC = "E25";
NET "LREADYIL" LOC = "A28":
NET "FHOLDA" LOC = "A27";
NET "LINTIL" LOC = "D25";
NET "LDREQL<1>" LOC = "E24";
NET "LDREQL<0>" LOC = "C26";
NET "FHOLD" LOC = "B26":
NET "LRESETOL" LOC = "AM18";
```

#### 11.3. SSRAM Bank 0

| 11.3. | 55          | RAM       | Ba           | NK U |       |              |
|-------|-------------|-----------|--------------|------|-------|--------------|
| NET   | "R0         | A<16      | 5>"          | LOC  | = "D  | 3":          |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   | רט_<br>ייםח | _A< 1<br> | ו <ו         |      | = L   | י∠ ,<br>`⊿"· |
|       |             |           |              |      |       |              |
| NET   |             | _         |              |      |       | •            |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   | "R0_        | _A<1>     | >" L(        | OC = | = "J4 | ".           |
| NET   | "R0_        | _A<0>     | >" L(        | OC = | = "H3 | 8";          |
| NET   | "R0_        | _D<35     | 5>"          | LOC  | = "K  | (5";         |
| NET   | "R0_        | D<34      | 4>"          | LOC  | = "⊢  | l2";         |
| NET   | "R0         | D<33      | 3>"          | LOC  | = "J  | 3";          |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             | -         |              |      |       |              |
| NET   | "R0         | D<29      | 9>"          | LOC  | = "K  | 2":          |
| NET   |             |           |              | LOC  |       |              |
| NET   |             | -         |              | LOC  |       |              |
| NET   |             |           | 3>"          |      | = "I  | .⊖ ,<br>1"·  |
| NET   | "R0         | D<2       | 5>"          |      | = "N  | ,<br>∕\⊿"·   |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   | "R0_        | D-2       | )~  <br>)~"  |      | _ "N  | י∠ ,<br>ו∧"י |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
|       |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   | "R0_        | _D<14     | 4>"          |      | = "F  | (3";         |
| NET   | "KU_        | _D<10     | <b>ວ</b> >″∣ |      | = "H  | (1";         |
| NET   |             |           |              |      |       |              |
| NET   | _           | -         |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   |             |           |              |      |       |              |
| NET   | "R0_        | _D<6>     | >" L         | OC = | = "V2 | )".<br>- ,   |
|       |             |           |              |      |       |              |

NET "R0\_D<5>" LOC = "V4"; NET "R0\_D<4>" LOC = "V5"; NET "R0\_D<3>" LOC = "V3"; NET "R0\_D<2>" LOC = "W1"; NET "R0\_D<1>" LOC = "W3"; NET "R0\_D<0>" LOC = "W5"; NET "R0\_WEL<3>" LOC = "D7"; NET "R0\_WEL<2>" LOC = "C5"; NET "R0\_WEL<1>" LOC = "E7"; NET "R0\_WEL<0>" LOC = "A3"; NET "R0\_GWEL" LOC = "D8"; NET "R0\_OEL" LOC = "B4"; NET "R0\_CEL" LOC = "A5"; NET "R0\_ADVL" LOC = "B5"; NET "R0\_C2L" LOC = "E8"; NET "R0\_CKEL" LOC = "C6";

### 11.4. SSRAM Bank 1

| 11.4. | 22   |                                              |
|-------|------|----------------------------------------------|
| NET   | "R1_ | _A<16>" LOC = "AK9";                         |
| NET   | "R1_ | A<15>" LOC = "AL8";                          |
|       | _    |                                              |
|       |      | A<13>" LOC = "AJ9";                          |
|       |      | _A<12>" LOC = "AL7";                         |
|       |      | _/(<12> LOO = //L/ ;<br>A<11>" LOC = "AN6";  |
|       | _    | _A<10>" LOC = "AM6";<br>_A<10>" LOC = "AM6"; |
|       |      |                                              |
|       |      | _A<9>" LOC = "AJ8";                          |
|       |      | _A<8>" LOC = "AL6";                          |
|       |      | _A<7>" LOC = "AK7";                          |
|       |      | _A<6>" LOC = "AM5";                          |
|       | _    | _A<5>" LOC = "AM4";                          |
|       |      | _A<4>" LOC = "AJ7";                          |
|       |      | _A<3>" LOC = "AL5";                          |
| NET   | "R1_ | _A<2>" LOC = "AK6";                          |
|       |      | _A<1>" LOC = "AN3";                          |
| NET   | "R1_ | _A<0>" LOC = "AL4";                          |
| NET   | "R1_ | _D<35>" LOC = "Y3";                          |
|       |      | D<34>" LOC = "Y4";                           |
| NET   | "R1  |                                              |
|       |      | _D<32>" LOC = "Y5";                          |
|       |      | _D<31>" LOC = "AA3";                         |
|       |      | _D<30>" LOC = "AA4";                         |
|       |      | _D<29>" LOC = "AB3";                         |
|       |      | D<28>" LOC = "AA5";                          |
|       |      | D<27>" LOC = "AC1";                          |
|       |      | _D<26>" LOC = "AB4";                         |
|       |      | _D<25>" LOC = "AC3";                         |
|       |      | D<24>" LOC = "AD3";                          |
|       | _    | D<23>" LOC = "AE1";                          |
|       |      | _D<22>" LOC = "AC5";                         |
|       |      | D<21>" LOC = "AE3";                          |
|       | -    | _D<20>" LOC = "AD4";                         |
|       |      | _D<19>" LOC = "AF1";                         |
|       |      | _D<18>" LOC = "AF2";                         |
|       | _    | _D<17>" LOC = "AD5";                         |
|       |      | _D<16>" LOC = "AG2";                         |
|       |      | _D<15>" LOC = "AE4";                         |
|       |      | _D<14>" LOC = "AF3";                         |
|       | _    | _D<13>" LOC = "AH1";                         |
|       |      | _D<12>" LOC = "AE5";                         |
|       |      | _D<12> LOC = 'AE3',<br>_D<11>" LOC = "AF4";  |
|       |      | _D<10>" LOC = "AJ1";                         |
|       |      | _D<10> LOC = 'AJ1',<br>_D<9>" LOC = "AJ2";   |
|       |      |                                              |
|       |      | _D<8>" LOC = "AF5";                          |
|       | _    | _D<7>" LOC = "AH3";<br>D<6>" LOC = "AG4";    |
|       | КÌ_  | $_{\rm D<0>}$ LUC = 'AG4';                   |
|       |      |                                              |

NET "R1\_D<5>" LOC = "AK2"; NET "R1\_D<4>" LOC = "AJ3"; NET "R1\_D<3>" LOC = "AG5"; NET "R1\_D<2>" LOC = "AL1"; NET "R1\_D<1>" LOC = "AH4"; NET "R1 D<0>" LOC = "AK3"; NET "R1\_WEL<3>" LOC = "AK10"; NET "R1\_WEL<2>" LOC = "AM9"; NET "R1\_WEL<1>" LOC = "AL9"; NET "R1\_WEL<0>" LOC = "AJ10"; NET "R1\_GWEL" LOC = "AK12"; NET "R1\_OEL" LOC = "AM10"; NET "R1\_CEL" LOC = "AJ12"; NET "R1\_ADVL" LOC = "AL11"; NET "R1\_C2L" LOC = "AL10"; NET "R1\_CKEL" LOC = "AJ11";

### 11.5. SSRAM Bank 2

| 11.5. | SSR  | am B | ank 2  |                   |
|-------|------|------|--------|-------------------|
| NET " | R2 A | <16> | " LOC  | = "B11";          |
|       | _    |      |        | ;= "C11";         |
|       | _    |      |        | = "B10";          |
|       |      |      |        | ; = "D10";        |
|       |      |      |        |                   |
|       |      |      |        | ;= "C10";         |
|       |      |      |        | ; = "A9";         |
| NET " | R2_A | <10> | " LOC  | = "E11";          |
| NET " | R2_A | <9>" | LOC :  | = "C9";           |
| NET " | R2 A | <8>" | LOC :  | = "D10";          |
|       |      |      |        | = "A8";           |
|       |      |      |        | = "B8";           |
|       |      |      |        | = "E10";          |
|       |      |      |        |                   |
|       |      |      |        | = "C8";           |
|       |      |      |        | = "D9";           |
|       |      |      |        | = "B7";           |
| NET " | R2_A | <1>" | LOC :  | = "A6";           |
| NET " | R2_A | <0>" | LOC :  | = "C7";           |
|       |      |      |        | = "C25";          |
|       | _    |      |        | ; = "D24";        |
|       |      |      |        | ; = "B25";        |
|       |      |      |        | ; = "E23";        |
|       | _    |      |        | ,                 |
|       |      |      |        | ; = "A25";        |
|       |      |      |        | ; = "D23";        |
|       |      |      |        | ; = "B24";        |
| NET " | R2_D | <28> | " LOC  | ; = "E22";        |
|       |      |      |        | ; = "C23";        |
| NET " | R2_D | <26> | " LOC  | ; = "A23";        |
|       |      |      |        | ; = "D22";        |
| NET " | R2 D | <24> | " LOC  | ; = "E21";        |
| NFT " |      | <23> | " I OC | ; = "B22";        |
| NFT " | R2 D | <22> |        | ; = "D21";        |
|       |      |      |        | ; = "C21";        |
|       |      |      |        | ; = "B21";        |
|       |      |      |        | ; = "E20";        |
|       |      |      |        | ; = "D20";        |
|       | _    |      |        |                   |
|       |      |      |        | ; = "C20";        |
|       |      |      |        | ; = "B20";        |
|       |      |      |        | ; = "E19";        |
|       |      |      |        | ; = "D19";        |
| NET " | R2_D | <13> | " LOC  | ; = "C19";        |
|       |      |      |        | ; = "A19";        |
|       |      |      |        | ; = "D18";        |
|       |      |      |        | ; = "E18";        |
|       |      |      |        | = "E17";          |
|       |      |      |        | = "B17";          |
|       | _    |      |        | = "B16";          |
|       |      |      |        | = ыю,<br>= "D16"; |
|       | אב_ט | <0>  | LOU    | - טוט,            |
|       |      |      |        |                   |

NET "R2\_D<5>" LOC = "E16"; NET "R2\_D<4>" LOC = "C16"; NET "R2\_D<3>" LOC = "A15"; NET "R2\_D<2>" LOC = "C15"; NET "R2\_D<1>" LOC = "D15"; NET "R2 D<0>" LOC = "E15"; NET "R2 WEL<3>" LOC = "D13"; NET "R2\_WEL<2>" LOC = "C12"; NET "R2\_WEL<1>" LOC = "E13"; NET "R2\_WEL<0>" LOC = "A11"; NET "R2\_GWEL" LOC = "C14"; NET "R2\_OEL" LOC = "D12"; NET "R2\_CEL" LOC = "D14"; NET "R2\_ADVL" LOC = "A13"; NET "R2\_C2L" LOC = "E14"; NET "R2\_CKEL" LOC = "C13";

#### 11.6. SSRAM Bank 3

| 11.6. | SSRAW Bank 3                                       |
|-------|----------------------------------------------------|
| NET ' | 'R3_A<16>" LOC = "AK16";                           |
|       | 'R3_A<15>" LOC = "AJ16";                           |
|       | 'R3 A<14>" LOC = "AL16";                           |
|       | 'R3_A<13>" LOC = "AM16";                           |
|       |                                                    |
|       | 'R3_A<12>" LOC = "AL15";                           |
|       | 'R3_A<11>" LOC = "AK15";                           |
|       | 'R3_A<10>" LOC = "AJ15";                           |
|       | 'R3_A<9>" LOC = "AN15";                            |
| NET ' | 'R3_A<8>" LOC = "AM14";                            |
| NET ' | 'R3 A<7>" LOC = "AK14";                            |
| NET ' | 'R3_A<6>" LOC = "AJ14";                            |
|       | 'R3 A<5>" LOC = "AN13";                            |
|       | 'R3 A<4>" LOC = "AM13";                            |
|       | 'R3_A<3>" LOC = "AL13";                            |
|       | 'R3_A<2>" LOC = "AK13";                            |
|       | 'R3_A<1>" LOC = "AM12";                            |
|       | $R_3_A < I > LOC = AIVI12$ ,                       |
|       | 'R3_A<0>" LOC = "AL12";                            |
|       | 'R3_D<35>" LOC = "AL30";                           |
|       | 'R3_D<34>" LOC = "AK28";                           |
|       | 'R3_D<33>" LOC = "AM31";                           |
|       | "R3_D<32>" LOC = "AJ27";                           |
| NET ' | 'R3_D<31>" LOC = "AN31";                           |
| NET ' | 'R3_D<30>" LOC = "AL29";                           |
| NET ' | 'R3_D<29>" LOC = "AK27";                           |
|       | 'R3_D<28>" LOC = "AL28";                           |
|       | 'R3 D<27>" LOC = "AJ26";                           |
|       | 'R3_D<26>" LOC = "AM30";                           |
|       | 'R3_D<25>" LOC = "AM29";                           |
|       | 'R3_D<24>" LOC = "AK26";                           |
|       | 'R3 D<23>" LOC = "AJ25":                           |
|       | 'R3_D<22>" LOC = "AN29";                           |
| NET ' |                                                    |
|       |                                                    |
|       | 'R3_D<20>" LOC = "AK25";                           |
|       | 'R3_D<19>" LOC = "AL26";                           |
|       | 'R3_D<18>" LOC = "AJ24";                           |
|       | 'R3_D<17>" LOC = "AM27";                           |
| NET ' | 'R3_D<16>" LOC = "AM26";                           |
| NET ' | 'R3_D<15>" LOC = "AK24";                           |
| NET ' | 'R3_D<14>" LOC = "AL25";                           |
| NET ' | 'R3_D<13>" LOC = "AJ23";                           |
|       | 'R3_D<12>" LOC = "AN26";                           |
|       | 'R3_D<11>" LOC = "AL24";                           |
|       | 'R3 D<10>" LOC = "AK23";                           |
|       | 'R3_D<9>" LOC = "AJ22";                            |
|       | 'R3_D<8>" LOC = "AL23";                            |
|       | 'R3 D<7>" LOC = "AL23 ;<br>'R3 D<7>" LOC = "AM24"; |
|       | R3_D<7> LOC = AM24 ;<br>'R3 D<6>" LOC = "AK22":    |
|       | $K_{0} = AK_{2};$                                  |
|       |                                                    |

NET "R3\_D<5>" LOC = "AM23"; NET "R3\_D<4>" LOC = "AJ21"; NET "R3\_D<3>" LOC = "AN23"; NET "R3\_D<2>" LOC = "AK21"; NET "R3\_D<1>" LOC = "AM22"; NET "R3 D<0>" LOC = "AJ20"; NET "R3\_WEL<3>" LOC = "AL19"; NET "R3\_WEL<2>" LOC = "AN19"; NET "R3\_WEL<1>" LOC = "AJ18"; NET "R3\_WEL<0>" LOC = "AK18"; NET "R3\_GWEL" LOC = "AN21"; NET "R3\_OEL" LOC = "AL21"; NET "R3\_CEL" LOC = "AL20"; NET "R3\_ADVL" LOC = "AJ19"; NET "R3\_C2L" LOC = "AM20"; NET "R3\_CKEL" LOC = "AK19";

# **Revision History**

| Date         | Revision | Nature of Change              |  |
|--------------|----------|-------------------------------|--|
| July-1999    | 1.0      | Initial release               |  |
| January-2000 | 1.1      | Improved section on clocks.   |  |
|              |          | UCF Naming revised.           |  |
|              |          | PCI Configuration guidelines. |  |
|              |          | Added references.             |  |
| January-2000 | 1.2      | Added I/O Pinout              |  |
| January-2001 | 1.3      | Added Pn4 Pinout              |  |