USER'S MANUAL

# INTELLIGENT M-MODULE CARRIER

MODEL VX406C

#### COPYRIGHT

C&H Technologies, Inc. (C&H) provides this manual "as is" without warranty of any kind, either expressed or implied, including but not limited to the implied warranties of merchantability and fitness for a particular purpose. C&H may make improvements and/or changes in the product(s) and/or program(s) described in this manual at any time and without notice.

This publication could contain technical inaccuracies or typographical errors. Changes are periodically made to the information herein; these changes will be incorporated in new editions of this publication.

#### Copyright © 2008 by C&H Technologies, Inc.

The information and/or drawings set forth in this document and all rights in and to inventions disclosed herein which might be granted thereon disclosing or employing the materials, methods, techniques, or apparatus described herein, are the exclusive property of C&H Technologies, Inc.

A Reader's Comment Form is provided at the back of this publication. If this form has been removed address comments to:

C&H Technologies, Inc. Technical Publications 445 Round Rock West Drive Austin, Texas 78681-5012

Or visit our web site for support information at:

http://www.chtech.com.

C&H may use or distribute any of the information you supply in any way that it believes appropriate without incurring any obligations.

#### **AMENDMENT NOTICE**

C&H Technologies, Inc. makes every attempt to provide up-to-date manuals with the associated equipment. Occasionally, changes are made to the equipment wherein it is necessary to provide amendments to the manual. If any amendments are provided for this manual they are printed on colored paper and will be provided with the module and manual. Manual updates may also be found on out web site at www.chtech.com.

#### NOTE

The contents of any amendment may affect operation, maintenance, or calibration of the equipment.

### **INTRODUCTION**

This manual describes the operation and use of the C&H Model VX406C Intelligent M-Module Carrier Module (Part Number 11028550). This VXI module is one of a number of test and data acquisition/control modules in the VME and VXI format provided by C&H.

Contained within this manual are the physical and electrical specifications, installation and startup procedures, functional description, and configuration guidelines to adequately use the product.

The part numbers covered by this manual are:

Part NumberDescription11028550-0001VX406C Intelligent M-Module Carrier

# TABLE OF CONTENTS

| 1.0 GEN  | ERAL DES | SCRIPTION                        | 1  |
|----------|----------|----------------------------------|----|
| 1.1      | PURPOSI  | E OF EQUIPMENT                   | 1  |
| 1.2      | SPECIFIC | CATIONS OF EQUIPMENT             | 1  |
|          | 1.2.1    | Key Features                     |    |
|          | 1.2.2    | Specifications                   |    |
|          | 1.2.3    | Electrical                       | 2  |
|          |          | 1.2.3.1 +5V Supply               | 2  |
|          |          | 1.2.3.2± 12V Supply              | 3  |
|          |          | 1.2.3.3 M-Module Power           |    |
|          |          | 1.2.3.4 PMC Power                | 3  |
|          |          | 1.2.3.5 +24V Auxiliary Power     | 3  |
|          |          | 1.2.3.6 +5V Auxiliary Power      |    |
|          | 1.2.4    | Mechanical                       |    |
|          | 1.2.5    | Environmental                    | 4  |
|          | 1.2.6    | Bus Compliance                   | 4  |
| 2.0 INST | ALLATIO  | N                                |    |
| 2.1      | UNPACK   | ING AND INSPECTION               | 5  |
| 2.2      | HANDLI   | NG PRECAUTIONS                   | 5  |
| 2.3      | INSTALL  | ATION OF M-MODULES               | 5  |
| 2.4      | INSTALL  | ATION OF PMC MODULES             | 7  |
| 2.5      | INSTALL  | ATION OF VX406C CARRIER          | 7  |
| 2.6      |          | ATION FOR RESHIPMENT             |    |
| 3.0 FUN  | CTIONAL  | OVERVIEW                         | 9  |
| 3.1      | GENERA   | L                                | 9  |
| 3.2      | HARDWA   | ARE OVERVIEW                     | 9  |
|          | 3.2.1    | M-Modules                        | 10 |
|          | 3.2.2    | Shared Memory                    | 10 |
|          | 3.2.3    | PowerPC and Peripherals          | 11 |
|          | 3.2.4    | VXI Interface Logic              | 11 |
|          | 3.2.5    | PMC Slot                         | 11 |
|          | 3.2.6    | External Drivers                 | 11 |
|          | 3.2.7    | External Input                   | 11 |
|          | 3.2.8    | JTAG/COP Interface               | 12 |
| 3.3      | SOFTWA   | RE OVERVIEW                      | 12 |
| 3.4      | HARDWA   | ARE CONFIGURATION                | 13 |
|          | 3.4.1    | Logical Address Switch           | 14 |
|          | 3.4.2    | Module Configuration Switch      | 14 |
|          | 3.4.3    | PowerPC Configuration Switches   | 16 |
|          | 3.4.4    | VIO Configuration Jumper         | 17 |
| 3.5      | CONNEC   | TORS                             | 18 |
|          | 3.5.1    | External Power Connectors        | 18 |
|          | 3.5.2    | External Relay Drivers Connector | 18 |
|          | 3.5.3    | External Input Connector         | 18 |
|          | 3.5.4    | JTAG/COP Connector               | 18 |

|     |     | 3.5.5         | Serial Co | omm Connector                    | 18 |
|-----|-----|---------------|-----------|----------------------------------|----|
|     |     | 3.5.6         | PMC Co    | nnectors                         | 19 |
|     |     | 3.5.7         | PMC I/O   | Connector                        | 19 |
|     |     | 3.5.8         | VXI Con   | inectors                         | 19 |
|     |     | 3.5.9         | VXI Loc   | al Bus Connector                 | 19 |
|     |     | 3.5.10        |           | le Connectors                    |    |
| 4.0 | SYS |               |           | RE                               |    |
|     | 4.1 |               |           |                                  |    |
|     | 4.2 |               |           | CHITECTURE                       |    |
|     | 1.2 | 4.2.1         |           | C Memory Map                     |    |
|     |     | 4.2.2         |           |                                  |    |
|     |     | 4.2.3         |           | M                                |    |
|     |     | 4.2.4         |           | emory                            |    |
|     |     | 4.2.5         |           | Architecture                     |    |
|     |     | 4.2.3         |           | PCIbus Enumeration               |    |
|     |     |               |           |                                  |    |
|     |     |               |           | IDSEL Signal Routing             |    |
|     |     |               |           | PCI Interrupts                   |    |
|     |     |               |           | Shared Memory Device             |    |
|     |     |               |           | PCI to M-Module Bridge           |    |
|     |     |               |           | PMC Device                       |    |
|     |     | 4.2.6         | 00        | ~ .                              |    |
|     |     | 4.2.7         | -         | ns Registers                     |    |
|     |     | 4.2.8         |           | Drivers                          |    |
|     |     | 4.2.9         |           | TTL Inputs                       |    |
|     |     | 4.2.10        | Watchdo   | g Timer                          | 30 |
|     |     |               |           | OP Interface                     |    |
|     | 4.3 | HOST-SII      | DE ARCH   | ITECTURE                         | 30 |
|     |     | 4.3.1         | VXI Mer   | nory Map                         | 31 |
|     |     | 4.3.2         | Data Bus  | Width                            | 33 |
|     |     | 4.3.3         | PCI Bus   | Mastering and Direct Access      | 33 |
|     | 4.4 | SHARED        | RESOUR    | CES AND DEVICE COMMUNICATIONS    | 33 |
|     |     | 4.4.1         | Operation | ns Registers                     | 34 |
|     |     |               | 4.4.1.1   | VXI Configuration Registers      | 35 |
|     |     |               |           | VXI Communication Registers      |    |
|     |     |               |           | VX406C Carrier Control Registers |    |
|     |     | 4.4.2         |           | rd Serial Protocol               |    |
|     |     | 4.4.3         | General I | Purpose Shared Memory            | 44 |
|     |     |               |           | Shared Memory Arbitration        |    |
|     |     |               |           | DMA/Burst                        |    |
|     |     | 4.4.4         |           | age Unit                         |    |
|     |     | 4.4.5         | -         | Purpose FIFOs                    |    |
|     | 4.5 |               |           | HITECTURE                        |    |
|     | 4.6 |               |           | DFTWARE                          |    |
|     | 4.7 |               |           | EM FIRMWARE                      |    |
|     | 1.7 | 4.7.1         |           | le                               |    |
|     |     | <b>T</b> ./.1 |           | PowerPC Initialization           |    |
|     |     |               | 4./.1.1   |                                  |    |

|     |      |           | 4.7.1.2               | Launching the Operating System        |     |
|-----|------|-----------|-----------------------|---------------------------------------|-----|
|     |      |           | 4.7.1.3               | Firmware Download Utility             | 50  |
|     |      | 4.7.2     | ICOS                  |                                       | 50  |
|     |      | 4.7.3     | 3 <sup>rd</sup> Party | RTOS Support                          | 50  |
|     |      | 4.7.4     | User Ap               | plication                             |     |
| 5.0 | PRO  | GRAMMIN   | IG INSTF              | RUCTIONS                              | 53  |
|     | 5.1  | GENERA    | L                     |                                       | 53  |
|     | 5.2  | FLASH P   | ROGRAM                | /MING                                 | 53  |
|     | 5.3  | PCI ACC   | ESSES                 |                                       | 54  |
|     | 5.4  |           |                       | ESS                                   |     |
|     | 5.5  | FIRMWA    | RE UPD                | ATE MODE                              | 55  |
|     |      | 5.5.1     | Firmwar               | e Update Mode Protocol                | 55  |
|     |      |           | 5.5.1.1               | Flash Program Command                 | 58  |
|     |      |           | 5.5.1.2               | Calculating the CRC                   | 58  |
|     | 5.6  | INTERRU   | JPTS                  |                                       | 59  |
|     |      | 5.6.1     | PCI Inte              | rrupts                                | 59  |
|     |      | 5.6.2     | M-Modu                | Ile Interrupts                        | 60  |
|     |      | 5.6.3     | VXI Inte              | errupts                               | 60  |
|     | 5.7  | CONFIGU   | <b>JRING</b> T        | RIGGERS                               | 61  |
|     | 5.8  | HOST-SI   | DE PCI B              | US MASTERING AND DIRECT ACCESS        | 61  |
|     |      |           | 5.8.1.1               | PCI Configuration Accesses            |     |
|     |      |           | 5.8.1.2               | Byte Enables in a Direct Access Cycle | 63  |
|     |      |           |                       |                                       |     |
|     |      |           |                       | S                                     |     |
| API | PEND | IX B CONF | FIGURAT               | ION REGISTERS                         | B-1 |

# LIST OF FIGURES

| Figure 1. M-Module Installation                            | 6     |
|------------------------------------------------------------|-------|
| Figure 2. Front Panel and Top View (Top Shield Not Shown)  | 6     |
| Figure 3. PMC Module Installation                          | 7     |
| Figure 4. System Hardware Architecture                     | 10    |
| Figure 5. Hardware Layout                                  |       |
| Figure 6. Logical Address Configuration Switch             | 14    |
| Figure 7. Module Configuration Switch                      | 14    |
| Figure 8. PowerPC Configuration Switches                   | 16    |
| Figure 9. VIO Configuration Jumper                         | 18    |
| Figure 10. Device-Side Architecture                        | 21    |
| Figure 11. Address Map Overview                            | 22    |
| Figure 12. Detailed PowerPC Address Map                    | 23    |
| Figure 13. Shared Memory Organization                      | 26    |
| Figure 14. PCI to M-Module Address Map                     | 27    |
| Figure 15. Trigger Architecture                            | 29    |
| Figure 16. External Driver Control Register                | 30    |
| Figure 17. Host-Side Architecture                          | 31    |
| Figure 18. VXI Memory Organization                         | 32    |
| Figure 19. Shared Resources                                | 34    |
| Figure 20. VXI Configuration Registers                     | 36    |
| Figure 21. VXI Communications Registers                    |       |
| Figure 22. VX406C Control Registers                        | 41    |
| Figure 23. Shared Memory Arbitration Utility Flag Register | 45    |
| Figure 24. General Purpose FIFO Registers                  | 47    |
| Figure 25. System Software Architecture                    |       |
| Figure 26. M-Module Internal Bridge Registers              | 55    |
| Figure 27. Shared memory banks for firmware update         | 56    |
| Figure 28. Firmware Update Protocol                        | 57    |
| Figure 29. Flash Program Command                           |       |
| Figure 30. CRC Calculation - Example Source Code           |       |
| Figure 31. Direct Access Control Register                  | 62    |
|                                                            |       |
| Figure A-1. M-Module Connector Configuration               | . A-1 |
| Figure A-2. VXI P1 Pin Configuration                       |       |
| Figure A-3. VXI P2 Pin Configuration                       |       |
| Figure A-4. PMC Pin Configuration                          |       |
| Figure A-5. PMC Pin Configuration (continued)              |       |
| Figure A-6. External Driver Outputs                        |       |
| Figure A-7. External Inputs                                |       |
| Figure A-8. Serial Comm                                    |       |
| Figure A-9. JTAG/COP Header                                |       |
| Figure A-10. External Power Connectors                     |       |
| Figure A-11. PMC I/O Connector                             | A-7   |

# LIST OF TABLES

| Table I. PowerPC Configuration Signals     |     |
|--------------------------------------------|-----|
| Table II. IDSEL Signal Routing             |     |
| Table III. PCI Interrupt Signal Routing    |     |
| Table IV. Operations Registers Map         |     |
|                                            |     |
| Table B-1. PowerPC Configuration Registers | B-1 |

C&H Technologies, Inc. <> 445 Round Rock West Drive <> Round Rock, TX 78681 <> www.chtech.com

# **1.0 GENERAL DESCRIPTION**

The VX406C is an intelligent VXI carrier module that provides an electrical and mechanical interface for up to four ANSI Standard M-Modules and one PMC module. It features an on-board 32-bit PowerPC<sup>®</sup> processor that can perform command translation, data analysis, and many other data processing or process control functions. For a complete list of M-Modules compatible with the VX406C, visit the SUPPORT $\rightarrow$ M-MODULE SUPPORT DIRECTORY on C&H's website (www.chtech.com).

## 1.1 PURPOSE OF EQUIPMENT

The VX406C was designed for Automated Test Equipment (ATE) applications requiring onboard instrument intelligence or data processing. Some of the more common applications include: legacy instrument emulation, data intensive signal acquisition, high speed signal analysis, and control processing.

## **1.2 SPECIFICATIONS OF EQUIPMENT**

- 1.2.1 Key Features
  - 300MHz Freescale MPC8245 Integrated Processor
  - Supports up to four ANSI/VITA 12-1996 compliant single-wide M-Modules, or any valid combination of 2, 3, or 4-wide modules.
  - Supports extended M-Module functions (MA) such as extended 24-bit addressing, 32bit data bus, and triggers
  - Supports one 33 MHz, 5V or 3.3V PMC device
  - 128 megabytes SDRAM
  - I6 kilobytes dual-ported SRAM accessible by both the processor and VXI
  - 8 megabytes flash memory
  - VXI A24/A32 access to shared memory
  - VXI block transfers to/from shared memory
  - DMA transfers between PowerPC, M-Modules, PMC device, and shared memory
  - Direct access to M-Modules and PMC module from VXI
  - Intelligent Carrier Operating System (ICOS) supports application firmware development

## 1.2.2 Specifications

#### **Processor:**

- Freescale 300MHZ MPC8245
- MPC603e core
- 16KB/16KB L1 Integrated Cache

#### **Local PCI Bus:**

• 33MHZ 32-bit

#### Main Memory:

- 128MB SDRAM
- 8MB Flash, VXI programmable
- 32KB Boot ROM, socketed

#### Shared Memory:

- 16 KB Dual-ported SRAM
- Four 32 deep 32-bit FIFO's
- DMA/Burst support
- Internal arbitration
- Fully accessible by both VXI and PowerPC

#### **M-Module Interface:**

- Up to four ANSI Standard M-Modules
- ANSI/VITA Standard 12-1996
- M-Module triggers map to VXI TTL triggers
- M-Module interrupt to PowerPC

#### **PMC Interface:**

- Support for one PMC module
- IEEE P1386.1 32-bit compliant
- 33MHz 32-bit
- PMC I/O connected to 64-pin header

#### **External Relay Control:**

- Darlington relay driver, 7-channels, 50V, 350ma
- Use internal +5V supply or external power

#### **External Input:**

- Four TTL inputs
- Allows direct external control of application firmware

#### **Interrupts:**

- M-Module to PowerPC interrupt support
- PowerPC to VXI interrupt level 1-7 (programmable)
- VXI Host to PowerPC interrupt support

#### **Temperature:**

| Operating: | 0°C to 50°C   |
|------------|---------------|
| Storage:   | -40°C to 70°C |

#### **Direct Access:**

- Direct VXI access of M-Modules and PMC
- Up to 8K of local PCI address space can be directly mapped to VXI A24 or A32 space

#### **Debugging Interface:**

- Common On-Chip Processor (COP)/JTAG
- Standard COP header
- Third-party development tools supported

#### C&H Intelligent Carrier Operating System (ICOS):

- Boot-up and initialization
- VXI word serial protocol support
- Firmware download to Flash memory via VXI
- Application Programming Interface

#### **3<sup>rd</sup> Party RTOS Support:**

Architecture supports common real-time operating systems, such as VxWorks, OS-9, Linux, and others.

## 1.2.3 Electrical

The VX406C requires the +5V and  $\pm 12V$  from the VXI backplane. The +5V supply drives a DC to DC converter that supplies +3.3V power to internal on-board devices and to the PMC position. The  $\pm 12V$  power is only used by installed M-Module or PMC modules.

## 1.2.3.1 +5V Supply

The VXI backplane can provide a total of 8.4 amps (1.2A per pin) of +5 volts, of which, the VX406C uses approximately 1.8 amps (9W) for internal purposes. The remaining 6.6 amps (33W) is available to the M-Modules, PMC, and auxiliary power connector through a combination of the +5V and +3.3V supplies. M-Modules do not use +3.3V power, so any power not used by the PMC is available to the M-Modules via the +5V supply. The +5V supply has a replaceable inline 10A fast blow fuse to protect the internal traces of the VX406C.

## 1.2.3.2 ±12V Supply

The  $\pm 12$  volt supplies are not used internally by the carrier; however, may be required by an installed M-Module or PMC module. Each VXI  $\pm 12$  volt supply has an inline replaceable 3A slow-blow fuse to protect the internal traces of the VX406C.

## 1.2.3.3 M-Module Power

Each M-Module position is provided individually fused and filtered +5V, +12V, and -12V power. The +5V supply has an inline 3A power-off resettable fuse and the  $\pm 12V$  supplies have inline 1.25A power-off resettable fuses to protect the internal traces of the VX406C. Note that the M-Module specification limits +5V power consumption to 1A and  $\pm 12V$  power consumption to 200mA per M-Module position. The VX406C allows that specification to be exceeded; however, total power consumption must remain within the available power limits discussed in Section 1.2.3.1. Refer to the documentation provided with an installed M-Module to determine its power requirements.

## 1.2.3.4 PMC Power

The PMC position is provided individually fused and filtered +5V, +3.3V, +12V, and -12V power. The +5V supply has an inline 3A power-off resettable fuse and the  $\pm 12V$  supplies have inline 1.25A power-off resettable fuses to protect the internal traces of the VX406C. +3.3V power is filtered and short-circuit protected by the on-board 10A +3.3V DCDC converter. The DCDC converter has an efficiency of around 90%, which should be taken into account when calculating power consumption. Total power consumption must remain within the available power limits discussed in Section 1.2.3.1. Refer to the documentation provided with an installed PMC module to determine its power requirements.

## 1.2.3.5 +24V Auxiliary Power

An auxiliary  $\pm 24V$  power connecter is available for special purpose use. The  $\pm 24V$  supply is not used by the carrier, or the M-Modules and PMC positions. The carrier can supply a maximum of 1 amp (24W) each to the  $\pm 24V$  and the  $\pm 24V$  pins on the connector. Each 24 volt supply has an inline 1A power-off resettable fuse to protect the internal traces of the VX406C.

## 1.2.3.6 +5V Auxiliary Power

An auxiliary +5V power connecter is available for special purpose use. A maximum of 2.5 amps (12.5W) can be provided by the carrier. The connection has an inline 2.5A power-off resettable fuse to protect the internal traces of the VX406C. Any power drawn from this connector reduces the total power available to the M-Module and PMC positions.

## 1.2.4 Mechanical

The mechanical dimensions of the VX406C are in conformance with the VXI bus specification for the height and width of Size-C modules. The nominal dimensions are 233.35 mm (9.187 in) high x 340.0 mm (13.386 in) deep. The module is designed for a standard mainframe with 30.48 mm (1.2 in) width between slots.

## 1.2.5 Environmental

The environmental specifications of the module are:

| Operating Temperature: | $0^{\circ}$ C to $+50^{\circ}$ C |
|------------------------|----------------------------------|
| Storage Temperature:   | -40°C to +70°C                   |
| Humidity:              | <95% without condensation        |

1.2.6 Bus Compliance

The module complies with the VXIbus Specification Revision 1.4 for C-Size VXI modules and with VMEbus Specification ANSI/IEEE STD 1014-1987, IEC 821.

| Manufacturer ID:     | $FC1_{16}$ (can also be set by PowerPC) |
|----------------------|-----------------------------------------|
| Model Code:          | $FDF_{16}$ (can also be set by PowerPC) |
| VXI Access Type:     | Register Based or Message Based         |
| VXI Addressing:      | A16/A24/A32                             |
| VXI Data Transfer:   | D16/D32                                 |
| VXI Sysfail:         | supported                               |
| VXI Interrupts:      | ROAK, programmable levels               |
| VXI Local Bus:       | Available                               |
| TTL Triggers         | SYNC trigger protocol supported         |
| Memory Requirements: | 32 Kilobytes                            |

The module's on-board M-Module bus complies with ANSI/VITA 12-1996 and the following features are supported:

| M-Module Bus Data Width: | D08, D16, D32                 |
|--------------------------|-------------------------------|
| M-Module Address Modes:  | A08                           |
| M-Module Triggers:       | TRIGA, TRIGB (input & output) |
| M-Module Interrupts:     | INTA, INTB, INTC              |
| M-Module Identification: | supported                     |

The modules on-board PMC bus complies with the PMC Specification IEEE P1386.1 for 32-bit PMC modules.

| PMC Bus Data Width: | 32-bit                         |
|---------------------|--------------------------------|
| PMC Bus Speed       | 33 MHz                         |
| PMC Bus Voltage     | 5V or 3.3V (jumper selectable) |
| PMC Rear I/O:       | 64-pin Header                  |

## 2.0 INSTALLATION

## 2.1 UNPACKING AND INSPECTION

In most cases the VX406C is individually sealed and packaged for shipment. Verify that there has been no damage to the shipping container. If damage exists then the container should be retained as it will provide evidence of carrier caused problems. Such problems should be reported to the carrier immediately as well as to C&H. If there is no damage to the shipping container, carefully remove the module from its box and anti static bag and inspect for any signs of physical damage. If damage exists, report immediately to C&H.

# 2.2 HANDLING PRECAUTIONS

The VX406C contains components that are sensitive to electrostatic discharge. When handling the module for any reason, do so at a static-controlled workstation, whenever possible. At a minimum, avoid work areas that are potential static sources, such as carpeted areas. Avoid unnecessary contact with the components on the module.

## 2.3 INSTALLATION OF M-MODULES

M-Modules must be installed before the VX406C is installed into the VXI system. To install M-Modules, remove the VX406C's top shield and front panel covers as needed. *There is never a need to remove the VX406C's bottom shield*. Install an M-Module by firmly pressing the connector on the M-Module together with the connector on the carrier as shown in Figure 1. Secure the M-Module through the holes on the bottom shield using screws provided with the M-Module.

CAUTION: The VX406C supports M-Modules that use either two or three row interface connectors. Extra caution must be taken for M-Modules that use two row connectors to ensure they are correctly positioned to use rows A and B on the carrier. When using M-Modules with two row connectors, row C on the VX406C is left unconnected.

CAUTION: M-Module connectors are NOT keyed. Use extra caution to avoid misalignment. Applying power to a misaligned module can damage the M-Module and carrier.



Figure 1. M-Module Installation

There are four possible mounting locations on the carrier: A, B, C, and D. M-Modules may be installed into any of the four locations. The mounting locations are illustrated in Figure 2.



Figure 2. Front Panel and Top View (Top Shield Not Shown)

#### 2.4 INSTALLATION OF PMC MODULES

A PMC module must be installed into the carrier before the carrier is installed into the host system. To install a PMC module, remove the VX406C's top shield. *There is never a need to remove the VX406C's bottom shield*. Firmly press the connector on the PMC module together with the connector on the carrier as shown in Figure 3. Secure the module through the holes in the bottom shield using the screws provided with the PMC module.



Figure 3. PMC Module Installation

### 2.5 INSTALLATION OF VX406C CARRIER

If necessary, remove the top shield from the VX406C and configure the switches and jumpers. Set the module's logical address and addressing mode as described in section 3.4. Replace the shield and insert the carrier into the appropriate slot according to the desired priority and apply power. If no obvious problems exist, proceed to communicate with the module as outlined throughout the rest of this manual.

CAUTION: Read the entire User's Manual before proceeding with the installation and application of power.

#### 2.6 PREPARATION FOR RESHIPMENT

If the module is to be shipped separately it should be enclosed in a suitable water and vapor proof anti static bag. Heat seal or tape the bag to insure a moisture-proof closure. When sealing the bag, keep trapped air volume to a minimum.

The shipping container should be a rigid box of sufficient size and strength to protect the equipment from damage. If the module was received separately from a C&H system, then the original module shipping container and packing material may be re-used if it is still in good condition.

C&H Technologies, Inc. <> 445 Round Rock West Drive <> Round Rock, TX 78681 <> www.chtech.com

#### **3.0 FUNCTIONAL OVERVIEW**

#### **3.1 GENERAL**

The VX406C provides an intelligent interface between the VXI bus and up to four M-Modules and one PMC module. It features an embedded processor system powered by a MPC8245 PowerPC integrated processor. An on-board PCI bus provides an interface to the four M-Modules, the PMC module position, and 16 kilobytes of shared memory. VXI interface logic provides an interface between the VXI bus and the PowerPC via the shared memory and the PowerPC's local bus.

C&H Intelligent Carrier Operating System (ICOS) is provided to assist an embedded user application in performing necessary tasks or to allow the carrier to function normally when no user application is used. ICOS utilities include: boot-up and initialization routines, system configuration routines, VXI communications routines, an application programming interface (API), and various hardware interface routines to provide a basic interface to the carrier and installed modules and to assist application development. Refer to the Intelligent Carrier Operating System User's Manual (C&H Document No. 11028578) for details on ICOS.

For more advanced application development, a Linux distribution and Linux embedded development kit is also available from C&H for the VX406C. The Linux distribution includes all the items needed to create an embedded Linux system including a bootloader, patched kernel, root filesystem and many standard utilities. In addition, the processor architecture supports various other 3<sup>rd</sup> party commercially available real time operating systems.

#### 3.2 HARDWARE OVERVIEW

The VX406C is powered by a highly integrated MPC8245 microprocessor with a PowerPC 603e core, a built-in Peripheral Component Interconnect (PCI) interface, and an advanced memory controller. The processor along with flash memory, ROM memory, and SDRAM form a complete embedded processing system with all the peripherals necessary for flexible application development.

Dual-ported shared memory and VXI interface logic allow for seamless communication between the VXI host and the PowerPC. Interrupts and handshaking logic is also provided to assist communications between the host and PowerPC.

A single PMC positions and four M-Module positions residing on the on-board PCI bus allow a variety of instruments and peripherals to be added to the system. Both the VXI host and the PowerPC can communicate with and control the modules.

Finally, relay driver logic and external TTL input logic allow special control hardware to be easily added to the overall integrated system. Figure 4 illustrates the system hardware architecture.



Figure 4. System Hardware Architecture

### 3.2.1 M-Modules

The M-Modules provide the measurement and control functionality for the given application. The carrier can support up to four single-wide M-Modules or any valid combination of 2, 3, or 4-wide modules. The modules interface to the on-board PCI bus through a PCI to M-Module Interface Bridge. Both the PowerPC application and the VXI host can communicate with and control the modules. A variety of M-Modules are commercially available from numerous manufacturers. For a complete list of M-Modules compatible with the VX406C, visit the SUPPORT $\rightarrow$ M-MODULE SUPPORT DIRECTORY on C&H's website (www.chtech.com).

## 3.2.2 Shared Memory

The 16 kilobyte shared memory device acts as a buffer between the VXI bus and the on-board PCI bus. The device provides 16 kilobytes of dual-port SRAM and various other communications utilities such as general purpose FIFO's. It connects to the VXI bus through a local bus interface controlled by the VXI interface logic and to the PowerPC through the PCI bus. The device performs on-chip memory arbitration allowing the 16 kilobytes of memory to be accessed at the same time from both the VXI bus and the PowerPC. It also contains an embedded PCI bus controller allowing the VXI bus to directly access the on-board PCI bus and thus directly access the M-Modules and the PMC module.

## 3.2.3 PowerPC and Peripherals

The PowerPC architecture was designed as a standard embedded processor system. It consists of a MPC8245 PowerPC, a boot ROM device, 128 megabytes of P133 SDRAM, and a flash memory device. This architecture allows the developer to select from standard off-the-shelf development tools and real-time operating systems for application development.

The PowerPC acts as the PCI bus master and can access the M-Modules, the PMC module, and the shared memory device. It also can access the VXI interface logic to perform handshaking between itself and the VXI bus.

# 3.2.4 VXI Interface Logic

The VXI interface logic acts as a transparent interface between the VXI bus and the shared memory device. It translates VXI bus accesses into shared memory local bus accesses by managing all local bus address and control lines. It maps all of the shared memory device's address space to VXI A24/A32 space.

The VXI interface also handles handshaking between the PowerPC and the VXI bus. It includes a set of registers that are mapped to VXI A16 space and are accessible by the PowerPC to handle host to device communications and handshaking.

Finally the interface logic provides VXI bus trigger and interrupt capabilities. The carrier has extensive mapping capabilities between the M-Module trigger lines and the VXI bus trigger lines controllable by the VXI host. In addition, VXI interrupts can be generated by the PowerPC application on any of the 8 VXI interrupt levels.

# 3.2.5 PMC Slot

The PMC slot on the PCI bus can be used to add additional functionality to the application. For example, a mass storage device could be added for on-board data collection by installing a PMC disk drive controller. It is also common to host a PMC Ethernet controller for embedded development pruposes. The PMC position is accessible by both the PowerPC and the VXI host.

# 3.2.6 External Drivers

The PowerPC can control a Darlington sink driver device residing on its local memory bus. The device's outputs are available at a 16 pin header for external use. The device is intended to drive external relays, display LED's, or other high current devices.

# 3.2.7 External Input

Four external TTL input lines can be read by the PowerPC. The signals are available at an external connector on the carrier. These lines allow direct external control of the application software.

# 3.2.8 JTAG/COP Interface

The JTAG interface to the PowerPC provides a debug and development interface supported by many standard off-the-shelf developments tools. The interface is used by development tools to communicate with the processor. It provides the developer with the ability to view system registers, view memory, set breakpoints, and use other standard debugging practices.

# 3.3 SOFTWARE OVERVIEW

The embedded software on the carrier as well as the host software are very application dependant and thus, must be developed specifically to suit the needs of the particular application. However, firmware is provided as part of the Intelligent Carrier Operating System (ICOS) to assist application development and to provide basic functionality when no user application exists. In addition a Linux distribution is available from C&H.

The Intelligent Carrier Operating System (ICOS) is a single-threaded OS kernel specifically designed for use on the VX406C and C&H Technologies' other intelligent carriers. When no user application exists, ICOS provides basic functionality allowing the user to communicate with the carrier and the M-Modules and PMC module. A limited set of VXI message based commands are available as well as the ability to access all defined registers and the shared memory. In this capacity, the carrier can operate as a fully functional instrument without the existence of a user application.

If a user application is to be provided, ICOS assists the developer in performing several tasks that require advanced knowledge of the carrier architecture and the devices that make up that architecture. For example a system routine is provided to program the flash memory so that the developer does not need to refer to the flash device's data sheet to learn the programming protocol. Also, ICOS automatically handles the communications required for VXI message passing so that the application can concentrate on performing high level tasks and not on the details of the VXI word serial protocol. ICOS is completely independent and fully interrupt and exception driven so that it only takes up a very small amount of processor resources and so the user application can be independently compiled and linked without knowledge of ICOS memory organization.

An ICOS User's Manual (C&H Document No. 11028578) is available from C&H Technologies detailing the operating system environment.

The Linux distribution available from C&H includes the DAS U-boot bootloader, a customized Linux kernel and a custom root filesystem that contains many familiar Linux utilities. Application development is performed using common open source development and debug tools and the C&H Linux Embedded Development includes the necessary hardware and software to ease application development. Contact C&H Technologies for details on the available Linux distribution and the Linux Embedded Development Kit.

The VX406C architecture also supports various 3<sup>rd</sup> party Real-Time Operating Systems (RTOS). Full support of 3<sup>rd</sup> party operating systems will depend on the availability of various VX406C specific software components for the RTOS. Contact the RTOS vendor and C&H Technologies for information on support for a particular RTOS.

## 3.4 HARDWARE CONFIGURATION

There are several switch and jumper selectable settings that configure the VX406C for operation. Configuration options include: the VXI logical address, PowerPC options, programming modes, and operational voltages. Figure 5 shows the layout of all the switches and jumpers on the VX406C.



Figure 5. Hardware Layout

## 3.4.1 Logical Address Switch

The logical address switch determines the logical address for the VX406C. The switch forms a binary weighted decimal value that sets the logical address of the module. The OFF position for each switch represents a binary one in that bit position. For example, the switch settings shown in Figure 6 would result in a logical address of 36.



Figure 6. Logical Address Configuration Switch

# 3.4.2 Module Configuration Switch

The module configuration switch is used to set some of the miscellaneous options on the VX406C. Figure 7 shows the options that are configurable with this switch.



Figure 7. Module Configuration Switch

<u>PMC JTAG Bypass Switch (Manufacturing Use Only)</u>: This switch will bypass the PMC device's JTAG interface by automatically daisy chaining the JTAG input to the JTAG output at the PMC connector. The JTAG bus is daisy chained between the PMC connector and other devices on the carrier. It is necessary to bypass the PMC position when using the JTAG interface to program the other devices during manufacturing. The user should never have to bypass the PMC JTAG interface and should therefore leave this switch in the OFF position. *The PowerPC's JTAG/COP interface is an independent JTAG interface and is not affected by this switch*.

<u>Flash Write Enable Switch</u>: This switch will enable or disable the ability for software to program flash memory. Setting this switch to ON will enable the flash programming capability. When the switch is OFF the carrier will not allow the PowerPC to program the flash device.

<u>Watchdog Enable Switch</u>: The Watchdog Enable Switch enables/disables the watchdog timer at the hardware level. The watchdog timer may also be disabled by software by writing to the Watchdog Timer Control Register (Offset 0x26). *Disabling the watchdog timer at the hardware level is required to utilize a JTAG debugger on the processor.* 

<u>Software Configuration Switch</u>: The software configuration switch is available for use by the user application and system firmware. This switch has no effect on the hardware operation of the VX406C. The value of the switch is copied to the operations registers so that the software can read the value and define the switch's function. Setting the switch to ON results in the corresponding bit of the operations register being set to a binary '0'. OFF corresponds to a binary '1'.

ICOS or other system software may use this switch for a specific purpose. Refer to the ICOS User's Manual or the manual of your system software for details.

<u>Firmware Update Mode Switch</u>: This switch determines whether the VX406C boots normally or into a mode where the system firmware can be updated. If this switch is set to OFF at power-up, the carrier will go into the firmware update mode and wait for firmware to be downloaded via the VXI bus. If this switch is ON at power-up, the carrier will initialize normally and launch the system firmware or operating system.

<u>A32 Switch</u>: This switch selects whether the VX406C performs VXI A24 or A32 address decoding. This address space is used to access the shared memory device. If this switch is set to ON, the carrier requests memory in the systems A32 address space, otherwise A24 address space is requested.

# 3.4.3 PowerPC Configuration Switches

The PowerPC configuration switches determine the value of various signals during reset. Each signal connected to these switches is a reset configuration signal for the PowerPC. The values of these signals at reset, determine the configuration of the processor. Figure 8 shows all available PowerPC reset configuration signals. Table I briefly describes each option and all possible settings. For details on reset configuration refer to the MPC8245 User's Manual.

WARNING: The PowerPC configuration switches are preset during manufacturing to the optimal settings for the VX406C. Modifying these settings is rarely necessary and in some cases may cause the VX406C to not function correctly.



Figure 8. PowerPC Configuration Switches

| Signal          | Description                                                                                                                                                | Settings                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MDL0,<br>FOE-   | Selects the data bus width for ROM bank 0 and SDRAM                                                                                                        | (MDL0 = 0, FOE_ = 0) = ROM 32-bit, SDRAM 32-bit<br>(MDL0 = 0, FOE_ = 1) = ROM 8-bit, SDRAM 32-bit <sup>1,2</sup><br>(MDL0 = 1, FOE_ = 0) = ROM 64-bit, SDRAM 64-bit<br>(MDL0 = 1, FOE_ = 1) = ROM 8-bit, SDRAM 64-bit                                                                                                                                                                  |
| MCP-,<br>CKE    | Sets the PCI output hold delay value<br>(in nanoseconds) relative to<br>PCI_SYNC_IN. Refer to the<br>MPC8245 documentation for details<br>on each setting. | $(MCP_{-} = 0, CKE = 0)$ $(MCP_{-} = 0, CKE = 1)$ $(MCP_{-} = 0, CKE = 1)$ $(MCP_{-} = 1, CKE = 0)$ $(MCP_{-} = 1, CKE = 1)$ |
| PMAA0,<br>PMAA1 | Memory signal driver capabilities.                                                                                                                         | (PMAA0 = 0, PMAA1 = 0) = reserved<br>(PMAA0 = 0, PMAA1 = 1) = 40 $\Omega$ drive capability<br>(PMAA0 = 1, PMAA1 = 0) = 20 $\Omega$ drive capability<br>(PMAA0 = 1, PMAA1 = 1) = 6 $\Omega$ drive capability <sup>1,3</sup>                                                                                                                                                             |
| PMAA2           | PCI and EPIC controller driver capabilities                                                                                                                | <b>0</b> = 40 $\Omega$ drive capability <sup>1,2,3</sup><br>1 = 20 $\Omega$ drive capability (except for IRQ2/S_RST and<br>IRQ3/S_FRAME- signals which have 6 $\Omega$ drive<br>capability)                                                                                                                                                                                            |
| QACK-           | Clock Flip Disable                                                                                                                                         | 0 = Clock flip enabled<br>1 = No clock flip <sup>1,2</sup>                                                                                                                                                                                                                                                                                                                             |
| GNT4-           | Debug Address Disable                                                                                                                                      | 0 = Debug address enabled<br><b>1 = Debug address disabled</b> <sup>1,2</sup>                                                                                                                                                                                                                                                                                                          |
| SDMA0           | DUART Signals Disabled                                                                                                                                     | 0 = DUART signals enabled<br>1 = PCI_CLK[0:3] signal used instead of DUART <sup>1,2</sup>                                                                                                                                                                                                                                                                                              |
| SDMA1           | Extended Addressing Mode                                                                                                                                   | <b>0</b> = Extended addressing mode enabled <sup>1,2</sup><br>1 = Extended addressing mode disabled                                                                                                                                                                                                                                                                                    |
| RCS0-           | Boot Memory Location                                                                                                                                       | 0 = Boot ROM is located on the PCI bus<br>1 = Boot ROM is located on the local bus <sup>1,2</sup>                                                                                                                                                                                                                                                                                      |
| MAA0            | Address Map Setting. The<br>MPC8245 only supports address<br>map B.                                                                                        | 0 = Invalid<br><b>1 = MPC8245</b> is configured for address map <b>B</b> <sup>1,2</sup>                                                                                                                                                                                                                                                                                                |
| MAA1            | PCI Host Mode                                                                                                                                              | 0 = MPC8245 is a PCI agent device<br>1 = MPC8245 is a PCI master device <sup>1,2</sup>                                                                                                                                                                                                                                                                                                 |
| MAA2            | PCI Arbiter Disable                                                                                                                                        | <b>0</b> = <b>PCI</b> arbiter enabled <sup>1,2</sup><br>1 = PCI arbiter disabled                                                                                                                                                                                                                                                                                                       |

| Table I.  | <b>PowerPC</b> | Configuration | Signals |
|-----------|----------------|---------------|---------|
| I able I. |                | Comiguiation  | Dignais |

Notes: 1. Bold indicates the recommended setting for the VX406C 2. 1=Switch OFF, 0=Switch ON (except for PMAA2 see note 3)

3. For the PMAA2 switch, 1=Switch ON, 0=Switch OFF

## 3.4.4 VIO Configuration Jumper

The VIO configuration jumper selects the voltage level supplied to the VIO pin on the PCI bus and PMC connector. The VIO power signal is used by universal PMC modules that can operate in both +5V and +3.3V systems. On these boards, the power for the I/O buffers is provided by the VIO pin instead of directly from the +3.3V or +5V power pins. Set the jumper according to the PMC module installed on the carrier as shown in Figure 9.

The other devices on the PCI bus (i.e. shared memory and M-Module bridge) can operate at either 3.3V or 5V signaling therefore, if no PMC module is installed, either jumper position is acceptable. The jumper must be installed for the PCI bus to operate.



Figure 9. VIO Configuration Jumper

# **3.5 CONNECTORS**

The VX406C incorporates several connectors to provide a physical connection to its various interfaces. Figure 5 shows the general location of each connector on the VX406C. Detailed pinout information can be found in Appendix A. A short description of each connector is provided in the following sections.

# 3.5.1 External Power Connectors

Two connectors are provided to connect +5V, +24V and -24V externally. The +5V connection is provided at a Molex 70543 male 4-pin connector. The +24V and -24V connections are provided by a Molex 70543 male 3-pin connector. Refer to Appendix A for details on the connector pin-outs.

# 3.5.2 External Relay Drivers Connector

The external relay driver's output signals are available at a 16-pin header (8x2 with 0.100 inch centers). Refer to Appendix A for details on the header pin-outs. Relay power can be externally supplied by removing jumper between +5V and COMMON and connecting power to COMMON pins. If internally +5V power is used (jumper installed), be sure to observe current specifications.

# 3.5.3 External Input Connector

The four external TTL input lines are available at a standard 8-pin female header (4x2 with 0.100 inch centers). Refer to Appendix A for details on the header pin-outs.

# 3.5.4 JTAG/COP Connector

Connection to the PowerPC's JTAG/COP debug interface is provided through a keyed 16-pin header (8x2 with 0.100 inch centers). This header is the standard size and employs the standard pin-out used by most JTAG based emulators. The pin-out details of the JTAG/COP header can be found in Appendix A.

# 3.5.5 Serial Comm Connector

Serial communication to the PowerPC is available at a standard 10-pin female header (5x2 with 0.100 inch centers). Refer to Appendix A for details on the header pin-outs.

### 3.5.6 PMC Connectors

The four PMC connectors provide the physical interface to a PMC module. The connectors are configured in accordance with the PMC specification. Refer to Appendix A for pin-out details.

#### 3.5.7 PMC I/O Connector

Some PMC modules provide 64 bits of I/O to the PMC carrier board though the PMC rear connectors. On the VX406C these 64 bits of I/O are available at the PMC I/O connector. The connector is a standard 64-pin header (32x2 with 0.100 inch centers). Refer to Appendix A for pin-out details.

#### 3.5.8 VXI Connectors

The rear connectors, labeled P1 and P2, provide the physical interface to the VXI system. They are configured in accordance with the VXI specification. Refer to Appendix A for pin-out details.

## 3.5.9 VXI Local Bus Connector

The VXI Local Bus signals are available at a standard 24-pin header (12x2 with 0.100 inch centers). The VX406C does not use the VXI Local Bus internally but makes it available for external use at this connector.

#### 3.5.10 M-Module Connectors

The four M-Module connectors provide the physical interface for up to four ANSI Standard M-Modules. The connectors are configured in accordance with the M-Module specification. Refer to Appendix A for pin-out details.

C&H Technologies, Inc. <> 445 Round Rock West Drive <> Round Rock, TX 78681 <> www.chtech.com

## **4.0 SYSTEM ARCHITECTURE**

#### 4.1 OVERVIEW

The system architecture illustrated in Figure 4 is viewed differently from an application running on the embedded PowerPC than from an application running on the VXI host. Most of the carrier's hardware can be accessed by both applications but, the methods for doing so differ. The system architecture is best described by viewing the host-side and the device-side separately. However, it is also important to understand how the resources shared between both applications are used for host to device communications.

## **4.2 DEVICE-SIDE ARCHITECTURE**

The device-side architecture is anchored by a standard embedded processor system powered by the MPC8245 PowerPC. The architecture provides on-board RAM, boot ROM, and flash memory to support the software application. The PowerPC acts as the PCI bus master and has full access to all devices on the PCI bus. A set of operational registers, the external relay driver and the external TTL inputs are available to the application via the processor's local bus. Figure 10 illustrates the device-side architecture.



Figure 10. Device-Side Architecture

#### 4.2.1 PowerPC Memory Map

Being a 32-bit processor, the MPC8245 can address up to 4 Gigabytes of physical memory. On the VX406C, the processor maps this 4 Gigabytes of memory into a configuration designated as Address Map B. The address map B configuration divides the memory space into sections that, when accessed, translate the operation to a local memory, PCI memory, PCI I/O, or ROM access. Figure 11 shows the general layout of address map B.



Figure 11. Address Map Overview

Details of the address map B implementation for the VX406C architecture are shown in Figure 12. Each section in the address map directly addresses a resource in the system architecture. Further details of each address block are provided throughout this document. Other address map B options and settings are also available but generally not used on the VX406C. Refer to the MPC8245 User's Manual for details.



Notes:

- 1. The boot ROM device only decodes 15 address lines. Therefore, the boot ROM is repeated throughout the address space. For example, address FF80\_0000<sub>16</sub> is the same location as FFF0\_000<sub>16</sub>. Addresses FEC0\_0000<sub>16</sub> and FEE0\_0000<sub>16</sub> are used to perform PCI configuration accesses as described in section 5.3.
- 2.
- PCI I/O accesses are forwarded to the PCI bus with the 8 most significant bits of the address cleared. 3.
- (i.e. processor address FE80\_0000<sub>16</sub> = PCI I/O address 0080\_0000<sub>16</sub>)
   M-module addresses are mapped to the PCI memory space via the PCI to M-module Bridge. Refer to section 4.2.5.5 for details.

#### Figure 12. Detailed PowerPC Address Map

# 4.2.2 SDRAM

The SDRAM provides 128 Megabytes of temporary storage for the application. The memory is organized in a 13 rows x 10 columns x 4 banks configuration. It has a 10ns access time and a 32 bits wide data bus. It is accessed through the PowerPC's addresses space starting at offset 0.

## 4.2.3 Boot ROM

The boot ROM provides 64 kilobytes of non-volatile, read-only memory. It is normally programmed during the manufacturing process to contain boot code and initialization routines. It can not be reprogrammed in circuit. The boot ROM is mapped to PowerPC address FF80\_0000<sub>16</sub> and has an 8-bit data bus. Only 15 address bits are decoded so that the 64 kilobytes are repeated throughout the PowerPC's ROM/Flash space between addresses FF80\_0000<sub>16</sub> and FFFF\_FFFF<sub>16</sub>. Consequently, the default exception vector table starting at address FFF0\_0000h resides in the boot ROM device.

# 4.2.4 Flash Memory

The flash device provides 8 megabytes of non-volatile storage for code and data. Unlike the boot ROM, flash is programmable in circuit and may be used by the system firmware. The flash device is accessed starting at PowerPC address FF00\_0000<sub>16</sub> and has an 8-bit wide data bus. Reads from flash are performed as standard PowerPC memory accesses. Programming and erasing the device, however, requires a sequence of commands to be sent to the device. C&H ICOS provides commands for programming the flash device. For details on using ICOS to program flash, refer to the C&H ICOS User's Manual. In addition, a hardware configuration switch is available to enable/disable programming of the flash device. If disabled, firmware can neither write-to nor erase the device.

# 4.2.5 PCIbus Architecture

The on-board PCI bus can contain up to 4 devices including the PowerPC which acts as the bus master. If a PCI to PCI Bridge is added at the PMC interface, more devices are available and can be accessed by the PowerPC. The devices on the primary bus include the PowerPC, the shared memory device, a PMC device, and the PCI to M-Module bridge. The bus operates at 33 MHz and 5V or 3.3V (jumper selectable).

PCI memory, configuration, and I/O space is memory mapped directly into the PowerPC's address map as shown in Figure 12. Approximately 2 gigabytes of PCI memory space is mapped starting at address 8010\_0000<sub>16</sub>. Each device requiring memory will have a base address within this mapped area. About 4 megabytes of PCI I/O space is mapped to PowerPC addresses FE00\_0000<sub>16</sub>. When performing a PCI I/O access, the processor clears the upper 8 bits of the address before forwarding the transaction to the PCI bus. So, for example, accessing processor address FE80\_0000<sub>16</sub> will read or write PCI I/O address 0080\_0000<sub>16</sub>. The base address of each device is determined by the PCI enumeration routines during initialization. The base address of a particular device can be determined by reading its Base Address Register (BAR) register in PCI configuration space for that device.

To perform a single PCI configuration write or read, two processor accesses are required. First, the PCI configuration address register at PowerPC address  $FEC0_0000_{16}$  must be set to point to the correct device and offset. Then the data can be read from or written to the PCI configuration

data register at PowerPC address FEE0\_0000<sub>16</sub>. The PCI configuration address register value is determined by the bus number, IDSEL signal routing, device function number, and the register offset. For details on performing PCI configuration accesses refer to the MPC8245 User's Manual. ICOS routines are provided that an application can use to easily perform configuration reads and writes. For details on ICOS refer to the ICOS User's Manual.

## 4.2.5.1 PCIbus Enumeration

During initialization, the boot-up firmware will search the PCI bus for devices, determine the resources needed for each device, and allocate processor resources accordingly. This procedure determines where in the PowerPC memory map a particular PCI device's resources are located. PCI device mapping is not guaranteed from one carrier configuration to another or even from one firmware version to another. The application software should always check a device's configuration registers for resource mapping information prior to accessing the device.

# 4.2.5.2 IDSEL Signal Routing

Each device on the PCI bus has a unique ID select line used to specify the destination of a configuration access. The PCI specification does not stipulate the source of each ID select line; however, the upper 16-bits of the address bus are normally used. On the VX406C each device has its IDSEL line tied to a specific address line as shown in Table II. The device number, normally provided to software routines, is also system dependant. Table II also shows the device numbering used on the VX406C. This information must be incorporated into a configuration access by the application when performing a write or read.

| Device                 | IDSEL | DevNum           |
|------------------------|-------|------------------|
| Shared Memory          | AD16  | 1610             |
| PowerPC                | AD17  | 17 <sub>10</sub> |
| • PMC                  | AD18  | 1810             |
| PCI to M-Module Bridge | AD19  | 19 <sub>10</sub> |

Table II. IDSEL Signal Routing

# 4.2.5.3 PCI Interrupts

The PowerPC's Embedded Programmable Interrupt Controller (EPIC) acts as the PCI interrupt controller. The interrupt lines from the PCI devices and M-Modules are routed to the EPIC controller's five interrupt inputs as shown in Table III. The PCI to M-Module bridge device does not generate interrupts. Instead each M-Module's interrupt line is routed directly to the EPIC controller. This architecture requires that the PMC interface and the shared memory device share a common interrupt line. It is up to the application software to determine the source of an interrupt on this shared line. The C&H ICOS firmware contains routines to assist the application developer in handling interrupts. Refer to the C&H ICOS User's Manual and the MPC8245 User's Manual for information on programming the EPIC controller to handle interrupts.

| Device        | PCI Interrupt Pin   | EPIC IRQ |
|---------------|---------------------|----------|
| M-Module A    | N/A                 | IRQ0     |
| M-Module B    | N/A                 | IRQ1     |
| M-Module C    | N/A                 | IRQ2     |
| M-Module D    | N/A                 | IRQ3     |
|               |                     |          |
| РМС           | INT A# B#, C#, & D# | IRQ4     |
| Shared Memory | INTA#               | IRQ4     |

**Table III. PCI Interrupt Signal Routing** 

#### 4.2.5.4 Shared Memory Device

The shared memory device's entire address space is mapped to PCI memory space including all registers, the  $I_2O$  messaging unit, and the general purpose shared memory. The offset into PowerPC memory space is determined at boot up by the PCI enumeration software.

Figure 13 shows the shared memory device's address map. All addresses are offsets from the devices base address. To determine the shared memory's base address, read offset  $10_{16}$  (BAR0 Register) of the shared memory's PCI configuration space. This value is the base address of the shared memory device. The general purpose shared memory begins at an offset of  $4000_{16}$  from this address. Full details of the shared memory device's address map, including register details, can be found in the *CY7C09449PV Data Sheet* from Cypress Semiconductor, Inc.



Figure 13. Shared Memory Organization

#### 4.2.5.5 PCI to M-Module Bridge

The PCI to M-Module Bridge provides the interface between the on-board PCI bus and the four M-Module positions. All four M-Modules share a common device number and PCI configuration space provided by the bridge. The bridge maps each M-Module's I/O and internal register spaces to PCI memory space as shown in Figure 14. The bridge will automatically translate any access to these PCI locations to the corresponding M-Module access. One of the internal registers provides the ability to perform an interrupt acknowledge cycle on the corresponding M-Module and return the interrupt vector (if supported by the M-Module).



Figure 14. PCI to M-Module Address Map

## 4.2.5.6 PMC Device

The PMC position resides on the on-board PCI bus. Its address space is mapped directly to the PowerPC's address map. The bus mode signals are implemented to inform the PMC module of the PCI bus configuration. The PMC module may contain a PCI to PCI Bridge whose secondary bus is fully accessible by the PowerPC. Interrupts from the PMC device are supported as described in section 4.2.5.3.

# 4.2.6 Triggers

The carrier includes a programmable switching matrix for mapping M-Module triggers to VXI triggers, other M-Module triggers, or the VXI CLK10 signal. The matrix is illustrated in Figure 15. Each trigger line in the architecture has an output driver that can be enabled or disabled. The source of each driver can be selected from the other trigger lines in the architecture. In effect, a VXI TTL trigger line can be driven by any of the M-Module trigger lines and an M-Module trigger line can be driven by any of the VXI TTL Trigger lines. In addition, the carrier allows for an M-Module trigger line to be driven by another M-Module trigger line or by the VXI CLK10 signal. The architecture also allows for the selected source to be inverted prior to reaching the output driver.

This architecture provides enormous flexibility allowing a large number of trigger-mapping combinations. When programming, care must be taken not to enable an output driver on a trigger line that is already being used for an input. This will not damage the carrier but will prohibit normal functionality of that trigger line. Programming of the matrix is provided via the operations registers discussed in section 4.2.7 and detailed in section 4.4.1.



#### 4.2.8 External Drivers

The architecture includes a seven (7) channel Darlington sink driver device residing on the PowerPC's local memory bus. The device is intended to drive external relays, display LED's, or other devices with high current requirements. The device's outputs are available at a 16 pin header for external use. Refer to section 3.5.2 and Appendix A for details on the header.

PowerPC and the operations registers is 8-bits wide and reads and writes are performed as

standard memory accesses. For register definitions in this space refer to section 4.4.1.



**Figure 15. Trigger Architecture** 

Access to the device is provided at address 7000\_1000<sub>16</sub>. The data bus width to the device is 8bits wide and each bit corresponds to one of the 8 channels. The device can only be written to. Figure 16 shows the external driver control register.



CHx  $\Rightarrow$  Channel value (1 = driven, 0 = not driven)

# Figure 16. External Driver Control Register

#### 4.2.9 External TTL Inputs

The PowerPC has access to four general purpose TTL inputs. The inputs can be driven externally at a standard 8-pin header. Refer to section 3.5.3 and APPENDIX A for details on the header. The values of the inputs are stored in the operations registers and can be read by the PowerPC. Refer to section 4.4.1 for details on the operations registers.

# 4.2.10 Watchdog Timer

A watchdog timer is available to reset the processor in the event that an errant software flow occurs. The watchdog can be disabled using the Module Configuration switch described in section 3.4.2 or by software by writing to the Watchdog Timer Control Register (Offset 0x26). *Disabling the watchdog timer at the hardware level is required to utilize a JTAG debugger on the processor.* 

# 4.2.11 JTAG/COP Interface

The JTAG interface to the PowerPC provides support for several standard off-the-shelf developments tools. Most development environments for the PowerPC support JTAG based communications with the processor. It provides the developer with the ability to view system registers, view memory, set breakpoints, and use other standard debugging practices. *To utilize a JTAG debugger on the processor, the watchdog timer must be disabled using the Module Configuration switch described in 3.4.2.* 

Connection to the JTAG/COP interface is provided through a standard 16 pin header. Refer to section 3.5.4 and Appendix A for details on the header.

# 4.3 HOST-SIDE ARCHITECTURE

The host-side architecture is anchored by the VXI system including a VXI chassis and a host computer. Standard off-the-shelf VXI controllers from several different manufacturers are available to interface the carrier to the host computer, including high performance embedded controllers. The VXI host has access to the entire address space of the shared memory device as well as to a set of the operations registers. The shared memory device provides a utility to

directly access devices on the PCI bus from the VXI host. Therefore, the VXI host application can control on-board PCI devices and thus the M-Modules without the assistance of the PowerPC. The standard VXI registers required by the VXI specification are implemented as part of the operations registers. These include the registers required to implement the VXI word serial protocol. The VXI host has the ability to fully access all devices on the on-board PCI bus and to fully utilize all host-to-device communications utilities. Figure 17 illustrates the intelligent carrier architecture as viewed from the VXI host computer.



Figure 17. Host-Side Architecture

#### 4.3.1 VXI Memory Map

Figure 18 shows the host-side memory organization for the intelligent carrier. The operations registers are accessed via VXI A16 space. These registers include the VXI required registers and the VXI message based communication registers as defined by the VXI bus specification.

A24/A32 memory space is a direct mapping of the shared memory device's memory map. This architecture gives the host full access to the shared memory and its registers including direct access to the PCI bus and other miscellaneous communications utilities.

A24 or A32 addressing is switch selectable as described in section 3.4.2. The VXI resource manager will write a base address to the offset register at address  $06_{16}$  in A16 space. If the carrier is configured for A32 addressing, the carrier will use the value of the offset register as the upper 16 bits of its 32-bit base address. If A24 addressing is selected, the carrier will use the value in the offset register as the upper 16 bits of its 24-bit base address. This behavior is illustrated at the bottom of Figure 18.



Figure 18. VXI Memory Organization

## 4.3.2 Data Bus Width

The intelligent carrier supports 16 and 32-bit wide data transactions to the shared memory device in the A24/A32 address space. However the device must be configured by software to be either 16 or 32-bits, but not both. Differences in the byte lane assignments between the VXI bus and the shared memory's local bus make dynamically switching between D16 and D32 impossible. If both D16 and D32 accesses are required then software must swap the bus width configuration before each type of access.

C&H ICOS provides a system command to configure the data bus width to the shared memory device. Refer to the C&H ICOS User's Manual for details.

Only 16-bit accesses to A16 address space are supported.

# 4.3.3 PCI Bus Mastering and Direct Access

The shared memory device provides an 8 Kilobyte window directly into PCI memory space. This window is accessible by the VXI host at offset  $2000_{16}$  in A24/A32 space. This window gives the host PC direct access to any PCI device residing on the on-board PCI bus including the M-Modules. To point the 8 Kilobyte window to the correct PCI bus address, the host must control the direct access control register defined by the shared memory device. The register is part of the shared memory operation registers accessible by the VXI host in A24/A32 space. Refer to section 5.8 for details on using the direct access capabilities of the carrier.

# 4.4 SHARED RESOURCES AND DEVICE COMMUNICATIONS

Communication between the host-side application and the device-side application is accomplished using a couple of resources available to both the host and the device. Namely, these shared resources are the operations registers and the shared memory device as shown in Figure 19. These shared resources are used to perform VXI communications, device configurations, block data transfers, and other miscellaneous functions.



**Figure 19. Shared Resources** 

# 4.4.1 Operations Registers

The operations registers combine the required VXI configuration registers, VXI communication registers and a set of carrier control registers. Table IV lists all available registers along with their offset. The VXI host can access each registers at its specified offset in the A16 address space. The PowerPC can access each register at its specified offset in its extended ROM space starting at address  $7000_{-}0000_{16}$ . There may be access restrictions on individual registers or individual bits within a register depending on the whether it is being accessed by the host-side or the device-side application. Refer to the register descriptions in Figure 20, Figure 21, and Figure 22 for details on each register.

NOTE: The PowerPC's interface to the operations registers is only 8-bits wide. In Figure 20, Figure 21, and Figure 22, the least significant bits reside in the low PowerPC address. For example, VXI ID bits 0-7 reside at PowerPC address 0x7000\_0000<sub>16</sub> and bits 8-15 reside at address 0x7000\_0001<sub>16</sub>.

| Offset (Hex) | Register Description      |
|--------------|---------------------------|
| VXI          | Configuration Registers   |
| 00           | VXI ID                    |
| 02           | VXI Device Type           |
| 04           | VXI Status/Control        |
| 06           | VXI Offset Register       |
| VXI C        | Communication Registers   |
| 08           | VXI Protocol              |
| 0A           | VXI Response              |
| 0C           | Reserved                  |
| 0E           | VXI Data Low              |
| 10 - 1F      | Reserved                  |
| VX406C       | Carrier Control Registers |
| 20           | Carrier Status/Control    |
| 22           | VXI Interrupt Control     |
| 24           | Trigger Control           |
| 26           | Watchdog Timer Control    |
| 28-3F        | Reserved                  |

Table IV. Operations Registers Map

### 4.4.1.1 VXI Configuration Registers

The VXI configuration registers contain basic information needed to configure a VXI system as required by the VXIbus specification. The configuration information includes: manufacturer identification, product model code, device type, memory requirements, device status, and device control. The registers are briefly described below and are detailed in Figure 20.

<u>VXI Identification (ID) Register</u>  $(00_{16})$ : This register provides the manufacturer identification, device classification (i.e., register based or message based), and the addressing mode (i.e. A32 or A24). It is a read only register from the VXI host. The PowerPC can write this register however it should be done immediately after reset prior to running VXI resource manager.

<u>VXI Device Type Register</u>  $(02_{16})$ : This register provides the model code identifier and required memory information. It is a read only register from the VXI host. The PowerPC can write this register however it should be done immediately after reset prior to running VXI resource manager.

<u>VXI Status/Control Register</u> ( $04_{16}$ ): A read of this register provides the state of the VXI MODID<sup>\*</sup> line and the pass, ready, and self-test status bits. A write to this register allows disabling of the SYSFAIL function and performing a reset of the carrier. This register is readable and writeable from both the VXI host and the PowerPC however, there are several access restrictions on individual bits depending on the source of the access.

<u>VXI Offset Register</u> ( $06_{16}$ ): This register controls the offset value for addressing the A24/A32 address space. The VXI system resource manager or control module sets this value according to the memory requirements specified for this module and the memory requirements of the other instruments in the system. This register is readable and writeable from the VXI host. The PowerPC only has read capability of this register.



| Device Class    | $\Rightarrow$ Device Class (10 = Message Based, 11 = Register Based, 00 & 01 = reserved) |
|-----------------|------------------------------------------------------------------------------------------|
| Address Space   | $\Rightarrow$ Address Space (00 = A16/A24, 01 = A16/A32, 10 = reserved, 11 = A16 Only))  |
| Manufacturer ID | $\Rightarrow$ Manufacturer Identification (default = 0xFC1)                              |



Required Memory ⇒ 32 Kbytes required (0xF if A32, 0x8 if A24) Model Code ⇒ Model Code (default = 0xFDF)

Figure 20. VXI Configuration Registers



A24/A32 Offset ⇒ Offset to the carriers A24/A32 memory space

#### Figure 20. VXI Configuration Registers (continued)

#### 4.4.1.2 VXI Communication Registers

The VXI communication registers are defined by the VXI specification for message based devices. They provide all the functionality necessary to perform the VXI word serial protocol. The on-board firmware must manage these registers to perform message passing. A word serial protocol handler is a standard part of C&H ICOS and may be developed for other operating systems. Only on very rare occasions should a user application need to access these registers directly. Figure 21 shows these registers in detail.

CAUTION: It is rarely necessary for either the host-side or the device-side user application to access the VXI communications registers directly. The host-side VXI libraries and the device-side firmware (ICOS) will automatically manage these registers when performing message passing functions. Directly accessing these registers is not advised without prior knowledge of the VXI specification for message based devices.

<u>VXI Protocol Register</u> ( $08_{16}$ ): This register indicates which message based protocols the carrier supports and indicates additional communication capabilities of the carrier. This register is a read only register by both the host and device applications.

<u>VXI Response Register</u>  $(0A_{16})$ : This register indicates status of the carrier's communications capabilities. The register is read-only from the host-side application. The PowerPC can write to this register to perform message passing. ICOS includes a VXI word serial protocol handler that automatically manages this register. Refer to the ICOS User's Manual for details.

<u>VXI Data Low Register</u> ( $0E_{16}$ ): This register is used to pass VXI commands and data to and from the carrier over the VXI bus. The status of this register is indicated in the VXI response register. This register is readable and writeable by both the host and device applications. However, the rules for message based communications as set by the VXI specification must be followed to ensure data integrity. Neither the PowerPC user application nor the VXI host applications should need to write directly to this register. ICOS includes a VXI word serial protocol handler that automatically manages this register. Refer to the ICOS User's Manual for details. The VXI host should use standard VXI libraries to communicate with the carrier.

| 0816      |                                             |                                                                                                                                                                            |                                               |                                         |                                       | VXI                                                                | Prot                               | ocol                                    |                                     |               |      |      |   |    |   |   |
|-----------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------------|---------------------------------------|--------------------------------------------------------------------|------------------------------------|-----------------------------------------|-------------------------------------|---------------|------|------|---|----|---|---|
| Bit       | 15                                          | 14                                                                                                                                                                         | 13                                            | 12                                      | 11                                    | 10                                                                 | 9                                  | 8                                       | 7                                   | 6             | 5    | 4    | 3 | 2  | 1 | 0 |
| PPC Write |                                             |                                                                                                                                                                            |                                               |                                         |                                       |                                                                    | (rea                               | d only)                                 | )                                   |               |      |      |   |    |   |   |
| VXI Write |                                             |                                                                                                                                                                            |                                               |                                         |                                       |                                                                    | (rea                               | d only)                                 |                                     |               |      |      |   |    |   |   |
| Read      | CMDR                                        | * SIG*                                                                                                                                                                     | MSTR*                                         | INT                                     | FHS*                                  | SMEM*                                                              |                                    |                                         |                                     |               | rese | rved |   |    |   |   |
| М         | MDR*<br>SIG*<br>STR*<br>INT<br>FHS*<br>MEM* | $\begin{array}{c} \Rightarrow & \operatorname{Sig} \\ \Rightarrow & \operatorname{Ma} \\ \Rightarrow & \operatorname{Int} \\ \Rightarrow & \operatorname{Fas} \end{array}$ | gnal Reg<br>aster (de<br>errupter<br>st Hands | ister (<br>fault 1<br>(defau<br>shake ( | default<br>=No V<br>ilt 1=h<br>defaul | Servant<br>1=No si<br>ME bus<br>as interru<br>t 1=Does<br>t 1=Does | gnal r<br>maste<br>pter e<br>not s | egister<br>er capa<br>capabil<br>upport | r)<br>bilitie<br>lities)<br>t the F | es)<br>Fast H |      |      |   | 1) |   |   |

VXI Response

| 0A <sub>16</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |     |     |      | V A  | i nesp | Unse    |      |   |   |    |        |    |   |   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----|------|------|--------|---------|------|---|---|----|--------|----|---|---|
| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 14   | 13  | 12  | 11   | 10   | 9      | 8       | 7    | 6 | 5 | 4  | 3      | 2  | 1 | 0 |
| PPC Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | rsvd | DOR | DIR | ERR* | RRDY | WRDY   | FHS*    | LCK* |   |   | re | eserve | ed |   |   |
| VXI Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |     |     |      |      |        | d only) |      |   |   |    |        |    |   |   |
| Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | rsvd | DOR | DIR | ERR* | RRDY | WRDY   | FHS*    | LCK* |   |   | re | eserve | ed |   |   |
| RF<br>WRI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | DOR       ⇒ Data Out Ready (1 = message byte available to be read by VXI host)         DIR       ⇒ Data In Ready (1 = carrier ready to receive message byte)         ERR*       ⇒ Error (0 = error occurred, 1 = no error)         RRDY <sup>1</sup> ⇒ Read Ready (1 = data has been place in the data low register for read by the VXI host)         WRDY <sup>2,3</sup> ⇒ Write Ready (1 = data low register is empty and ready for VXI host to write a command)         FHS*       ⇒ Fast Handshake Active (0 = Fast handshake mode is active)         LCK*       ⇒ Locked (0 = a commander has locked the carrier from being accessed by other sources) |      |     |     |      |      |        |         |      |   |   |    |        |    |   |   |
| <ol> <li>Notes:</li> <li>The Read Ready (RRDY) bit is automatically cleared by the VXI interface logic when the VXI Data Low Register is read by the VXI host.</li> <li>The Write Ready (WRDY) bit is automatically cleared by the VXI interface logic when the VXI Data Low Register is written by the VXI host.</li> <li>The Write Ready (WRDY) bit is logically tied to the PowerPC's System Management Interrupt (SMI) such that when the bit is cleared by the VXI host writing data to the Data Low register, a SMI interrupt is generated signaling to the PowerPC that data is available. This can be disabled using the VXDIS bit in the VX406C Control/Status Register.</li> </ol> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |     |     |      |      |        |         |      |   |   |    |        |    |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |     |     |      |      |        |         |      |   |   |    |        |    |   |   |

| 0E16                    |    |    |    |    |    |    | VXI C | Data L | ow  |   |   |   |   |   |   |   |
|-------------------------|----|----|----|----|----|----|-------|--------|-----|---|---|---|---|---|---|---|
| 0E <sub>16</sub><br>Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8      | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PPC Write               |    |    |    |    |    |    |       | Data   | Low |   |   |   |   |   |   |   |
| VXI Write               |    |    |    |    |    |    |       | Data   | Low |   |   |   |   |   |   |   |
| Read                    |    |    |    |    |    |    |       | Data   | Low |   |   |   |   |   |   |   |

Data Low ⇒ Low Data Word

Notes:

- The VXI specification for message based devices must be followed for reading and writing the data low register
   The Read Ready (RRDY) bit in the VXI Response Register is automatically cleared by the VXI interface logic when the data low register is read by the VXI host.
- 3. The Write Ready (WRDY) bit in the VXI Response Register is automatically cleared by the VXI interface logic when the data low register is written by the VXI host.

# Figure 21. VXI Communications Registers

# 4.4.1.3 VX406C Carrier Control Registers

The VX406C carrier control registers provide miscellaneous configuration, status, and control functionality for the carrier. Refer to the register descriptions and Figure 22 for details.

<u>Carrier Control/Status</u> ( $20_{16}$ ): This register provides miscellaneous status information and control functionality for the carrier. Each bit has individual read/write restrictions depending on whether the host-side or the device-side application is accessing it.

<u>VXI Interrupt Control</u> (22<sub>16</sub>): This register is used configure and control the interrupt capabilities of the carrier. The PowerPC or the shared memory device can interrupt the VXI host. The host or PowerPC application can enable/disable the ability of the carrier to interrupt the VXI host and can configure the interrupt level. The PowerPC application can also set a vector that'll be passed to the VXI host and generate the interrupt.

<u>Trigger Control</u> (24<sub>16</sub>): This register is used to configure the trigger matrix to map M-Module and VXI trigger lines. The same address location is used to configure each trigger line within the matrix. The trigger line to be configured is specified by setting the trigger select bits in the VX406C Control/Status register. The Trigger Control Register is readable and writeable by both the VXI host and the PowerPC. Refer to section 4.2.6 for details on the trigger architecture.

<u>Watchdog Timer Control</u> ( $26_{16}$ ): This register is used to configure and control the Watchdog Timer. The watchdog timer can be enabled or disabled by the PowerPC using the enable bit of this register. If enabled, the Watchdog must be reset within every 250 ms to avoid a processor reset. This register is not writable by the VXI host.

| 20 <sub>16</sub> | 20 carrier Status/Control |                  |       |        |         |                  |         |        |        |            |           |       |                |        |          |         |         |            |
|------------------|---------------------------|------------------|-------|--------|---------|------------------|---------|--------|--------|------------|-----------|-------|----------------|--------|----------|---------|---------|------------|
|                  | 15                        | 14               | 13    | 12     | 11      | 10               | 9       | 8      | 7      | 6          | 5         |       | 4              | 3      | 2        | 1       | 0       |            |
| PPC Write        |                           |                  | -     |        |         | TRIG             |         |        | -      |            | PMC R     |       | BRDG RST       | -      | -        | -       | -       |            |
| VXI Write        |                           |                  | -     |        |         | TRIG             |         |        | -      |            |           |       | BRDG RST       | -      | -        | -       | -       |            |
| Read             |                           | EX               | T IN  |        |         | TRIG             | SEL     |        | -      | VXDIS      | PMC R     | ST    | BRDG RST       | -      | WDE      | CFG     | USF     |            |
|                  | USF                       | 71 ⊏             | 0 =   | Boo    | t norr  | nally            |         |        |        |            | •         | /ste  | m Firmware o   | confi  | iguratio | on swit | ch)     |            |
|                  |                           | -2 _             |       |        |         |                  |         |        |        | ware mo    |           | г     | 11 6           |        | • 1      | `       |         |            |
| v                | VDE                       | 5 -              |       |        |         | able s<br>g enat |         | h (V   | alue   | of the W   | atchdog   | En    | able configur  | atioi  | 1 SWITCH | 1)      |         |            |
|                  |                           |                  |       |        |         | g disa           |         |        |        |            |           |       |                |        |          |         |         |            |
| (                | CFG                       | <sup>3</sup> ⊏   |       |        |         |                  |         | Swit   | ch (   | Value of   | configu   | ratio | on switch)     |        |          |         |         |            |
|                  |                           |                  |       | - Swit |         |                  |         |        | (      |            |           |       | ,              |        |          |         |         |            |
|                  |                           |                  | 1 =   | - Swit | tch or  | ben              |         |        |        |            |           |       |                |        |          |         |         |            |
| BRDG             | RS                        | T =              |       |        |         |                  | idge l  | Rese   | t (wr  | iting a '1 | ' to this | bit   | resets the PC  | I to   | M-Mod    | lule B  | ridge s | lot; after |
|                  |                           |                  |       |        |         |                  |         |        |        |            |           |       | normal opera   |        |          |         | U       |            |
| PMC              | RS                        | T =              | > PM  | IC Re  | eset (v | writin           | g a '1  | l' to  | this ł | oit resets | the mod   | lule  | in PMC slot;   | ; afte | er a min | imum    | of 100  | )µs a '0'  |
|                  |                           |                  |       |        |         |                  |         |        |        | l operatio |           |       |                |        |          |         |         |            |
| VX               | DIS                       | 5 <sup>4</sup> = | > VX  | KI Dis | sable   | (writi           | ng a    | '1' to | o this | bit will   | disable   | the   | interrupt gene | erate  | d when   | ever a  | messa   | ige byte   |
|                  |                           |                  |       |        |         | ver the          |         |        |        |            |           |       |                |        |          |         |         |            |
| TRIG             | SE                        | Ľ                | > Tri | gger   | line t  | hat is           | acces   | ssed   | wher   | never the  | Trigger   | Co    | ntrol register | is re  | ad or w  | ritten  |         |            |
|                  |                           |                  |       |        |         | Trigg            | or I ii | ne     |        |            |           | Tria  | gger Line      |        |          |         |         |            |
|                  |                           |                  |       | 000    |         | VXI              |         |        | 0      | 1(         | 000       | MS    | Slot A Trig A  |        |          |         |         |            |
|                  |                           |                  |       | 000    |         | VXI              |         | -      |        |            |           |       | Slot A Trig B  |        |          |         |         |            |
|                  |                           |                  |       | 001    |         | VXI              |         |        |        |            |           |       | Slot B Trig A  |        |          |         |         |            |
|                  |                           |                  |       | 001    |         | VXI              |         |        |        |            |           |       | Slot B Trig B  |        |          |         |         |            |
|                  |                           |                  |       | 010    |         | VXI              |         |        |        |            |           |       | Slot C Trig A  |        |          |         |         |            |
|                  |                           |                  |       | 010    |         | VXI              |         |        |        |            |           |       | Slot C Trig B  |        |          |         |         |            |
|                  |                           |                  |       | 011    |         | VXI              |         |        |        |            |           |       | Slot D Trig A  |        |          |         |         |            |
|                  |                           |                  |       | 011    |         | VXI              |         |        |        |            |           |       | Slot D Trig B  |        |          |         |         |            |
|                  |                           |                  |       |        |         |                  |         | 0      |        |            |           |       | 3              |        |          |         |         |            |

EXT IN  $\Rightarrow$  External Input Status (see section 3.5.3 for more details)

Notes:

- 1. This bit is used by the boot code to determine whether to go into firmware update mode immediately on power-up or whether to boot normally
- 2. The Watchdog Enable Switch enables/disables the watchdog timer at the hardware level. The watchdog timer may also be disabled by software by writing to the Watchdog Timer Control Register (Offset 0x26). **Disabling the watchdog timer at the hardware level is required to utilize a JTAG debugger on the processor.**
- 3. The user configuration switches have no effect on the carrier operation. The PowerPC firmware can use these values in any way it desires. ICOS or other system software may define the function of these switches. Otherwise the user application can use them however it wishes.
- 4. The Write Ready (WRDY) bit in the VXI response register is logically tied to the PowerPC's System Management Interrupt (SMI) such that when the bit is cleared by the VXI host writing data to the Data Low register, a SMI interrupt is generated signaling to the PowerPC that data is available. The VXDIS bit will disable the interrupt generation. Disabling the VXI interrupt may cause the VXI message based firmware to not operate and may not be recoverable. Make sure the DIR and DOR bits in the VXI Response register are cleared before setting this bit to avoid problems.

Figure 22. VX406C Control Registers

| 22 <sub>16</sub> |                 |                                                                                      |                                                                                    |                                                          | v                                                                                      | XI In                                                                                | terru                                                                     | pt Co                                                         | ntrol                                                                                         |           |            |               |          |       |            |  |
|------------------|-----------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-----------|------------|---------------|----------|-------|------------|--|
| Bit 15           | 14              | 13                                                                                   | 12                                                                                 | 11                                                       | 10                                                                                     | 9                                                                                    | 8                                                                         | 7                                                             | 6                                                                                             | 5         | 4          | 3             | 2        | 1     | 0          |  |
| PPC Write        |                 |                                                                                      | Vec                                                                                | tor                                                      |                                                                                        |                                                                                      |                                                                           | PIP                                                           | -                                                                                             | PIE       | SMIE       | V             | XI Level |       | MIE        |  |
| VXI Write        |                 |                                                                                      | (re                                                                                | ead or                                                   | nly)                                                                                   |                                                                                      |                                                                           |                                                               | -                                                                                             | PIE       | SMIE       | VXI Level MIE |          |       |            |  |
| Read             |                 |                                                                                      | Vec                                                                                | tor                                                      |                                                                                        |                                                                                      |                                                                           | PIP                                                           | SMIP                                                                                          | PIE       | SMIE       | V             | XI Level |       | MIE        |  |
| Vector           | ,1 ⇔            | $ \begin{array}{c} 00_{1}\\ 80_{1}\\ 81_{1}\\ 82_{1}\\ 83_{1}\\ 84_{1} \end{array} $ | 6 – 7F<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>8<br>6<br>8<br>7<br>8<br>7<br>16 | 16 V<br>re<br>M<br>N<br>M<br>M<br>M<br>V<br>V<br>V<br>re | XI res<br>eserved<br>I-Mod<br>I-Mod<br>I-Mod<br>Ser def<br>XI rec<br>XI rec<br>eserved | ponse<br>d for sl<br>ule A<br>ule B<br>i<br>ule C<br>ined in<br>quest fa<br>quest tr | interru<br>interru<br>interru<br>interru<br>interru<br>alse ev<br>rue int | upt<br>memory<br>apt pend<br>apt pend<br>apt pend<br>apt pend | y interru<br>ling <sup>2</sup><br>ling <sup>2</sup><br>ling <sup>2</sup><br>ling <sup>2</sup> |           | rrupt ack  | nowle         | dge cyc  | ŀle   |            |  |
| PI               | P ⇒             | Proces                                                                               | sor in                                                                             |                                                          |                                                                                        |                                                                                      |                                                                           | =1 and                                                        | MIE=1                                                                                         | then wr   | riting a 1 | to this       | s bit wi | ll ge | enerate an |  |
| SMIP             | <sup>,3</sup> ⇔ | interru<br>Shared<br>asserte                                                         | l mem                                                                              |                                                          |                                                                                        |                                                                                      | ding (                                                                    | a value                                                       | of 1 ind                                                                                      | dicates t | hat the s  | hared         | memor    | y de  | evice has  |  |
| PI               | ∃ ⇒             |                                                                                      |                                                                                    |                                                          |                                                                                        |                                                                                      | = a va                                                                    | lue of                                                        | 1 in the                                                                                      | PIP bit   | will gene  | erate a       | n interr | upt   | )          |  |
| SMI              |                 |                                                                                      |                                                                                    |                                                          |                                                                                        |                                                                                      |                                                                           |                                                               |                                                                                               |           | m the sh   |               |          |       |            |  |
| VXI Level        |                 | VXI Ir                                                                               |                                                                                    |                                                          |                                                                                        |                                                                                      |                                                                           |                                                               |                                                                                               | *         |            |               | 5        |       | ,          |  |
| MIE              |                 | Master                                                                               |                                                                                    |                                                          |                                                                                        |                                                                                      |                                                                           |                                                               |                                                                                               |           |            |               |          |       |            |  |
| Notes            |                 |                                                                                      |                                                                                    |                                                          |                                                                                        |                                                                                      |                                                                           | -r em                                                         |                                                                                               |           |            |               |          |       |            |  |

- 1. The vector value specifies the type of interrupt that is pending. The 'user defined interrupt' vector range may be used by the user application when generating processor interrupts. All other interrupt vector values are defined by the VXI specification or reserved by the VX406C. The operating system manages this register field when generating VXI defined interrupts. 2. The user must configure the operating system (ICOS) to pass M-Module interrupts onto the VXI bus. This is done using a
- VXI Word Serial System Command.
- 3. If both the PIP and SMIP bits are set, the shared memory interrupt will have priority and a vector value of 80<sub>16</sub> will be returned regardless of the value in the vector field.
- 4. The VXI interrupt level is typically configured by the VXI resource manager. While this register allows modification of this setting, it is not recommended and doing so may result in indeterminate interrupt behavior.
- 5. All interrupts are Release On Acknowledge (ROAK) interrupts. This is achieved by clearing the MIE bit during the interrupt acknowledge cycle. This bit should be re-enabled prior to returning from the interrupt service routine in order for interrupts to continue to occur.

#### Figure 22. VX406C Control Registers (continued)



The VXI Trigger or M-Trigger specified by Reg. 0x24 depends on the value specified in the TRIGSEL field of the Carrier Status/Control Register (Reg. 0x20).

 $VMAP^1 \Rightarrow$  Trigger Source. Bit 3 is ignored allowing the definition of the Trigger Source to be the same as that when defining a M-Trigger source.

| x000 | M Slot A Trig A |
|------|-----------------|
| x001 | M Slot A Trig B |
| x010 | M Slot B Trig A |
| x011 | M Slot B Trig B |
| x100 | M Slot C Trig A |
| x101 | M Slot C Trig B |
| x110 | M Slot D Trig A |
| x111 | M Slot D Trig B |

 $MMAP^1 \Rightarrow M$ -Trigger Source. If the CK10 bit is set to a '1', the VXI CLK10 signal is mapped to the output trigger regardless of the value of MAP.

| 0000 | VXI TTL Trig 0 | 1000 | M Slot A Trig A |
|------|----------------|------|-----------------|
| 0001 | VXI TTL Trig 1 | 1001 | M Slot A Trig B |
| 0010 | VXI TTL Trig 2 | 1010 | M Slot B Trig A |
| 0011 | VXI TTL Trig 3 | 1011 | M Slot B Trig B |
| 0100 | VXI TTL Trig 4 | 1100 | M Slot C Trig A |
| 0101 | VXI TTL Trig 5 | 1101 | M Slot C Trig B |
| 0110 | VXI TTL Trig 6 | 1110 | M Slot D Trig A |
| 0111 | VXI TTL Trig 7 | 1111 | M Slot D Trig B |

INV  $\Rightarrow$  Invert the trigger (1 = inverted, 0 = non-inverted (default))

EN  $\Rightarrow$  Enable the trigger (1 = enabled, 0 = disabled (default))

 $CK10^2 \Rightarrow$  Map the VXI CLK10 signal to the selected output trigger. (1=VXI CLK10, 0 = Use Map Field (default))

Notes:

1. Refer to section 4.2.6 for details on the trigger architecture.

2. CK10 is not available as a source on VXI TTL Triggers.

Figure 22. VX406C Control Registers (continued)



 $RST_{a}^{1} \Rightarrow$  Reset Watchdog Timer (Write a 1 to this bit to reset the watchdog timer)

 $EN^2 \Rightarrow$  Watchdog Timer Enable (0 = Disabled, 1 = Enabled, default)

Notes:

1. The RST will automatically be cleared after the timer is reset.

2. The watchdog timer is enabled by default.

3. If enabled, the watchdog timer expires every 250ms unless reset. Upon expiration, the watchdog will reset the processor.

#### Figure 22. VX406C Control Registers (continued)

#### 4.4.2 VXI Word Serial Protocol

Most communications between the host and the PowerPC is via the VXI word serial protocol defined by the VXI bus specification. Message passing is implemented via the VXI communication registers as described in section 4.4.1.2. The PowerPC handles the device-side of the communication protocol with the on-board system firmware.

The word serial protocol implementation is dependant upon the software environment running on the carrier. C&H ICOS implements a word serial protocol handler that defines all standard word serial commands specified in the VXIbus specification. ICOS commands are also defined to provide general access to the M-Modules, PowerPC utilities, and carrier configuration options. Application dependant commands can be developed per application. Refer to the C&H ICOS User's Manual for details on the word serial command protocol implementation.

### 4.4.3 General Purpose Shared Memory

The 16 kilobytes of general purpose shared memory can be used to pass large amounts of data between the host application and the PowerPC application. High performance, data intensive applications can take advantage of burst access to this memory space from the host and DMA access to this memory space from the PowerPC or other device on the PCI bus. The shared memory device will provide low level arbitration for this memory space. High level handshaking can be provided through message based commands and/or VXI interrupts.

The host-side application can access the general purpose shared memory at offset  $4000_{16}$  in VXI A24/A32 address space. The on-board PowerPC application can access this memory at offset  $4000_{16}$  in shared memory device's PCI BAR0 space. The device's BAR0 space is determined during PCI bus enumeration and can be read by performing a PCI configuration read of the shared memory device's BAR0 register.

#### 4.4.3.1 Shared Memory Arbitration

The shared memory device provides arbitration logic so that any location can be accessed at the same time by both the VXI host and the PowerPC.

The shared memory device also provides an Arbitration Utility Flag Register accessible to the host through VXI A24/A32 space and to the PowerPC through the shared memory device's PCI BAR0 space. Software can use this register to implement high level memory arbitration. As shown in Figure 23, the register provides four arbitration flags that can be owned by either the local bus (VXI) or the PCI bus (PowerPC) but never both at the same time.

| 04C0 <sub>16</sub> |    |    |    |    | Arbitration | Utili | ty Fl | ag l | Registe | r  |    |   |   |   |    |    |
|--------------------|----|----|----|----|-------------|-------|-------|------|---------|----|----|---|---|---|----|----|
| Bit                | 31 | 26 | 25 | 24 | 23 1        | 8 17  | 16    | 15   | 10      | 9  | 8  | 7 |   | 2 | 1  | 0  |
| Write              |    | -  | L3 | P3 | -           | L2    | P2    |      | -       | L1 | P1 |   | - |   | L0 | P0 |
| Read               |    | -  | L3 | P3 | -           | L2    | P2    |      | -       | L1 | P1 |   | - |   | L0 | P0 |

Lx ⇒ Local bus ownership (This bit can only be set by the VXI host and only if the corresponding Px bit is not set)

Px ⇒ PCI bus ownership (This bit can only be set by the PowerPC and only if the corresponding Lx bit is not set)

#### Figure 23. Shared Memory Arbitration Utility Flag Register

#### 4.4.3.2 DMA/Burst

The PowerPC contains an embedded DMA controller than can be used to burst data into and out of shared memory. The destination or source of the DMA transfer can be local memory or another PCI device. Details on using the embedded DMA controller are beyond the scope of this document. Refer to the MPC8245 User's Manual for further information.

The shared memory device also contains an embedded DMA controller that can burst between the shared memory device and any PCI device. The shared memory can be programmed to perform the DMA transfer then interrupt the VXI host when the transfer is complete. The shared memory's DMA controller is fully accessible without the help of a PowerPC application.

The VXI host can burst data into and out of shared memory using VXI block transfer cycles. If supported, the host's VXI library should provide functions to perform block transfers. The data width of block transfers can be 16 or 32 bits however, the data bus width must be configured as discussed in section 4.3.2.

#### 4.4.4 I<sub>2</sub>0 Message Unit

The shared memory device has an on-board  $I_2O$  messaging unit that can be used to communicate between the host and the PowerPC. However, the  $I_2O$  messaging unit will only be used in special circumstances since the VXI Word Serial Protocol provides full message passing capabilities. Full access to the  $I_2O$  messaging unit is provided through VXI A24/A32 space and through PCI memory space. Refer to the Cypress *CY7C09449PV Data Sheet* for further details.

# 4.4.5 General Purpose FIFOs

The I<sub>2</sub>O messaging unit contains four FIFOs that are available for general purpose use when the I<sub>2</sub>O messaging unit is not being used. Each FIFO is 32 deep x 32 bits and can be accessed by both the host and the PowerPC applications. Access to the FIFOs is achieved through 4 registers that are part of the I<sub>2</sub>O Specific Registers section mapped to VXI A24/A32 space and to PCI memory space. Figure 24 describes the FIFO registers. Each register is a shared port such that on a write it places data on one FIFO and on a read it reads data from a different FIFO. This way each FIFO can be accessed by both the host and the PowerPC simultaneously.

| 004016 |    | Inbound Free/Post FIFO  |   |
|--------|----|-------------------------|---|
| Bit    | 31 |                         | 0 |
| Write  |    | Inbound Post FIFO Write |   |
| Read   |    | Inbound Free FIFO Read  |   |

Inbound Post FIFO Write ⇒ Place data into the Inbound Post FIFO 

| 0044 <sub>16</sub> |    | Outbound Post/Free FIFO  |   |
|--------------------|----|--------------------------|---|
| Bit                | 31 |                          | 0 |
| Write              |    | Outbound Free FIFO Write |   |
| Read               |    | Outbound Post FIFO Read  |   |

Outbound Free FIFO Write ⇒ Place data into the Outbound Free FIFO Outbound Post FIFO Read ⇒ Pull data from the Outbound Post FIFO

| 04816 |    | Inbound Post/Free FIFO  |   |
|-------|----|-------------------------|---|
| Bit   | 31 |                         | 0 |
| Vrite |    | Inbound Free FIFO Write |   |
| Read  |    | Inbound Post FIFO Read  |   |

Inbound Post FIFO Read ⇒ Pull data from the Inbound Post FIFO

| 004C <sub>16</sub> | Outbound Free/Post FIFO  |   |
|--------------------|--------------------------|---|
| Bit                | 31                       | 0 |
| Write              | Outbound Post FIFO Write |   |
| Read               | Outbound Free FIFO Read  |   |

Outbound Post FIFO Write ⇒ Place data into the Outbound Post FIFO Outbound Free FIFO Read ⇒ Pull data from the Outbound Free FIFO

Notes:

1. Writing to a full FIFO will result in loss of data. The contents of the FIFO will not change.

Reading from an empty FIFO will return FFFFFFF<sub>16</sub>.

2. 3. All FIFOs are empty at reset.

Figure 24. General Purpose FIFO Registers

#### **4.5 SOFTWARE ARCHITECTURE**

For a typical application, the system software will consist of both an on-board application running on the PowerPC and a host application running on the VXI host computer. The two applications will communicate over the VXI bus using the shared resources of the VX406C described in section 4.4. Figure 25 illustrates the system architecture for a typical application.



Figure 25. System Software Architecture

### 4.6 HOST SYSTEM SOFTWARE

The host-side application will normally run on a standard PC or an embedded VXI controller and will communicate with the device using standard off-the-shelf VXI interfaces and software libraries. The application may be part of a large automated test system responsible for controlling the VX406C along with numerous other instruments, or it may be an independent diagnostic application allowing the user to interact with the VX406C. The typical application will be responsible for sending high level commands to the PowerPC application and retrieving, analyzing, and reporting data. It might also provide a soft front panel that a user may use to interact with the instrument.

The instrument driver library will provide high level functions to communicate with the device. The library can be separated into general ICOS functions and application specific functions. The general ICOS functions will provide functionality that exists regardless of the M-Modules and PowerPC application residing on the board. It will provide an interface via the VXI bus to the various utilities provided by ICOS. The application specific functions will be developed along with the PowerPC user application and will be specific to the given application.

This document does not attempt to define the scope or the architecture of the host application. It is only mentioned here to illustrate how the application would interact with the software running on-board the VX406C's PowerPC system.

# 4.7 ON-BOARD SYSTEM FIRMWARE

The on-board system firmware will usually consist of boot code, an operating system or kernel, and a user application. The boot code is responsible for initializing the processor and launching the operating system. Once launched, the operating system is responsible for initializing of the carrier, launching the user application, and performing various system level tasks during execution. The user application will perform many of the high level tasks that are unique to the function of the carrier in the overall system application.

# 4.7.1 Boot Code

The VX406C boot code is located in the carrier's 32 kilobyte boot ROM device. At reset, the PowerPC automatically jumps to the reset exception vector at address  $FFF0_0100_{16}$  located in boot ROM and begins running the boot code. The boot code is responsible for initializing the PowerPC to a state where a minimal application can run, and launching the operating system or other system firmware. The boot ROM also contains code to download and update the on-board firmware via the VXI bus.

# 4.7.1.1 PowerPC Initialization

The first action the VX406C boot code performs is to initialize the PowerPC and all its associated peripheral interfaces. The MPC8245 is a highly integrated processor with the capability of interfacing to many different peripherals. An extensive set of configuration registers are provided to configure the processor for all the different possible architectures. During the boot sequence, these registers are initialized to values appropriate for the VX406C hardware architecture. Detailed settings for each configuration option are beyond the scope of this document. However, a list of configuration registers and the value that each is initialized to, is provided in APPENDIX B. For further details on the processor configuration, refer to the MPC8245 User's Manual.

# 4.7.1.2 Launching the Operating System

Once the boot code has initialized the PowerPC to a state where it can run a minimal application, it will attempt to launch ICOS or another third part operating system. This is accomplished by initializing the PowerPC's registers that determine how the processor returns from an exception and performing a *return from interrupt* (rfi) instruction. The registers are setup such that after the rfi instruction is executed, the processor immediately begins executing the instruction at

address  $FF00_{1000_{16}}$ . This address is located in the first sector of the flash device. The first instruction of the operating system or other system firmware must exist at this location.

Essentially, the boot code performs a blind jump to address  $FF00_{1000_{16}}$  leaving the carrier in a fairly raw, un-initialized state. Other than initializing the PowerPC processor, the boot code does not configure the carrier for operation. It is the responsibility of the operating system to configure the carrier including: enumerating the PCI bus, initializing the VXI interface, configuring the shared memory device, and initializing stack, data, and other memory pointers. The register initializations shown in APPENDIX B outline the extent of initialization efforts performed by the boot code.

# 4.7.1.3 Firmware Download Utility

If the 'Firmware Update Mode' hardware switch is set to the OFF position at reset, the boot code will automatically launch the firmware download utility instead of the operating system as described in the previous section. The firmware download utility allows the user to download firmware and data into the flash device via the VXI bus using the shared memory device as a buffer for the data. This mode is useful for programming a blank flash device or updating the embedded operating system. Once in the download utility mode, the carrier must be reset and the 'Firmware Update Mode' switch must be set back to the ON position for normal operation to continue. For details on the download protocol for updating firmware refer to section 0. For details on the 'Firmware Update Mode' hardware switch, refer to section 3.4.2.

# 4.7.2 ICOS

The Intelligent Carrier Operating System (ICOS) is a single threaded OS kernel developed specifically for the VX406C and other intelligent carriers manufactured by C&H Technologies. It provides carrier initialization routines, a VXI word serial protocol handler, 488.2 utilities, and other features that allow an embedded user application and an application running on the VXI host to access the VX406C and associated M-Modules. ICOS can greatly reduce the development effort of designing software to operate the VX406C. It is installed on all VX406C's prior to shipment to the customer. For details on ICOS including instructions on how to operate a VX406C that is running ICOS and how to write a user application, refer to the ICOS User's Manual (C&H Document No. 11028578).

# 4.7.3 3<sup>rd</sup> Party RTOS Support

The VX406C hardware architecture will also support several commercial off-the-shelf, Real-Time Operating Systems (RTOS). Development efforts may be required to support any given operating system on the VX406C. It may also be required to develop utilities such as the VXI word serial protocol that will run on the given RTOS. Such development efforts are OS dependant and beyond the scope of this document. Contact the RTOS vendor and C&H Technologies for information on support for a particular RTOS.

#### 4.7.4 User Application

The user application will be responsible for performing higher level tasks specific to the integrated carrier and M-Modules. The user application will normally communicate with the carrier and associated M-Modules via the operating system. It will typically be stored in Flash memory or downloaded over the VXI bus at reset. Launching of the user application and restrictions on the resources available to the user application is dependant upon the operating system or other system firmware running on the carrier. Refer to the ICO User's Manual for details on developing a user application for a VX406C running ICOS. Refer to the specific RTOS documentation for details on systems running 3<sup>rd</sup> party RTOS's.

C&H Technologies, Inc. <> 445 Round Rock West Drive <> Round Rock, TX 78681 <> www.chtech.com

#### **5.0 PROGRAMMING INSTRUCTIONS**

#### 5.1 GENERAL

Programming the VX406C can be greatly simplified by using the commands and other utilities provided by ICOS and by using the Intelligent Carrier VXI Plug and Play (VXIpnp) Driver available by download at <u>http://www.chtech.com</u>.

ICOS provides a list of VXI word serial commands that allow the user to communicate with and control the VX406C via the VXI bus. The Intelligent Carrier VXIpnp Driver provides a high level programming interface to these VXI word serial commands. The VXIpnp driver can be called from a host side application to communicate and control the carrier.

In addition to the VXI commands, ICOS also provides an embedded Application Programming Interface (API) that a PowerPC user application can use to control the carrier. The embedded API is available to the embedded user application via the PowerPC's *system call (sc)* instruction.

The following sections will describe how to access many of the various features of the VX406C. However, most of the functionality described here is available via the high level commands provided by ICOS or via the VXIpnp driver. Therefore most of the details described in this section are extraneous and are only provided to give the reader a better understanding of the carrier's architecture. Further programming instructions can be found in the ICOS User's Manual and the VXIpnp driver's help documentation.

### 5.2 FLASH PROGRAMMING

Programming a single byte in flash requires sending a stream of commands to the device. ICOS provides API system calls and VXI commands to perform flash programming so that the user does not need to know the specifics of the device protocol. Refer to the ICOS User's Manual for details on the system calls and the VXI commands. Other operating systems may or may not provide flash programming utilities. If detailed programming information is needed on programming the flash, refer to the AM29LV065D Data Sheet from Advanced Micro Devices (AMD).

The device is organized into sectors that are 64 kilobytes each. The sectors are organized sequentially in memory so that sector 0 is from address  $00_{0000_{16}} - 00_{FFFF_{16}}$ , sector 1 is from address  $01_{0000_{16}} - 01_{FFFF_{16}}$  and so forth. The 64 kilobytes are mapped to the PowerPC address space starting at address FF00\_0000\_{16}. The operating system or other system firmware may reserve some of the sectors for system use. Refer to the firmware's documentation for details.

Programming operations can be performed on any address in the flash device. Only 8-bit accesses are supported. *The programming operation can only toggle a bit from '1' to '0'*. To set a bit back to '1' an erase operation must be performed. Erase operations can only be performed on a sector by sector basis. Therefore, in most cases it is necessary to erase an entire sector and rewrite it to change a single byte within that sector.

Writing and erasing of the flash device can be disabled via a hardware switch. See section 3.4.2 for details on the Flash Write Enable hardware switch. If flash writes are disabled, neither the write nor the erase command will affect the data in the device. Reads of the flash device cannot be disabled.

## **5.3 PCI ACCESSES**

Devices on the PCI bus are mapped into the PowerPC's address space. Therefore, accessing these devices (except for configuration accesses) is as simple as performing a standard memory read or write. The base address for the device, in the PowerPC's memory space, is determined during PCI bus enumeration and is dependant upon the resources required by all the devices on the bus. A PCI configuration read can be used to determine the base address of a specific device. Every PCI device is required to have a set of Base Address Registers (BAR) that the PCI controller configures during bus initialization. These registers determine the base address(s) of the resource(s) on the device. Each BAR can point to either PCI memory space or PCI I/O space. If bit 0 (the least significant bit) of the base address register is a '1', the resource is mapped to PCI I/O space. Otherwise the resource is mapped to PCI memory space. PCI memory space is mapped directly into the PowerPC's address map (i.e. PowerPC address 9000\_0000<sub>16</sub> is mapped to the same address in PCI memory space). PCI I/O space, however, is mapped relative to a base address of  $FE00_{00016}$  (i.e. PowerPC address  $FE80_{000016}$  is mapped to PCI I/O address 0080\_000016). For details on the PowerPC address map refer to Figure 12. For information on a particular device's BAR registers, refer to that PCI device's documentation.

Two accesses are required to perform a single PCI configuration write or read. The PCI configuration address register at PowerPC address FEC0\_0000<sub>16</sub> must first be set to point to the correct device and offset. The data can then be read from or written to the PCI configuration data register at PowerPC address FEE0\_0000<sub>16</sub>. The PCI configuration address register value is determined by the device number, IDSEL signal routing, device function number, and the register offset. IDSEL signal routing information can be found in section 4.2.5.2 of this document. For further details on performing PCI configuration accesses refer to the MPC8245 User's Manual. ICOS system routines and VXI word serial commands are available to assist the user in performing PCI configuration reads and writes.

### 5.4 M-MODULE ACCESS

M-Modules are accessed via the PCI bus by accessing specified addresses in the PCI to M-Module Bridge's address space. The bridge device will automatically translate the PCI access into an M-Module access according to the location in the bridge being accessed. Figure 14 illustrates the address mapping of the PCI to M-Module Bridge.

All four M-Module's share the same PCI Base Address Register (BAR). BAR2 is used for accessing modules with a 16-bit data bus width and BAR3 is used for 32-bit bus width accesses. Each M-Module's I/O space can be accessed at an offset to the PCI to M-Module Bridge's BAR2 or BAR3 address space. Each M-Module has 256 bytes of I/O space available. The M-Module's I/O space in slot A starts at offset 0 of the BAR2 space, the I/O space of slot B starts at offset  $100_{16}$  in BAR2 space and so forth.

In addition, each M-Module slot has a set of internal bridge registers that are used for reset, status, and interrupt acknowledgment. These registers are located at the BAR2 (BAR3) + 0x1000000 + the offset shown. See Figure 26 for the bit definitions.



1. This same internal register exists for each M-Module position. See Figure 14 for M-Module address mapping.

2. Reading this register causes an interrupt acknowledge cycle to occur on the specified M-Module interface. The data provided by the M-Module is presented as the Interrupt Vector.

#### Figure 26. M-Module Internal Bridge Registers

#### 5.5 FIRMWARE UPDATE MODE

The firmware update mode allows the user to download code and data over the VXI bus via shared memory. The downloaded code and data will be programmed to flash memory. The PowerPC will automatically go into firmware update mode when the 'Firmware Update Mode' hardware switch is set to the OFF position at reset. When the update is complete, the VX406C must be restarted and the switch must be set back to the ON position for normal operation to continue.

#### 5.5.1 Firmware Update Mode Protocol

The firmware update routine uses the general purpose shared memory as a buffer between the host and the PowerPC. The protocol divides the 16 kilobytes of memory into four 4 kilobyte banks as shown in Figure 27. Each bank has two associated ownership bits in the 'Arbitration'

Utility Flag Register' at shared memory offset  $4C0_{16}$ . One bit signifies ownership of the associated bank by the host and the other signifies ownership of the bank by the PowerPC. The register functions such that the host cannot take ownership of a bank that the PowerPC has ownership of and vice-versa. Software must guarantee that it does not write to or read from a bank that it does not have ownership of. Further details of the arbitration utility flag register are discussed in section 4.4.3.1.



Figure 27. Shared memory banks for firmware update

The download protocol is illustrated in the flow chart of Figure 28. The host computer takes ownership of bank 0 to signify that it is ready to download data. The PowerPC application will wait until it has verified that bank 0 is no longer free. The PowerPC application then takes ownership of bank 3 to signify that it is ready. Like the PowerPC application, the host application must wait until it has verified that bank 3 is no longer free. At this point the download can begin.

The data must always begin with a command code and ends with a Cyclic Redundancy Check (CRC) value. To transfer the data, the host simply places it in consecutive address locations of shared memory. When the host fills an entire bank, it must perform a bank swap by first, verifying the next bank is free, second, taking ownership of the bank, and finally, releasing ownership of the completed bank. When a bank becomes free, the PowerPC will take ownership of it prior to reading the data. Like the host, the PowerPC application will verify that it has ownership of the next bank prior to releasing the current bank. Bank swapping must be done in the order illustrated in Figure 27 in order to preserve data integrity. When the download is complete the PowerPC application verifies the CRC value and returns an acknowledge (ACK) or negative acknowledge (NACK) value to the host. Both the host and the PowerPC must release all bank ownerships prior to returning from their respective download routines.



Figure 28. Firmware Update Protocol

#### 5.5.1.1 Flash Program Command

The flash program command identifies the format of the data being downloaded and instructs the PowerPC to program the data to flash memory. Once the PowerPC sees the 'Flash Program' command code, it erases the appropriate flash sectors prior to downloading the rest of the data. The PowerPC maintains an address counter that is initialized to the start address value. The start address value must point to an offset within the flash device and not an absolute PowerPC address. For each byte of data received, the PowerPC performs a flash write to the offset specified by the address counter and increments the counter. A running CRC is calculated as each byte is read from shared memory. The calculated CRC value is compared to the CRC value received as part of the download to determine whether or not the download was successful. The flash program command is illustrated in Figure 29.

| PROGRAM<br>COMMAND | 32-BIT PROGRAM COMMAND = 0000_005A <sub>16</sub>                                    |
|--------------------|-------------------------------------------------------------------------------------|
| SIZE               | 32-BIT SIZE OF THE DATA SECTION (DOES NOT INCLUDE COMMAND, SIZE, CRC, OR ADDRESS)   |
| START<br>ADDRESS   | 32-BIT FLASH OFFSET AT WHICH DATA IS PROGRAMMED TO $(00\_0000_{16} - 7E\_FFF_{16})$ |
| DATA               | DATA TO BE PROGRAMMED                                                               |
| CRC                | 32-BIT CRC OF THE DATA SECTION                                                      |

Figure 29. Flash Program Command

# 5.5.1.2 Calculating the CRC

The Cyclic Redundancy Check (CRC) value must be a 32-bit value that is calculated based on the 'Data' section of the 'Flash Program' command. The command code, size and start address field must not be used in the CRC calculation. An accurate calculation of the CRC must be performed in order for the firmware update to complete successfully. The example source code in Figure 30 can be used to calculate an accurate CRC. The exact CRC Polynomial shown in the example must be used.

```
#define CRC_POLYNOMIAL 0x04C11DB7
void CalculateCRC(unsigned char *buffer, int size, int *crc)
  int i, j;
  int *crc table;
  int index;
  crc_table = malloc(sizeof(int) * 256);
  /* Build CRC Table */
  for(i=0; i<256; i++)</pre>
     *crc = i;
     for(j=8; j>0; j--)
     { if (((*crc) & 0x1) == 1)
           *crc = ((*crc) >> 1) CRC_POLYNOMIAL;
        else
           *crc = (*crc) >> 1;
     crc_table[i] = *crc;
  }
  /* Calculate CRC */
  * \operatorname{crc} = 0;
  i = 0;
  while (size-- != 0)
     index = ((*crc) >> 24) & 0xFF;
     *crc = ((*crc) << 8) | buffer[i++];
      *crc ^= crc_table[index];
  }
  free(crc_table);
```

Figure 30. CRC Calculation - Example Source Code

# **5.6 INTERRUPTS**

The PowerPC application handles all interrupts from the M-Modules and from the on-board PCI devices. In addition, the PowerPC can generate a VXI interrupt by accessing an operations register. Finally, the shared memory device can also interrupt the VXI host on various programmable conditions such as the completion of a DMA transfer.

# 5.6.1 PCI Interrupts

PCI interrupts are handled by the Embedded Programmable Interrupt Controller (EPIC) of the MPC8245. The interrupt lines are routed between the PCI devices and the EPIC's interrupt lines as described in Table III. The PMC device and the Shard Memory device share a single EPIC interrupt line. It is the responsibility of the software to determine the source of an interrupt. Each interrupt line must be set to direct input mode so that the EPIC controller can respond to interrupts from the PCI devices. The interrupt lines can also be prioritized and can be programmed for level or edge sensitivity and either polarity.

Further details on programming the EPIC controller can be found in the MPC8245 User's Manual.

### 5.6.2 M-Module Interrupts

M-Module interrupts are also handled by the MPC8245's EPIC controller. As described in Table III, M-Module slot A's interrupt line is mapped to IRQ0 of the MPC8245, slot B's interrupt line is mapped to IRQ1, slot C's to IRQ2, and finally slot D's to IRQ3. The software must handle the M-Module interrupt like a PCI interrupt as described in section 5.6.1. In addition, if the M-Module requires an interrupt acknowledge cycle, the software must perform the cycle by accessing the interrupt acknowledge register for the particular M-Module slot. This register, when read, will perform an interrupt acknowledge and will return the interrupt vector (if supported by the M-Module). Depending upon the M-Module, the interrupt acknowledge cycle may automatically clear the pending interrupt.

Refer to the M-Module's documentation for details on interrupt support. In general, M-Modules can support 3 types of interrupts. Type A (software end of interrupt) is a Release on Register Access (RORA) type interrupt and does not support an interrupt acknowledge cycle. Type B (hardware end of interrupt without a vector) is a Release on Acknowledge (ROAK) type interrupt that supports the interrupt acknowledge cycle but does not return a vector. Finally, Type C (hardware end of interrupt with a vector) is also a ROAK type interrupt however it does return a vector.

# 5.6.3 VXI Interrupts

The source of VXI interrupts can be the on-board firmware, shared memory device, or an M-Module. In all cases the 'Interrupt Control' register at offset  $22_{16}$  in the VX406C's operations register provides the control for the interrupt. All cases share a single interrupt line and the cause of the interrupt can be determined from the status/ID value returned to the host during the interrupt acknowledge cycle.

The interrupt priority level used by the VX406C is programmable using the 'VXI Level' field of the interrupt control register. Any level between 1 and 7 can be selected. Writing a value of '0' to this field will disable the VXI interrupts. The Master Interrupt Enable (MIE) bit must also be set to a value of '1' for interrupts to occur. In addition, there is an interrupt enable bit for shared memory interrupts and one for processor based interrupts.

The VXI interrupt is always automatically released by the VX406C during the interrupt acknowledge cycle (i.e. ROAK). To achieve this behavior, the carrier automatically clears the MIE bit during the acknowledge cycle. The interrupt handler routine should re-enable this bit, after performing the interrupt handling functions, if interrupts are to continue to occur. *If an interrupt is still pending when the MIE bit is re-enabled another interrupt will immediately be generated.* The method of clearing a pending interrupt is dependent upon the type of interrupt.

The on-board firmware can generate VXI interrupts by setting the interrupt vector value in the 'Interrupt Pending' register and setting the PIP bit to a '1'. Some vector values are reserved for specific VXI defined interrupts. Others are available for definition by the user. Figure 22 show the defined vector values. The Processor Interrupt Enable (PIE) bit must also be set to a '1'. Clearing the interrupt is achieved by setting the PIP bit to a '0'. The method for instructing the PowerPC to clear the interrupt is application specific.

The shared memory device can interrupt the VXI host for several reasons including to signify the completion of a DMA transaction. If the Shared Memory Interrupt Enable (SMIE) bit is set to a '1' all interrupts from the shared memory device will be forwarded to the VXI bus. Shared memory interrupts have priority over processor based interrupts. The vector returned during the interrupt acknowledge cycle will always be 80<sub>16</sub> for shared memory interrupts. Configuring the shared memory device to generate interrupts is done through the device's operation registers. Refer to the *CY7C09449PV Data Sheet* from Cypress for details on the shared memory device.

## 5.7 CONFIGURING TRIGGERS

Triggers are configured using the 'VX406C Status/Control' register and the 'Trigger Control' register at offsets  $20_{16}$  and  $24_{16}$  of the operations registers. The trigger architecture for the carrier is described in section 4.2.6. A large number of trigger mapping combinations are available including mapping M-Module triggers to VXI TTL triggers and vice versa.

The 'VX406C Status/Control' register is used to specify the trigger line to configure. The 'Trigger Control' register is used to perform the configuration. Specifically, the user configures an output driver for the selected trigger lines. Configurations include enabling/disabling the driver, inverting the trigger, and mapping the trigger to another trigger line in the architecture. If a VXI trigger is selected in the 'VX406C Status/Control' register, the only valid mappings are any one of the M-Module trigger lines. If an M-Module trigger line is selected in the 'VX406C Status/Control' register, the mapping can be any VXI TTL trigger line, M-Module trigger line, or the VXI CLK10 signal.

To configure a specific trigger the user must first write to the 'VX406C Status/Control' register with the TRIGSEL value set to the desired output trigger to configure. Then the user can configure the selected trigger by writing to the 'Trigger Control' register. Figure 22 describes the 'Trigger Control' register and the 'VX407C Control/Status' register in detail.

The current configuration for a specific trigger can be read by first setting the TRIGSEL value in the 'VX406C Status/Control' register to the desired trigger then reading the 'Trigger Control' register. Once the TRIGSEL value is set, any read or a write of the 'Trigger Control' register will access the configuration for that trigger until TRIGSEL is either written another value or the carrier is reset.

# 5.8 HOST-SIDE PCI BUS MASTERING AND DIRECT ACCESS

The shared memory device provides an 8 Kilobyte window into PCI memory space. By accessing this window in VXI A24/A32 space, the host PC has direct access to the PMC module and all four M-Modules. To point the 8 Kilobyte window to the correct PCI bus address, the host must control the 'Direct Access' register defined by the shared memory device. Figure 31 shows a description of the control register.

| 0460 <sub>16</sub> Difference of the second sec | 2 1  | _ |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      | 0 |
| Write PCI Physical Base Address - F - A1A0 Byte Enables for Reads -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Туре | - |
| Read PCI Physical Base Address - F - A1A0 Byte Enables for Reads -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Туре | - |
| PCI Physical Base Address       ⇒       PCI physical base address of the 8K byte direct access windor VXI A24/A32 offset 0x2000         F       ⇒       Force contents of A1A0 to PCI during PCI address phase (0 = don't force, 1 = force)         A1A0       ⇒       Value of PCI A1 and PCI A0 to be placed on the PCI bus if F = Data Byte Enables for Reads         Byte Enables for Reads       ⇒       Data Byte Enables for PCI Master Reads, C/BE#[3:0]         Type       ⇒       PCI Command Type for PCI Master Access         00       Interrupt Acknowledge (read) (PCI command 0x0)         Special Cycle (write) (PCI command 0x1)       01         01       I/O Cycle (read/write) (PCI command 0x2 or 0x3)         10       Memory Cycle (read/write) (PCI command 0x6 or 0x7         11       Configuration Cycle (read/write) (PCI command 0xA or 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1    |   |

Figure 31. Direct Access Control Register

Before the shared memory device can generate a PCI access, its master enable bit must be set in the 'PCI Command' register at offset  $04_{16}$  of the shared memory device's PCI configuration space. This bit is set by default after power-up during the configuration of the shared memory device. The master enable bit can only be cleared by the PowerPC. If for some reason this occurs the VXI host must request that the PowerPC re-enable this bit before it can perform a direct access. Even if the PowerPC's boot procedure fails, the Master Enable bit will be set by default and the VXI host will automatically gain control of the PCI bus.

The procedure for directly accessing the onboard PCI bus is as follows:

- 1) Make sure the Master Enable Bit in the shared memory's PCI configuration space is set.
- 2) Program the Direct Access Register with the desired PCI system's physical base address. This is the 8 kilobyte address block that the Direct Access Window points to.
- 2a) In the Direct Access Register, set the type of PCI command to be generated.
- 2b) In the Direct Access Register, set the byte enables for the desired accesses if they are to be read accesses.
- 3) Access the PCI bus by reading or writing to the 8 kilobyte Direct Accesses Window.
- Note: Step 2 should be repeated if a different 8 kilobyte area of PCI space needs to be accessed or if a different access type or byte enables are needed.

#### 5.8.1.1 PCI Configuration Accesses

PCI configuration cycles use a different addressing method than normal PCI command cycles. During the cycle, each device is selected by asserting a unique IDSEL line. The PCI specification does not stipulate the routing of the IDSEL signals however in most systems the IDSEL line for a given device is connected to one of the upper PCI address bits. Refer to Table II in Section 4.2.5.2 for details on IDSEL signal routing on the VX406C.

To perform a type 0 PCI configuration cycle, perform the following steps:

- 1) Determine which address bit must be asserted in order to assert the IDSEL line of the desired device. Use Table II as a reference.
- 2a) Set the correct bit in the PCI Physical Base Address section of the Direct Access Register. Only set one bit to select the PCI device.
- 2b) Set the 'F' bit (bit 11) in the Direct Access Register to 0.
- 2c) Set the access type in the Direct Access Register to '11' which specifies a configuration cycle
- 3) Access the 8 kilobyte direct access window at an offset that incorporates the function number (bits 10-8) and the register offset (bits7-0). Determine the A24/A32 offset to read or write to using the following formula:

 $A24/A32 \ Offset = 2000_{16} + (FuncNum \ x \ 256) + Reg \ Offset$ 

#### 5.8.1.2 Byte Enables in a Direct Access Cycle

The byte enable field of the Direct Access Register is only used during a read access. Byte enable for write accesses are determined by the type of VXI bus access. The byte enable field is applied directly to the C/BE# signals on the PCI bus during direct access reads from the VXI host. Since the PCI byte enables are active low, the byte enable bits of the control register are active low. If a target supports pre-fetching, it will return all bytes regardless of byte enables.

# APPENDIX A CONNECTORS

| Pin | Row A  | Row B     | Row C |
|-----|--------|-----------|-------|
| 1   | /CS    | GND       | (/AS) |
| 2   | A01    | +5V       | D16   |
| 3   | A02    | +12V      | D17   |
| 4   | A03    | -12V      | D18   |
| 5   | A04    | GND       | D19   |
| 6   | A05    | (/DREQ)   | D20   |
| 7   | A06    | (/DACK)   | D21   |
| 8   | A07    | GND       | D22   |
| 9   | D08    | D00/(A08) | TRIGA |
| 10  | D09    | D01/(A09) | TRIGB |
| 11  | D10    | D02/(A10) | D23   |
| 12  | D11    | D03/(A11) | D24   |
| 13  | D12    | D04/(A12) | D25   |
| A14 | D13    | D05/(A13) | D26   |
| 15  | D14    | D06/(A14) | D27   |
| 16  | D15    | D07/(A15) | D28   |
| 17  | /DS1   | /DS0      | D29   |
| 18  | DTACK  | /WRITE    | D30   |
| 19  | /IACK  | /IRQ      | D31   |
| 20  | /RESET | SYSCLK    | /DS2  |

Note: Signals in parentheses ( ) are not used on this module.

Figure A-1. M-Module Connector Configuration

| PIN | С         | В       | А        |
|-----|-----------|---------|----------|
| 1   | D08       | -       | D00      |
| 2   | D09       | -       | D01      |
| 3   | D10       | -       | D02      |
| 4   | D11       | BG0IN*  | D03      |
| 5   | D12       | BG0OUT* | D04      |
| 6   | D13       | BG1IN*  | D05      |
| 7   | D14       | BG10UT* | D06      |
| 8   | D15       | BG2IN*  | D07      |
| 9   | GND       | BG20UT* | GND      |
| 10  | SYSFAIL*  | BG3IN*  | -        |
| 11  | -         | BG3OUT* | -        |
| 12  | SYSRESET* | -       | DS1*     |
| 13  | LWORD*    | -       | DS0*     |
| 14  | AM5       | -       | WRITE*   |
| 15  | A23       | -       | -        |
| 16  | A22       | AM0     | DTACK*   |
| 17  | A21       | AM1     | _        |
| 18  | A20       | AM2     | _        |
| 19  | A19       | AM3     | _        |
| 20  | A18       | GND     | IACK*    |
| 21  | A17       | -       | IACKIN*  |
| 22  | A16       | -       | IACKOUT* |
| 23  | A15       | GND     | AM4      |
| 24  | A14       | IRQ7*   | A07      |
| 25  | A13       | IRQ6*   | A06      |
| 26  | A12       | IRQ5*   | A05      |
| 27  | A11       | IRQ4*   | A04      |
| 28  | A10       | IRQ3*   | A03      |
| 29  | A09       | IRQ2*   | A02      |
| 30  | A08       | IRQ1*   | A01      |
| 31  | +12 V     | -       | -12 V    |
| 32  | +5 V      | +5 V    | +5 V     |

Figure A-2. VXI P1 Pin Configuration

| PIN         | С        | В   | А        |
|-------------|----------|-----|----------|
| 1           | -        | +5V | -        |
| 2           | -        | GND | -        |
| 2<br>3<br>4 | GND      | -   | -        |
| 4           | -        | A24 | GND      |
| 5           | -        | A25 | -        |
| 6           | -        | A26 | -        |
| 7           | GND      | A27 | -        |
| 8           | -        | A28 | -        |
| 9           | -        | A29 | -        |
| 10          | GND      | A30 | GND      |
| 11          | -        | A31 | -        |
| 12          | -        | GND | -        |
| 13          | -        | +5V | -        |
| 14          | -        | D16 | -        |
| 15          | -        | D17 | -        |
| 16          | GND      | D18 | GND      |
| 17          | -        | D19 | -        |
| 18          | -        | D20 | -        |
| 19          | -        | D21 | -        |
| 20          | -        | D22 | -        |
| 21          | -        | D23 | -        |
| 22          | GND      | GND | GND      |
| 23          | TTLTRG1* | D24 | TTLTRG0* |
| 24          | TTLTRG3* | D25 | TTLTRG2* |
| 25          | GND      | D26 | +5V      |
| 26          | TTLTRG5* | D27 | TTLTRG4* |
| 27          | TTLTRG7* | D28 | TTLTRG6* |
| 28          | GND      | D29 | GND      |
| 29          | -        | D30 | -        |
| 30          | GND      | D31 | MODID    |
| 31          | -        | GND | GND      |
| 32          | -        | +5V | -        |

Figure A-3. VXI P2 Pin Configuration

|     | P3        |     |          | P4 |     |           |     |           |
|-----|-----------|-----|----------|----|-----|-----------|-----|-----------|
| PIN | Signal    | PIN | Signal   |    | PIN | Signal    | PIN | Signal    |
| 1   | ТСК       | 2   | -12V     |    | 1   | +12V      | 2   | TRST#     |
| 3   | GND       | 4   | INTA#    |    | 3   | TMS       | 4   | TDO       |
| 5   | INTB#     | 6   | INTC#    |    | 5   | TDI       | 6   | GND       |
| 7   | BUSMODE1# | 8   | +5V      |    | 7   | GND       | 8   | PCI-RSVD  |
| 9   | INTD#     | 10  | PCI-RSVD |    | 9   | PCI-RSVD  | 10  | PCI-RSVD  |
| 11  | GND       | 12  | +3.3Vaux |    | 11  | BUSMODE2# | 12  | +3.3V     |
| 13  | CLK       | 14  | GND      |    | 13  | RST#      | 14  | BUSMODE3# |
| 15  | GND       | 16  | GNT#     |    | 15  | +3.3V     | 16  | BUSMODE4# |
| 17  | REQ#      | 18  | +5V      |    | 17  | PME#      | 18  | GND       |
| 19  | V(I/O)    | 20  | AD[31]   |    | 19  | AD[30]    | 20  | AD[29]    |
| 21  | AD[28]    | 22  | AD[27]   |    | 21  | GND       | 22  | AD[26]    |
| 23  | AD[25]    | 24  | GND      |    | 23  | AD[24]    | 24  | +3.3V     |
| 25  | GND       | 26  | C/BE[3]# |    | 25  | IDSEL     | 26  | AD[23]    |
| 27  | AD[22]    | 28  | AD[21]   |    | 27  | +3.3V     | 28  | AD[20]    |
| 29  | AD[19]    | 30  | +5V      |    | 29  | AD[18]    | 30  | GND       |
| 31  | V(I/O)    | 32  | AD[17]   |    | 31  | AD[16]    | 32  | C/BE[2]#  |
| 33  | FRAME#    | 34  | GND      |    | 33  | GND       | 34  | PMC-RSVD  |
| 35  | GND       | 36  | IRDY#    |    | 35  | TRDY#     | 36  | +3.3V     |
| 37  | DEVSEL#   | 38  | +5V      |    | 37  | GND       | 38  | STOP#     |
| 39  | GND       | 40  | LOCK#    |    | 39  | PERR#     | 40  | GND       |
| 41  | PCI-RSVD  | 42  | PCI-RSVD |    | 41  | +3.3V     | 42  | SERR#     |
| 43  | PAR       | 44  | GND      |    | 43  | C/BE[1]#  | 44  | GND       |
| 45  | V(I/O)    | 46  | AD[15]   |    | 45  | AD[14]    | 46  | AD[13]    |
| 47  | AD[12]    | 48  | AD[11]   |    | 47  | M66EN     | 48  | AD[10]    |
| 49  | AD[09]    | 50  | +5V      |    | 49  | AD[08]    | 50  | +3.3V     |
| 51  | GND       | 52  | C/BE[0]# |    | 51  | AD[07]    | 52  | PMC-RSVD  |
| 53  | AD[06]    | 54  | AD[05]   |    | 53  | +3.3V     | 54  | PMC-RSVD  |
| 55  | AD[04]    | 56  | GND      |    | 55  | PMC-RSVD  | 56  | GND       |
| 57  | V(I/O)    | 58  | AD[03]   |    | 57  | PMC-RSVD  | 58  | PMC-RSVD  |
| 59  | AD[02]    | 60  | AD[01]   |    | 59  | GND       | 60  | PMC-RSVD  |
| 61  | AD[00]    | 62  | +5V      |    | 61  | ACK64#    | 62  | +3.3V     |
| 63  | GND       | 64  | REQ64#   |    | 63  | GND       | 64  | PMC-RSVD  |

Note: Italicized words are unused signals.

| Figure A-4. PMC Pin Configuration | Figure A-4. | PMC Pin | Configuration |
|-----------------------------------|-------------|---------|---------------|
|-----------------------------------|-------------|---------|---------------|

|     | F        | P6  |          |     | F      | 25  |        |
|-----|----------|-----|----------|-----|--------|-----|--------|
| PIN | Signal   | PIN | Signal   | PIN | Signal | PIN | Signal |
| 1   | PCI-RSVD | 2   | GND      | 1   | I/O    | 2   | I/O    |
| 3   | GND      | 4   | C/BE[7]# | 3   | I/O    | 4   | I/O    |
| 5   | C/BE[6]# | 6   | C/BE[5]# | 5   | I/O    | 6   | I/O    |
| 7   | C/BE[4]# | 8   | GND      | 7   | I/O    | 8   | I/O    |
| 9   | V(I/O)   | 10  | PAR64    | 9   | I/O    | 10  | I/O    |
| 11  | AD[63]   | 12  | AD[62]   | 11  | I/O    | 12  | I/O    |
| 13  | AD[61]   | 14  | GND      | 13  | I/O    | 14  | I/O    |
| 15  | GND      | 16  | AD[60]   | 15  | I/O    | 16  | I/O    |
| 17  | AD[59]   | 18  | AD[58]   | 17  | I/O    | 18  | I/O    |
| 19  | AD[57]   | 20  | GND      | 19  | I/O    | 20  | I/O    |
| 21  | V(I/O)   | 22  | AD[56]   | 21  | I/O    | 22  | I/O    |
| 23  | AD[55]   | 24  | AD[54]   | 23  | I/O    | 24  | I/O    |
| 25  | AD[53]   | 26  | GND      | 25  | I/O    | 26  | I/O    |
| 27  | GND      | 28  | AD[52]   | 27  | I/O    | 28  | I/O    |
| 29  | AD[51]   | 30  | AD[50]   | 29  | I/O    | 30  | I/O    |
| 31  | AD[49]   | 32  | GND      | 31  | I/O    | 32  | I/O    |
| 33  | GND      | 34  | AD[48]   | 33  | I/O    | 34  | I/O    |
| 35  | AD[47]   | 36  | AD[46]   | 35  | I/O    | 36  | I/O    |
| 37  | AD[45]   | 38  | GND      | 37  | I/O    | 38  | I/O    |
| 39  | V(I/O)   | 40  | AD[44]   | 39  | I/O    | 40  | I/O    |
| 41  | AD[43]   | 42  | AD[42]   | 41  | I/O    | 42  | I/O    |
| 43  | AD[41]   | 44  | GND      | 43  | I/O    | 44  | I/O    |
| 45  | GND      | 46  | AD[40]   | 45  | I/O    | 46  | I/O    |
| 47  | AD[39]   | 48  | AD[38]   | 47  | I/O    | 48  | I/O    |
| 49  | AD[37]   | 50  | GND      | 49  | I/O    | 50  | I/O    |
| 51  | GND      | 52  | AD[36]   | 51  | I/O    | 52  | I/O    |
| 53  | AD[35]   | 54  | AD[34]   | 53  | I/O    | 54  | I/O    |
| 55  | AD[33]   | 56  | GND      | 55  | I/O    | 56  | I/O    |
| 57  | V(I/O)   | 58  | AD[32]   | 57  | I/O    | 58  | 1/0    |
| 59  | PCI-RSVD | 60  | PCI-RSVD | 59  | I/O    | 60  | I/O    |
| 61  | PCI_RSVD | 62  | GND      | 61  | I/O    | 62  | I/O    |
| 63  | GND      | 64  | PCI-RSVD | 63  | I/O    | 64  | I/O    |

Note: Italicized words are unused signals.

| Figure A-5. P | PMC Pin | Configuration | (continued) |
|---------------|---------|---------------|-------------|
|---------------|---------|---------------|-------------|

|             |     |   | СС     | MMON |
|-------------|-----|---|--------|------|
|             |     |   |        | . 🔺  |
|             | CH7 |   | 0      | Ц    |
| Ω           | CH6 | 0 | 0      | Ц    |
| EXT DRIVERS | CH5 | 0 | 0      | Ц    |
| 무           | CH4 | 0 | 0      | Ц    |
| Ž           | CH3 | 0 | 0      | Ц    |
| Ē           | CH2 | 0 | 0      | Ц    |
| ŝ           | CH1 | 0 | 0      |      |
|             | +5V | 0 | $\sim$ |      |

**Figure A-6. External Driver Outputs** 



**Figure A-7. External Inputs** 



Figure A-8. Serial Comm

| TDO<br>TDI<br>+3.3 V<br>TCK<br>TMS<br>-<br>HRESET-<br>+3.3 V | 0000000 | 000000000 | -<br>COPTRST-<br>+3.3 V<br>-<br>-<br>-<br>-<br>- (KEY)<br>GND | СОР |
|--------------------------------------------------------------|---------|-----------|---------------------------------------------------------------|-----|
|--------------------------------------------------------------|---------|-----------|---------------------------------------------------------------|-----|

Figure A-9. JTAG/COP Header



Figure A-10. External Power Connectors



Figure A-11. PMC I/O Connector

# APPENDIX B CONFIGURATION REGISTERS

| Devi                                                  | ce ID                         | Ven                            | dor ID                 | 00 |  |
|-------------------------------------------------------|-------------------------------|--------------------------------|------------------------|----|--|
| PCI                                                   | Status                        | PCI C                          | ommand                 | 04 |  |
| Class Code                                            | Subclass Code                 | Standard Programming           | Revision ID            | 08 |  |
| BIST Control                                          | Header Type                   | Latency Timer                  | Cache Line Size        | 0C |  |
|                                                       | Local Memory Bas              | se Address Register            |                        | 10 |  |
|                                                       | Peripheral Control And Status | Register Base Address Register |                        | 14 |  |
|                                                       | Local Memory Base             | e Address Register 1           |                        | 18 |  |
| Subsys                                                | item ID                       | Subsystem                      | n Vendor ID            | 2C |  |
|                                                       | Expansion Ron                 | n Base Address                 |                        | 30 |  |
| MAX LAT                                               | MAX LAT MIN GNT               |                                | Interrupt Line         | 3C |  |
| Rese                                                  | erved                         | Subordinate Bus #              | Bus Number             | 40 |  |
| PCI Arbit                                             | er Control                    | PCI Gene                       | eral Control           | 44 |  |
| Output Driver Control                                 | PMCR2                         | PM                             | ICR1                   | 70 |  |
| Misc Driver Control Reg 2                             | Misc Driver Control Reg 1     | Clock Driver                   | Control Register       | 74 |  |
| Embedded Utilities Memory Block Base Address Register |                               |                                |                        | 78 |  |
| Memory Starting Address                               |                               |                                |                        |    |  |
| Memory Starting Address                               |                               |                                |                        |    |  |
| Extended Memory Starting Address                      |                               |                                |                        |    |  |
| Extended Memory Starting Address                      |                               |                                |                        |    |  |
| Memory Ending Address                                 |                               |                                |                        |    |  |
|                                                       | Memory End                    | ding Address                   |                        | 94 |  |
|                                                       | Extended Memor                | y Ending Address               |                        | 98 |  |
|                                                       | Extended Memor                | y Ending Address               |                        | 9C |  |
| Memory Page Mode                                      | Rese                          | rved                           | Memory Bank Enable     | A0 |  |
|                                                       | Processor Interface Co        | onfiguration Register 1        | · · · · · ·            | A8 |  |
|                                                       | Processor Interface Co        | onfiguration Register 2        |                        | AC |  |
| Rese                                                  | erved                         | ECC Single-Bit Trigger         | ECC Single-Bit Counter | B8 |  |
| Proc. Bus Error Status                                | Reserved                      | Error Detection 1              | Error Enabling 1       | C0 |  |
| PCI Bus Error Status                                  | Reserved                      | Error Detection 2              | Error Enabling 2       | C4 |  |
|                                                       | Processor/PCI                 | Error Address                  |                        | C8 |  |
|                                                       | Extended ROM Con              | figuration Register 1          |                        | D0 |  |
|                                                       | Extended ROM Con              | 0 0                            |                        | D4 |  |
|                                                       | Extended ROM Con              | <u> </u>                       |                        | D8 |  |
| Extended ROM Configuration Register 4                 |                               |                                |                        | DC |  |
| Reserved                                              | PLL Configuration             | Reserved                       | Addr. Map B Options    | E0 |  |
|                                                       | Memory Control Cor            | nfiguration Register 1         | • •                    | F0 |  |
|                                                       | Memory Control Cor            | figuration Register 2          |                        | F4 |  |
|                                                       | Memory Control Cor            | figuration Register 3          |                        | F8 |  |
|                                                       | Memory Control Cor            | figuration Register 4          |                        | FC |  |

# Table B-1. PowerPC Configuration Registers

# **B.1 PCI INTERFACE CONFIGURATION REGISTERS**

| <b>00</b> 16            | Device ID (Read)                                                         |                           | Vendor ID (Read)           |                    |  |  |  |
|-------------------------|--------------------------------------------------------------------------|---------------------------|----------------------------|--------------------|--|--|--|
| Default                 | 000616                                                                   |                           |                            | 1057 <sub>16</sub> |  |  |  |
| Initialized             |                                                                          |                           | (read only)                |                    |  |  |  |
| Innualized              | (read only)                                                              |                           | (read only)                |                    |  |  |  |
| 0.4                     | DOLO                                                                     |                           |                            |                    |  |  |  |
| 04 <sub>16</sub>        | PCI Status                                                               |                           | PCI Command                |                    |  |  |  |
| Default                 | 00A0 <sub>16</sub>                                                       |                           | 000416                     |                    |  |  |  |
| Initialized             | (bit reset only)                                                         |                           | 0004 <sub>16</sub>         |                    |  |  |  |
| <b>08</b> 16            | Class Code                                                               | Subclass Code             | Standard Programm          | ning Revision ID   |  |  |  |
| Default                 | 0616                                                                     | 0016                      | 0016                       | MPC8245 revision   |  |  |  |
| Initialized             | (read only)                                                              | (read only)               | (read only)                | (read only)        |  |  |  |
|                         |                                                                          |                           |                            | • • • •            |  |  |  |
| 0C <sub>16</sub>        | BIST control                                                             | Header type               | Latency timer              | Cache line size    |  |  |  |
| Default                 | 0016                                                                     | 0016                      | 0016                       | 0016               |  |  |  |
| Initialized             | (read only)                                                              | (read only)               | 0116                       | 0816               |  |  |  |
|                         |                                                                          |                           | - 10                       | - 10               |  |  |  |
| 10 <sub>16</sub>        | Local memory Base                                                        | Address Register 0        |                            |                    |  |  |  |
| Default                 | 0000_0008 <sub>16</sub>                                                  |                           |                            |                    |  |  |  |
| Initialized             | 0000_000816                                                              |                           |                            |                    |  |  |  |
| Innualized              | 0000_000010                                                              |                           |                            |                    |  |  |  |
| 14 <sub>16</sub>        | Perinheral control a                                                     | nd status register base a | ddress register            |                    |  |  |  |
| Default                 | Peripheral control and status register base address register 0000_000016 |                           |                            |                    |  |  |  |
| Initialized             | 0000_000016                                                              |                           |                            |                    |  |  |  |
| Innualized              | 0000_000010                                                              |                           |                            |                    |  |  |  |
| 1816                    | Local memory Base                                                        | Address Register 1 (Rea   | d/Write)                   |                    |  |  |  |
| Default                 | 0000 0008 <sub>16</sub>                                                  | riduress Register 1 (Red  |                            |                    |  |  |  |
| Initialized             | 0000_000816                                                              |                           |                            |                    |  |  |  |
| Initianized             | 0000_000010                                                              |                           |                            |                    |  |  |  |
| 2C <sub>16</sub>        | Subsystem ID                                                             |                           | Subsystem Vendor           | ID                 |  |  |  |
| Default                 | 000016                                                                   |                           | 000016                     |                    |  |  |  |
| Initialized             | 000016                                                                   |                           | 000016                     |                    |  |  |  |
| Initialized             | 000010                                                                   |                           | 000010                     |                    |  |  |  |
| <b>30</b> <sub>16</sub> | Expansion ROM bas                                                        | se address                |                            |                    |  |  |  |
| Default                 | 0000_000016                                                              |                           |                            |                    |  |  |  |
| Initialized             | (read only)                                                              |                           |                            |                    |  |  |  |
|                         | · · · · · · · · · · · · //                                               |                           |                            |                    |  |  |  |
| 3C <sub>16</sub>        | MAX LAT                                                                  | MIN GNT                   | Interrupt Pin              | Interrupt line     |  |  |  |
| Default                 | 0016                                                                     | 0016                      | 01 <sub>16</sub>           | 0016               |  |  |  |
| Initialized             | (read only)                                                              | (read only)               | (read only)                | 01 <sub>16</sub>   |  |  |  |
| u                       | (                                                                        | (read only)               | (read only)                | ~ * 10             |  |  |  |
| 4016                    | Reserved                                                                 | Reserved                  | Subordinate Bus Numl       | ber Bus Number     |  |  |  |
| Default                 | -                                                                        | -                         | 0016                       | 0016               |  |  |  |
| Initialized             | -                                                                        | -                         | 0016                       | 0016               |  |  |  |
| muunzeu                 | 1                                                                        |                           | ~~1 <u>0</u>               | 0010               |  |  |  |
| 44                      | DCI ambitan control                                                      | rogistor                  | <b>BCI</b> general control | nogiston           |  |  |  |
| 44 <sub>16</sub>        | PCI arbiter control                                                      | register                  | PCI general control        | register           |  |  |  |
| Default<br>Initialized  | 0000 <sub>16</sub><br>C080 <sub>16</sub>                                 |                           | 000016                     |                    |  |  |  |
|                         | 1 1 100016                                                               |                           | 1 101/112                  |                    |  |  |  |

### **B.2 PERIPHERAL POWER MANAGEMENT CONFIGURATION REGISTERS**

| 70 <sub>16</sub> | Output Dr Cntl    | PMCR2             | PMCR1              |
|------------------|-------------------|-------------------|--------------------|
| Default          | switch configured | switch configured | 0000 <sub>16</sub> |
| Initialized      | A5 <sub>16</sub>  | 44 <sub>16</sub>  | C007 <sub>16</sub> |

### **B.3 OUTPUT/CLOCK DRIVER AND MISC I/O CONTROL REGISTERS**

| 74 <sub>16</sub> | Misc. Dr. Cntl 2 | Misc. Dr. Cntl 1 | CLK Driver Control register |
|------------------|------------------|------------------|-----------------------------|
| Default          | 0016             | 0016             | 0000 <sub>16</sub>          |
| Initialized      | 0016             | 0016             | FC00 <sub>16</sub>          |

### **B.4 EMBEDDED UTILITIES MEMORY BLOCK ADDRESS REGISTER**

| 78 <sub>16</sub> | Embedded utilities memory block base address register |
|------------------|-------------------------------------------------------|
| Default          | 0000_000016                                           |
| Initialized      | 8000_000016                                           |

# **B.5 MEMORY INTERFACE CONFIGURATION REGISTERS**

| 80 <sub>16</sub>        | Memory Star<br>Bank 3   |            | Bank 2       |         | Bank 1   |         | Bank 0    |          |
|-------------------------|-------------------------|------------|--------------|---------|----------|---------|-----------|----------|
| Default                 | 0000_000016             |            |              |         |          |         |           |          |
| Initialized             | 8080_8000 <sub>16</sub> |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
| 84 <sub>16</sub>        | Memory Star             | ting Addr  | ess          |         |          |         |           |          |
|                         | Bank 7                  |            | Bank 6       |         | Bank 5   |         | Bank 4    |          |
| Default                 | 0000_000016             |            | •            |         | •        |         | •         |          |
| Initialized             | 8080_808016             |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
| 88 <sub>16</sub>        | Extended Me             | mory Star  | ting Address |         |          |         |           |          |
|                         | Reserved                | Bank 3     | Reserved     | Bank 2  | Reserved | Bank 1  | Reserved  | Bank     |
| Default                 | 0000_000016             |            |              |         |          |         |           |          |
| Initialized             | 8080_800016             |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
| 8C16                    | Extended Me             | emory Star | ting Address |         |          |         |           |          |
|                         | Reserved                | Bank 7     |              | Bank 6  | Reserved | Bank 5  | Reserved  | Bank     |
| Default                 | 0000_000016             |            |              |         |          |         |           |          |
| Initialized             | 8080_808016             |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
| 00                      | Memory End              | ling Addro |              |         |          |         |           |          |
| 90 <sub>16</sub>        | Bank 3                  | ing Autre  | Bank 2       |         | Bank 1   |         | Bank 0    |          |
| Default                 | 0000_0000 <sub>16</sub> |            | Dalik 2      |         | Dalik I  |         | Dalik U   |          |
| Initialized             | 8080_807F <sub>16</sub> |            |              |         |          |         |           |          |
| IIIIuaiizeu             | 8080_8071 <sub>16</sub> |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
| 94 <sub>16</sub>        | Memory End              | ling Addre | 88           |         |          |         |           |          |
| <b>71</b> 0             | Bank 7                  | ing Huure  | Bank 6       |         | Bank 5   |         | Bank 4    |          |
| Default                 | 0000_0000 <sub>16</sub> |            | Dunk 0       |         | Dulik 5  |         | Dunk 4    |          |
| Initialized             | 8080_8080 <sub>16</sub> |            |              |         |          |         |           |          |
| mnanzeu                 | 0000_000016             |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
| 98 <sub>16</sub>        | Extended Me             | mory Fnd   | ing Address  |         |          |         |           |          |
| <b>JO</b> 16            | Reserved                | Bank 3     | Reserved     | Bank 2  | Reserved | Bank 1  | Reserved  | Bank     |
| Default                 | 0000_0000 <sub>16</sub> | Dalik 3    | Reserved     | Dalik 2 | Reserved | Dalik I | Reserved  | Dalik    |
| Initialized             | 8080_8000 <sub>16</sub> |            |              |         |          |         |           |          |
| minanzeu                | 8080_800016             |            |              |         |          |         |           |          |
|                         |                         |            |              |         |          |         |           |          |
| 0.0                     |                         |            |              |         |          |         |           |          |
| 9C <sub>16</sub>        | Extended Me             |            |              | D 1 (   | D 1      | D 1 5   |           |          |
| D C L                   | Reserved                | Bank 7     | Reserved     | Bank 6  | Reserved | Bank 5  | Reserved  | Bank     |
| Default                 | 0000_000016             |            |              |         |          |         |           |          |
| Initialized             | 8080_8080 <sub>16</sub> |            |              |         |          |         |           |          |
| minumzea                |                         |            |              |         |          |         |           |          |
| Initianizea             |                         |            |              |         |          |         |           |          |
| Intuized                |                         | - Mada     | Reserved     |         | Reserved |         | Memory Ba | nk Enabl |
| A0 <sub>16</sub>        | Memory Page             | e Mode     |              |         |          |         | 0016      |          |
|                         | Memory Page 0016        | e Mode     | -            |         |          |         |           |          |
| A0 <sub>16</sub>        | 1 8                     | e Mode     | -            |         | -        |         | 0116      |          |
| <b>A0</b> 16<br>Default | 0016                    |            | -            |         | -        |         |           |          |

| Default $00n4_0010_{16}$            |  |
|-------------------------------------|--|
| Initialized 0014_1310 <sub>16</sub> |  |

| AC <sub>16</sub> | Processor interface configuration register 2 |
|------------------|----------------------------------------------|
| Default          | $000C_{000}C_{16}$                           |
| Initialized      | 0000 000016                                  |

# **B.7 ERROR HANDLING REGISTERS**

| B816        | Reserved | ECC Single-Bit Trigger | ECC Single-Bit Counter |
|-------------|----------|------------------------|------------------------|
| Default     | -        | 0016                   | 0016                   |
| Initialized | -        | 0016                   | 0016                   |

| C016        | Proc. Bus Error Status | Reserved | Error Detection 1 | Error Enabling 1 |
|-------------|------------------------|----------|-------------------|------------------|
| Default     | 0016                   | -        | 0016              | 01 <sub>16</sub> |
| Initialized | (bit reset)            | -        | (bit reset)       | 0016             |

| C4 <sub>16</sub> | PCI Bus Error Status | Reserved | Error Detection 2 | Error Enabling 2 |
|------------------|----------------------|----------|-------------------|------------------|
| Default          | 0016                 | 0016     | 0016              | 0016             |
| Initialized      | (bit reset)          | -        | (bit reset)       | 0016             |

| C816        | Processor/PCI Error Address Register |
|-------------|--------------------------------------|
| Default     | 0000_000016                          |
| Initialized | (read only)                          |

#### **B.8 EXTENDED ROM CONFIGURATION REGISTERS**

| D0 <sub>16</sub> I | Extended ROM Configuration Register 1 |
|--------------------|---------------------------------------|
| Default H          | B5FF_8000 <sub>16</sub>               |
| Initialized 8      | 819F_815F <sub>16</sub>               |

| D4 <sub>16</sub> | Extended ROM Configuration Register 2 |
|------------------|---------------------------------------|
| Default          | B5FF_8000 <sub>16</sub>               |
| Initialized      | 84FF_8013 <sub>16</sub>               |

| D816        | Extended ROM Configuration Register 3 |
|-------------|---------------------------------------|
| Default     | 0C00_000E <sub>16</sub>               |
| Initialized | 0100_0000 <sub>16</sub>               |

| <b>DC</b> <sub>16</sub> | Extended ROM Configuration Register 4 |
|-------------------------|---------------------------------------|
| Default                 | 0C00 000E <sub>16</sub>               |

| Derman      | 0000_00010  |  |  |
|-------------|-------------|--|--|
| Initialized | 0000 100016 |  |  |

### **B.9 ADDRESS MAP B OPTIONS AND PLL CONFIGURATION REGISTER**

| E0 <sub>16</sub> | PLL Config Register | Reserved | Reserved | Addr. Map B Options |
|------------------|---------------------|----------|----------|---------------------|
| Default          | config setting      | -        | -        | C0 <sub>16</sub>    |
| Initialized      | (read only)         | -        | -        | 40 <sub>16</sub>    |

# **B.10 MEMORY CONTROLCONFIGURATION REGISTER**

F016Memory Control Configuration Register 1DefaultFFn2\_000016Initialized0B80\_000216

| F4 <sub>16</sub>            | Memory Control Configuration Register 2                |  |
|-----------------------------|--------------------------------------------------------|--|
| Default                     | 0000_000016                                            |  |
| Initialized                 | A660_0AB0 <sub>16</sub>                                |  |
|                             |                                                        |  |
|                             |                                                        |  |
|                             |                                                        |  |
| F8 <sub>16</sub>            | Memory Control Configuration Register 3                |  |
| F8 <sub>16</sub><br>Default | Memory Control Configuration Register 3<br>0000_000016 |  |
|                             |                                                        |  |

| FC <sub>16</sub> | Memory Control Configuration Register 4 |
|------------------|-----------------------------------------|
| Default          | 0010_000016                             |
| Initialized      | 25B2_3320 <sub>16</sub>                 |

#### **READER'S COMMENT FORM**

Your comments assist us in improving the usefulness of C&H's publications; they are an important part of the inputs used for revision.

C&H Technologies, Inc. may use and distribute any of the information that you supply in any way that it believes to be appropriate without incurring any obligation whatsoever. You may, of course, continue to use the information, which you supply.

Please refrain from using this form for technical questions or for requests for additional publications; this will only delay the response. Instead, please direct your technical questions to your authorized C&H representative.

COMMENTS:

Thank you for helping C&H to deliver the best possible product. Your support is appreciated.

Sincerely,

F. R. Harrison President and CEO

#### **INSTRUCTIONS**

In its continuing effort to improve documentation, C&H Technologies, Inc. provides this form for use in submitting any comments or suggestions that the user may have. This form may be detached, folded along the lines indicated, taped along the loose edge (DO NOT STAPLE), and mailed. Please try to be as specific as possible and reference applicable sections of the manual or drawings if appropriate. Also, indicate if you would like an acknowledgment mailed to you stating whether or not your comments were being incorporated.

NOTE: This form may not be used to request copies of documents or to request waivers, deviations, or clarification of specification requirements on current contracts. Comments submitted on this form do not constitute or imply authorization to waive any portion of the referenced document(s) or to amend contractual requirements.

—— (Fold along this line) —

(Fold along this line) -

C&H Technologies, Inc. <> 445 Round Rock West Drive <> Round Rock, TX 78681 <> www.chtech.com

Place Stamp Here

C&H Technologies, Inc. Technical Publications 445 Round Rock West Drive Round Rock, Texas 78681-5012