FOXI PCI Host Adapter

**Instruction Manual** 

February, 2007

(C) 1999, 2002, 2007 Copyright by KineticSystems Company, LLC Lockport, Illinois All rights reserved

# Contents

| Data | Sheet |
|------|-------|
|      |       |

| INTRODUCTION                                    | 1     |
|-------------------------------------------------|-------|
| INSTALLATION                                    | 1     |
| HIGHWAY TIMEOUT SELECTION                       | 2     |
| PCI CONFIGURATION SPACE                         | 2     |
| VENDOR IDENTIFICATION Field                     | 3     |
| DEVICE IDENTIFICATION Field                     |       |
| PCI COMMAND Register                            |       |
| PCI STATUS Register                             | 4     |
| REVISION Field                                  | 5     |
| CLASS CODE Field                                |       |
| CACHE LINE SIZE Field                           |       |
| LATENCY TIMER REGISTER                          | 5     |
| HEADER Field                                    | 6     |
| BUILD IN SELF TEST Field                        | 6     |
| BASE ADDRESS REGISTERS                          | 6     |
| EXPANSION ROM BASE ADDRESS Register             | 6     |
| INTERRUPT LINE Field                            | 7     |
| INTERRUPT PIN Field                             | 7     |
| MINIMUM GRANT Register                          | 7     |
| V124 Operational Registers                      | 7     |
| PCI Interface Operational Registers             |       |
| Outgoing/Incoming Mailboxes                     | <br>8 |
| Data FIFO Register                              | 8     |
| Master Write Address Register                   | 9     |
| Master Write Transfer Count Register            | 9     |
| Master Read Address Register                    | 9     |
| Master Read Transfer Count Register             | 10    |
| Mailbox Empty/Full Status Register              | 10    |
| PCI Interface Interrupt Control/Status Register | 11    |
| Bus Master Control/Status Register              | 13    |
| HIGHWAY OPERATIONAL REGISTERS                   | 14    |
| Control/Status Register                         |       |
| Interrupt Control/Status Register               | 19    |
| Timer Control Register                          | 21    |
| Command Memory Address Register                 | 23    |
|                                                 | 24    |

| List Transfer Count Register                | . 24 |
|---------------------------------------------|------|
| Total Transfer Count Register               |      |
| Memory Address Register                     |      |
| Demand FIFO Register                        |      |
| Reset Interface                             |      |
| Reset Demand FIFO Register                  | . 27 |
| PROGRAMMED TRANSFERS                        | . 27 |
| DMA TRANSFERS                               | 20   |
| COMMAND MEMORY INSTRUCTIONS FORMATS         | 29   |
| VXI/VME Instructions                        | 31   |
| VXI/VME Address                             |      |
| VXI/VME Single Transfer Instructions        | 35   |
| VXI/VME Block Transfer Instructions         | 35   |
| VXI/VME Single Inline Write Instruction     |      |
| Special Instructions                        | 38   |
| Halt Instruction                            |      |
| Addressed Slave Trigger Instruction         |      |
| Broadcast Trigger Instruction               | 39   |
| Generate Host Interrupt Instruction         | 40   |
| Write Reply FIFO Short Instruction          | 41   |
| Write Reply FIFO Long Instruction           | 41   |
| VXI LIST PROCESSING EXAMPLE                 | 42   |
| NTERRUPTS                                   | 43   |
| DEMANDS                                     | 44   |
| APPEND STATUS                               | 44   |
| EXTERNAL CLOCK INPUT                        | 45   |
| EDs.                                        | 45   |
| APPENDIX A - V124 Composite Register Layout |      |
|                                             |      |

WARRANTY

#### INTRODUCTION

The V124 PCI FOXI Highway Driver (IHD) is a half size PCI card, which interfaces the PCI bus to the Interconnect Highway. The Interconnect Highway is a fiber-optic highway, which allows serial access to up to 126 slave nodes. These slave nodes may be any combination of CAMAC Crate Controllers, VXI Chassis Controllers and VME Chassis Controllers. The maximum signaling distance between fiber-optic nodes is 2 kilometers. The highway runs at 125 Megabits-per-second using 12-bits per word, 8 of which are information bits and 4 of control. Therefore, the maximum bandwith of data transfers on the highway is 10 Megabytes-per-second.

The V124 executes highway operations provided by a list of instructions preloaded into a 32K x 32-list memory. This memory is loaded prior to initiating operations by programmed I/O transfers. Once list processing is initiated, data transfers to/from the V124 may occur using either DMA or programmed transfers. DMA operations to/from the V124 are executed using a 32-bit word format.

The list may contain such instructions as Single Operations, Block Transfer Operations, Single Inline Write Operations, Generate Host Interrupts, Load Loop Counter, and Conditional/Unconditional Branches. These instructions allow for a very versatile list. The format of the instruction varies depending on the type of slave node being accessed.

A Demand FIFO is provided to retain up to 2048 demand messages. These messages are generated by VXI/VME slaves. VXI/VME slaves generate these messages in response to interrupt requests in the chassis. When these messages are received by the V124, the chassis address and a demand identification byte are stored in the FIFO. Optionally, the receipt of a demand message may assert an interrupt request to the PCI bus.

#### INSTALLATION

The Model V124 is designed to fit into any half size PCI expansion slot. After selecting the desired Highway Timeout value, the V124 is ready to be installed in the computer.

Before the installation is initiated, turn off the power to the computer and remove the power cord. Remove the cover to the computer and locate an empty expansion slot. Remove the blank plate from the mounting rail of the selected slot. Insert the V124 into the slot and secure the mounting plate with the screw that was removed from the blank plate. Replace the cover on the computer and then plug the power cord back into the unit.

After the card is installed in the computer, connect the fiber optic cables to the V124. The top fiber optic connector on the V124 is the highway output connector. The bottom fiber optic connector is the highway input connector. One fiber optic cable should run from the V124 highway output connector (top) to the first chassis V160 Slot0 input connector (for VXI). A second fiber optic cable should run from the bottom highway input fiber optic connector on the V124 to the highway output connector on the V160.

#### HIGHWAY TIMEOUT SELECTION

The V124 contains a strap selectable timer to control the timeout value for the highway. If the V124 transmits a message on the highway and does not receive a reply message within the selected timeout period, an error is generated and the highway is reset. This timeout value ranges from 3 seconds to 10 seconds. The timeout may also be disabled to allow for an infinite timeout value. Please refer to Appendix B of this manual for the location and settings of the Highway Timeout.

#### PCI CONFIGURATION SPACE

The PCI Specification mandates a 64-byte Configuration Header that describes the requirements of add-in cards. The data contained in this region uniquely identifies the device and allows for generic control of the device. The configuration data indicates the memory requirements of the device along with other device specific information.

This section describes the 64 bytes of configuration space implemented by the V124. The following diagram is a composite chart showing the configuration header.

| ć  | 31                       | 16              | 15                | 00             |  |  |  |  |  |  |  |  |
|----|--------------------------|-----------------|-------------------|----------------|--|--|--|--|--|--|--|--|
| 00 | Device Ide               | entification    | Vendor            | Identification |  |  |  |  |  |  |  |  |
| 04 | Sta                      | atus            | Co                | ommand         |  |  |  |  |  |  |  |  |
| 08 |                          | Class Code      |                   | Revision       |  |  |  |  |  |  |  |  |
| 0C | BIST                     | Header Type     | Latency           | Cache Size     |  |  |  |  |  |  |  |  |
| 10 | Base Address Register #1 |                 |                   |                |  |  |  |  |  |  |  |  |
| 14 | Base Address Register #2 |                 |                   |                |  |  |  |  |  |  |  |  |
| 18 | Base Address Register #3 |                 |                   |                |  |  |  |  |  |  |  |  |
| 1C | Base Address Register #4 |                 |                   |                |  |  |  |  |  |  |  |  |
| 20 |                          | Base Add        | lress Register #5 |                |  |  |  |  |  |  |  |  |
| 24 |                          | Base Add        | lress Register#6  |                |  |  |  |  |  |  |  |  |
| 28 |                          | F               | Reserved          |                |  |  |  |  |  |  |  |  |
| 2C |                          | F               | Reserved          |                |  |  |  |  |  |  |  |  |
| 30 |                          | Expansion l     | ROM Base Address  |                |  |  |  |  |  |  |  |  |
| 34 |                          | F               | Reserved          |                |  |  |  |  |  |  |  |  |
| 38 |                          | F               | Reserved          |                |  |  |  |  |  |  |  |  |
| 3C | Maximum Latency          | Minimum Latency | Interrupt Pin     | Interrupt Line |  |  |  |  |  |  |  |  |

#### **VENDOR IDENTIFICATION Field**

The VENDOR IDENTIFICATION field contains read-only bits that identify the manufacturer of the device. The ID assigned to KineticSystems is 11F4 Hex.

## **DEVICE IDENTIFICATION Field**

The DEVICE IDENTIFICATION field contains read-only bits, which identify a particular device. The DEVICE ID field for this unit is 0112 Hex.

## PCI COMMAND Register

The COMMAND field contains write/read bits used to configure basic PCI functions. The following diagram shows the COMMAND field as implemented by the V124.

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 09         | 80         | 07 | 06         | 05 | 04 | 03 | 02         | 01         | 00         |  |
|---|----|----|----|----|----|----|------------|------------|----|------------|----|----|----|------------|------------|------------|--|
|   | 0  | 0  | 0  | 0  | 0  | 0  | FST<br>BTB | SER<br>ENA | 0  | PER<br>ENA | 0  | 0  | 0  | MAS<br>ENA | MEM<br>ENA | I/O<br>ENA |  |

- <15:10> Not Used. These bits are not used and read as zeros.
- FAST BACK-TO-BACK is a write/read bit used to enable or disable the V124 from executing "fast" back-to-back bus master cycles after completing a write cycle. Setting this bit to a one enables fast transfers and a zero disables the mode.
- SYSTEM ERROR ENABLE is a write/read bit used to enable and disable the V124 from driving the PCI SYSTEM ERROR (SERR) signal. This signal is used by the V124 to inform the host CPU of a parity error during an address or control portion of a bus operation. Setting this bit to a one enables the V124 to assert SERR and disabled with a zero.
- <7> Not Used. These bits are not used and read as zeros.
- PARITY ERROR ENABLE is a write/read bit used to enable and disable the V124 from driving the PCI PARITY ERROR (PERR) signal. This signal is asserted by the V124 when a parity error is detected during a data transfer to/from the V124. The PERR function is enabled by setting this bit to a one and disabled with a zero.
- <5:3> Not Used. These bits are not used and read as zeros.

- SUS MASTER ENABLE is a write/read bit which enables and disables the V124 from executing bus master operations. Setting this bit to a one enables the V124 to function as a bus master and a zero disables the master operation. Since the V124 interface hardware actually controls bus master operations, this bit is not used.
- <1> MEMORY SPACE ENABLE is a write/read bit that allows the V124 to function in memory regions that may be defined in one of the base address registers. Since the V124 is initially configured as an I/O device, this bit should be set to zero.
- <0> I/O SPACE ENABLE is a write/read bit that allows the V124 to function in I/O regions as defined in one of the base address registers. This bit is set to a one that allows the V124 to function in I/O regions.

## PCI STATUS Register

The PCI STATUS Register is used to record status information regarding PCI bus transfers. This register contains read-only bits and write/read bits. The following diagram shows the Status Register bits implemented by the V124.

| 15         | 14         | 13         | 12         | 11         | 10         | 09         | 08        | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |
|------------|------------|------------|------------|------------|------------|------------|-----------|----|----|----|----|----|----|----|----|
| PAR<br>DET | SIG<br>SER | RCV<br>MAB | RCV<br>TAB | SIG<br>TAB | DEV<br>TM1 | DEV<br>TMO | DP<br>RPT | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

- <15> DETECTED PARITY ERROR is a write/read bit that is set whenever the V124 detects a PCI parity error. This bit does not depend on the state of the PAR ENA bit in the PCI COMMAND Register. Once an error has been detected, this may be cleared by writing a one to bit position 15.
- <14> SIGNALED SYSTEM ERROR is a write/read bit which is set whenever the V124 asserts the PCI SYSTEM ERROR (SERR) signal. Once this bit is set, it may be cleared by writing a one to bit position 14.
- <13> RECEIVED MASTER ABORT is a write/read bit that is set when the V124 is accessed as a target and the master aborts the transaction. This bit can be reset by writing a one to this bit position.
- <12> RECEIVED TARGET ABORT is a write/read bit that is set when the V124, acting as a bus master, has initiated a transfer and the addressed target aborts the transfer. This bit can be reset by writing a one to this bit position.

- <11> SIGNALED TARGET ABORT is a write/read bit that is set when a bus master accesses the V124 as a target and the V124 aborts the cycle. This bit is reset when a one is written to this bit location.
- <10:9> DEVICE SELECT TIMING 1 and 0 encode the timing of the PCI DEVSEL (Device Select) signal. This time reflects the slowest time that a device asserts DEVSEL for any bus command except Configuration Read and Configuration Write. Since the V124 may be accesses in the fast mode, these bits are set to zero.
- OATA PARITY REPORTED is a write/read bit that is set when the V124 detects a parity error when the V124 is a bus master. This bit can be reset by writing a one to this bit position.

#### **REVISION Field**

The REVISION field contains read-only bits that reflect the current revision level of the V124. The V124 starts at revision one and subsequent revisions increment the number.

#### **CLASS CODE Field**

The CLASS CODE field actually contains three subfields that represent device characteristics. These three subfields are the BASE CLASS, the SUB-CLASS and the PROG I/F fields. These subfields define such parameters as network controllers, display controllers, video device, etc. The V124 does not fit into any of the defined class codes. Therefore, the class code that the V124 uses is FF0000 Hex that indicates that the V124 class code is undefined by the PCI specification.

#### **CACHE LINE SIZE Field**

The CACHE LINE SIZE field is used by the system to define the cache line size. The V124 does not use Memory Write and Invalidate PCI bus cycles when operating as a bus master and therefore sets this field to zero.

#### LATENCY TIMER REGISTER

The LATENCY TIMER REGISTER is only used when the V124 is operating as a bus master. The values loaded in this register are the minimum number of PCI bus clocks that the V124 can be guaranteed as a master. After the V124 becomes bus master and asserts the PCI FRAME signal, the Latency Timer is decremented for each PCI bus clock. Subsequent to the timer decrementing to zero, the V124 ignores the PCI bus grant signal and continues to transfer data until the timer expires. The value loaded into this register is in multiples of eight clock cycles since the low 3 bits of this field are hardwired to zero.

#### **HEADER Field**

The HEADER field establishes whether a PCI device contains a single function or multifunction PCI bus agent. Since the V124 contains only a single function, this field is set to zero.

#### BUILD IN SELF TEST Field

This field is used to present Built In Self-Test diagnostic results to a bus master. The V124 does not implement BIST and returns a zero for this field.

#### BASE ADDRESS REGISTERS

The BASE ADDRESS REGISTERS are used to specify the memory or I/O requirements of addin devices and also to configure the base addresses of these devices.

After power-up, system software can determine how much address space a particular device requires by writing all ones to a base address register and then reading that value back. The device returns zeros in all address bit locations that do not define the base address.

The least significant bit in each of the base address registers is used for specifying the region of address space for which the device is to reside. A value of zero specifies a memory region and a value of one specifies an I/O region. The V124 is configured to operate in the I/O region.

The V124 implements two of the Base Address registers. The first Base Address register is used to communicate with the PCI Interface Operational Registers (IOR) and the second is used to communicate with the Highway Operational Registers (HOR). The Interface Operational Registers require 16 longwords (64 bytes) of address space. A read of the first base address register, after a write of all ones, returns the value FFFFFC1 Hex, indicating a request for 16 longwords of I/O space.

The Highway Operational Registers require 16 longwords (64 bytes) of address space. A read of the second base address register, after a write of all ones, returns the value FFFFFC1 Hex, indicating a request for 16 longwords in I/O space.

After the system software has determined the total address space requirements of the system, it assigns the base addresses to memory and I/O devices by writing their Base Address Registers.

## **EXPANSION ROM BASE ADDRESS Register**

This field is used to assign a physical memory address to expansion ROM in a system. The V124 does not contain an expansion ROM and therefore does not require use of this field.

## INTERRUPT LINE Field

This write/read field is used for communicating interrupt routing information and is configured by the PCI BIOS after power-up. The value in this field informs the system interrupt controller which pin of the controller the interrupt is connected to.

#### INTERRUPT PIN Field

The INTERRUPT PIN field is read-only and specifies which PCI interrupt pin that the V124 is connected to. The V124 returns a value of one in this field indicating that it uses the INTA interrupt.

## MINIMUM GRANT Register

This write/read register is used by bus masters to specify the minimum amount of time the device needs for a period of burst transfers. Since the V124 does not have this requirement, a value of zero must be used.

# V124 Operational Registers

The V124 PCI FOXI Highway Driver uses several I/O addressable registers to control and monitor operations. All data transfers to/from the V124 must be executed using 32-bit data transfers. The V124 does not accommodate byte or shortword accesses.

The V124 incorporates a PCI Interface Controller manufactured by Applied Micro Circuits Corporation, the S5933. This device contains several PCI configuration registers and also some of the V124 operational registers. The primary register that the V124 uses is the bi-directional FIFO register. This FIFO is used in transferring data to/from slave nodes on the interconnect highway. A Control/Status register provides access to FIFO flags.

# **PCI Interface Operational Registers**

The PCI Interface Operational Registers are contained in the PCI interface chip used on the V124. This chip is the S5933 and is manufactured by Applied Micro Circuits Corporation. The base address of these registers is loaded by power-on BIOS routines and is contained in the Base Address Register #1 location of the PCI Configuration Registers.

Note: All references to Incoming and Outgoing are referred to the host. An Outgoing operation is a write operation from the host and an Incoming operation is a read operation from the V124.

The following chart shows the various PCI Interface Registers along with their offsets from the base address.

| $\underline{\text{Offset}}$ | Register                    | Access   |
|-----------------------------|-----------------------------|----------|
| 0                           | Outgoing Mailbox #1         | W/R      |
| 4                           | Outgoing Mailbox #2         | W/R      |
| 8                           | Outgoing Mailbox #3         | W/R      |
| $\mathbf{C}$                | Outgoing Mailbox #4         | W/R      |
| 10                          | Incoming Mailbox #1         | ${ m R}$ |
| 14                          | Incoming Mailbox #2         | ${ m R}$ |
| 18                          | Incoming Mailbox #3         | ${ m R}$ |
| 1C                          | Incoming Mailbox #4         | ${ m R}$ |
| 20                          | Data FIFO                   | W/R      |
| 24                          | Master Write Address        | ${f R}$  |
| 28                          | Master Write Transfer Count | ${f R}$  |
| 2C                          | Master Read Address         | ${ m R}$ |
| 30                          | Master Read Transfer Count  | ${f R}$  |
| 34                          | Mailbox Empty/Full Status   | W/R      |
| 38                          | Interrupt Control/Status    | W/R      |
| 3C                          | Bus Master Control/Status   | W/R      |

# Outgoing/Incoming Mailboxes

The Incoming and Outgoing Mailboxes are used by the KineticSystems software drivers to provide a communication mechanism between the list processor and the host CPU. The details of this communication scheme is beyond the scope of this manual.

#### Data FIFO Register

The Data FIFO Register is composed of two 8 x 32-bit FIFOs located in the PCI interface chip. When executing Interconnect Highway operations, all write and read data passes through these FIFOs. Data transfers to or from these FIFOs can be done by either programmed transfers executed by the host or by allowing the V124 to become a bus master and transfer the data.

When executing write operations to the highway, the write data is first written to the Data FIFO Register. The data is then moved from the PCI interface chip to a 2K X 16-bit FIFO external to the chip in preparation for transmission onto the highway. When read operations from the highway are executed, the read data is initially stored in a 2K X 16 FIFO before transfer to the PCI interface chips' 8 X 32 FIFO.

Several status indicators are provided which indicate the amount of data contained in the PCI interface chip FIFOs and the external 2K X 32 FIFOs. The Bus Master Control/Status register contains 6 status bits that correspond to the PCI Interface chip internal FIFOs. Two status bits are provided in the Control/Status register of the Highway Operational registers for the two external 2K X 32 FIFOs. Both sets of status flags must be used in determining the amount of data contained in the write FIFO data path or the read FIFO data path.

# Master Write Address Register

The Master Write Address Register is a read-only register that contains the last address that was accessed during a bus master write operation executed by the V124. This address is actually pointing to one longword beyond the last address accessed since the memory address is incremented after each execution of a data transfer.

The Master Write Address Register can be written to by either the DSP or by programmed I/O through the Highway Operational Registers. When the Memory Address Register (MAR) of the Highway Operational Registers is written by programmed I/O or by the DSP, a hardware mechanism loads both the Master Write Address Register and the Master Read Address Register.

After a bus master operation completes, the current memory address minus 4 may be read from the Master Write Address Register. The initial memory address used for the bus master operation can be read through the Memory Address Register of the Highway Operational Registers.

# Master Write Transfer Count Register

This register is not used by the V124. When executing bus master operations, the V124 uses the Total Transfer Count Register of the Highway Operational Registers to determine the number of bus operations to perform.

## Master Read Address Register

The Master Read Address Register is a read-only register that contains the last address that was accessed during a bus master read operation executed by the V124. This address is actually pointing to one longword beyond the last address accessed since the memory address is incremented after each execution of a data transfer.

The Master Read Address Register can be written to by either the DSP or by programmed I/O through the Highway Operational Registers. When the Memory Address Register (MAR) of the Highway Operational Registers is written by programmed I/O or by the DSP, a hardware mechanism loads both the Master Write Address Register and the Master Read Address Register.

After a bus master operation completes, the current memory address minus 4 may be read from the Master Read Address Register. The initial memory address used for the bus master operation can be read through the Memory Address Register of the Highway Operational Registers.

## Master Read Transfer Count Register

This register is not used by the V124. When executing bus master operations, the V124 uses the Total Transfer Count Register of the Highway Operational Registers to determine the number of bus operations to perform.

# Mailbox Empty/Full Status Register

The Empty/Full Status Register is used by the KineticSystems software driver to implement "special" functions. The communication scheme for the mailbox register used in the software driver is beyond the scope of this manual. The following shows the bit pattern for the Mailbox Empty/Full Status Register. The register is shown here for completeness only.

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21   | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|-----|-----|-----|
| IMB | I MB | IMB | IMB | IMB | IMB | IMB |
| 4D  | 4C  | 4B  | 4A  | 3D  | 3C  | 3B  | 3A  | 2D  | 2C  | 2B   | 2A  | 1D  | 1C  | 1B  | 1A  |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 08  | 07  | 06  | 05   | 04  | 03  | 02  | 01  | 00  |
| OMB  | OMB | OMB | ОМВ | ОМВ | OMB |
| 4D  | 4C  | 4B  | 4A  | 3D  | 3C  | 3B  | 3A  | 2D  | 2C  | 2B   | 2A  | 1D  | 1C  | 1В  | 1A  |

The IMB bits refer to the incoming mailbox registers. The OMB bits refer to the outgoing mailbox registers. The numbers 1 through 4 refer to the mailbox number and the letters D through A refer to the byte within the longword. Since the mailbox may only be written as longwords from either side, all byte indicators within a word will be either set or cleared.

# PCI Interface Interrupt Control/Status Register

The PCI Interface Interrupt Control/Status Register of the PCI Interface Operational Registers is used to monitor and control interrupts generated by the PCI interface chip. Before an interrupt is sourced from the interface chip to the PCI bus, it must be enabled with the PCI INTERRUPT ENABLE bit in the Interrupt Control/Status Register of the Highway Operational Registers.

The following shows the bit pattern for the Interrupt Control/Status Register of the PCI Interface Operational Registers.

| 31        | 30        | 29 | 28        | 27         | 26         | 25         | 24         | 23         | 22 | 21         | 20         | 19         | 18         | 17         | 16         |
|-----------|-----------|----|-----------|------------|------------|------------|------------|------------|----|------------|------------|------------|------------|------------|------------|
| 0         | 0         | 0  | 0         | 0          | 0          | 0          | 0          | INT<br>REQ | 0  | TAR<br>ABT | MAS<br>ABT | RTC        | WTC        | IMB<br>SRC | OMB<br>SRC |
| 15        | 14        | 13 | 12        | 11         | 10         | 09         | 08         | 07         | 06 | 05         | 04         | 03         | 02         | 01         | 00         |
| RTC<br>IE | WTC<br>IE | 0  | IMB<br>IE | IMB<br>EMB | IMB<br>EMA | IMB<br>EBB | IMB<br>EBA | 0          | 0  | 0          | OMB<br>IE  | OMB<br>EMB | OMB<br>EMA | OMB<br>EBB | OMB<br>EBA |

- <31:24> These 8 bits control endian conversion and must be set to zero for the V124 to operate properly.
- <23> INTERRUPT REQUEST is a read-only bit that is set when the PCI interface chip is requesting service. This bit reflects the interrupt output of the PCI chip and does not indicate that the PCI bus interrupt is asserted. If the PCI Interrupt Enable bit of the Interrupt Control/Status Register of the Highway Operational Registers is set to a one, this bit indicates that a PCI bus interrupt is requested.
- <22> This bit is not used and is read as a zero.

- <21> TARGET ABORT is a read/write-to-clear bit that indicates when the V124 executes a bus master transfer and the addressed target aborts the transfer. An interrupt source is generated when this bit is set. This bit is cleared by writing a one to this bit position.
- <20> MASTER ABORT is a read/write-to-clear bit that indicates when the V124 executes a bus master operation and the addressed target does not respond. An interrupt source is generated when this bit is set. A write operation to this register with this bit set to a one clears the bit.
- <19> READ TRANSFER COMPLETE is a read/write-to-clear bit that is set when the Master Read Transfer Count Register is decremented to zero. Since the V124 does not use this register, the bit should never be set.
- <18> WRITE TRANSFER COMPLETE is a read/write-to-clear bit that is set when the Master Write Transfer Count Register is decremented to zero. Since the V124 does not use this register, the bit should never be set.
- <17> INCOMING MAILBOX INTERRUPT SOURCE is a read/write-to-clear bit that is set to a one when the mailbox selected by bits 12 through 8 of this register are written by the DSP. An interrupt source is generated when this bit is a one. A write operation with this bit set to a one clears the bit.
- OUTGOING MAILBOX INTERRUPT SOURCE is a read/write-to-clear bit that is set to a one when the mailbox selected by bits 4 through 0 of this register is read by the DSP. An interrupt source is generated if this bit is set to a one. A write operation with this bit set to a one causes the bit to be cleared.
- <15> READ TRANSFER COMPLETE INTERRUPT ENABLE is a write/read bit used to enable and disable the generation of an interrupt when the read transfer count is exhausted. Since the V124 does not used the Master Read Transfer Count, this bit should always be set to the disable state.
- <14> WRITE TRANSFER COMPLETE INTERRUPT ENABLE is a write/read bit used to enable and disable the generation of an interrupt when the write transfer count is exhausted. Since the V124 does not use the Master Write Transfer Count, this bit should always be set to the disable state.
- <13> This bit is not used and is read as a zero.
- <12> INCOMING MAILBOX INTERRUPT ENABLE is a write/read bit that is used to enable/disable the generation of an interrupt source when a preselected incoming mailbox register is written. Bits 11 through 8 of this register select which mailbox register write operation will generate the interrupt source.

- <11:10> INCOMING INTERRUPT SELECT bits are used to select which incoming mailbox write operations are to generate an interrupt source. The binary combinations of these bits determine which mailbox to enable. Data 0 is mailbox #1, data 1 is mailbox #2, data 2 is mailbox #3 and data 3 is mailbox #4.
- <9:8> INCOMING MAILBOX BYTE INTERRUPT SELECT bits are used to select which byte of the mailbox, selected by bits 11 and 10 of this register, are actually causing the interrupt source.
- <7:5> These bits are not used and are read as zeros.
- OUTGOING MAILBOX INTERRUPT ENABLE is a write/read bit that is used to enable/disable the generation of an interrupt when a preselected outgoing mailbox register is written. Bits 3 through 0 of this register select which mailbox write operation will generate the interrupt source.
- <3:2> OUTGOING INTERRUPT SELECT bits are used to select which outgoing mailbox write operations are to generate an interrupt source. The binary combinations of these bits determine which mailbox to enable. Data 0 is mailbox #1, data 1 is mailbox #2, data 2 is mailbox #3 and data 3 is mailbox #4.
- <1:0> OUTGOING MAILBOX BYTE INTERRUPT SELECT bits are used to select which byte of the mailbox, selected by bits 3 and 2 of this register, are actually causing the interrupt source.

## Bus Master Control/Status Register

The Bus Master Control/Status Register is used to monitor/control bus master operations and to check status of the two PCI interface chip FIFOs. The following diagram shows the bit pattern for the Bus Master Control/Status Register.

| 31 | 30 | 29 | 28 | 27         | 26         | 25         | 24         | 23 | 22 | 21         | 20        | 19         | 18        | 17         | 16          |
|----|----|----|----|------------|------------|------------|------------|----|----|------------|-----------|------------|-----------|------------|-------------|
| 0  | 0  | 0  | 0  | MBX<br>RST | INF<br>RST | OTF<br>RST | AON<br>RST | 0  | 0  | 0          | 0         | 0          | 0         | 0          | 0           |
| 15 | 14 | 13 | 12 | 11         | 10         | 09         | 08         | 07 | 06 | 05         | 04        | 03         | 02        | 01         | 00          |
| 0  | 0  | 0  | 0  | 0          | 0          | 0          | 0          | 0  | 0  | I FE<br>MT | IFI<br>4+ | IFI<br>FUL | OTF<br>MT | OT F<br>4+ | OT F<br>FUL |

The bits shown as zeros in the proceeding bit layout must be set to zeros when writing to the Bus Master Control/Status Register. The bits that have non-zero indications are the only useful bits in this register. The remaining bits are reserved for diagnostic purposes. Even though some of these bits are shown as zeros, they may eventually be read as ones. Note that the Inbound FIFO refers to the internal PCI controller interface chips' FIFO for executing highway read operations and the Outbound FIFO refers to highway write operations.

These bits are not used but must be written to zero. <31:28> <27> MAILBOX FLAG RESET is a write-only bit that resets all of the mailbox status flags. INBOUND FIFO RESET is a write-only bit which clears the inbound FIFO, <26> Inbound FIFO +4 bit, Inbound FIFO Full and sets the Inbound FIFO Empty flag. OUTBOUND FIFO RESET is a write-only bit which clears the outbound FIFO, <25> Outbound FIFO +4 bit, Outbound FIFO Full and sets the Outbound FIFO Empty bit. <24> ADD-ON RESET is a write-only bit which, when set to a one, resets all of the Highway Operational Registers. <23:6> These bits are not used but must be written to zero. INBOUND FIFO EMPTY is a read-only bit that is set when the inbound FIFO <5> contains no data. INBOUND FIFO +4 is a read-only bit and is set to a one as long as there are at < 4 >least 4 longwords of data in the inbound FIFO. INBOUND FIFO FULL is a read-only bit that is set when the incoming FIFO is <3> full. OUTBOUND FIFO EMPTY is a read-only bit that is set when the outbound <2> FIFO contains no data. OUTBOUND FIFO +4 is a read-only bit and is set to a one as long as there are at <1> least 4 longwords of data in the outbound FIFO. <0> OUTBOUND FIFO FULL is a read-only bit that is set when the outbound FIFO is full.

#### HIGHWAY OPERATIONAL REGISTERS

The following section describes the registers used to control operations directed toward the Interconnect Highway. The base address of these registers is set dynamically when the computer is powered-up and the PCI BIOS is executed. The PCI BIOS determines the resources required by each add-in card and allocates memory and I/O addresses accordingly. After the setup has been completed, the Base Address Register #2 from the PCI Interface Registers may be read to determine the address allocated to the V124 by the PCI BIOS.

| Address                           | Register Description              | Mnemonic |
|-----------------------------------|-----------------------------------|----------|
| Base + 00                         | Control/Status Register           | CSR      |
| Base + 04                         | Interrupt Control/Status Register | ICSR     |
| Base + 08                         | Timer Control Register            | I CR     |
| Base + OC                         | Command Memory Address Register   | CMA      |
| Base + 10                         | Command Memory Data Register      | CMD      |
| Base + 14                         | List Transfer Count Register      | LTCR     |
| Base + 18                         | Total Transfer Count Register     | TTCR     |
| Base + 1C                         | Memory Address Register           | MAR      |
| Base + 20                         | Reserved                          | RSVD     |
| Base + 24                         | Reserved                          | RSVD     |
| Base + 28                         | Demand FIFO Register              | DFR      |
| Base + 2C                         | Reset Interface                   | RSTIFC   |
| Base + 30                         | Reset Demand FIFO                 | RSTDFR   |
| Base + 34<br>through<br>Base + 3F | Reserved                          |          |

Appendix A contains a composite register layout chart for the V124.

## Control/Status Register

The Control/Status Register (CSR) is a write/read register located at an offset of 0 from the selected base address. This register is used to control and monitor various operations occurring within the V124 and on the Interconnect Highway. Since this register contains read-only, write-only, and write/read bits, two bit patterns are shown. Those bits that are shown as zero for the write layout must be set to zero when writing to this register.

## Control/Status Register(CSR)

## Write Operations:

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21              | 20         | 19         | 18         | 17       | 16 |
|----|----|----|----|----|----|----|----|----|----|-----------------|------------|------------|------------|----------|----|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0          | 0          | 0          | 0        | 0  |
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05              | 04         | 03         | 02         | 01       | 00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | APN<br>D<br>STA | RLD<br>ENA | DMA<br>DIR | DMA<br>ENA | SUS<br>P | GO |

## Read Operations:

| 31         | 30         | 29              | 28              | 27         | 26       | 25              | 24         | 23       | 22             | 21                   | 20         | 19         | 18         | 17       | 16       |
|------------|------------|-----------------|-----------------|------------|----------|-----------------|------------|----------|----------------|----------------------|------------|------------|------------|----------|----------|
| ERR<br>CD3 | ERR<br>CD2 | ERR<br>CD1      | ERR<br>CD0      | VXI<br>TMO | RSV<br>D | RSV<br>D        | RSV<br>D   | RSV<br>D | NO<br>SYN<br>C | 0                    | PAR<br>ERR | RSV<br>D   | RSV<br>D   | RSV<br>D | RSV<br>D |
| 15         | 14         | 13              | 12              | 11         | 10       | 09              | 08         | 07       | 06             | 05                   | 04         | 03         | 02         | 01       | 00       |
| 0          | 0          | LIS<br>T<br>INT | DMD<br>OFL<br>O | DMD<br>PND | 0        | XMT<br>FUL<br>L | RCV<br>DAV | DON<br>E | 0              | APN<br>D<br>STA<br>T | RLD<br>ENA | DMA<br>DIR | DMA<br>ENA | SUS<br>P | 0        |

<31:28> ERROR CODE3 through 0 are read-only bits that encode the source of a V124 error. The following chart shows the error code hex pattern along with the source of the error. The error sources are encoded by a priority encoder resulting in the highest priority error being displayed in the case where multiple errors are encountered. Individual bits in the CSR may be read to determine other error sources that may have occurred along with the highest priority error encoded.

| Error Code | Error Source                                                                                                                                                                                               |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F          | Reserved.                                                                                                                                                                                                  |
| ${f E}$    | Reserved.                                                                                                                                                                                                  |
| D          | PARITY ERROR. The V124 highway receiver detected a parity error on the incoming message.                                                                                                                   |
| С          | ADDRESS_NOT_RECOGNIZED. An addressed highway command message was transmitted by the V124 and then received by the V124                                                                                     |
| В          | indicating that the addressed slave did not accept the message. TIMEOUT. A highway command message was transmitted by the V124 and a reply message was not received within the preselected timeout period. |
| A          | VXI TIMEOUT. A VXI bus timeout occurred in the VXI chassis addressed during the last highway operation.                                                                                                    |
| 9          | Reserved.                                                                                                                                                                                                  |
| 8          | Reserved                                                                                                                                                                                                   |
| 7          | Reserved                                                                                                                                                                                                   |
| 6          | Reserved                                                                                                                                                                                                   |
| 5          | Reserved                                                                                                                                                                                                   |
| 4          | ILLEGAL COMMAND. This error code is generated when an attempt is made at accessing a non-existent location within a VXI controller.                                                                        |

REMOTE PARITY ERROR. This code is generated when an addressed slave receives a parity error.

## Error Code Error Source

- 2 Reserved.
- 1 Reserved.
- 0 NO ERROR. There are no errors to report from the V124.
- < 27> VXI/VME TIMEOUT is a read-only bit that is set when an operation in an addressed VXI/VME chassis resulted in a bus timeout.
- < 26> Reserved
- < 25> Reserved
- < 24> ILLEGAL COMMAND is a read-only bit that is set when an attempt is made to access a non-existent address location within a CAMAC or VXI controller.
- < 23> REMOTE PARITY ERROR is a read-only bit that is set when an addressed slave receives a parity error.
- < 22> NO SYNC is a read-only bit that is set when the V124 highway driver is not receiving a synchronization message from the highway. When no list processing operations are occurring, the V124 sends a synchronization message around the highway, expecting to see it returned. The SYNC LED may not be lit during large block transfer operations since the sync message is not inserted during large data transfers. A loss of the SYNC signal during large data transfers does not set any NO SYNC error conditions.
- < 21> This bit is not used and is read as a zero.
- < 20> PARITY ERROR is a read-only bit that is set when the V124 receives a message that contains a parity error.
- <19> TIMEOUT is a read-only bit that is set when the V124 transmits a command message to a slave and the slave does not respond within the selectable timeout period. This period can range from 3 to 10 seconds.
- < 18> ADDRESS\_NOT\_RECOGNIZED is a read-only bit that is set when the V124 transmits a command message to a slave and receives the message back indicating that the addressed slave did not respond.
- < 17> Reserved

- < 16> Reserved
- <15:14> These bits are not used and are read as zeros.
- <13 > LIST INTERRUPT is a read-only bit that is set when the list processing DSP asserts an interrupt to the host computer. This bit also appears in the Interrupt Control/Status Register.
- < 12> DEMAND OVERFLOW is a read-only bit that is set when the V124 has 2048 demands pending in the Demand FIFO Register and a subsequent demand message is received. This bit may be cleared by a write operation to the Clear Demand FIFO Register address.
- < 11> DEMAND PENDING is a read-only bit that is set when at least one demand message is contained in the Demand FIFO Register.
- < 10> This bit is not used and is read as a zero.
- < 9> TRANSMIT FULL is a read-only bit that reflects the status of the highway transmitter write data FIFO. The full flag is used to determine if the FIFO may accept additional write data words when executing programmed I/O highway operations. As long as this bit is zero, the FIFO may be written.
- < 8> RECEIVE DATA AVAILABLE is a read-only bit that is set to a one as long as highway read data is contained in the read data FIFO. This bit is used for programmed I/O read operations for determining data availability.
- < 7> DONE is a read-only bit that indicates when the V124 is not executing any list operations. Once a list operation is initiated, the DONE bit is set to a zero until the operation is completed.
- <6> This bit is not used and is read as a zero.
- APPEND STATUS is a write/read bit that enables and disables the appending of a status word after a list execution terminates. Setting this bit to a one enables the status append and a zero disables the function. Refer to the Append Status section of this manual for additional information.
- <4> Reserved
- OMA DIRECTION is a write/read bit that specifies the direction of DMA transfers. A direction of zero specifies DMA transfers from host memory to the V124 (write operations). A one specifies DMA transfers from the V124 to host memory (read operations).

- DMA ENABLE is a write/read bit that is used to enable/disable DMA activity. Setting this bit to a one enables DMA operations to occur when the list processor requests data transfers. A zero allows for programmed I/O transfers and disables DMA operations.
- < 1> SUSPEND is a write/read bit used to suspend list processing operations in the V124. After SUSPEND is set to a one, the host must wait for the DONE bit to be set before using the V124 for other operations. After the DONE bit has been set, the SUSPEND bit may then be written back to a zero.
- < 0> GO is a write-only bit that is used to initiate list-processing operations at the address specified in the List Memory Address Register.

# Interrupt Control/Status Register

The Interrupt Configuration Register (ICSR) is a write/read register located at an offset of 4 from the selected base address. This register is used to enable/disable the various sources of interrupts on the V124. Status bits are also in this register reflecting the state of the interrupt sources. Once enabled and sourced, the V124 asserts the PCI INTA signal to the host.

The V124 has five sources of interrupts as follows:

- 1.) List Processing Done
- 2.) List Interrupt
- 3.) Demand
- 4.) A PCI Interface Controller Interrupt.

The ICSR contains individual enables and status bits for each of the five sources. To allow an interrupt status bit to be enabled in the ICSR, the corresponding enable bit must be set to a one. Interrupt sources are disabled by setting the bit to a zero. In the case where polling is used instead of interrupt generation, the interrupt source bits may be cleared by writing to the ICSR with the data set equal to the source bit to be cleared.

The following diagram shows the bit layout of the Interrupt Control/Status Register.

Interrupt Control/Status Register (ICSR)

| 31 | 30 | 29 | 28 | 27 | 26 | 25         | 24       | 23         | 22              | 21              | 20        | 19       | 18         | 17             | 16             |
|----|----|----|----|----|----|------------|----------|------------|-----------------|-----------------|-----------|----------|------------|----------------|----------------|
| 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0        | 0          | 0               | 0               | 0         | 0        | 0          | 0              | 0              |
| 15 | 14 | 13 | 12 | 11 | 10 | 09         | 08       | 07         | 06              | 05              | 04        | 03       | 02         | 01             | 00             |
| 0  | 0  | 0  | 0  | 0  | 0  | PCI<br>INT | RSV<br>D | DMD<br>INT | LIS<br>T<br>INT | DON<br>E<br>INT | PCI<br>IE | RSV<br>D | DMD<br>I E | LIS<br>T<br>IE | DON<br>E<br>IE |

<31:10> These bits are not used and read as zero.

- < 9> PCI INTERFACE INTERRUPT SOURCE is a read only bit that reflects the status of the PCI interface chips' interrupt source. The actual source of these interrupts may be found in the PCI Interrupt Control/Status Register.
- < 8> Reserved
- < 7> DEMAND INTERRUPT SOURCE is a read/write-to-clear bit that is set whenever a demand message is received by the V124 and this interrupt source is enabled. A write of this bit with data set to one clears the source. The DMD IE bit in this register must be set to a one to enable this interrupt source.
- < 6> LIST INTERRUPT SOURCE is a read/write-to-clear bit that is set when the list processor executes a Generate Host Interrupt instruction. A write of this bit with data set to one clears the source. The LIST IE bit in this register must be set to a one to enable this interrupt source.
- < 5> DONE INTERRUPT SOURCE is a write/read bit that is set when the V124 completes execution of a list and this interrupt source is enabled. A write of this bit with data set to a one clears the source. The DONE IE bit in this register must be set to a one to enable this source.
- < 4> PCI INTERFACE INTERRUPT ENABLE is a write/read bit that is used to enable/disable the generation of a PCI interrupt request when the PCI Interface chip requires service. Setting this bit to a one enables the interrupt source and a zero disables the source.
- < 3> Reserved
- DEMAND INTERRUPT SOURCE ENABLE is a write/read bit that enables/disables the generation of an interrupt source when the V124 receives a demand message from the highway. Setting this bit to a one enables the interrupt source and a zero disables the source.
- <1 > LIST INTERRUPT SOURCE ENABLE is a write/read bit used to enable/disable the assertion of an interrupt source when the list processor executes a Generate Host Interrupt instruction. Setting this bit to a one enables the interrupt source and a zero disables the source.
- <0> DONE INTERRUPT SOURCE ENABLE is a write/read bit used to enable/disable the generation of an interrupt source when a list processing operation completes. Setting this bit to a one enables the interrupt source and a zero disables the source.

## Timer Control Register

The Timer Control Register (TCR) is a write/read register located at an offset of 08 hex from the selected base address. This register is used to specify the frequency at which list execution is initiated during timer initiated list processing operations.

The timer frequency can range from 250 Kilohertz to .059 hertz. This range yields 'tic' rates (periods) from 40 microseconds to 16.777 seconds in 1 microsecond increments. This timer rate specification does not refer to the interval at which each element in the list is executed but the rate at which the entire list is initiated. This automatic mode is enabled with bit 24 in this register.

The V124 provides for an external clock input that controls the rate at which the list is started. This input is routed through the external clock LEMO connector mounted on the front panel of the V124. The clock period may range from 250 kHz to DC. The input signal is low true and must have a minimum pulse width of 200 nanoseconds and a maximum of 1 microsecond.

If the timer rate selected for list execution is faster than the time it takes to execute the entire list, the clock transitions that occur while the list is executing are ignored.

The data for this register is calculated as follows:

((1/Desired Frequency)/1 X 10-6) -1

The following diagram shows the bit layout of the Timer Control Register.

Timer Control Register (TCR)

| 31        | 30        | 29        | 28        | 27        | 26        | 25         | 24         | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|-----------|-----------|-----------|-----------|-----------|-----------|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| 0         | 0         | 0         | 0         | 0         | 0         | CLK<br>SRC | TMR<br>ENA | TCR<br>23 | TCR<br>22 | TCR<br>21 | TCR<br>20 | TCR<br>19 | TCR<br>18 | TCR<br>17 | TCR<br>16 |
| 15        | 14        | 13        | 12        | 11        | 10        | 09         | 80         | 07        | 06        | 05        | 04        | 03        | 02        | 01        | 00        |
| TCR<br>15 | TCR<br>14 | TCR<br>13 | TCR<br>12 | TCR<br>11 | TCR<br>10 | TCR<br>9   | TCR<br>8   | TCR<br>7  | TCR<br>6  | TCR<br>5  | TCR<br>4  | TCR<br>3  | TCR<br>2  | TCR<br>1  | TCR<br>0  |

<31:26> These bits are not used and are read as zeros.

<25> CLOCK SOURCE is a write/read bit that selects the source of the timing signal that initiates list execution when the TMR ENA bit is set to a one. Setting the CLK SRC bit to a one selects the external clock input and a zero selects the internal timer.

- <24>
- TIMER ENABLE is a write/read bit that is used to enable/disable timer initiated list-processing operations. Setting this bit to a one enables timer initiated operations and a zero disables timer operations.
- <23:0>

TIMER CONTROL RATE23 through 0 are write/read bits that are used to select the rate at which list processing operations are initiated when the timer operations are enabled. The least significant bit of this field corresponds to a 1-microsecond interval. The data loaded in this register is actually one less than the desired interval. For example, to select a 250-microsecond interval, load the value 249 into this register.

# Command Memory Address Register

The Command Memory Address Register (CMA) is a write/read register located at an offset of OC Hex from the selected base address. This register is used for several purposes. The CMA is used to specify the start address for list processing, specify the memory address at which subsequent write/read operations to the Command Memory Data Register occur, and to read the last address that the list processor accessed during a list processing operation.

The Command Memory Data Register (CMD) is a 32K X 32 memory that is used to hold the list processing instructions to be executed. The CMD is loaded by executing programmed I/O write operations to offset 10 Hex. Prior to executing the initial write to the memory, the CMA must first be loaded with the first address location to access. The valid address range is 0 to 7FFF Hex. After the CMA is loaded, the first CMD data word may then be written. After a write operation to the CMD, the CMA is automatically incremented to the next address location. This allows the CMD to be loaded without having to write the CMA for every CMD write operation.

If it is necessary to read the CMD, the CMA must first be loaded with the initial address to be accessed. After a word of data is read from the CMD, the CMA is automatically incremented to the next address location.

A bit in this register is also provided which initiates a single list processing operation. Setting this bit causes the same operation as setting the GO bit in the Control/Status Register. The format of the Command Memory Address Register is shown in the following diagram.

| 31             | 30        | 29        | 28        | 27        | 26        | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
|----------------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 0              | 0         | 0         | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 15             | 14        | 13        | 12        | 11        | 10        | 09       | 08       | 07       | 06       | 05       | 04       | 03       | 02       | 01       | 00       |
| LIS<br>T<br>GO | CMA<br>14 | CMA<br>13 | CMA<br>12 | CMA<br>11 | CMA<br>10 | CMA<br>9 | CMA<br>8 | CMA<br>7 | CMA<br>6 | CMA<br>5 | CMA<br>4 | CMA<br>3 | CMA<br>2 | CMA<br>1 | CMA<br>O |

<31:16> These bits are not used and are read as zeros.

<15> LIST GO is a write-only bit that is set to a one to initiate a list processing operation. Setting this bit has the same effect as setting the GO bit in the CSR. This bit is not latched.

<14:0> COMMAND MEMORY ADDRESS14 through 0 are used for specifying the initial address for CMD write/read operations, the initial address for list execution, and for determining where the list processor halted after list processing.

## Command Memory Data Register

The Command Memory Data Register (CMD) is a write/read register located at an offset of 10 Hex from the selected base address. This register is used to load the instructions for the list processor. The format of these instructions/commands may be found in the Command Memory Instructions section of this manual.

The Command Memory is a 32K X 32 memory that is accessed by programmed I/O. Before initial words may be written to the CMD, the Command Memory Address Register (CMA) must be loaded. After the CMA is loaded with the first address of the CMD to access, the CMD may then be written. After a write operation to the CMD, the CMA is automatically incremented to the next sequential address location. This eliminates the need to reload the CMA for every access to the CMD.

If necessary, the CMD may be read to verify its contents. As with write operations to the CMD, the CMA must be loaded prior to the initial access to the CMD. After a read operation is executed to the CMD, the CMA is automatically incremented.

The format of the Command Memory Data Register is shown in the following diagram.

## Command Memory Data Register

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| CMD |
| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 08  | 07  | 06  | 05  | 04  | 03  | 02  | 01  | 00  |
| CMD |
| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | O   |

<31:0>

COMMAND MEMORY DATA31 through 0 are write/read bits used to load/read the 32K X 32 Command Memory.

## List Transfer Count Register

The List Transfer Count Register (LTCR) is a read-only register located at an offset of 14 Hex from the selected base address. This register returns the two's complement of the number of transfers remaining during a block transfer mode of operation. When the list processor encounters a block transfer instruction, it loads the 32-bit List Transfer Count Register with the count specified in the instruction. This value is the two's complement of the maximum number of transfers that are to occur for the block transfer operation. When this counter is incremented to zero, the block transfer operation terminates and the next instruction in the list is interpreted. If an error occurs during the block operation, the LTCR may then be read to

determine the number of transfers remaining. The Transfer Count reflects the number of transfers without regard to the data word size.

The following diagram shows the bit pattern for the List Transfer Count Register.

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| LTC |
| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 80  | 07  | 06  | 05  | 04  | 03  | 02  | 01  | 00  |
| LTC |
| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |

<31:0>

LIST TRANSFER COUNT31 through 0 are read-only bits That reflect the number of transfers remaining after a block transfer operation concludes. This data is in two's complement format.

## **Total Transfer Count Register**

The Total Transfer Count Register (TTCR) is a write/read register located at an offset of 18 Hex from the selected base address. This register is used to specify the maximum number of DMA transfers that are to occur. Before a list operation is executed where data transfers to/from the highway occur using Direct Memory Access (DMA), the Total Transfer Count Register must be loaded with the two's complement of the maximum number of transfers. In case that the list terminates prematurely, the TTCR may be read to determine the number of transfers remaining to be executed.

Along with write access to the TTCR from the host by programmed I/O, the TTCR may also be loaded by using a list instruction. When the list processor encounters this instruction, the contents of the count specification are loaded into the TTCR.

The TTCR is incremented once for every DMA write or read access to PCI. When the counter increments to zero, the transfer is considered complete.

The following diagram shows the bit layout for the Total Transfer Count Register.

| 31             | 30             | 29             | 28             | 27             | 26             | 25             | 24             | 23             | 22             | 21             | 20             | 19             | 18             | 17             | 16             |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| TTC<br>R<br>31 | TTC<br>R<br>30 | TTC<br>R<br>29 | TTC<br>R<br>28 | TTC<br>R<br>27 | TTC<br>R<br>26 | TTC<br>R<br>25 | TTC<br>R<br>24 | TTC<br>R<br>23 | TTC<br>R<br>22 | TTC<br>R<br>21 | TTC<br>R<br>20 | TTC<br>R<br>19 | TTC<br>R<br>18 | TTC<br>R<br>17 | TTC<br>R<br>16 |
| 15             | 14             | 13             | 12             | 11             | 10             | 09             | 08             | 07             | 06             | 05             | 04             | 03             | 02             | 01             | 00             |
| TTC<br>R<br>15 | TTC<br>R<br>14 | TTC<br>R<br>13 | TTC<br>R<br>12 | TTC<br>R<br>11 | TTC<br>R<br>10 | TTC<br>R 9     | TTC<br>R 8     | TTC<br>R 7     | TTC<br>R 6     | TTC<br>R 5     | TTC<br>R 4     | TTC<br>R 3     | TTC<br>R 2     | TTC<br>R 1     | TTC<br>R O     |

<31:0>

TOTAL TRANSFER COUNT31 through 0 are write/read bits which specify the maximum number of DMA transfers to execute. A read of this register returns the two's complement of the number of transfer remaining.

## **Memory Address Register**

The Memory Address Register (MAR) is a write/read register located at an offset of 1C Hex from the selected base address. This register is used to specify the initial Direct Memory Access (DMA) address. Before any DMA operations are executed by the V124, the MAR must be loaded with the first address to be accessed during DMA write or read operations. After the V124 executes the first DMA operation, the MAR is automatically incremented to the next sequential longword address. Note that all DMA MAR specifications must be longword aligned.

DMA operations to/from the V124 are always 32-bits in length. Therefore, the MAR specification must be on a longword boundary.

The following diagram shows the bit pattern for the Memory Address Register.

| 31        | 30        | 29        | 28        | 27        | 26        | 25        | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| MAR<br>31 | MAR<br>30 | MAR<br>29 | MAR<br>28 | MAR<br>27 | MAR<br>26 | MAR<br>25 | MAR<br>24 | MAR<br>23 | MAR<br>22 | MAR<br>21 | MAR<br>20 | MAR<br>19 | MAR<br>18 | MAR<br>17 | MAR<br>16 |
| 15        | 14        | 13        | 12        | 11        | 10        | 09        | 08        | 07        | 06        | 05        | 04        | 03        | 02        | 01        | 00        |
| MAR<br>15 | MAR<br>14 | MAR<br>13 | MAR<br>12 | MAR<br>11 | MAR<br>10 | MAR<br>9  | MAR<br>8  | MAR<br>7  | MAR<br>6  | MAR<br>5  | MAR<br>4  | MAR<br>3  | MAR<br>2  | 0         | 0         |

<31:2> MEMORY ADDRESS31 through 2 are write/read bits used to specify the initial DMA Memory Address.

<1:0> These bits are not used and are read as zeros.

## **Demand FIFO Register**

The Demand FIFO Register (DFR) is a read-only register located at an offset of 28 Hex from the selected base address. This register is loaded with demand message data received from the highway. When a slave chassis requires service, it may generate an asynchronous demand message on the highway. When the V124 receives these demands, they are placed in a 2K X 16 FIFO. Optionally, the V124 may assert a PCI interrupt when the V124 receives a demand message. The FIFO data contains the node address of the chassis that generated the demand message along with an 8-bit identifier. Please refer to the individual slave module manuals for details on the sources of the identifiers.

As long as there is at least one demand message contained in the Demand FIFO Register the DEMAND PENDING (DMD PND) bit in the CSR is set to a one. If the DFR is full (2048 demands) and an additional demand message is received from the highway, the DEMAND OVERFLOW (DMD OFL) bit in the CSR is set to a one. The Demand FIFO Register and the DEMAND OVERFLOW bit are cleared by power-up, a write to the Reset Interface address, and by a write to the Reset Demand FIFO address.

The following diagram shows the bit pattern for the Demand FIFO Register.

| 31 | 30        | 29        | 28        | 27       | 26       | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
|----|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 0  | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 15 | 14        | 13        | 12        | 11       | 10       | 09       | 08       | 07       | 06       | 05       | 04       | 03       | 02       | 01       | 00       |
| 0  | NDA<br>64 | NDA<br>32 | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 | DID<br>7 | DID<br>6 | DID<br>5 | DID<br>4 | DID<br>3 | DID<br>2 | DID<br>1 | DID<br>O |

<31:15> These bits are not used and are read as zeros.

<14:8> NODE ADDRESS64 through 1 are read-only bits which indicates the chassis' node address that generated the demand message.

<7:0> DEMAND IDENTIFIER7 through 0 are read-only bits which indicate the chassis' internal demand source.

#### Reset Interface

The Reset Interface (RSTIFC) is a write-only address location located at an offset of 2C Hex from the selected base address. A write operation to this address with any data pattern causes the V124 to be reset to an initial state.

## Reset Demand FIFO Register

The Reset Demand FIFO Register is a write-only address location located at an offset of 30 Hex from the selected base address. A write operation to this address with any data pattern causes the Demand FIFO Register and the DEMAND OVERFLOW bit to be cleared.

### PROGRAMMED TRANSFERS

Programmed transfers are used to setup and initiate highway operations. Once these operations are started, data transfer to/from the Data FIFO Registers may occur under programmed transfer or by Direct Memory Access (DMA). DMA transfers have a significant speed advantage over programmed transfers. The DMA transfers to the V124 occur without any software overhead once the transfer is setup.

When using programmed transfers, the software must examine the FIFO flags in order to determine whether to transfer data to/from the Data FIFO Resister (FIFO). These flags are located in the Control/Status Register of the Highway Operational Registers and the Bus Master Control/Status Register of the PCI Interface Registers. Before a write operation to the V124 FIFOs may occur, the software must read the Control/Status Register (CSR) to determine if there is room in the FIFO for another piece of write data. If either the TRANSMIT FIFO FULL bit in the Control/Status Register is set or the OUTBOUND FIFO FULL bit in the Bus Master Control/Status Register is set, the software must suspend the write operation until both bits are negated. When read commands are executed, the software must first check the INBOUND FIFO EMPTY bit in the Bus Master Control/Status Register before the data may be retrieved. If this bit is set, the software must loop on reading these registers until the bit is asserted. These procedures must be followed when executing programmed transfer operations to the FIFO while list processing is in progress.

The following is a basic example of how to execute a programmed transfer list operation. For this example, the direction of data transfer is from the 2960 to a highway slave device.

- 1.) Set the Command Memory Address Register to zero.
- 2.) Load the Command Memory Data Register with the instructions required to execute the write operation. Make sure that the last element in the list is a HALT instruction.
- 3.) Set the Command Memory Address Register to zero.
- 4.) Set the GO bit in the Control/Status Register.
- 5.) Read the Control/Status Register and loop on this step until the TRANSMIT FIFO FULL bit is false.
- 6.) Read the Bus Master Control/Status Register and loop on this step until the OUTBOUND FIFO FULL bit is false.
- 7.) Write the Data FIFO Register with the data to be transmitted. Return to step 5 until all the transmit data words have been loaded into the V124.
- \* 8.) Wait for the DONE bit in the Control/Status Register to be asserted, indicating that the operation is complete.
  - 9.) Read the Control/Status Register and Error/Status Register to check for any errors.

The following example shows the steps required to execute a programmed transfer operation that transfers data from a highway slave device to the 2960.

- 1.) Set the Command Memory Address Register to zero.
- 2.) Load the Command Memory Data Register with the instructions required to execute the write operation. Make sure that the last element in the list is a HALT instruction.
- 3.) Set the Command Memory Address Register to zero.
- 4.) Set the GO bit in the Control/Status Register.

- 5.) Loop on reading the Control/Status Register until the Bus Master Control/Status Register until the INBOUND FIFO EMPTY bit is set.
- 6.) Read the data from the Data FIFO Register and return to step 5 until all data words have been read.
- \* 7.) Wait for the DONE bit in the Control/Status Register to be asserted indicating that the operation is complete.
  - 8.) Read the Control/Status Register and the Error/Status Register to check for any errors.
- \* When using the V124 with the Done Interrupt enabled, the steps that include waiting for DONE may be removed since the assertion of the DONE bit generates an interrupt.

#### DMA TRANSFERS

Direct Memory Access (DMA) transfers provide the most efficient mechanism of transferring data to/from the V124 during list processing operations. Minimal programming is required to setup the DMA mechanism.

Before a DMA operation begins, the V124 must have the Memory Address loaded with the initial host memory address to access during the operation. After the V124 accesses the specified location, the memory address is incremented to the next longword address. Note that the address specification must be longword aligned. As the DMA operations progresses, the Memory Address is incremented until the DMA operation is complete.

The maximum number of transfers that the V124 is to execute must be loaded in the Total Transfer Count Register prior to enabling DMA. This register is loaded with the two's complement of the number of transfers to occur during the DMA operation. This value must take into account all data transfer instructions in the list, excluding the Single Inline Write operation. As each data word is transferred to/for host memory, the transfer count is incremented. When the count is incremented to zero, the DMA operation is complete.

## COMMAND MEMORY INSTRUCTION FORMATS

The V124 contains a 32K x 32-word memory used to hold the list processing instructions to be executed by the hardware list processor or the DSP. When list processing is initiated, the hardware list processor examines the header instruction of the first list instruction. If the header indicates that the instruction is a data transfer instruction to a VXI/VME chassis, the hardware processor forms the necessary command to transmit on the highway. After the highway transaction is complete, the Command Memory Address is incremented and the next instruction interpreted.

The lower 16-bits of the first longword of a command instruction specifies the type of the instruction. This 16-bit word is referred to as the instruction header. The following diagram shows the format of the instruction header.

| 15      | 14      | 13        | 12        | 11        | 10       | 09       | 80       | 07       | 06      | 05      | 04      | 03      | 02      | 01      | 00 |  |
|---------|---------|-----------|-----------|-----------|----------|----------|----------|----------|---------|---------|---------|---------|---------|---------|----|--|
| CM<br>1 | CM<br>O | NDA<br>64 | NDA<br>32 | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 | TM<br>2 | TM<br>1 | AM<br>2 | AM<br>1 | WS<br>2 | WS<br>1 | AD |  |

Bits 15 and 14 of the instruction header specify the type of instruction as follows:

| CM1 | СМО | Instruction Type    |
|-----|-----|---------------------|
| 0   | 0   | Reserved            |
| 0   | 1   | VXI/VME Instruction |
| 1   | 0   | Special Instruction |
| 1   | 1   | Reserved            |

If the CM1 bit is a zero, indicating that highway data transfers are to occur, bits 13 through 7 specify the node address at which the addressed command is directed. For special instructions, these bits may take on other definitions. The bits 13 through 7 for data transfer instructions allow a node address value from zero to 127. Even though node address 0 and 127 are valid, they are reserved for future expansion.

The definitions of the remaining bits in the instruction header vary depending on the type of command. The next two sections fully define bits 6 through 0 of the instruction header.

The next two sections of this manual describe the various VXI/VME instructions.

#### **VXI/VME Instructions**

For all VXI/VME instructions, the instruction header has bits 15 set to a zero and bit14 set to a one. Bits 13 through 7 are used to specify the node address of the VXI/VME chassis to access during the operation. Other bits in this word define the Transfer Mode, Access Mode, and Data Word Size. The following diagram shows the instruction header for VXI/VME instructions.

| 15 | 14 | 13        | 12 | 11        | 10       | 09       | 08       | 07       | 06  | 05  | 04  | 03  | 02  | 01  | 00 |
|----|----|-----------|----|-----------|----------|----------|----------|----------|-----|-----|-----|-----|-----|-----|----|
| 0  | 1  | NDA<br>64 |    | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 | TM2 | TM1 | AM2 | АМ1 | WS2 | WS1 | AD |

Bits 15 must be set to a zero and bit 14 to a one.

Bits 13 through 7 are used to specify the node address of the VXI/VME chassis to access.

Bits 6 and 5 are the Transfer Mode bits and specify the VXI/VME transfer protocol as follows:

| TM2 | TM1 | Transfer Mode                    |  |  |  |  |  |  |  |
|-----|-----|----------------------------------|--|--|--|--|--|--|--|
| 0   | 0   | Single Operation                 |  |  |  |  |  |  |  |
| 0   | 1   | Block Transfer Operation         |  |  |  |  |  |  |  |
| 1   | 0   | Single Inline Write<br>Operation |  |  |  |  |  |  |  |
| 1   | 1   | Reserved                         |  |  |  |  |  |  |  |

The Single Operation Transfer Mode simply transfers one data word to/from the VXI/VME chassis for the specified VXI/VME command. These operations may include write or read operations.

Block Transfer Operations move blocks of data to/from a VXI/VME chassis for each block instruction. The number of data words to transfer during Block Transfer operations are found in additional words accompanying this instruction. These operations may include either VXI/VME write or read operations.

Single Inline Write Operations are single transfers VXI/VME write operations that have the write data embedded in the list. These commands are useful for initializing modules and also allow VXI/VME write operations to occur in a read command list.

The Access Mode bits, AM2 and AM1, specify the access method to be used during the requested transfer. This mode concerns the addressing of the VXI/VME chassis. After the initial VXI/VME transfer is executed during block transfers, the address may be either incremented or left the same for subsequent transfers of the block. The Access Modes provided are as follows.

| AM2 | AM1 | Access Mode       |
|-----|-----|-------------------|
| 0   | 0   | Increment Address |
| 0   | 1   | Reserved          |
| 1   | 0   | Address Unchanged |
| 1   | 1   | Reserved          |

The Word Size bits, WS2 and WS1, are used to specify the size of the VXI/VME data word accessed in the addressed chassis. The following chart shows the available VXI/VME data word size selections.

| WS2 | WS1 | Data Word Size |
|-----|-----|----------------|
| 0   | 0   | 32-Bits        |
| 0   | 1   | Reserved       |
| 1   | 0   | 16-Bits        |
| 1   | 1   | 8-Bits         |

The last bit in the instruction header, ABORT DISABLE, is used to enable or disable the termination of an operation when a VXI Timeout is encountered. Setting this bit to a one allows an operation to run to completion without regard to the bus timeouts. Setting this bit to a zero causes an operation to terminate when a bus error occurs.

#### VXI/VME Address

The second 16-bit word for VXI/VME instructions contains the VME Address Modifier, a bit indicating the direction of the transfer (write or read), and a bit that is set to execute operations within the chassis controller. This second 16-bit word is the high 16-bits of the first 32-bit Command Memory Data word. The following diagram shows the second instruction word for VXI/VME instructions.

| 31  | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
|-----|-----|----|----|----|----|----|----|----|----|----------|----------|----------|----------|----------|----------|
| INT | DIR | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | AMD<br>5 | AMD<br>4 | AMD<br>3 | AMD<br>2 | AMD<br>1 | AMD<br>0 |

The INTERNAL bit, bit 31, is used to indicate whether the addressed command is to be executed internal to the chassis controller or external. Setting this bit to a one specifies that the operation is executed internal to the chassis controller. For operations to occur on the VXI/VME backplane, this bit must be set to a zero.

The DIRECTION bit, bit 30, is used to define the direction of the transfer. When DIRECTION is set to zero, the direction of the transfer is from the V124 to the VXI/VME chassis controller (write operations). This bit is set to a one for transferring data from the addressed VXI/VME chassis to the V124 (read operations).

Bits 29 through 22 are not used and must be set to zeros.

The ADDRESS MODIFIER bits, AMD5 through AMD0, are used to specify the VME address modifier that the addressed chassis controller is to use for the VXI/VME bus cycle. The following chart is a subset of the VME address modifiers.

| Address Modifier Data (Hex) | Function                                   |
|-----------------------------|--------------------------------------------|
| 3F                          | Standard (A24) Supervisory Block Transfer  |
| 3E                          | Standard (A24) Supervisory Program Access  |
| 3D                          | Standard (A24) Supervisory Data Access     |
| 3B                          | Standard (A24) Nonprivleged Block Transfer |
| 3A                          | Standard (A24) Nonprivleged Program Access |
| 39                          | Standard (A24) Nonprivleged Data Access    |
| 2D                          | Short (A16) Supervisory Access             |
| 29                          | Short (A16) Nonprivleged Access            |
| 0F                          | Extended (A32) Supervisory Block Transfer  |
| OE                          | Extended (A32) Supervisory Program Access  |
| 0D                          | Extended (A32) Supervisory Data Access     |
| 0B                          | Extended (A32) Nonprivleged Block Transfer |
| 0A                          | Extended (A32) Nonprivleged Program Access |
| 09                          | Extended (A32) Nonprivleged Data Access    |

The next longword (32-bits) of any VXI/VME instruction is the physical address. The following diagram shows the bit pattern for the 2nd longword of a VXI/VME instruction.

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| A31 | A30 | A29 | A28 | A27 | A26 | A25 | A24 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 08  | 07  | 06  | 05  | 04  | 03  | 02  | 01  | 00  |
| A15 | A14 | A13 | A12 | A11 | A10 | A9  | 8A  | A7  | A6  | A5  | A4  | А3  | A2  | A1  | AO  |

#### **VXI/VME** Single Transfer Instructions

The Header Word, Address Modifier, and Address specification are common for all VXI/VME instructions. This information occupies two 32-bit Command Memory Data words. For VXI/VME Single Operations, this is the only data required. For each Single Transfer instruction encountered in the list, only one data word is transferred. The direction of the transfer is controlled by the DIRECTION bit. To transfer multiple data words to/from a VXI/VME chassis with one instruction, the VXI/VME Block Transfer instruction must be used.

The following diagram shows the composite format for the VXI/VME Single Operation instruction.

| 31  | 30  | 29        | 28        | 27        | 26       | 25       | 24       | 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
|-----|-----|-----------|-----------|-----------|----------|----------|----------|----------|----|----------|----------|----------|----------|----------|----------|
| INT | DIR | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0  | AMD<br>5 | AMD<br>4 | AMD<br>3 | AMD<br>2 | AMD<br>1 | AMD<br>0 |
| 15  | 14  | 13        | 12        | 11        | 10       | 09       | 08       | 07       | 06 | 05       | 04       | 03       | 02       | 01       | 00       |
| 0   | 1   | NDA<br>64 | NDA<br>32 | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 | 0  | 0        | AM2      | AM1      | WS2      | WS1      | AD       |

#### VXI/VME Block Transfer Instructions

VXI/VME Block Transfer instructions allow multiple data words to be transferred to/from a VXI/VME chassis with one instruction. This provides an efficient method for transferring a block of data to/from a particular module(s).

Associated with each Block Transfer instruction is a Transfer Count. The Transfer Count, which is 32-bits is length, is the two's complement of the maximum number of VXI/VME words to transfer during the block operation. This transfer count specifies the number of data words to transfer, regardless of the Data Word Size.

When the list processor finds a Block Transfer instruction in the Command Memory, it loads the List Transfer Count Register on the V124 with the Transfer Count data found in the list. The List Transfer Count Register is then incremented as each data word is transferred to/from the VXI/VME chassis. The Block Transfer operation continues until the List Transfer Count is exhausted or an error occurs. If the transfer terminates prematurely, the List Transfer Count Register may then be read to determine the number of data words remaining to transfer.

Model V124

The format of the VXI/VME Block Transfer instruction is shown in the following diagram.

### 1st Longword:

| <br>31 | 30  | 29        | 28        | 27        | 26       | 25       | 24       | 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
|--------|-----|-----------|-----------|-----------|----------|----------|----------|----------|----|----------|----------|----------|----------|----------|----------|
| INT    | DIR | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0  | AMD<br>5 | AMD<br>4 | AMD<br>3 | AMD<br>2 | AMD<br>1 | AMD<br>0 |
| <br>15 | 14  | 13        | 12        | 11        | 10       | 09       | 08       | 07       | 06 | 05       | 04       | 03       | 02       | 01       | 00       |
| 0      | 1   | NDA<br>64 | NDA<br>32 | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 | 0  | 1        | AM2      | AM1      | WS2      | WS1      | AD       |

## 2nd Longword:

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18                                      | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------------------------------------|-----|-----|
| A31 | A30 | A29 | A28 | A27 | A26 | A25 | A24 | A23 | A22 | A21 | A20 | A19 | A18                                     | A17 | A16 |
|     |     | l   |     |     |     |     |     | L   | İ   |     |     |     | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |     |     |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 08  | 07  | 06  | 05  | 04  | 03  | 02                                      | 01  | 00  |
| A15 | A14 | A13 | A12 | A11 | A10 | A9  | A8  | A7  | A6  | A5  | A4  | А3  | A2                                      | A1  | AO  |
|     |     |     |     |     |     |     |     |     |     |     |     | :   |                                         |     |     |

## 3rd Longword:

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR |
| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 80  | 07  | 06  | 05  | 04  | 03  | 02  | 01  | 00  |
| TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR | TCR |
| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |

#### VXI/VME Single Inline Write Instruction

The Single Inline Write instruction allows a predetermined data word to be placed in the list and written to the specified VXI/VME address. Most often, this type of instruction is used for module initialization or as a mechanism to execute a VXI/VME write operation in a read list.

The format of the VXI/VME Single Inline Write instruction is shown in the following diagram.

#### 1st Longword:

| 31  | 30  | 29        | 28        | 27        | 26       | 25       | 24       | 23       | 22 | 21       | 20       | 19       | 18       | 17       | 16       |
|-----|-----|-----------|-----------|-----------|----------|----------|----------|----------|----|----------|----------|----------|----------|----------|----------|
| INT | DIR | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0  | AMD<br>5 | AMD<br>4 | AMD<br>3 | AMD<br>2 | AMD<br>1 | AMD<br>0 |
| 15  | 14  | 13        | 12        | 11        | 10       | 09       | 08       | 07       | 06 | 05       | 04       | 03       | 02       | 01       | 00       |
| 0   | 1   | NDA<br>64 | NDA<br>32 | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 | 1  | 0        | AM2      | AM1      | WS2      | WS1      | AD       |

#### 2nd Longword:

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21                                    | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------------------------------|-----|-----|-----|-----|-----|
| A31 | A30 | A29 | A28 | A27 | A26 | A25 | A24 | A23 | A22 | A21                                   | A20 | A19 | A18 | A17 | A16 |
| 45  | 11  | 4-5 | 4.0 |     |     |     |     |     |     | · · · · · · · · · · · · · · · · · · · |     |     |     |     |     |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 08  | 07  | 06  | 05                                    | 04  | 03  | 02  | 01  | 00  |
| A15 | A14 | A13 | A12 | A11 | A10 | А9  | A8  | A7  | A6  | A5                                    | Α4  | А3  | A2  | A1  | Α0  |

#### 3rd Longword:

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| W31 | W30 | W29 | W28 | W27 | W26 | W25 | W24 | W23 | W22 | W21 | W20 | W19 | W18 | W17 | W16 |
| 15  | 14  | 13  | 12  | 11  | 10  | 09  | 08  | 07  | 06  | 05  | 04  | 03  | 02  | 01  | 00  |
| W15 | W14 | W13 | W12 | W11 | W10 | W9  | w8  | W7  | W6  | W5  | W4  | w3  | W2  | W1  | MO  |

#### **Special Instructions**

There are several special instructions implemented by the V124. These instructions are not handled by the hardware list processor. When the hardware list processing mechanism encounters any special instructions, it sends a signal to the DSP. The DSP then examines the special instruction and executes the operation.

The only required special instruction that must be used is the HALT instruction. The HALT must be the last list instruction loaded following a valid list.

The following chart shows the special instructions implemented by the V124. The hex data shown corresponds to the first 16-bit word of the special instruction (header).

| Special<br>Instruction<br>(hex) | Function                |
|---------------------------------|-------------------------|
| 8000                            | Halt                    |
| 8040                            | Addressed Slave Trigger |
| 8041                            | Broadcast Trigger       |
| 8043                            | Generate Host Interrupt |
| 8100                            | Write Reply FIFO Short  |
| 8101                            | Write Reply FIFO Long   |

#### **Halt Instruction**

The Halt instruction has a value of 8000 hex and must be placed at the end of a list sequence. This special instruction informs the list processor to cease processing until retriggered. The following diagram shows the bit pattern for the Halt instruction.

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22 | 21 | 20       | 19 | 18 | 17    | 16 |
|----|----------|----|----|----|----|----|----|----------|----|----|----------|----|----|-------|----|
| 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0        | 0  | 0  | 0     | 0  |
|    | <u> </u> | l  |    | 1  | !  |    | l  | <u>I</u> |    | I  | <u> </u> |    |    | W. W. |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 09 | 80 | 07       | 06 | 05 | 04       | 03 | 02 | 01    | 00 |
| 1  | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0        | 0  | 0  | 0     | 0  |
| L  |          |    |    |    |    |    |    |          |    |    |          |    |    |       |    |

#### Addressed Slave Trigger Instruction

The Addressed Slave Trigger instruction has an opcode of 8040 hex and is used to initiate a trigger at an addressed slave. The data sent to the addressed slave is contained in the list instruction. The addressed slave takes the write data and strobes it into the Trigger Source Register. Refer to the individual slave device manuals for further information on the Trigger Source Register.

The following is the format of the Addressed Slave Trigger instruction.

#### 1st Longword:

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22        | 21        | 20        | 19       | 18       | 17       | 16       |
|----|----|----|----|----|----|----|----|----|-----------|-----------|-----------|----------|----------|----------|----------|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | NDA<br>64 | NDA<br>32 | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 |
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06        | 05        | 04        | 03       | 02       | 01.      | 00       |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1         | 0         | 0         | 0        | 0        | 0        | 0        |

NODE ADDRESS 64 through 1 specify the node address to be accessed.

#### 2nd Longword:

| 31       | 30       | 29       | 28       | 27       | 26       | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|----------|----------|----------|----------|----------|----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 0        | 0        | 0        | 0        | 0        | 0        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| 15       | 14       | 13       | 12       | 11       | 10       | 09  | 08  | 07  | 06  | 05  | 04  | 03  | 02  | 01  | 00  |
| TD1<br>5 | TD1<br>4 | TD1<br>3 | TD1<br>2 | TD1<br>1 | TD1<br>0 | TD9 | TD8 | TD7 | TD6 | TD5 | TD4 | TD3 | TD2 | TD1 | TD0 |

TRIGGER DATA 15 through 0 is the data to be written into the addressed slave Trigger Source Register.

#### **Broadcast Trigger Instruction**

The Broadcast Trigger Instruction has an opcode of 8041 hex and is used to generate a Broadcast Trigger Message on the highway. This message is received by all slave devices on the highway. Once a slave device receives this message, it takes the data preloaded in the Broadcast Trigger Mask Register and applies the data to the Trigger Source Register. Any bit that is set to a one in the Broadcast Trigger Mask Register causes the corresponding local

trigger to be asserted. Please refer to the individual slave devices operating manual for additional information.

The following shows the format of the Broadcast Trigger instruction.

#### 1st Longword:

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 1  |

#### 2nd Longword:

| 31 | 30 | 29 | 28 | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|
| 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  | 0  | 0  | 0  | 0  | . 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### **Generate Host Interrupt Instruction**

The Generate Host Interrupt Instruction has an opcode of 8043 hex and is used to generate an interrupt to the host computer. In order for this instruction to generate an interrupt to the PCI bus, it must be first enabled in the Interrupt Control/Status Register. If polling is desired, the LIST INTERRUPT bit in the Control/Status Register can be used.

The following shows the format for the Generate Host Interrupt instruction.

| 31       | 30       | 29 | 28 | 27 | 26  | 25       | 24 | 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16  |
|----------|----------|----|----|----|-----|----------|----|----|----------|----|----|----|----|----|-----|
| 0        | 0        | 0  | 0  | 0  | 0   | 0        | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0   |
| <u> </u> | <u> </u> |    |    |    | L., | <u> </u> |    |    | <u> </u> |    |    |    |    |    |     |
| 15       | 14       | 13 | 12 | 11 | 10  | 09       | 80 | 07 | 06       | 05 | 04 | 03 | 02 | 01 | 00  |
| 1        | 0        | 0  | 0  | 0  | 0   | 0        | 0  | 0  | 1        | 0  | 0  | 0  | 0  | 1  | 1   |
|          |          |    |    |    |     |          |    |    | 1        |    |    |    |    |    | i I |

#### Write Reply FIFO Short Instruction

The Write Reply FIFO Short instruction has an opcode of 8100 hex and is used to write 16-bits of data to the Reply FIFO on the V124. The second longword associated with this command contains the data to write to the FIFO. The Reply FIFO holds all the data received from the highway during read operations on the highway. If desired, the list processor may be instructed to insert a data pattern into the read data path. This can be used to tag data when a branch instruction is used or to realign a read data buffer to longwords. Since the V124 forms 32-bit read data words before transferring the data to the output FIFO, it may be necessary to include a Write Reply FIFO Short instruction in a list to make sure longword alignment is maintained. For example, if a list operation resulted in an odd number of 16-bit words being transferred, the user must include a Write Reply FIFO Short instruction to ensure that the last 16-bit word is not "stuck" in the V124.

The following diagram shows the format for the Write Reply FIFO Short instruction.

| 31        | 30        | 29        | 28        | 27        | 26        | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 0         | 0         | 0         | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 15        | 14        | 13        | 12        | 11        | 10        | 09       | 08       | 07       | 06       | 05       | 04       | 03       | 02       | 01       | 00       |
| 1         | 0         | 0         | 0         | 0         | 0         | 0        | 1        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 31        | 30        | 29        | 28        | 27        | 26        | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| 0         | 0         | 0         | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 15        | 14        | 13        | 12        | 11        | 10        | 09       | 08       | 07       | 06       | 05       | 04       | 03       | 02       | 01       | 00       |
| RFD<br>15 | RFD<br>14 | RFD<br>13 | RFD<br>12 | RFD<br>11 | RFD<br>10 | RFD<br>9 | RFD<br>8 | RFD<br>7 | RFD<br>6 | RFD<br>5 | RFD<br>4 | RFD<br>3 | RFD<br>2 | RFD<br>1 | RFD<br>0 |

#### Write Reply FIFO Long Instruction

The Write Reply FIFO Long instruction has an opcode of 8101 hex and is used to write 32-bits of data to the Reply FIFO on the V124. The second longword associated with this command contains the data to write to the FIFO. The Reply FIFO holds all the data received from the highway during read operations on the highway. If desired, the list processor may be instructed to insert a data pattern into the read data path. This can be used to tag data when a branch instruction is used.

The following diagram shows the format for the Write Reply FIFO Long instruction.

| 31        | 30                                      | 29        | 28        | 27        | 26        | 25        | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|-----------|-----------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| 0         | 0                                       | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |
| L         | <u> </u>                                | L         | l         |           |           | <b>L</b>  |           |           |           |           |           |           |           | <u> </u>  |           |
| 15        | 14                                      | 13        | 12        | 11        | 10        | 09        | 80        | 07        | 06        | 05        | 04        | 03        | 02        | 01        | 00        |
| 1         | 0                                       | 0         | 0         | 0         | 0         | О         | 1         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 1         |
|           | *************************************** |           |           |           |           | l         |           | L         |           |           |           | <b>L</b>  |           | l         |           |
| 31        | 30                                      | 29        | 28        | 27        | 26        | 25        | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
| RFD<br>31 | RFD<br>30                               | RFD<br>29 | RFD<br>28 | RFD<br>27 | RFD<br>26 | RFD<br>25 | RFD<br>24 | RFD<br>23 | RFD<br>22 | RFD<br>21 | RFD<br>20 | RFD<br>19 | RFD<br>18 | RFD<br>17 | RFD<br>16 |
| 15        | 14                                      | 13        | 12        | 11        | 10        | 09        | 08        | 07        | 06        | 05        | 04        | 03        | 02        | 01        | 00        |
| RFD<br>15 | RFD<br>14                               | RFD<br>13 | RFD<br>12 | RFD<br>11 | RFD<br>10 | RFD<br>9  | RFD<br>8  | RFD<br>7  | RFD<br>6  | RFD<br>5  | RFD<br>4  | RFD<br>3  | RFD<br>2  | RFD<br>1  | RFD<br>O  |

#### VXI LIST PROCESSING EXAMPLE

As an example, assume it is desired to setup, enable, and read a block of 20000 32-bits words from a VXI module. For this example, the following parameters exist:

Node Address = 16

Logical Address = 2

A32 Device

Readout address for data is at base address for A32 space

For this example, two Single VXI Inline Write operations are executed to setup the modules Offset Register in A16 address space and then enable the module by setting the A24/A32 enable bit in the Status/Control Register. The module will be set to occupy address 30000000 in A32 address space. After setup, a VXI Block Transfer instruction is executed to read the data.

With a Logical Address of 2, the modules' Status/Control Register is located at C084 hex and the Offset Register is at address C086 hex. Both of these registers are located in A16 address space and may be accessed with an address modifier of 2D hex.

For this example, the following instructions are executed.

Single Inline VXIWrite Address(C086)
Single Inline VXIWrite Address (C084)

Address Modifier (2D) Address Modifier (2D)

Data(3000)
Data (8000)

Block VXI Read

Address (30000000) Address Modifier (D)

Transfer Count (-20000)

After the list elements are formed, the actual list is as follows:

| Hex<br>Instruction<br>Data | List Entry Contents                                                       |
|----------------------------|---------------------------------------------------------------------------|
| 002D4840                   | Address Modifier (2D) VXI Single Inline Write 32-Bit                      |
| 0000C086                   | Address (C086)                                                            |
| 00003000                   | DATA(00003000)                                                            |
| 002D4840                   | Address Modifier (2D) VXI Single Inline Write 32-Bit                      |
| 0000C084                   | Address (0000C084)                                                        |
| 0008000                    | DATA(00008000)                                                            |
| 400D4820                   | Read, Address Modifier (D) VXI Block Transfer Increment<br>Address 32-Bit |
| 30000000                   | Address (3000000)                                                         |
| FFFFB1E0                   | Transfer Count (-20000)                                                   |
| 00008000                   | HALT                                                                      |

#### **INTERRUPTS**

The V124 may generate interrupts to the PCI bus from any of four sources. These sources include the assertion of the DONE, the presence of a Demand Message in the Demand FIFO Register, the list processor encountering the Generate Host Interrupt instruction and the PCI interface chip. These sources are individually enabled in the Interrupt Control/Status Register. The level at which the V124 interrupts the host computer is based on the computer architecture and the mapping of the V124 PCI interrupt to the host computer bus interrupt. The V124 interrupts on the PCI bus by asserting the INTA signal.

The DONE interrupt source is generated when a list processing operation is completed and the DONE, bit 7, in the Control/Status Register is set to a one. The DONE INTERRUPT ENABLE, bit 0, in the Interrupt Control/Status Register must be set to a one in order to generate a PCI interrupt.

If enabled, the receipt of a Demand Message from the highway can generate a PCI interrupt. The interrupt is enabled in the Interrupt Control/Status Register using the DEMAND

INTERRUPT ENABLE bit, bit 2. When this interrupt source is generated, the entire contents of the Demand FIFO Register should be read in order to allow additional interrupts to occur.

The list processor may also generate an interrupt to the PCI bus. The Generate Host Interrupt instruction asserts the interrupt source and must be enabled using the LIST INTERRUPT ENABLE bit in the Interrupt Control/Status Register.

The last interrupt source from the V124 may be generated from the PCI interface chip. To enable this source, the PCI INTERRUPT ENABLE bit in the Interrupt/Control/Status Register must be set to a one. Refer to the PCI Interface Interrupt Control/Status Register section of this manual for additional information on the PCI interface chip interrupts.

Once an interrupt is asserted, it remains asserted until cleared by writing to the Interrupt Control/Status Register with the data that matches the interrupt sources to clear.

#### **DEMANDS**

Demands are asynchronous messages received from devices on the interconnect highway. These messages provide a means of informing the V124 that the device sourcing the message requires attention. The Demand Message contains the chassis address of the node requesting service along with an 8-bit Demand Identification byte. For the definition of the Demand Identification bits, refer to the manual for the slave device.

After a Demand Message is received by the V124, it is stored in a 2048 word FIFO. As long as there is at least one demand in the FIFO, the DEMAND PENDING bit in the Control/Status Register is set to a one. After all demand words are read from the FIFO, the bit is reset to a zero.

If the Demand FIFO is full and another Demand Message is received by the 2960, the message is lost and the DEMAND OVERFLOW bit in the Control/Status Register is set to a one. After the overflow occurs, the DEMAND FIFO OVERFLOW bit can be cleared by executing a write to the Demand FIFO Reset Register address.

#### APPEND STATUS

The V124 may be enabled to append a status byte onto the end of a highway read operation by enabling the APPEND STATUS bit in the Control/Status Register. Setting this bit to a one enables the feature.

After a read list operation is ended by the list processor encountering a HALT instruction, the APPEND STATUS bit is examined to see if an additional word of data is to be written into the highway read reply FIFO. If the bit is set to a one, the list processor reads a status word from internal registers and writes the data to the read reply FIFO. If append status is used, care must be taken to allocate the additional 32-bit data word in the read data block. The first 16-bit word contains the status and the second 16-bit word contains zero.

The following diagram shows the bit layout for the returned appended status word. The Error/Status Register section of this manual should be consulted for a detailed description of these bits.

| 15 | 14 | 13 | 12 | 11         | 10         | 09       | 80       | 07 | 06              | 05       | 04  | 03       | 02       | 01       | 00 |
|----|----|----|----|------------|------------|----------|----------|----|-----------------|----------|-----|----------|----------|----------|----|
| 0  | 0  | 0  | 0  | DMD<br>PND | VXI<br>TMO | RSV<br>D | RSV<br>D | 0  | RMT<br>PER<br>R | PER<br>R | ТМО | ADN<br>R | RSV<br>D | RSV<br>D | 0  |

#### EXTERNAL CLOCK INPUT

If the clock rate selections on the V124 do not meet an application requirement for timer initiated list processing, an external clock source may be connected to the V124. This input is fed into the V124 through the LEMO connector located on the rear panel. This input provided to the V124 must be TTL compatible. The list is triggered by the high to low transition of the input, and must have a minimum pulse width of 300 nanoseconds.

To enable the external clock input, the Timer Control Register must have both the CLOCK SOURCE and TIMER ENABLE bits set to a one. Refer to the Timer Control Register section of this manual for additional information.

#### **LEDs**

Two LEDs are mounted on the V124. One LED is used as an indication of highway synchronization and the other indicates when a list processing operation is in progress. As viewed from the V124 front panel bracket, the left-most LED is illuminated when the highway is in sync. This is a red LED. The green LED is illuminated as long as the list processor is busy.

| Cont           | rol/St     | tatus           |                 |            | IX A      | \ - V1          |                 | ompo<br>fset 0 |                 |                      | er La      | yout       |            |                |                |
|----------------|------------|-----------------|-----------------|------------|-----------|-----------------|-----------------|----------------|-----------------|----------------------|------------|------------|------------|----------------|----------------|
| 31             | 30         | 29              | 28              | 27         | 26        | 25              | 24              | 23             | 22              | 21                   | 20         | 19         | 18         | 17             | 16             |
| ERR<br>CD3     | ERR<br>CD2 | ERR<br>CD1      | ERR<br>CD0      | VXI<br>TMO | QTM<br>O  | N>2<br>3        | ILL<br>G<br>CMD | RMT<br>PER     | NO<br>SYN<br>C  | 0                    | PAR<br>ERR | тмо        | ADN<br>R   | NOX            | NOQ            |
| 15             | 14         | 13              | 12              | 11         | 10        | 09              | 08              | 07             | 06              | 05                   | 04         | 03         | 02         | 01             | 00             |
| 0              | 0          | LIS<br>T<br>INT | DMD<br>OFL<br>O | DMD<br>PND | 0         | XMT<br>FUL<br>L | RCV<br>DAV      | DON<br>E       | 0               | APN<br>D<br>STA<br>T | RLD<br>ENA | DMA<br>DIR | DMA<br>ENA | SUS<br>P       | GO             |
| Inter          | rupt       | Cont            | rol/St          | atus       | Regis     | ter             |                 | 0              | ffset (         | 04 he                | X          | ,          |            |                |                |
| 31             | 30         | 29              | 28              | 27         | 26        | 25              | 24              | 23             | 22              | 21                   | 20         | 19         | 18         | 17             | 16             |
| 0              | 0          | 0               | 0               | 0          | 0         | 0               | 0               | 0              | 0               | 0                    | 0          | 0          | 0          | 0              | 0              |
| 15             | 14         | 13              | 12              | 11         | 10        | 09              | 08              | 07             | 06              | 05                   | 04         | 03         | 02         | 01             | 00             |
| 0              | 0          | 0               | 0               | 0          | 0         | PCI<br>INT      | RSV<br>D        | DMD<br>INT     | LIS<br>T<br>INT | DON<br>E<br>INT      | PCI<br>IE  | RSV<br>D   | DMD<br>IE  | LIS<br>T<br>IE | DON<br>E<br>IE |
| Time           | r Cor      | itrol ]         | Regis           | ter        |           |                 |                 | <b>O</b> :     | ffset (         | 08 he                | ĸ          |            |            |                |                |
| 31             | 30         | 29              | 28              | 27         | 26        | 25              | 24              | 23             | 22              | 21                   | 20         | 19         | 18         | 17             | 16             |
| 0              | 0          | 0               | 0               | 0          | 0         | CLK<br>SRC      | TMR<br>ENA      | TCR<br>23      | TCR<br>22       | TCR<br>21            | TCR<br>20  | TCR<br>19  | TCR<br>18  | TCR<br>17      | TCR<br>16      |
| 15             | 14         | 13              | 12              | 11         | 10        | 09              | 08              | 07·            | 06              | 05                   | 04         | 03         | 02         | 01             | 00             |
| TCR<br>15      | TCR<br>14  | TCR<br>13       | TCR<br>12       | TCR<br>11  | TCR<br>10 | TCR<br>9        | TCR<br>8        | TCR<br>7       | TCR<br>6        | TCR<br>5             | TCR<br>4   | TCR<br>3   | TCR<br>2   | TCR<br>1       | TCR<br>0       |
| Comr           | nand       | Mem             | ory A           | ddre       | ss Re     | giste           | r               | O              | ffset (         | )C he                | x          | •          |            |                |                |
| 31             | 30         | 29              | 28              | 27         | 26        | 25              | 24              | 23             | 22              | 21                   | 20         | 19         | 18         | 17             | 16             |
| 0              | 0          | 0               | 0               | 0          | 0         | 0               | 0               | 0              | 0               | 0                    | 0          | 0          | 0          | 0              | 0              |
| 15             | 14         | 13              | 12              | 11         | 10        | 09              | 08              | 07             | 06              | 05                   | 04         | 03         | 02         | 01             | 00             |
| LIS<br>T<br>GO | CMA<br>14  | CMA<br>13       | CMA<br>12       | CMA<br>11  | CMA<br>10 | CMA<br>9        | CMA<br>8        | CMA<br>7       | CMA<br>6        | CMA<br>5             | CMA<br>4   | CMA<br>3   | CMA<br>2   | CMA<br>1       | CMA<br>O       |

| Com            | mand                                        | l Men          | nory I         | Data 1         | Regis          | ter            |                | О              | ffset          | 10 he          | x              |                |                |                                         |                                              |
|----------------|---------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------------------------------|----------------------------------------------|
| 31             | 30                                          | 29             | 28             | 27             | 26             | 25             | 24             | 23             | 22             | 21             | 20             | 19             | 18             | 17                                      | 16                                           |
| CMD<br>31      | CMD<br>30                                   | CMD<br>29      | CMD<br>28      | CMD<br>27      | CMD<br>26      | CMD<br>25      | CMD<br>24      | CMD<br>23      | CMD<br>22      | CMD<br>21      | CMD<br>20      | CMD<br>19      | CMD<br>18      | CMD<br>17                               | CMD<br>16                                    |
| 15             | 14                                          | 13             | 12             | 11             | 10             | 09             | 08             | 07             | 06             | 05             | 04             | 03             | 02             | 01                                      | 00                                           |
| CMD<br>15      | CMD<br>14                                   | CMD<br>13      | CMD<br>12      | CMD<br>11      | CMD<br>10      | CMD<br>9       | CMD<br>8       | CMD<br>7       | CMD<br>6       | CMD<br>5       | CMD<br>4       | CMD<br>3       | CMD<br>2       | CMD<br>1                                | CMD<br>0                                     |
| List '         | Trans                                       | sfer C         | ount           | Regis          | ster           |                | Off            | set 1          | 4 hex          |                |                |                |                |                                         |                                              |
| 31             | 30                                          | 29             | 28             | 27             | 26             | 25             | 24             | 23             | 22             | 21             | 20             | 19             | 18             | 17                                      | 16                                           |
| LTC<br>31      | LTC<br>30                                   | LTC<br>29      | LTC<br>28      | LTC<br>27      | LTC<br>26      | LTC<br>25      | LTC<br>24      | LTC<br>23      | LTC<br>22      | LTC<br>21      | LTC<br>20      | LTC<br>19      | LTC<br>18      | LTC<br>17                               | LTC<br>16                                    |
| 15             | 14                                          | 13             | 12             | 11             | 10             | 09             | 08             | 07             | 06             | 05             | 04             | 03             | 02             | 01                                      | 00                                           |
| LTC<br>15      | LTC<br>14                                   | LTC<br>13      | LTC<br>12      | LTC<br>11      | LTC<br>10      | LTC<br>9       | LTC<br>8       | LTC<br>7       | LTC<br>6       | LTC<br>5       | LTC<br>4       | LTC<br>3       | LTC<br>2       | LTC<br>1                                | LTC<br>0                                     |
| Total          | Fotal Transfer Count Register Offset 18 hex |                |                |                |                |                |                |                |                |                |                |                |                |                                         |                                              |
| 31             | 30                                          | 29             | 28             | 27             | 26             | 25             | 24             | 23             | 22             | 21             | 20             | 19             | 18             | 17                                      | 16                                           |
| TTC<br>R<br>31 | TTC<br>R<br>30                              | TTC<br>R<br>29 | TTC<br>R<br>28 | TTC<br>R<br>27 | TTC<br>R<br>26 | TTC<br>R<br>25 | TTC<br>R<br>24 | TTC<br>R<br>23 | TTC<br>R<br>22 | TTC<br>R<br>21 | TTC<br>R<br>20 | TTC<br>R<br>19 | TTC<br>R<br>18 | TTC<br>R<br>17                          | TTC<br>R<br>16                               |
| 15             | 14                                          | 13             | 12             | 11             | 10             | 09             | 08             | 07             | 06             | 05             | 04             | 03             | 02             | 01                                      | 00                                           |
| TTC<br>R<br>15 | TTC<br>R<br>14                              | TTC<br>R<br>13 | TTC<br>R<br>12 | TTC<br>R<br>11 | TTC<br>R<br>10 | TTC<br>R 9     | TTC<br>R 8     | TTC<br>R 7     | TTC<br>R 6     | TTC<br>R 5     | TTC<br>R 4     | TTC<br>R 3     | TTC<br>R 2     | TTC<br>R 1                              | TTC<br>R 0                                   |
| Memo           | ory A                                       | ddres          | s Reg          | gister         |                |                |                | Oi             | ffset 1        | IC he          | x              | •              |                | : ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; | , <u>,                                  </u> |
| 31             | 30                                          | 29             | 28             | 27             | 26             | 25             | 24             | 23             | 22             | 21             | 20             | 19             | 18             | 17                                      | 16                                           |
| MAR<br>31      | MAR<br>30                                   | MAR<br>29      | MAR<br>28      | MAR<br>27      | MAR<br>26      | MAR<br>25      | MAR<br>24      | MAR<br>23      | MAR<br>22      | MAR<br>21      | MAR<br>20      | MAR<br>19      | MAR<br>18      | MAR<br>17                               | MAR<br>16                                    |
| 15             | 14                                          | 13             | 12             | 11             | 10             | 09             | 08             | 07             | 06             | 05             | 04             | 03             | 02             | 01                                      | 00                                           |
| MAR<br>15      | MAR<br>14                                   | MAR<br>13      | MAR<br>12      | MAR<br>11      | MAR<br>10      | MAR<br>9       | MAR<br>8       | MAR<br>7       | MAR<br>6       | MAR<br>5       | MAR<br>4       | MAR<br>3       | MAR<br>2       | 0                                       | 0                                            |

## Model~V124

## Demand FIFO Register

## Offset 28 hex

| 31 | 30        | 29        | 28        | 27       | 26       | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
|----|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| 0  | 0         | 0         | 0         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 15 | 14        | 13        | 12        | 11       | 10       | 09       | 08       | 07       | 06       | 05       | 04       | 03       | 02       | 01       | 00       |
| 0  | NDA<br>64 | NDA<br>32 | NDA<br>16 | NDA<br>8 | NDA<br>4 | NDA<br>2 | NDA<br>1 | DID<br>7 | DID<br>6 | DID<br>5 | DID<br>4 | DID<br>3 | DID<br>2 | DID<br>1 | DID<br>O |

## APPENDIX B - V124 Strap Locations



#### WARRANTY

KineticSystems Company, LLC warrants its standard hardware products to be free of defects in workmanship and materials for a period of one year from the date of shipment to the original end user. Software products manufactured by KineticSystems are warranted to conform to the Software Product Description (SPD) applicable at the time of purchase for a period of ninety days from the date of shipment to the original end user. Products purchased for resale by KineticSystems carry the original equipment manufacturer's warranty.

KineticSystems will, at its option, either repair or replace products that prove to be defective in materials or workmanship during the warranty period.

Transportation charges for shipping products to KineticSystems shall be prepaid by the purchaser, while charges for returning the repaired warranty product to the purchaser, if located in the United States, shall be paid by KineticSystems. Return shipment will be made by UPS, where available, unless the purchaser requests a premium method of shipment at their expense. The selected carrier shall not be construed to be the agent of KineticSystems, nor will KineticSystems assume any liability in connection with the services provided by the carrier.

The product warranty may vary outside the United States and does not include shipping, customs clearance, or any other charges. Consult your local authorized representative or reseller for more information regarding specific warranty coverage and shipping details.

# PRODUCT SPECIFICATIONS AND DESCRIPTIONS IN THIS DOCUMENT SUBJECT TO CHANGE WITHOUT NOTICE.

KINETICSYSTEMS SPECIFICALLY MAKES NO WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE OR ANY OTHER WARRANTY EITHER EXPRESSED OR IMPLIED, EXCEPT AS IS EXPRESSLY SET FORTH HEREIN. PRODUCT FAILURES CREATED BY UNAUTHORIZED MODIFICATIONS, PRODUCT MISUSE, OR IMPROPER INSTALLATION ARE NOT COVERED BY THIS WARRANTY.

THE WARRANTIES PROVIIDED HEREIN ARE THE PURCHASER'S SOLE AND EXCLUSIVE REMEDIES ON ANY CLAIM OF ANY KIND FOR ANY LOSS OR DAMAGE ARISING OUT OF, CONNECTED WITH, OR RESULTING FROM THE USE, PERFORMANCE OR BREACH THEREOF, OR FROM THE DESIGN, MANUFACTURE, SALE, DELIVERY, RESALE, OR REPAIR OR USE OF ANY PRODUCTS COVERED OR FURNISHED BY KINETICSYSTEMS INCLUDING BUT NOT LIMITED TO ANY CLAIM OF NEGLIGENCE OR OTHER TORTIOUS BREACH, SHALL BE THE REPAIR OR REPLACEMENT, FOB FACTORY, AS KINETICSYSTEMS MAY ELECT, OF THE PRODUCT OR PART THEREOF GIVING RISE TO SUCH CLAIM, EXCEPT THAT KINETICSYSTEMS' LIABILITY FOR SUCH REPAIR OR REPLACEMENT SHALL IN NO EVENT EXCEED THE CONTRACT PRICE ALLOCABLE TO THE PRODUCTS OR PART THEROF WHICH GIVES RISE TO THE CLAIM. IN NO EVENT SHALL KINETICSYSTEMS BE LIABLE FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOSS OF PROFITS.

Products will not be accepted for credit or exchange without the prior written approval of KineticSystems. If it is necessary to return a product for repair, replacement or exchange, a Return Authorization (RA) Number must first be obtained from the Repair Service Center prior to shipping the product to KineticSystems. The following steps should be taken before returning any product:

- 1. Contact KineticSystems and discuss the problem with a Technical Service Engineer.
- 2. Obtain a Return Authorization (RA) Number.
- 3. Initiate a purchase order for the estimated repair charge if the product is out of warranty.
- 4. Include a description of the problem and your technical contact person with the product.
- 5. Ship the product prepaid with the RA Number marked on the outside of the package to:

KineticSystems Company, LLC Repair Service Center 900 North State Street Lockport, IL 60441

Telephone: (815) 838-0005 Facsimile: (815) 838-4424 Email: tech-serv@kscorp.com