# Real-Time Clock and Interrupt Module (RCIM) User's Guide





0898007-900 June 2017 Copyright 2017 by Concurrent Real-Time, Inc.. All rights reserved. This publication or any part thereof is intended for use with Concurrent Real-Time, Inc. products by Concurrent Real-Time, Inc. personnel, customers, and end–users. It may not be reproduced in any form without the written permission of the publisher.

The information contained in this document is believed to be correct at the time of publication. It is subject to change without notice. Concurrent Real-Time, Inc. makes no warranties, expressed or implied, concerning the information contained in this document.

To report an error or comment on a specific portion of the manual, photocopy the page in question and mark the correction or comment on the copy. Mail the copy (and any additional comments) to Concurrent Real-Time, Inc., 2881 Gateway Drive Pompano Beach, FL 33069. Mark the envelope "Attention: Real-Time OS Publications **Department**." This publication may not be reproduced for any other reason in any form without written permission of the publisher.

Concurrent Real-Time, Inc. and its logo are registered trademarks of Concurrent Real-Time, Inc.. All other Concurrent Real-Time product names are trademarks of Concurrent Real-Time while all other product names are trademarks or registered trademarks of their respective owners. Linux® is used pursuant to a sublicense from the Linux Mark Institute.

Printed in U.S.A.

| Revision History:              | Level: | Effective With:               |
|--------------------------------|--------|-------------------------------|
| Original Release August 2002   | 000    | RedHawk Linux Release 1.1     |
| Previous Release December 2003 | 210    | RedHawk Linux Release 2.0     |
| Current Release May 2005       | 300    | RedHawk Linux Release 2.3     |
| Update September 2005          | 310    | RedHawk Linux Release 2.3-4.1 |
| Update May 2007                | 320    | RedHawk Linux Release 4.2     |
| Update April 2008              | 330    | RedHawk Linux Release 5.1     |
| Update June 2008               | 400    | RedHawk Linux Release 5.1     |
| Update October 2010            | 500    | RedHawk Linux Release 5.4     |
| Update December 2011           | 600    | RedHawk Linux Release 6.0     |
| Update February 2013           | 610    | RedHawk Linux Release 6.3     |
| Update February 2014           | 620    | RedHawk Linux Release 6.3     |
| Update March 2016              | 700    | RedHawk Linux Release 7.2     |
| Update June 2016               | 800    | RedHawk Linux Release 7.2     |
| Update June 2017               | 900    | RedHawk Linux Release 7.3     |

#### Scope of Manual

This manual is intended for users responsible for the installation and use of the Real-Time Clock and Interrupt Module (RCIM) on Concurrent Real-Time's iHawk<sup>TM</sup> systems under the RedHawk<sup>TM</sup> Linux<sup>®</sup> operating system.

#### NOTE

Three RCIM models are described in this guide: RCIM I, RCIM II and RCIM III. The use of the term "RCIM" refers to functionality common to all three boards. "RCIM I", "RCIM II" and "RCIM III" refer to the specific boards. Refer to the section "Specifications" on page 1-2 for specifications for each of the boards.

### Structure of Manual

This manual consists of the following:

- Chapter 1, *Introduction*, contains a general overview and specifications for the RCIM boards.
- Chapter 2, *Hardware, Installation and Configuration*, provides a description of the RCIM boards and connectors, as well as installation and configuration instructions.
- Chapter 3, *Functional Description*, provides the general operation, user interfaces and configuration options for the clocks and interrupts available on the RCIM.
- Appendix A, RCIM III Registers, describes the RCIM registers.
- Appendix D, *Calculating RCIM Cable Propagation Delays*, provides a formula for guarding against propagation delay when chaining RCIMs.
- The *Index* contains an alphabetical reference to key terms and concepts and the pages where they occur in the text.

#### Syntax Notation

The following notation is used throughout this guide:

| italic    | Books, reference cards, and items that the user must specify appear in <i>italic</i> type. Special terms may also appear in <i>italic</i> .                                                          |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| list bold | User input appears in <b>list bold</b> type and must be entered exactly<br>as shown. Names of directories, files, commands, options and man<br>page references also appear in <b>list bold</b> type. |

| list            | Operating system and program output such as prompts, messages and listings of files and programs appears in list type.                                                                                                                                                                                                                                                              |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| []              | Brackets enclose command options and arguments that are optional.<br>You do not type the brackets if you choose to specify these options or<br>arguments.                                                                                                                                                                                                                           |
| hypertext links | When viewing this document online, clicking on chapter, section, figure, table and page number references will display the corresponding text. Clicking on Internet URLs provided in <i>blue</i> type will launch your web browser and display the web site. Clicking on publication names and numbers in <i>red</i> type will display the corresponding manual PDF, if accessible. |

## **Related Publications**

| Title                                                      | Pub No. |
|------------------------------------------------------------|---------|
| RedHawk Linux Release Notes Version x.x                    | 0898003 |
| RedHawk Linux User's Guide                                 | 0898004 |
| RedHawk Linux Frequency-Based Scheduler (FBS) User's Guide | 0898005 |

where x.x = release version

# Contents

| Preface                                            | iii  |
|----------------------------------------------------|------|
| Chapter 1 Introduction                             |      |
| Overview                                           |      |
| Chapter 2 Hardware, Installation and Configuration |      |
| Board Descriptions                                 | 2-1  |
| RCIM III.                                          |      |
| Board Illustration.                                |      |
| Connectors and LEDs                                |      |
| LED Functions                                      |      |
| Input and Output Cables and Connectors             |      |
| Oscillators                                        |      |
| GPS Antenna                                        |      |
| External Interrupt I/O Connector                   |      |
| System Identification.                             |      |
| Daisy Chain Cable.                                 |      |
| RCIM II                                            |      |
| Board Illustration.                                | 2-8  |
| Connectors and LEDs                                | 2-8  |
| LED Functions                                      | 2-9  |
| Input and Output Cable Connectors                  | 2-10 |
| Oscillators                                        | 2-10 |
| GPS Antenna                                        | 2-10 |
| External Interrupt I/O Connector                   | 2-10 |
| System Identification.                             | 2-12 |
| Daisy Chain Cable.                                 | 2-12 |
| RCIM I                                             | 2-13 |
| Board Illustration                                 | 2-13 |
| Connectors and LEDs                                | 2-14 |
| LED Functions                                      | 2-14 |
| Output Cable Connector (P2)                        | 2-15 |
| Input Cable Connector (P3).                        | 2-16 |
| External Interrupts Connector (P4)                 |      |
| Debug Visibility Connector (P5).                   |      |
| In-System Programming Interface Connector (P6)     |      |
| System Identification.                             |      |
| Connection Modes                                   |      |
| Unpacking the RCIM.                                |      |
| Installation                                       |      |
| Configuration                                      |      |
| Kernel Configuration                               |      |
| Driver Configuration                               |      |
| General Considerations                             |      |
| MSI Interrupt Configuration.                       | 2-22 |

| ntp Configuration for GPS Support | 2-22 |
|-----------------------------------|------|
| Verifying ntp/GPS Operation       | 2-23 |

## Chapter 3 Functional Description

| Overview                                 | 3-1  |
|------------------------------------------|------|
| Clocks.                                  | 3-1  |
| The Tick Clock                           | 3-2  |
| The POSIX Clock                          | 3-2  |
| Direct Access to the Clocks              | 3-3  |
| Synchronizing the Clocks                 | 3-3  |
| The rcim_clocksync Utility               | 3-3  |
| Synchronizing the Tick Clock             | 3-5  |
| RCIM Masterclock Considerations          | 3-5  |
| Synchronizing the POSIX Clock            | 3-6  |
| Automatic Synchronization                | 3-6  |
| Using GPS for System Timekeeping         | 3-7  |
| Interrupt Processing                     | 3-8  |
| Interrupt Processing Logic               | 3-8  |
| Arming and Enabling DIs and ETIs         | 3-9  |
| Interrupt Recognition Logic              | 3-9  |
| Setting up Distributed Interrupts        | 3-10 |
| Obtaining RCIM Values                    | 3-11 |
| Edge-Triggered Interrupts                | 3-12 |
| ETI Configuration                        | 3-12 |
| ETI Device Files                         | 3-13 |
| User Interface to ETIs                   | 3-13 |
| Distributed ETIs                         | 3-14 |
| Real-Time Clocks (RTCs)                  | 3-14 |
| RTC Device Files                         | 3-14 |
| Distributed RTCs                         | 3-14 |
| User Interface to RTCs                   | 3-15 |
| External Output Interrupts               | 3-15 |
| Configuration                            | 3-16 |
| Programmable Interrupt Generators (PIGs) | 3-16 |
| PIG Device File                          | 3-16 |
| Distributed PIGs                         | 3-17 |
| Distributed Interrupts                   | 3-17 |
| DI Configuration                         | 3-18 |
| DI Device Files                          | 3-19 |
| User Interface to DIs                    | 3-19 |

## Appendix A RCIM III Registers

| RCIM III Address Map | A-1 |
|----------------------|-----|
| RCIM III Registers   | A-4 |

## Appendix B RCIM II Registers

| RCIM II Address Map | B-1 |
|---------------------|-----|
| RCIM II Registers.  | B-3 |

## Appendix C RCIM I Registers

| RCIM I Address Map | C-1 |
|--------------------|-----|
| RCIM I Registers   | C-2 |

## Appendix D Calculating RCIM Cable Propagation Delays

| RCIM II<br>RCIM II<br>RCIM I | D-1   |
|------------------------------|-------|
| Index In                     | dex-1 |

RCIM User's Guide

# 1 Introduction

This chapter provides an overview and specifications for the Real-Time Clock and Interrupt Module (RCIM).

#### NOTE

Three RCIM models are described in this guide: RCIM I, RCIM II and RCIM III. The use of the term "RCIM" refers to functionality common to all three boards. "RCIM I", "RCIM II" and "RCIM III" refer to the specific boards. The section "Specifications" provides specifications for each of the boards.

# **Overview**

The Real-Time Clock and Interrupt Module (RCIM) is a PCI-based card that supports time-critical applications that require rapid response to external events, synchronized clocks and/or synchronized interrupts.

When RCIM boards of various systems are chained together, an interrupt can be simultaneously distributed to all connected RCIMs, and from the RCIMs to all the associated host systems.

A synchronized high-resolution clock is provided so that all the RCIMs in an RCIM chain on multiple systems can share a common time base. It also provides a local POSIX 1003.1 compliant high resolution clock. An optional GPS module allows alignment of the clock to GPS standard time.Multiple RCIMs equipped with the GPS module can provide a common time base without cable connections. A high stability oscillator is standard. Optional oscillators improve the accuracy of times measured with the RCIM.

In addition to the clocks, this multi-purpose PCI-based card has the following functionality:

- · connection of external device interrupts
- · real time clock timers that can interrupt the system
- programmable interrupt generators which allow generation of an interrupt from an application program

These functions can all generate local interrupts on the system where the RCIM card is installed. When systems are chained together, multiple input and output interrupts can be distributed to other RCIM-connected systems. This allows one timer or one external interrupt or one application program to interrupt multiple RedHawk Linux systems almost simultaneously to create synchronized actions.

# **Specifications**

| Feature                                                    | RCIM III                                                  | RCIM II                                                   | RCIM I                                                    |
|------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------|
| Clocks                                                     |                                                           |                                                           |                                                           |
| POSIX                                                      |                                                           |                                                           |                                                           |
| Length                                                     | 64 bits (two 32-bit words)                                | 64 bits (two 32-bit words)                                | 64 bits (two 32-bit words)                                |
| Resolution                                                 | High-order 32 bits–1 second<br>Low-order 32 bits–400 nsec | High-order 32 bits–1 second<br>Low-order 32 bits–400 nsec | High-order 32 bits–1 second<br>Low-order 32 bits–400 nsec |
| Oscillator stability                                       | +/-2.5 PPM                                                | +/-20 PPM                                                 | +/-100 PPM                                                |
| Tick Timer                                                 |                                                           |                                                           |                                                           |
| Length                                                     | 64 bits (two 32-bit words)                                | 64 bits (two 32-bit words)                                | 64 bits (two 32-bit words)                                |
| Resolution                                                 | 64 bit counter of 400 ns ticks                            | 64 bit counter of 400 ns ticks                            | 64 bit counter of 400 ns ticks                            |
| Real-Time Clocks                                           |                                                           | ·                                                         |                                                           |
| Number                                                     | 8                                                         | 8                                                         | 4                                                         |
| Length                                                     | 32 bits                                                   | 32 bits                                                   | 32 bits                                                   |
| Resolution                                                 | 1 microsecond<br>(larger values programmable)             | 1 microsecond<br>(larger values programmable)             | 1 microsecond<br>(larger values programmable)             |
| Oscillator stability                                       | +/-2.5 PPM                                                | +/-20 PPM                                                 | +/-100 PPM                                                |
| Local Interrupts                                           |                                                           |                                                           |                                                           |
| External Edge-Triggered Interrupts                         | 12                                                        | 12                                                        | 4                                                         |
| External Output Interrupts                                 | 12                                                        | 12                                                        | 4                                                         |
| Real-Time Clocks                                           | 8                                                         | 8                                                         | 4                                                         |
| Distributed Interrupts                                     |                                                           |                                                           |                                                           |
| Input                                                      | 12                                                        | 12                                                        | 8                                                         |
| Output                                                     | 12                                                        | 12                                                        | 8                                                         |
| Interrupt Response Time                                    |                                                           |                                                           |                                                           |
| Interrupt to user process                                  | < 8 microseconds                                          | < 8 microseconds                                          | < 8 microseconds                                          |
| Packaging                                                  |                                                           |                                                           |                                                           |
| Form Factor                                                | PCIe                                                      | PCI                                                       | PCI                                                       |
| Maximum cable length<br>(See Appendix D for calculations.) | 30 meters                                                 | 32 ft.                                                    | 10 ft.                                                    |
| External Connectors                                        | Molex LFH-60                                              | Molex LFH-60                                              | 16 position .1" Latching Header                           |
| PCI Performance                                            | x1                                                        | 66 MHz 64-bit                                             | 33 MHz 32-bit                                             |
| Options                                                    | GPS Module, Oven Oscillator                               | GPS Module, Oven Oscillator                               | None                                                      |
| Environmental                                              |                                                           |                                                           |                                                           |
| Operating Temperature                                      | 10 <sup>o</sup> to 40 <sup>o</sup> C                      | 10 <sup>o</sup> to 40 <sup>o</sup> C                      | 10° to 40° C                                              |
| Storage Temperature                                        | -40° to 65° C                                             | -40° to 65° C                                             | -40° to 65° C                                             |
| Relative Humidity                                          | 10 to 90% (non-condensing)                                | 10 to 90% (non-condensing)                                | 10 to 80% (non-condensing)                                |
| Power                                                      | 1                                                         |                                                           |                                                           |
| Consumption                                                | ~5 watts                                                  | ~5 watts                                                  | ~5 watts                                                  |

# Hardware, Installation and Configuration

This chapter provides a description of the RCIM PCI-based boards as well as installation and configuration information.

# **Board Descriptions**

This section provides illustrations and descriptions of the RCIM III, RCIM II and RCIM I boards.

RCIM II and RCIM I boards mount in a standard PCI slot and the RCIM III board mounts into a standard PCI-e slot on a host system. A connector is mounted on each RCIM for connection to external interrupts, and a synchronization cable is included for daisy-chaining a master RCIM to one or more slave RCIMs.

2

# **RCIM III**

## **Board Illustration**

Figure 2-1 shows the RCIM III board with optional high stability OCXO (Oven Controlled Crystal Oscillator) and GPS modules installed.

Figure 2-1 RCIM III Board



### **Connectors and LEDs**

Figure 2-2 shows the input/output connectors and LEDs on the RCIM III board. Detailed information on the LEDs and each of the connectors is provided in the following sections.





### **LED Functions**

There are two bi-colored status LEDs near the input and output connectors on the RCIM III board. They will both glow dimly RED when the board is in reset mode

| LED             | description                            | Function                                                                         |  |  |  |  |
|-----------------|----------------------------------------|----------------------------------------------------------------------------------|--|--|--|--|
| Output          | RED solid                              | 10 MHz clock failure                                                             |  |  |  |  |
| Status<br>LED   | RED 2/sec flash                        | cable option installed but not synchronized or miss-<br>ing, POSIX clock stopped |  |  |  |  |
|                 | GREEN 1/sec flash                      | POSIX clock running without cable option                                         |  |  |  |  |
|                 | GREEN 1/sec blink                      | POSIX clock running with cable attached and syn-<br>chronized                    |  |  |  |  |
|                 | RED/GREEN alter-<br>nating 2/sec flash | POSIX clock running with cable unsychronized or missing                          |  |  |  |  |
| Input<br>Status | RED 2/sec flash                        | cable option installed but cable unsynchronized or missing                       |  |  |  |  |
| LED             | GREEN solid                            | cable attached and synchronized                                                  |  |  |  |  |

followed by brief intervals of bright RED and GREEN as a test. During normal operation of the board the LEDs function as follows:

#### Input and Output Cables and Connectors

The RCIM III uses a pair of standard SFP (small form-factor pluggable) connectors installed in cages to interface to the RCIM III cable. The cable is used to communicate interrupts, time stamps and a reference clock between RCIM III boards. The output cable connector is used when the RCIM is either the master or a slave in the middle of an RCIM chain (see page 2-18 for a description of RCIM modes). The input cable connector is used when the RCIM is acting in slave mode or in the middle of an RCIM chain. The cable part number (HS002-3CBL-xx where xx is length in meters) includes an LC fiber optic cable and two SFPs that are installed in the empty cages on the master and slave RCIMs. Refer to the section "Daisy Chain Cable" for more information about the cable.

#### NOTE

The cable SFPs should only be installed and removed with the system containing the RCIM III powered down. See the Installation section for ESD caution. Care should be taken to insure that the SFP modules lock into position and that the RCIM III is not pushed out of its PCIe slot during the installation of the SFPs. The fiber optic cables themselves can be installed and removed at any time without damaging the RCIM III.

#### Oscillators

The temperature compensated crystal oscillator (TCXO) provided with RCIM III has an accuracy of +/- 2.5 PPM (parts per million).

Two optional oven controlled crystal oscillators (OCXO) provide a temperature stability of +/- 210 PPB (parts per billion) or +/- 10 PPB (parts per billion).

#### **GPS** Antenna

The GPS option on the RCIM III includes an active GPS antenna and coaxial cable.

The antenna receives the GPS satellite signals and passes them to the receiver. The GPS signals are spread spectrum signals in the 1575 MHz range and do not penetrate conductive or opaque surfaces. Therefore, the antenna must be located outdoors with a clear view of the sky.

If a different antenna or cable is used, it should match the following specifications:

- 50 Ohm impedence
- 27 dB gain
- 3.3 volt DC power max 30 ma.

#### **External Interrupt I/O Connector**

The external interrupt I/O connector on the RCIM III is a Molex LFH-60 (Low Force Helix) that provides twelve outputs and twelve inputs.

The external outputs allow equipment to be attached and controlled by the RCIM. The outputs are driven by a multiplexer which can select any of the programmable interrupt generators (PIGs), real-time clock timers (RTCs), edge-triggered interrupts (ETIs) or distributed interrupts (DIs) to drive the output. The selection is controlled by a set of configuration registers.

See Chapter 3 for information on using external output interrupts and programmable interrupts.

The pin-outs for the external interrupt I/O connector are shown in Figure 2-3.



Figure 2-3 RCIM III External Interrupt I/O Connector Pin-outs

The external interrupt input signals are 5 volt ttl levels. The external interrupt outputs (labeled EXT\_PIG[0-11]) are driven using a 74ABT16240 line driver. The external interrupt inputs are terminated with 180 ohms to +5 volts, 330 ohms and 0.1 uf to ground. To drive this input requires a line driver that can sink at least 30 ma. The input termination limits the speed of the external interrupt signals and helps prevent noise from causing spurious interrupts. Since most line drivers can sink more current than they can source, the falling edge of the signal will be faster.

The signals EXT\_CLKIN and EXT\_CLKOUT are used for external 10MHz clocks in or out. An external clock driving the RCIM III should be capable of driving a 5V ttl signal into a 50 ohm load. The RCIM III will automatically switch to using the external clock if one is present. The external clock output from the RCIM III is driven using a 74ABT16240 line driver.

The signals EXT\_RXD1, EXT\_TXD1, EXT\_RXD2, and EXT\_TXD2 are RS-232 level signals. They are currently used for debug purposes.

#### System Identification

The following output to **lspci(8)** shows the PCI class, vendor and device IDs for the RCIM III (0e:04.0 (*bus:slot.function*) will differ on your system):

# lspci -v | grep -i rcim 0e:04.0 System peripheral: Concurrent Real-Time, Inc. RCIM III Real-Time Clock & Interrupt Module (PCIe) (rev 01) # lspci -ns 0e:04.0 0e:04.0 Class 0880: 1542:9271 (rev 01)

#### **Daisy Chain Cable**

The RCIM III uses a fiber optic serial synchronization cable with SFP (small form-factor pluggable) connectors (part no. HS002-3CBL-xx) to connect RCIM IIIs in an RCIM chain. The serial data on the cable includes parity and framing information which allow cable problems to be detected. Polling is done continuously and messages that report the status of the RCIM III daisy chain cables are output when an error condition is detected. Messages indicating problems will appear on the systems directly connected by a failing link.

The serial cables are point to point connections. The "input" cable refers to the cable going upstream towards the master RCIM. The "output" cable is the downstream connection away from the master.

RCIM: Input cable disconnected. RCIM: Input cable connected. RCIM: Input cable connected but not synchronized. RCIM: Input cable unsynchronized. RCIM: Output cable 0.K. RCIM: Output cable disconnected. RCIM: Output cable connected but not synchronized. RCIM: Output cable unsynchronized. RCIM: Output cable unsynchronized. RCIM: Output cable 0.K. RCIM: Cable error on input cable. RCIM: Cable error on output cable.

The "disconnected" and "connected" messages will only occur based on whether an SFP is installed in the appropriate cage of the RCIM III.

They will not occur when the optical cable is inserted or removed. They should not occur during normal operation unless the SFP is not installed correctly or it is malfunctioning.

The "not synchronized" and "unsynchronized" messages indicate that the cable is not answering attempts to communicate. These messages will occur when the optical cable is installed or removed. They will also occur when a connected system is powered off. The last two messages indicate transient errors such as cable parity errors or temporary loss of cable synchronization. If a transient error occurs, it may require a link in the cable to resynchronize. If a distributed interrupt is being broadcast on the cable, it may be lost.

Transient errors also affect the synchronization of the tick timers since the cable clock will not reach all of the systems. Refer to Chapter 3 for instructions for synchronizing clocks.

## **RCIM II**

#### **Board Illustration**

Figure 2-4 shows the RCIM II board with optional high stability OCXO (Oven Controlled Crystal Oscillator) and GPS modules installed.



#### Figure 2-4 RCIM II Board

#### **Connectors and LEDs**

Figure 2-5 shows the input/output connectors and LEDs on the RCIM II board.

Detailed information on the LEDs and each of the connectors is provided in the following sections.



Figure 2-5 RCIM II Connectors and LED Locations

## **LED Functions**

The four LEDs for the RJ45 input and output connectors on the RCIM II board function as follows:

| Connector       | LED   | Function                                                                                                           |  |  |  |  |  |
|-----------------|-------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| RJ45 Output     | LED 1 | Red Failure, Green Activity                                                                                        |  |  |  |  |  |
| Cable Connector | LED 2 | Cable status:offcable not connectedyellowcable connected but not synchronizedgreencable connected and synchronized |  |  |  |  |  |
| RJ45 Input      | LED 3 | Always flashing green                                                                                              |  |  |  |  |  |
| Cable Connector | LED 4 | Cable status:offcable not connectedyellowcable connected but not synchronizedgreencable connected and synchronized |  |  |  |  |  |

#### Input and Output Cable Connectors

The output cable connector is used when the RCIM II is either the master, or a slave in the middle of an RCIM chain (see page 2-18 for a description of RCIM modes). The input cable connector is used when the RCIM is acting in slave mode.

The cable attached to the output cable connector is an RJ45 serial synchronization cable (part no. HS002-CBL-10). Refer to the section "Daisy Chain Cable" for more information about the cable.

Note that although RJ45 cables are used with Gigabit Ethernet, the RCIM II cables are not Ethernet compatible.

#### Oscillators

The standard crystal oscillator provided with RCIM II has an accuracy of +/- 20 PPM (parts per million).

Two optional oven controlled crystal oscillators (OCXO) provide a temperature stability of +/- 210 PPB (parts per billion) or +/- 10 PPB (parts per billion).

#### **GPS** Antenna

The GPS option on the RCIM II includes an active GPS antenna and coaxial cable.

The antenna receives the GPS satellite signals and passes them to the receiver. The GPS signals are spread spectrum signals in the 1575 MHz range and do not penetrate conductive or opaque surfaces. Therefore, the antenna must be located outdoors with a clear view of the sky.

If a different antenna or cable is used, it should match the following specifications:

- 50 Ohm impedence
- 27 dB gain
- 3.3 volt DC power max 30 ma.

#### **External Interrupt I/O Connector**

The external interrupt I/O connector on the RCIM II is a Molex LFH-60 (Low Force Helix) that provides twelve outputs and twelve inputs.

The external outputs allow equipment to be attached and controlled by the RCIM. The outputs are driven by a multiplexer which can select any of the programmable interrupt generators (PIGs), real-time clock timers (RTCs), edge-triggered interrupts (ETIs) or distributed interrupts (DIs) to drive the output. The selection is controlled by a set of configuration registers.

See Chapter 3 for information on using external output interrupts and programmable interrupts.

The pin-outs for the external interrupt I/O connector are shown in Figure 2-6.



Figure 2-6 RCIM II External Interrupt I/O Connector Pin-outs

The external interrupt input signals are 5 volt ttl levels. The external interrupt outputs (labeled EXT\_PIG[0-11]) are driven using a 74ABT16240 line driver. The external interrupt inputs are terminated with 180 ohms to +5 volts, 330 ohms and 0.1 uf to ground. To drive this input requires a line driver that can sink at least 30 ma. The input termination limits the speed of the external interrupt signals and helps prevent noise from causing spurious interrupts. Since most line drivers can sink more current than they can source, the falling edge of the signal will be faster.

The signals EXT\_CLKIN and EXT\_CLKOUT are used for external 10MHz clocks in or out. An external clock driving the RCIM II should be capable of driving a 5V ttl signal into a 50 ohm load. The RCIM II will automatically switch to using the external clock if one is present. The external clock output from the RCIM II is driven using a 74ABT16240 line driver.

The signals EXT\_RXD1, EXT\_TXD1, EXT\_RXD2, and EXT\_TXD2 are RS-232 level signals. They are currently used for debug purposes.

#### System Identification

The following output to **lspci(8)** shows the PCI class, vendor and device IDs for the RCIM II (0d:06.0 (*bus:slot.function*) will differ on your system):

# lspci -v | grep -i rcim Od:06.0 System peripheral: Concurrent Real-Time, Inc. RCIM II Realtime Clock and Interrupts Module (rev 01) # lspci -ns 0d:06.0 Od:06.0 Class 0880: 1542:9260 (rev 01)

#### **Daisy Chain Cable**

The RCIM II uses an RJ45 serial synchronization cable (part no. HS002-CBL-10) to connect RCIM IIs in an RCIM chain. The serial data on the cable includes parity and framing information which allow cable problems to be detected. Polling is done continuously and messages that report the status of the RCIM II daisy chain cables are output when an error condition is detected. Messages indicating problems will appear on the systems directly connected by a failing link.

The serial cables are point to point connections. The "input" cable refers to the cable going upstream towards the master RCIM. The "output" cable is the downstream connection away from the master.

RCIM: Input cable disconnected. RCIM: Input cable connected. RCIM: Input cable connected but not synchronized. RCIM: Input cable unsynchronized. RCIM: Output cable 0.K. RCIM: Output cable disconnected. RCIM: Output cable connected. RCIM: Output cable connected but not synchronized. RCIM: Output cable unsynchronized. RCIM: Output cable 0.K. RCIM: Cable error on input cable. RCIM: Cable error on output cable.

The "not synchronized" and "unsynchronized" messages indicate that the cable is connected but not answering attempts to communicate. This would be the case if the connected system was powered off.

The last two messages indicate transient errors such as cable parity errors or temporary loss of cable synchronization. If a transient error occurs, it may require a link in the cable to resynchronize. If a distributed interrupt is being broadcast on the cable, it may be lost. Transient errors also affect the synchronization of the tick timers since the cable clock will not reach all of the systems. Refer to Chapter 3 for instructions for synchronizing clocks.

# **RCIM I**

This section provides illustrations and descriptions of the RCIM I board.

## **Board Illustration**

Figure 2-7 shows the RCIM I board.

| Figure | 2-7 | RCIM | L | Board |
|--------|-----|------|---|-------|
| iguic  |     |      |   | Douid |



## **Connectors and LEDs**

Figure 2-8 shows the input/output connectors and LEDs on the RCIM I board.

Detailed information on the LEDs and each of the connectors is provided in the following sections.



Figure 2-8 RCIM I Connectors and LED Locations

### **LED Functions**

The four LEDs are on the circuit side of the RCIM I board between the output cable connector (P2) and the external interrupts connector (P4). They function as follows:

| LED    | Number | Function                                                        |
|--------|--------|-----------------------------------------------------------------|
| Red    | DS1    | If on after reset, indicates RCIM module failed power-up reset. |
| Yellow | DS2    | If on, indicates cable clock not connected.                     |
| Green  | DS3    | If on, indicates activity in progress.                          |
| Green  | DS4    | If on, indicates power applied to RCIM.                         |

### **Output Cable Connector (P2)**

The output cable connector is used when the RCIM I is either the master, or a slave in the middle of an RCIM chain (see page 2-18 for a description of RCIM modes). The cable attached to the output cable connector is called a synchronization cable (part no. 6010178-109). The pin-outs for the output cable connector are shown in Figure 2-9.

Figure 2-9 RCIM I Output Cable Connector (P2) Pin-outs



## Input Cable Connector (P3)

The input cable connector is used when the RCIM I is acting in slave mode (see page 2-18 for a description of RCIM modes). The cable attached to the input cable connector is called a synchronization cable (part no. 6010178-109). The pin-outs for the input cable connector are shown in Figure 2-10.





#### **External Interrupts Connector (P4)**

The external interrupts connector on the RCIM I provides four outputs and four inputs.

The external outputs allow equipment to be attached and controlled by the RCIM. The outputs are driven by a multiplexer which can select any of the programmable interrupt generators (PIGs), real-time clock timers (RTCs), edge-triggered interrupts (ETIs) or distributed interrupts (DIs) to drive the output. The selection is controlled by a set of configuration registers.

See Chapter 3 for information on using external output interrupts and programmable interrupts.

Pin-outs for the external interrupts connector are shown in Figure 2-11.



Figure 2-11 RCIM I External Interrupts Connector (P4) Pin-outs

### **Debug Visibility Connector (P5)**

The debug visibility connector is intended for use on the Concurrent Real-Time, Inc. manufacturing floor and should not be used outside of that environment.

#### In-System Programming Interface Connector (P6)

The in-system programming interface connector is intended for use on the Concurrent Real-Time, Inc. manufacturing floor and should not be used outside of that environment.

#### System Identification

The following output to **lspci(8)** shows the PCI class, vendor and device IDs for the RCIM I (0d:06.0 (*bus:slot.function*) will differ on your system):

# lspci -v | grep -i rcim Od:06.0 System peripheral: PLX Technology, Inc. RCIM Realtime Clock and Interrupts Module old ID (rev 01) # lspci -ns 0d:06.0 Od:06.0 Class 0880: 10b5:8845 (rev 01)

# **Connection Modes**

When RCIM boards of various systems are chained together, an interrupt can be simultaneously distributed to all connected RCIMs, and from the RCIMs to all the associated host systems.

#### NOTE

All RCIMs in a chain must be the same model; for example, all RCIM IIs.

If your system will be part of an RCIM chain, it is best to determine the desired connection mode before installing an RCIM; it is easier to connect the cable to the cable connectors before the RCIM is installed.

Note that to reconfigure an RCIM chain, the systems must be powered off and rebooted after moving the cables. The driver determines if a system is the master RCIM at boot time and configures the master system to control the cable clock and its enable. Swapping the cables without rebooting the systems will result in problems with the cable clock.

An RCIM can be connected in one of the following modes:

| Isolated mode              | There are no connections to any other RCIM.                                                                                                                                                                                   |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Master mode                | The RCIM is at the head of a chain of RCIMs. There is no cable connection going into this RCIM, only a cable connection going out. The RCIM master is unique in that it controls the clocks (see Chapter 3 for a discussion). |
| Pass-through<br>Slave mode | The RCIM is connected to two other RCIMs. There is an input<br>cable connection coming from the previous RCIM in the chain, and<br>an output cable connection going to the next RCIM in the chain.                            |
| Final Slave mode           | The RCIM is connected to one other RCIM. There is an input cable connection going into a final slave RCIM but no output cable connection coming out of it.                                                                    |

## Unpacking the RCIM

When unpacking the equipment from the shipping container, refer to the packing list and verify that all items are present. Save the packing material for storing and reshipping the equipment.

#### NOTE

If the shipping container is damaged upon receipt, request that the carrier's agent be present during unpacking and inspection of the equipment.

## Installation

Normally, installation and configuration of the card is done by Concurrent Real-Time. This information is provided for those cases where an RCIM is added to a system in a post-manufacturing environment.

In order to successfully install the RCIM, you must know if you will be using the RCIM to accept or deliver external interrupts and the mode in which the RCIM will run (isolated, master, pass-through slave or final slave). Refer to the section "Connection Modes" above for details.

#### CAUTION

Avoid touching areas of integrated circuitry as static discharge can damage circuits.

Concurrent Real-Time strongly recommends that you use an antistatic wrist strap and a conductive foam pad when installing or upgrading a system. Electronic components such as disk drives, computer boards, and memory modules can be extremely sensitive to Electrostatic Discharge (ESD). After removing the board from the system or its protective wrapper, place it flat on a grounded, static-free surface, component side up. Do not slide the board over any surface.

If an ESD station is not available, you can avoid damage resulting from ESD by wearing an antistatic strap (available at electronic stores) that is attached to an unpainted metal part of the system chassis.

Use the following procedure to install an RCIM in your system:

- 1. Ensure that your system is powered down.
- 2. Remove the power cable from the system.
- 3. Open the case of your system and identify the PCIe slot (RCIM III) or PCI slot (RCIM II or RCIM I) where you want the RCIM to reside. In general, it is best for the RCIM to be configured in a slot where minimal or no contention with other devices occurs and at the highest IRQ priority possible. Refer to the *iHawk Optimization Guide*, publication number 0898011, for slot configuration guidelines.
- 4. Install the RCIM into the desired slot, securing the card in the slot using the mechanism provided by the case.
- 5. If this is to be part of an RCIM chain, attach the cable as required. See the section "Connection Modes" to determine how to connect the cable based on the connection mode for this system.
- 6. If you are installing an RCIM board equipped with the optional GPS module, attach the GPS antenna lead and mount the antenna. The antenna should be mounted on the rooftop or in an open area. Refer to the sections "Connectors and LEDs" and "GPS Antenna" more information about the antenna.
- 7. Replace the cover.
- 8. Attach the power cable to the system.
- 9. Apply power and boot the system.

# Configuration

## **Kernel Configuration**

The following RedHawk Linux kernel parameters are associated with the RCIM. All are accessible through the Character Devices selection of the Kernel Configuration GUI and are enabled by default in all the pre-built RedHawk Linux kernels.

| RCIM               | This parameter configures the RCIM driver in the kernel. It can be configured as a module, if desired.                                                                                                                                                                                                                        |  |  |  |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| RCIM_MASTERCLOCK   | This parameter enables the RCIM to be used as a master clock thta<br>monitors and adjusts system time, resulting in more precise system<br>timekeeping.                                                                                                                                                                       |  |  |  |  |
| RCIM_PPSKIT        | This parameter disciplines the RCIM tick and POSIX time-of-day<br>registers to the pulse-per-second support of the optional GPS<br>receiver. This provides for time more closely aligned to the official<br>atomic time as defined by the GPS system. This option has no<br>effect if your RCIM does not have GPS capability. |  |  |  |  |
| RCIM_IRQ_EXTENSION | SThis parameter allows other drivers to attach their own interrupt<br>routines to the RCIM driver. The Frequency-based Scheduler<br>(FBS) requires this support.                                                                                                                                                              |  |  |  |  |
| MULTI_RCIM_MAX     | Default 8. This numerical parameter defines the maximum number<br>of individual RCIM cards that can be configured into the system.                                                                                                                                                                                            |  |  |  |  |

For complete information about modifying kernel tunables and building a kernel, refer to the *RedHawk Linux User's Guide*, publication number 0898004.

## **Driver Configuration**

RCIM boards have many features that can be configured for application use. Configuration is performed by echoing a series of comma-separated tokens to the configuration file associated with the RCIM board of interest. Each token specifies how a single feature configuration option is to be changed; feature tokens not specified remain unchanged.

For example, the following command changes etil edge-triggered interrupt to trigger on a falling edge:

echo "eti1/f" > /proc/driver/rcim:0/config

Quotes around the tokens are always recommended and must be used to surround a configuration request that contains a vertical bar, as in the following command example:

echo "rtc0|di1" > /proc/driver/rcim:0/config

After execution of the above command, the RCIM's rtc0 real-time clock will be routed into the RCIM's dil distributed interrupt.

Here is a more complex example for an RCIM slave system:

echo "host/server1.ccur.com, eti1/rising, di3/high, rtc3|di6" >
/proc/driver/rcim:0/config

This command performs all of the following actions:

- sets the master RCIM hostname to server1.ccur.com
- sets the etil edge-triggered interrupt to trigger on a rising edge
- sets the di3 distributed interrupt to trigger on a high value
- routes the rtc3 real-time clock into the di6 distributed interrupt.

Note that all RCIM configuration options fall into one of the following catagories:

- Set the manner in which various interrupts will be triggered: rising or falling edge, high or low level.
- Create associations between internally generated interrupt signals, output lines and distributed-interrupt lines.
- Set the name of the system in an RCIM chain that has the master RCIM.
- Decide whether the tick and POSIX clock is to be driven by the local RCIM oscillator or by the master RCIM oscillator, for RCIMs that are in an RCIM chain.

Configuration changes require write permissions to the RCIM's config file (e.g. root access) and should only be made when the RCIM is not otherwise in use.

Configuration modifications are not automatically retained between system reboots. To make them persistant, create an /etc/init.d script to issue the desired RCIM configuration commands during each system boot.

Refer to the *Available Configuration Options* section of the **rcim(4)** man page for complete details on RCIM configuration.

#### **General Considerations**

When configuring the RCIM systems, keep the following in mind:

• For a chain of RCIMs, the tick clock and POSIX clock in all slave RCIMs will be synchronized with the master because the clock signal incrementing time in the master is broadcast to all slaves. Once the clocks on all RCIMs are initially syncronized they will remain synchronized.

To synchronize tick clocks, a working TCP/IP connection between all systems is needed. In addition, each slave RCIM hostname configuration must be set to the master RCIM, and each slave must be configured to run the **rcim\_clocksync** init script once on boot. This is only required if your application is using the tick clock for synchronization.

**ntp** can be used to synchronize the POSIX clocks, however for the RCIM-III there is a better mechanism: **rcimdate**(8). The RCIM-III master broadcasts its POSIX time down the RCIM cabling once per second; **rcimdate** uses this to make the slave POSIX clocks exactly match the master. This has several advantages over **ntp**: no TCP/IP connections between systems are required, synchronization is faster, and synchronization is extremely accurate.

- Interrupts, whether operating locally or distributed across an RCIM chain, will be processed according to the values configured on each system. If you wish them to function in a manner different from established defaults, the desired configuration options must be specified.
- When distributing interrupts across the systems in an RCIM chain, all systems must have a compatible configuration for the distributed interrupt lines.

## **MSI Interrupt Configuration**

The latest version of RCIM III (revision 9 and later) supports MSI (message signaled interrupts). By default, the RCIM kernel driver will initialize the hardware to use MSI interrupts instead of PCI INTA interrupts whenever possible. By using MSI interrupts, the RCIM III is guaranteed of having its own non-shared interrupt, thus providing more reliable interrupt response times.

The RCIM driver has an rcim.nomsi=1 option which is independent of the rcim= configuration option described earlier. All versions of the driver have this option. If specified the MSI capability is disabled on all RCIM boards that support it. There is no mechanism to pick which boards are to be MSI-disabled and which ones are not. When this option is specified, the RCIM driver will fallback to using the PCI INTA interrupt method. For perfomance reasons, this option should only be used if a problem with MSI interrupts is encountered.

For a statically linked RCIM driver, this tunable can be specified on the GRUB boot loader command line (rcim.nomsi=1). For an RCIM in module form, this tunable can be placed in /etc/modprobe.conf as "options rcim.nomsi=1".

This option has no effect on RCIM II or RCIM I systems.

## ntp Configuration for GPS Support

If your system contains the optional GPS module, **ntp** must be installed and configured to use the GPS receiver to synchronize the RCIM's POSIX clock to GPS time. Follow these steps:

- 1. Verify that the latest ntpd rpm is installed on the system:
  - # rpm -ql ccur-ntp-4.2.2p1-7\*

\* includes possible updates (.1, .2, etc.) and the architecture type, **i386** or **x86\_64**.

If it is not installed, refer to the *RedHawk Linux Release Notes*, publication number 0898003, for instructions to install this rpm from the RedHawk installation media.

2. The file **/etc/ntp.conf** supplied with the rpm contains the following lines that are required to use the GPS.

server 127.127.8.0 mode 138 prefer #PARSE TSIP (10) + PPS(128)
fudge 127.127.8.0 flag3 1 #enable PPS signal

The following three lines define a pool of world-wide servers that are randomly selected at poweron for time synchronization. This feature acts as the default NTP configuration and serves as backup to GPS. You may wish to include your local country code before "pool" in these entries for best results; e.g., 0.us.pool.ntp.org. See www.pool.ntp.org for more information.

server 0.pool.ntp.org
server 1.pool.ntp.org
server 2.pool.ntp.org

A block of commented out entries beginning with "logfile" is used to configure files used for logging statistics. Uncomment the entries if you wish to enable them.

In addition to the log files, **ntpq(1)** and **ntpdc(1)** are used for NTP monitoring. For more information about NTP, refer to the **ntpd(1)** man page and **www.ntp.org**.

At system poweron, once all data is received from the GPS satellites, accurate timekeeping is available.

## Verifying ntp/GPS Operation

To determine when the GPS is producing accurate time, use the peer listing of **ntpq(1)** as shown below. This example utilizes command line options, however **ntpq** can also be run interactively. Refer to the man page for complete information.

|        | # / ubi / bbin/ ncp | 4 mp                                    |    |            |                |                |       |        |                     |        |
|--------|---------------------|-----------------------------------------|----|------------|----------------|----------------|-------|--------|---------------------|--------|
| remote |                     | refid                                   | st | t<br>===== | when<br>====== | poll<br>====== | reach | delay  | offset<br>========= | jitter |
|        |                     | ======================================= |    |            |                |                |       |        |                     |        |
|        | 0 11                | 100 10 011 10                           | ~  |            |                | ~ .            |       |        |                     |        |
|        | xns2.medbanner.c    | 192.43.244.18                           | 2  | u          | 33             | 64             | 377   | 72.443 | -2.897              | 11.235 |
|        | +toshi.keneli.or    | .GPS.                                   | 1  | u          | 43             | 64             | 377   | 27.915 | 0.938               | 2.075  |
|        | -216.56.81.86       | 193.131.101.50                          | 3  | u          | 33             | 64             | 377   | 49.388 | -0.579              | 2.710  |
|        | +new.localdomain    | .GPS.                                   | 1  | u          | 42             | 64             | 377   | 0.182  | 0.010               | 0.020  |
|        | *GENERIC(0)         | .GPS.                                   | 0  | 1          | 46             | 64             | 377   | 0.000  | 0.000               | 0.001  |
|        |                     |                                         |    |            |                |                |       |        |                     |        |

#### # /usr/sbin/ntpq -np

The output shows how the system time compares to other time sources. This includes the GPS receiver and other time servers.

The column labeled remote is the hostname of the timeserver. The system new.localdomain is a local network time server; GENERIC(0) is the GPS attached to the RCIM. The other lines are time servers assigned by pool.ntp.org. The first column indicates which servers are being selected for synchronization. The '\*' in front of GENERIC(0) indicates that the RCIM GPS receiver is being used as the system peer.

The columns delay, offset, and jitter are all times in milliseconds. The offset is the difference between the local system time and the time source. In this case we are synchronized to the GPS receiver to microsecond accuracy. The delay field is the measured network delay to exchange the time with the remote server.

The jitter measures the difference between offset values from the same source.

The refid indicates where the remote system gets its time.

The st column is the stratum number. A stratum zero system should have a direct connection to an authoritative source.

The poll column shows how frequently this server is being polled. The when column is the time in seconds since the last poll.

The reach column is a bitmap in octal which shows if recent polls have been successful. The value 377 would indicate that the last 8 polls succeeded.

Another indicator is through the **ntpq clockvar** command:

#### # /usr/sbin/ntpq

ntpg> clockvar assID=0 status=0003 clk\_okay, last\_clk\_fault, device="Trimble GPS (TSIP) receiver", timecode="\x10\xff\x02\x10", poll=52, noreply=0, badformat=0, baddata=0, fudgetime1=20.000, stratum=0, refid=GPS, flags=4, refclock ppstime="c66be732.0000000 Tue, Jun 28 2005 15:11:46.000", refclock time="c66be734.03ffffff Tue, Jun 28 2005 15:11:48.015", refclock status="TIME CODE; PPS; POSITION; (LEAP INDICATION; PPS SIGNAL; POSITION)", refclock format="Trimble TSIP", refclock states="\*NOMINAL: 00:54:26 (98.04%); NO RESPONSE: 00:00:02 (0.06%); FAULT: 00:01:03 (1.89%); running time: 00:55:31", trimble tracking status[08]="ch=4, acq=ACQ, eph=19, signal level= 6.40, elevation= 9.12, azimuth= 34.35, collecting data", trimble satview="mode: 2D-AUTO, PDOP 8.96, HDOP 8.91, VDOP 1.00, TDOP 2.90, 3 satellites in view: 18, 26, 29", trimble tracking status[10]="ch=0, acg=ACQ, eph=3, signal level= 2.60, elevation= 18.18, azimuth= 86.56, collecting data", trimble tracking status[18]="ch=1, acq=ACQ, eph=19, signal level= 5.20, elevation= 39.47, azimuth= 289.19, collecting data", trimble tracking status[26]="ch=2, acq=ACQ, eph=19, signal level= 15.40, elevation= 69.34, azimuth= 49.55, collecting data", trimble tracking status[29]="ch=3, acq=ACQ, eph=19, signal level= 15.80, elevation= 52.49, azimuth= 48.45, collecting data", trimble\_receiver\_health="doing position fixes, Battery backup failed", trimble\_status="machine id 0x5a, Battery Powered Time Clock Fault, Superpackets supported", gps\_position\_ext(XYZ)="x= 1445085.4m, y= -4476862.4m, z= 4277122.9m", gps\_position\_ext(LLA)="lat 42.379423 N, lon 71.531318 W, alt 88.35m", trimble\_tracking\_status[15]="ch=7, acq=ACQ, eph=3, signal\_level= 3.00, elevation= 28.28, azimuth= 311.83, collecting data", trimble\_tracking\_status[09]="ch=4, acq=ACQ, eph=3, signal\_level= 1.60, elevation= 23.21, azimuth= 163.20, collecting data" ntpq>

The refclock\_states message in this example indicates that 98.04% of the time the GPS is receiving useful data. A higher nominal number indicates the most accuracy.

Additional information is provided by many other messages in this output. Refer to **ntpq(1)** for complete details

RCIM User's Guide

This chapter describes the clocks and interrupt capabilities provided by the RCIM and the user interfaces for each.

# Overview

The Real-Time Clock and Interrupt Module (RCIM) provides two non-interrupting clocks. One of these clocks can be synchronized with all the RCIMs in an RCIM chain to provide a common time stamp across systems. The other clock is POSIX 1003.1 compliant and, although not synchronized across the RCIM chain, it increments in unison with the other clock on the RCIM board and can be set to a specific time.

In addition to the clocks, the following methods for handling signal processing (interrupts) are available:

- Edge-Triggered Interrupts (ETIs)
- Real-Time Clocks (RTCs)
- External Output Interrupts
- Programmable Interrupt Generators (PIGs)
- Distributed Interrupts (DIs)

These interrupts operate locally on an RCIM system or can be distributed across all RCIM systems in an RCIM chain. The **open(2)**, **close(2)** and **ioctl(2)** system calls are used to manipulate the interrupts. Separate device files are associated with each interrupt.

The clocks and interrupts are described in this chapter.

# Clocks

The RCIM provides two non-interrupting clocks, which are fully explained in the sections that follow.

tick a 64-bit non-interrupting clock that increments by one on each tick of the common 400ns clock signal. This clock can be reset to zero and synchronized across the RCIM chain, providing a common time stamp.
POSIX a 64-bit non-interrupting clock encoded in POSIX 1003.1 format. The upper 32 bits contain seconds and the lower 32 bits contain nanoseconds. This clock is incremented on each tick of the common clock signal. It is primarily used as a high-resolution local clock. It can be configured to synchronize system time with GPS standard time on boards equipped with GPS.

All clocks on all RCIMs in the chain are incremented in unison, as they are all driven by a common clock signal emanating from the master RCIM.

# The Tick Clock

The tick clock is a 64-bit non-interrupting counter that increments by one on each tick of the common clock signal. Although it cannot be set to a specific time, it can be incremented or set to zero. Hence the tick clock cannot be adjusted on the fly to approximate the current time of day as would be required of a true time-of-day clock. On RCIM I systems, the system clock is frequency-synchronized with the tick clock.

When an RCIM board is part of an RCIM chain, the tick clocks on all slave RCIMs are incremented and cleared in synchronization with whatever incrementing and clearing is done to the tick clock located on the master RCIM.

The tick clock can be read on any system, master or slave, using direct reads when the device file /dev/rcim:N/sclk (where N is the RCIM card number starting from zero) is mapped into the address space of a program. See the section "Direct Access to the Clocks" below for details.

By default, tick clock initialization (zeroing) and synchronization with other tick clocks on the RCIM chain occur automatically whenever the RCIM master boots. Initializing and synchronizing tick clocks is accomplished using the **rcim\_clocksync(1)** command. See the sections "Synchronizing the Tick Clock" and "The rcim\_clocksync Utility" below for details.

# The POSIX Clock

The POSIX clock is a 64-bit non-interrupting counter encoded in POSIX 1003.1 format. The upper 32 bits contain seconds and the lower 32 bits contain nanoseconds. This clock is incremented on each tick of the common clock signal. On RCIM III and RCIM II systems, the system clock is synchronized to the POSIX clock.

For RCIM II and III, setting the system clock (for example, with clock\_settime(2)) will set both the system clock and the RCIM POSIX clock to the new time. In addition, the POSIX clock can be mapped with mmap and then read like any other RCIM register by applications. However, modifying the RCIM POSIX clock via the mmap method is not recommended while the system is sychronizing with the RCIM POSIX clock.

The POSIX clock can be loaded with any desired time; however, the value loaded is not synchronized with other clocks in an RCIM chain. Only the POSIX clock of the RCIM attached to the host is updated. See the section "Direct Access to the Clocks" below for details about accessing the POSIX clock.

Although the RCIM I and II have no hardware support for setting the POSIX clocks of all boards to a consistent value, it is possible to pause the operation of the RCIM board chain, synchronize the POSIX clock values during the pause using the rcim\_clocksync(1) command on each of the systems, then restart the RCIM board chain. See the section "Synchronizing the POSIX Clock" later in this chapter for instructions. For the RCIM III, rcimdate can be run on each slave to synchronize the POSIX clock to that of the master. No TCP/IP connection or other software is needed. rcimdate utilizes the POSIX timestamp sent down the RCIM cabling once per second by the RCIM III maser.

On an RCIM system with GPS module and NTP running, the GPS receiver is used to synchronize the POSIX clock on the RCIM on which it is attached to GPS time. One GPS-

equipped RCIM II can synchronize all iHawks in an RCIM chain. Multiple RCIM IIs equipped with the GPS module can provide a common time base without any cable connections between systems. POSIX timers based on absolute GPS time can be used to simultaneously start the execution of programs on systems which are not physically connected.

See the section "Using GPS for System Timekeeping" for details. Generally, only the master RCIM needs a GPS; slaves use one of the software methods available for syncronizing their POSIX clock to the master.

# **Direct Access to the Clocks**

The device file /dev/rcim:N/sclk (where N is the RCIM card number starting from zero) can be used to access the RCIM clocks directly using mmap (2). From the address returned by mmap, the following offsets are used to access the clock fields:

| 0x0   | upper 32-bits of tick clock             |
|-------|-----------------------------------------|
| 0x8   | lower 32-bits of tick clock             |
| 0x10  | status and control (cannot be modified) |
| 0x100 | POSIX clock seconds                     |
| 0x108 | POSIX clock nanoseconds                 |
| 0x110 | status and control (cannot be modified) |

These offsets are defined in the header file /usr/include/linux/rcim.h (with names beginning with RCIM\_SYNCCLOCK\_).

To set the value of the POSIX clock, the **rcim\_clocksync(1)** utility can be used in interactive mode using the "update" command.

# Synchronizing the Clocks

The sections below describe the techniques and tools used to synchronize the clocks on the RCIM.

## The rcim\_clocksync Utility

The **rcim\_clocksync(1)** utility can be used to reset the tick clocks on all connected RCIMs to zero to provide a common time stamp across the system. This synchronization operation occurs automatically when the RCIM master system boots. As slave systems become available, it will be necessary to reissue this command to synchronize the tick clocks across the RCIM chain, however, this can be automated (see the section "Automatic Synchronization" below). **rcim\_clocksync** can also be used to synchronize the POSIX clocks on all connected RCIMs. This procedure is described in the section "Synchronizing the POSIX Clock."

Note that the system clock is synchronized with the RCIM and when rcim\_clocksync is run other than at system boot, there are consequences and should be used with caution. On RCIM III and RCIM II, master and slave system times are synchronized with the POSIX clock; on RCIM I, the times are synchronized with the tick clock. When system time stops advancing, time-based functions using those clocks will stop.

Synchronization always succeeds on the RCIM master or isolated system; an error is returned if synchronization is attempted on an RCIM slave system.

Specifying **rcim\_clocksync** with no options on the RCIM master system synchronizes all tick clocks in the RCIM chain.

rcim\_clocksync takes the following options:

- -i interactive mode (see below)
- -m prints the configured hostname where the RCIM master is located (see "Configuration" in Chapter 2).
- -s prints the RCIM connection state
- **devname** The device name of the desired RCIM board. Defaults to /dev/rcim:0/rcim which is the first RCIM board that was found on boot. /dev/rcim:1/rcim, /dev/rcim:2/rcim, etc. should be used to point this tool to the second, third, etc. RCIM board found on boot.

When interactive mode is invoked, a display similar to the following example provides configuration and status information updated every two seconds, as well as command usage. These items are explained below.

| RCIM is isolated RCIM version: 1<br>Configured RCIM master hostname is Not_Configured |                                                                                                                                                                                                                                                                                                   |  |  |
|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| cable<br>tick t<br>posix<br>tick t                                                    | status and values<br>signal : ENABLED<br>timer : CABLE_ENABLE LOCAL_ENABLE<br>clock : CABLE_ENABLE LOCAL_ENABLE<br>timer : 10.3361 seconds ( 25840213 ticks)<br>clock : 18665.4696 seconds                                                                                                        |  |  |
| s<br>0[tp]<br>1[tp]<br>w[tp]<br>i[tp]<br>c[tp]<br>d                                   | <pre>tions are:     synchronize clocks     stop clock ([t]ick/[p]osix)     start clock ([t]ick/[p]osix)     update clock value ([t]ick/[p]osix)     isolate clock ([t]ick/[p]osix)     connect clock ([t]ick/[p]osix)     disable cable clock signal     enable cable clock signal     quit</pre> |  |  |
| enter                                                                                 | enter operation:                                                                                                                                                                                                                                                                                  |  |  |

RCIM is indicates the RCIM mode for this system: master, pass-through slave, final slave or isolated

RCIM version is the RCIM version number

Configured RCIM master hostname is

indicates the hostname of the RCIM master. This must be configured using the host configuration option (see "Configuration" in Chapter 2)

| cable signal                         | is one of the following:                                                                                                                                                                                                                                                                                         |  |
|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                      | ENABLED/DISABLED – For the RCIM master, indicates if the cable clock signal is being propagated to slaves. For RCIM slaves, indicates if clocks are being driven by the RCIM master or if ticking locally (without synchronization).                                                                             |  |
|                                      | CLOCK_MISSING – Error condition indicating cable clock signal is not being properly propagated to slaves.                                                                                                                                                                                                        |  |
|                                      | CLOCK_STOPPED – Error condition indicating cable clock signal has been stopped.                                                                                                                                                                                                                                  |  |
| Status:<br>tick timer<br>posix clock | is one of the following:                                                                                                                                                                                                                                                                                         |  |
|                                      | CABLE_SYNC – indicates that the RCIM slave clock is being driven by RCIM master cable clock signal, if available                                                                                                                                                                                                 |  |
|                                      | CABLE_ENABLE - indicates that the RCIM clock resets when RCIM master does a synchronization                                                                                                                                                                                                                      |  |
|                                      | LOCAL_ENABLE – indicates that the clock is enabled                                                                                                                                                                                                                                                               |  |
|                                      | NO_RESET_WHEN_DISABLED – indicates that the clock is not reset when disabled                                                                                                                                                                                                                                     |  |
| Values:<br>tick timer<br>posix clock | current clock values for each clock                                                                                                                                                                                                                                                                              |  |
| operations<br>are:                   | This section is usage information for the interactive mode. At the enter operation: prompt, supply one of the operation codes to accomplish the task described for that operation. As noted, some operations require a designation for the clock to be operated on: t for the tick clock; p for the POSIX clock. |  |

## Synchronizing the Tick Clock

When the RCIM master system boots, **rcim\_clocksync** is executed, which resets all tick clocks in the RCIM chain to zero.

When an RCIM slave system boots after the master has booted, the tick clocks on the systems in the RCIM chain will be out of sync, unless automatic clock synchronization is configured (see the section "Automatic Synchronization" below). Invoking **rcim\_clocksync** without options on the master RCIM system synchronizes all tick clocks in the RCIM chain. See the section "The rcim\_clocksync Utility" and the **rcim\_clocksync(1)** man page for more information about this utility.

#### **RCIM Masterclock Considerations**

For RCIM II and III, the RCIM POSIX clock is the system masterclock. This means that system time continually looks at the RCIM's POSIX clock and adjusts itself to match.

In previous releases of RedHawk, a broken or stopped RCIM would confuse and often lock up the system, however this is no longer the case. The RedHawk masterclock code now continually tests the RCIM POSIX clock for validity and pauses clock synchronization if problems are detected. This means that the two clocks, the RCIM POSIX clock and the system clock, become free-running. Once the RCIM POSIX clock again becomes valid clock synchronization is resumed.

In order for synchronization to resume, RedHawk must detect that both the system clock and the RCIM POSIX clock are incrementing, that each clock is incrementing at the correct rate, and that each clock has a value within approximately two seconds of the other. This latter condition is most easily achieved by executing a **clock\_settime**(3),

but other methods, as documented in **masterclock**(5), are available that may be more suitable for specific situations.

#### Synchronizing the POSIX Clock

The POSIX clocks tick synchronously but generally do not have the same clock values and should not be used as a common time stamp. They can be synchronized with the other POSIX clocks in the RCIM chain so that they are consistent, if desired. For the RCIM III, run rcimdate on each slave; on return the slave's RCIM POSIX clocks will be synchronized with the master. For RCIM I and II use the following rcim\_clocksync interactive mode procedure defined below.

Note that this operation also synchronizes the RCIM tick clocks. Be aware that while performing this procedure, the system time stops and time-base functions will be affected.

- 1. Ensure that all POSIX clocks on all RCIM slave systems are connected using the **cp** command.
- 2. Disable the cable clock signal on the RCIM master system (using the **d** command). The POSIX clocks on all systems should stop ticking.
- 3. Update the time values of the POSIX clocks on each system to the same value (using the **wp** command).
- 4. Re-enable the cable clock signal on the RCIM master system (using the e command). All clocks should begin ticking.

On RCIM systems equipped with the optional GPS module, the POSIX clock can be synchronized to standard GPS time. Refer to the section "Using GPS for System Timekeeping" below for information.

#### **Automatic Synchronization**

For the RCIM III, each slave system can be configured so that its POSIX clock will be automatically synchronized with that of the master on boot. To do this, uncomment either the RCIMDATE=continuous or RCIMDATE=oneshot line in /etc/sysconfig/rcim on the slave. Subsequently, each time the slave is booted it will run rcimdate either once or continuously. If it is run once then the slave's POSIX clock will match that of the master until such time as some application on the master executes a clock\_settime(3) (this is usually done by ntp or ptpd). If rcimdate is run in continuous mode, then the slave will execute a clock\_settime(3) within a few seconds of each clock settime(3) occurring on the master.

The system can also be configured to automatically synchronize the tick clocks when an RCIM slave system is booted. This feature is disabled by default and should be used with caution. It causes the tick clock on all systems to be reset to zero when any system in the RCIM chain is booted, which may have an undesirable impact on processes using the tick clock during synchronization.

To set up automatic synchronization of tick clocks when a slave system is booted, create an empty file /etc/sysconfig/rcim\_clocksync on the slave system. This activates the /etc/init.d/rcim\_clocksync startup script, asking it to reset its RCIM board and (by default) also reset the slave RCIM boards. This uses **ssh(1)**, which must be set up to communicate between the slave and master systems.

# Using GPS for System Timekeeping

On RCIM systems equipped with the optional GPS module, the POSIX clock can be used for system time synchronized to standard GPS time. The NTP daemon is utilized and treats the GPS receiver as a time server. For information about how to configure NTP for this support, see the section "ntp Configuration for GPS Support" in Chapter 2.

RedHawk Linux includes the RFC-2783 pulse per second (PPS) interface that synchronizes the system time to the GPS PPS interface. The POSIX clock register is captured on the on-time edge of the GPS PPS signal. This avoids the jitter which would be introduced if an interrupt was used to capture the error between the system time and the GPS time.

A dedicated serial interface, /dev/rcim\_uart, is used by NTP to communicate with the GPS receiver. This symbolic link is pointed to the last RCIM found with a GPS. If another RCIM is to be used, the administrator must point this special device to the uart special device file of the desired RCIM to, for example, /dev/rcim:3/uart.

Likewise, the device which will receive the GPS pulse per second must be pointed to by /dev/refclock-0. This symbolic link also points to the last RCIM found having a GPS. If that is not the GPS that is wanted, the adminstrator must point this symbolic link to, for example, /dev/rcim:3/gps.

Tools such as ntpq(1) and ntpdc(1) can be used for monitoring NTP activity. Other aids include various log files that can be added to /etc/ntp.conf if desired. Refer to the ntpd(1) man page and www.ntp.org for details.

# **Interrupt Processing**

One or more of the following modules is used for interrupt processing on the RCIM:

- Edge-Triggered Interrupts (ETIs) An ETI allows you to use an external event to trigger an interrupt. Documentation for ETIs begins on page 3-12.
- **Real-Time Clocks (RTCs)** An RTC allows you to set up a counter to trigger an interrupt. Documentation for RTCs begins on page 3-14.
- External Output Interrupts An external output signal allows you to use any of the other signal processing modules as the source for an interrupt on an external device. Documentation for external output interrupts begins on page 3-15.
- **Programmable Interrupt Generators (PIGs)** A PIG allows you to programmatically generate a signal that can be used to trigger interrupts. Documentation for PIGs begins on page 3-16.
- **Distributed Interrupts (DIs)** Distributed interrupts allow you to distribute signals or interrupts across all systems connected using an RCIM chain. Documentation for DIs begins on page 3-17.

The sections that follow explain how the RCIM interrupts are processed.

# Interrupt Processing Logic

Interrupt requests, whether generated by the RCIM board or by a software request, are handled by the edge-triggered interrupts (ETIs) and the distributed interrupts (DIs). Figure 3-1 illustrates how each interrupt request is processed.





DIs and ETIs must be armed and enabled for an interrupt to occur. Each interrupt can be armed/disarmed and enabled/disabled individually. After power up initialization, all interrupts are disarmed and disabled.

When the interrupt is armed, interrupt requests set a request bit. When an interrupt is disarmed, any outstanding requests are turned off and ignored.

Requests for an enabled interrupt are allowed to enter the interrupt priority resolution logic. The enable bit may be thought of as granting the RCIM board permission to deliver any interrupt requests that it accepts. When the ETI or DI is disabled, it accepts interrupt requests, but delays delivering the interrupt until it is re-enabled.

On RCIM III and RCIM II, the input to the interrupt block is used to drive the DI. On RCIM I, the pending bit is the output of the ETI or DI. This output is routed to the host computer to which the RCIM board is attached, and additionally to other systems in the RCIM chain if configured to do so. The ETI or DI interrupt handler on the host clears the pending bit each time it concludes the processing of an interrupt. This clears the way for the RCIM board to output the next instance of this interrupt.

#### Arming and Enabling DIs and ETIs

DIs and ETIs are armed using the **ioctl(2)** system call with the following operations, which can be used interchangeably:

DISTRIB\_INTR\_ARM ETI\_ARM

DIs and ETIs are enabled using **ioctl(2)** with the following operations, which can be used interchangeably:

DISTRIB\_INTR\_ENABLE ETI\_ENABLE

#### Interrupt Recognition Logic

By default, the RCIM looks for the leading edge of an input signal to trigger an interrupt. Once the interrupt is recognized, it must be deasserted and reasserted to cause a new interrupt request. Optionally, an interrupt may be configured as level-sensitive. In this mode, an interrupt is triggered when the interrupt signal is high or low. Configuration options are included with the documentation for each type of interrupt later in this chapter.

For the RCIM to be able to reliably extract interrupts from an input signal, the equipment generating the signal must hold any value generated for at least 1.5 microseconds before transitioning to the reset value.

## Setting up Distributed Interrupts

The RCIM provides the ability to share interrupts across interconnected systems using an RCIM chain. Although distributed interrupts are covered in detail starting on page 3-17, the figures below provide an illustration of how they operate. Guidelines for setting up distributed interrupts based on the illustration follow.



Figure 3-2 Distributed Interrupt Operation Example

In Figure 3-2, there are three scenarios:

- A signal is generated on ETI<sub>3</sub> that drives an interrupt on DI<sub>0</sub> and another on OUT<sub>3</sub>. The interrupt is also passed to the host system.
- An interrupt is received from the RCIM chain on DI<sub>7</sub>. This interrupt is sent to the host system and also sent to an external device via OUT<sub>0</sub>.
- An interrupt is generated on PIG<sub>0</sub> that is passed to an external device via OUT<sub>0</sub>.

Note that on RCIM III and RCIM II, the local interrupt does not drive the configured DI. An ETI\_REQUEST ioctl will cause a local interrupt but will not affect the DI associated with the ETI. For example, if  $ETI_0$  is configured to drive  $DI_0$ , it will connect the external ETI input to  $DI_0$  directly without passing through the local  $ETI_0$  interrupt control logic. A benefit of this is that a local interrupt is not issued for every distributed PIG and ETI. A PIG should be used for a programmable software controlled interrupt and an ETI should be used for an external interrupt output.

Please note the following in this example:

• A problem can occur when more than one interrupt module tries to drive the same signal line. In the example, the ETI<sub>3</sub> signal drives the interrupt on

 $DI_0$  and on  $OUT_3$ . It is possible to configure another signal processing module (say  $RTC_0$ ) to drive the interrupts on  $DI_0$  and  $OUT_3$  at the same time. In this case, the signal that drives the line will be the one with the strongest amplifier. It is up to the administrator to avoid this condition.

• You determine which direction a distributed interrupt takes. This means that on a system where a distributed device resides, it may generate two interrupts: its local device interrupt (ETI, PIG or RTC) and the distributed interrupt. There is a separate interrupt vector for each.

It may be desirable to receive both interrupts, but generally only one is sufficient. By disarming the distributed interrupt, one can prevent that interrupt from being generated on the local system. By default, a distributed interrupt is in a disarmed state.

# **Obtaining RCIM Values**

There are several methods available for displaying or obtaining RCIM values:

/proc/driver/rcim: *N* filesystem (where *N* starts from zero):

The following files in this filesystem can be viewed (read only unless noted otherwise):

**config** – the RCIM configuration in a form suitable to cut and paste (read/write) **interrupts** – a count of all ETI, DI and RTC interrupts per CPU and in total **status** – miscellaneous RCIM board status and time synchronization

**rawregs** – named hex display of all readable RCIM board registers

rtc – status of the RTCs (run status, count values, etc.)

eti – status of the ETIs (armed, enabled, etc.)

di – status of the DI lines (armed, enabled, etc.)

ioctl(2) system call:

Information about a specific interrupt type can be retrieved by specifying the appropriate operation with the appropriate device file **mmap**'d into the address space of the program; for example, ETI\_INFO with /dev/rcim:0/etil. Refer to the rcim\_eti(4), rcim\_rtc(4) and rcim\_distrib\_intr(4) man pages.

The RCIM\_GET\_INFO operation with the /dev/rcim:0/rcim device file mmap'd provides the same information as /proc/driver/rcim:0/config.

The RCIM\_GET\_ADDR operation with the **/dev/rcim:0/rcim** device file **mmap**'d provides the virtual and physical address of the RCIM control registers.

The header file /usr/include/rcim.h describes the layout of the information returned by RCIM\_GET\_INFO and RCIM\_GET\_ADDR. Refer to the rcim(4) man page.

mmap(2) system call:

**mmap** can be used to map in some or all of the device registers of the RCIM board. The register layout is in /usr/include/linux/rcim\_ctl.h and in Appendix A in this guide.

# **Edge-Triggered Interrupts**

Each RCIM board has incoming external interrupt lines, called ETIs or edge-triggered interrupts, so-named after their most common mode of operation. These lines permit users to provide their own interrupt sources. The RCIM processes and delivers these interrupts to the host system and, if they are distributed, routes and delivers them to all other RCIMs in the chain as distributed interrupts. RCIM III and RCIM II support twelve ETIs (0-11); RCIM I supports four ETIs (0-3).

Each ETI is independently configurable. An ETI may treat the incoming signal as an edge or level sensitive interrupt. If edge sensitive, it may raise an interrupt on either the rising or the falling edge. If level sensitive, it may raise interrupts for either the high or the low signal value. To specify how the incoming signal pattern is converted to interrupt requests, use one of the ETI configuration options described under "ETI Configuration".

Applications in turn arm or disarm, enable or disable each ETI on each system on the fly as appropriate to the needs of those applications.

One requirement the RCIM imposes on external signal generating equipment is that the signals they output must hold any low or high signal value for at least 1.5 microseconds before changing to the next state. Pulses of shorter duration may not be recognized by the interrupt controller. As long as the pulse is longer than 1.5 microseconds, the duration of the pulse is not important.

The **rcim\_eti(4)** man page provides complete information about ETIs.

## **ETI Configuration**

Each edge-triggered interrupt can be configured to trigger on the rising or falling edge of a signal, or on a high or low signal value using the **eti** configuration option. This option has the following syntax:

etiN / [rising | falling | high | low]

The default setting for an ETI is "falling."

The flag words (rising, falling, high, low) can be specified using the first character of the word. These words are not case sensitive.

Examples include:

| eti0/falling | sets ETI 0 to trigger on the falling edge of its input signal |
|--------------|---------------------------------------------------------------|
| eti1/r       | sets ETI 1 to trigger on the rising edge of its input signal  |
| eti2/h       | sets ETI 2 to trigger on a high signal value                  |

See the "Configuration" section in Chapter 2 or the **rcim(4)** man page for the various methods available for specifying configuration options.

#### ETI Device Files

Each ETI is accessed through its own special device file:

#### /dev/rcim:N/etiM

where N is the RCIM card number (starting from zero) and M is the ID of the ETI.

These files are created automatically on system boot by the /etc/init.d/rcim initialization script.

#### User Interface to ETIs

An ETI is controlled by **open(2)**, **close(2)**, and **ioctl(2)** system calls. Note that this device does not support the **read(2)**, **write(2)** or **mmap(2)** system calls.

The **open** call assigns a file descriptor to one edge-triggered interrupt and verifies that the interrupt is not currently being used by another device driver. One device file exists for each edge-triggered interrupt. A **close** call frees the file descriptor and removes any attached signals. Refer to the man pages for more information.

The following commands to **ioctl** are used to manipulate the ETIs. These commands can also be applied to DIs. All **ioctl** calls use the constants defined in /usr/include/rcim.h. Refer to the rcim\_eti(4) man page for more information.

| ETI_ARM        | arms the ETI                                                 |
|----------------|--------------------------------------------------------------|
| ETI_DISARM     | disarms the ETI                                              |
| ETI_ENABLE     | enables the ETI                                              |
| ETI_DISABLE    | disables the ETI                                             |
| ETI_REQUEST    | generates a software requested interrupt                     |
| ETI_INFO       | gets information about the ETI                               |
| ETI_WAIT       | causes the process to sleep                                  |
| ETI_WAKEUP     | wakes all sleeping processes                                 |
| ETI_GETICNT    | returns the number of times this ETI has fired               |
| ETI_KEEPALIVE  | sets or clears the keepalive state                           |
| ETI_VECTOR     | gets the interrupt vector associated with ETI                |
| IOCTLGETICNT   | returns the number of times this ETI has fired (generic)     |
| IOCTLKEEPALIVE | sets or clears the keepalive state (generic)                 |
| IOCTLVECNUM    | sets the interrupt vector associated with ETI (generic)      |
| IOCTLSIGATTACH | requests a signal when an RCIM device generates an interrupt |

Note that like DIs, an ETI must be armed and enabled before an interrupt can be received.

#### **Distributed ETIs**

Any or all of the ETIs on an RCIM can be distributed to all systems connected by an RCIM chain. The source of a distributed ETI can be located on any of the RCIMs in the chain.

To determine if a specified ETI has its interrupts sent to all connected systems, use one of the methods described in the section entitled "Obtaining RCIM Values" on page 3-11. See the "Distributed Interrupts" section on page 3-17 for information about setting up distributed interrupts.

# Real-Time Clocks (RTCs)

The RCIM provides real-time clock timers. Each of these counters is accessible using a special file and each can be used for almost any timing or frequency control function. RCIM III and RCIM II support eight 32-bit RTCs (0-7); RCIM I supports four (0-3).

The real-time clock timers are programmable to several different resolutions which, when combined with a clock count value, provide a variety of timing intervals. This makes them ideal for running processes at a given frequency (e.g., 600Hz) or for timing code segments. The timers may be one-shot or periodic; if periodic, the original load value is automatically reloaded into the counter each time zero is reached.

In addition to being able to generate an interrupt on the host system, the output of an RCIM real-time counter can be distributed to other RCIM boards for delivery to their corresponding host systems, or delivered to external equipment attached to one of the RCIM's external output interrupt lines.

The rcim rtc(4) man page provides complete information about RTCs.

#### **RTC Device Files**

Each RTC is accessed through its own special device file:

#### /dev/rcim:N/rtcM

where N is the RCIM card number (starting from zero) and M is the ID of the RTC.

These files are created automatically on system boot by the /etc/init.d/rcim initialization script.

#### **Distributed RTCs**

Any or all of the RTCs on an RCIM can be distributed to all systems connected by an RCIM chain. The source of a distributed RTC may be located on any of the RCIMs in the chain.

To determine if a specified RTC has its interrupts sent to all connected systems, use one of the methods described in the section entitled "Obtaining RCIM Values" earlier in this chapter. See the "Distributed Interrupts" section on page 3-17 for information about setting up distributed interrupts.

#### User Interface to RTCs

A real-time clock timer is controlled by **open(2)**, **close(2)**, and **ioctl(2)** system calls. The **close** system call, if it closes the last open to the device, stops the RTC and clears its settings unless the IOCTLKEEPALIVE **ioctl** command was issued to the RTC before the **close**.

The parameters passed through **ioctl** control the modes of the real-time clock timer, the clock count value, and counting itself, as well as getting the current settings of the RTC. This device does not support the **read(2)** and **write(1)** system calls.

The following commands to ioctl are used to manipulate the RTCs. All ioctl calls use the constants defined in /usr/include/rcim.h. Refer to the rcim\_rtc(4) man page for further information.

| RTCIOCSETL     | initializes RTC values (32-bit interface)              |
|----------------|--------------------------------------------------------|
| RTCIOCGETL     | retrieves RTC values (32-bit interface)                |
| RTCIOCSET      | initializes RTC values (16-bit interface)              |
| RTCIOCGET      | retrieves RTC values (16-bit interface)                |
| RTCIOCSETCNT   | sets RTC clock count                                   |
| RTCIOCMODCNT   | modifies RTC clock count                               |
| RTCIOCGETCNT   | gets RTC clock count                                   |
| RTCIOCRES      | gets RTC clock resolution                              |
| RTCIOCSTART    | starts RTC counting                                    |
| RTCIOCSTOP     | stops RTC counting                                     |
| RTCIOCWAIT     | blocks until RTC clock count reaches zero              |
| RTCIOCWAKEUP   | wakes all sleeping processes                           |
| RTCIOCINFO     | gets information about RTC                             |
| IOCTLGETICNT   | returns the number of times this clock has fired       |
| IOCTLVECNUM    | sets interrupt vector for RTC                          |
| IOCTLKEEPALIVE | does not destroy the timer on final close              |
| IOCTLSIGATTACH | requests a signal when this RTC generates an interrupt |
|                |                                                        |

# **External Output Interrupts**

Each RCIM provides external output signals. These signals can be used as interrupt sources for other machines or used as signals to control external devices. RCIM III and RCIM II support twelve external output interrupts (0-11); RCIM I supports four (0-3).

The external output interrupts can be driven from one of several sources internal to the RCIM. The most common source is from the programmable interrupt generators (PIGs). PIGs provide full software control for generation of the output signals.

The pin-outs for the external interrupt connectors are described in Chapter 2.

#### Configuration

Each external output line can be configured to be driven by a specified source using the following configuration option:

<source> | outN

The value specified for the source can be one of the following:

| <b>rtc</b> N | real-time clock timers              |
|--------------|-------------------------------------|
| <b>pig</b> N | programmable interrupt generators   |
| <b>eti</b> N | edge triggered interrupts           |
| <b>di</b> N  | distributed interrupts              |
| none         | let the interrupt output line float |

Examples include:

| rtc3 out0 | sets output line 0 to be driven by real-time clock 3       |
|-----------|------------------------------------------------------------|
| di5 out2  | sets output line 2 to be driven by distributed interrupt 5 |

Defaults for this configuration option are a PIG as source for the corresponding output line; i.e.:

```
pig0|out0
pig1|out1
etc.
```

See the "Configuration" section in Chapter 2 or the **rcim(4)** man page for the various methods available for specifying configuration options.

## Programmable Interrupt Generators (PIGs)

Each RCIM provides programmable interrupt generators (PIGs). PIGs are generally used to provide software control for the output of an external output signal. Additionally, the PIGs can be used to drive a signal onto a distributed interrupt line, permitting user software to generate distributed interrupts that are simultaneously delivered to all RCIMs in an RCIM chain. RCIM III and RCIM II support twelve PIGs (0-11); RCIM I supports four PIGs (0-3).

The rcim pig(4) man page provides complete information about PIGs.

#### **PIG Device File**

The device file /dev/rcim:N/pig is used to access the PIG register on the local system. This file must be mapped into the address space of a program using mmap(2). By default, only users with root privileges have access to do this.

On RCIM III and RCIM II, the PIG register is 12 bits wide, one bit for each PIG. Two additional registers allow the PIG bits to be set and cleared in a multiprocessor safe manner. In the **mmap**'ed PIG register page, the set register (PIGS) is at offset 0x10 and the clear register (PIGC) is at offset 0x20. Setting a PIG generates a distributed interrupt or

external output, depending on how the PIGs are connected. The required length of the signal depends upon the requirements of the attached device. If the signal is being fed into another RCIM, it must hold any low or high value for at least 1.5 microseconds before changing to the next state.

On RCIM I, the PIG register is a 32-bit register, one bit for each PIG. PIG 0 is controlled by bit 0 (the least significant bit), PIG 1 by bit 1, etc. The remaining bits are unused. Writing a value to the bit corresponding to a PIG causes the inverted signal value to be emitted from the PIG RCIM signal generator. This can be used to control external devices or generate distributed interrupts, depending on how the PIGs are connected. The required length of the signal depends upon the requirements of the attached device. If the signal is being fed into another RCIM, it must hold any low or high value for at least 1.5 microseconds before changing to the next state.

#### **Distributed PIGs**

Any or all of the PIGs on an RCIM can be distributed to all systems connected by an RCIM chain. The source of a distributed PIG may be located on any of the RCIMs in the chain.

To determine if a specified PIG has its interrupts sent to all connected systems, use one of the methods described in the section entitled "Obtaining RCIM Values" earlier in this chapter. See the "Distributed Interrupts" section below for information about setting up distributed interrupts.

# **Distributed Interrupts**

The real heart and power of the RCIM lies in its distributed interrupt system. Each RCIM can distribute interrupts simultaneously to all systems connected via an RCIM chain. RCIM III and RCIM II support a total of twelve distributed interrupts (0-11); RCIM I supports a total of eight (0-7). A diagram of this functionality and guidelines for setting up distributed interrupts can be found in the section "Setting up Distributed Interrupts" earlier in this chapter.

Any of the edge-triggered interrupts, real-time clock timers or programmable interrupt generators on any of the RCIM boards in the chain can be configured to be distributed. A distributed device file is associated with each of the distributed interrupts.

RCIM distributed interrupts must be configured on each system attached to the RCIM that is either broadcasting or intending to receive a distributed interrupt. Distributed interrupts can also be configured and used locally on an isolated system. Configuration details are given in the "DI Configuration" section below. See the section "Obtaining RCIM Values" on page 3-11 for the methods available for obtaining configuration information.

The **rcim\_distrib\_intr(4)** man page provides complete information about DIs.

#### **DI** Configuration

It is important that all RCIM-connected systems have a compatible configuration for the distributed interrupt lines of the RCIM.

By default, no distributed interrupts are configured.

Distributed interrupts must first have a source, and then can be configured to trigger on the rising or falling edge of a signal, or on a high or low signal value.

To define the source for a distributed interrupt, use the following configuration option:

<source> | diN

The value specified for the source can be one of the following:

| real-time clock timers                              |
|-----------------------------------------------------|
| programmable interrupt generators                   |
| edge-triggered interrupts                           |
| the RCIM is not to drive this distributed interrupt |
|                                                     |

Examples include:

| rtc3 di6 | sets distributed interrupt 6 to be driven by real-time clock 3                  |
|----------|---------------------------------------------------------------------------------|
| pig1 di3 | sets distributed interrupt 3 to be driven by programmable interrupt generator 1 |
| none di0 | the RCIM is not to drive distributed interrupt 0                                |

Each distributed interrupt can be configured to trigger on the rising or falling edge of a signal, or on a high or low signal value using the **di** configuration option. This option has the following syntax:

#### diN/[rising|falling|high|low]

The flag words (rising, falling, high, low) can be specified using the first character of the word. These words are not case sensitive.

Examples include:

| di0/falling | sets distributed interrupt 0 to trigger on the falling edge of its input signal |
|-------------|---------------------------------------------------------------------------------|
| di1/r       | sets distributed interrupt 1 to trigger on the rising edge of its input signal  |

See the "Configuration" section in Chapter 2 or the **rcim(4)** man page for the various methods available for specifying configuration options.

#### **DI Device Files**

Each distributed interrupt is accessed through its own special device file:

#### /dev/rcim:N/diM

where N is the RCIM card number (starting from zero) and M is the ID of the distributed interrupt.

These files are created automatically on system boot by the /etc/init.d/rcim initialization script.

#### User Interface to DIs

A distributed interrupt is controlled by **open(2)**, **close(2)**, and **ioctl(2)** system calls. Note that this device does not support the **read(2)**, **write(2)** and **mmap(2)** system calls.

The **open** call assigns a file descriptor to one distributed interrupt. A **close** call frees the file descriptor and, if it is the last close, disarms the interrupt if the IOCTLKEEPALIVE state is clear. Refer to the man pages for more information.

The following commands to **ioctl** are used to manipulate distributed interrupts. These commands can also be applied to ETIs. All **ioctl** calls use the constants defined in /usr/include/rcim.h. Refer to the rcim\_distrib\_intr(4) man page for more information.

| DISTRIB_INTR_ARM       | arms the DI                                                  |
|------------------------|--------------------------------------------------------------|
| DISTRIB_INTR_DISARM    | disarms the DI                                               |
| DISTRIB_INTR_ENABLE    | enables the DI                                               |
| DISTRIB_INTR_DISABLE   | disables the DI                                              |
| DISTRIB_INTR_REQUEST   | generates a software requested interrupt                     |
| DISTRIB_INTR_INFO      | gets information about the DI                                |
| DISTRIB_INTR_WAIT      | sleeps until the next DI                                     |
| DISTRIB_INTR_WAKEUP    | wakes up all sleeping processes                              |
| DISTRIB_INTR_KEEPALIVE | sets or clears keepalive state                               |
| DISTRIB_INTR_GETICNT   | returns the number of times this DI has fired                |
| DISTRIB_INTR_VECTOR    | gets interrupt vector for the DI                             |
| IOCTLKEEPALIVE         | sets or clears keepalive state (generic)                     |
| IOCTLGETICNT           | returns the number of times this DI has fired (generic)      |
| IOCTLVECNUM            | sets interrupt vector for the DI (generic)                   |
| IOCTLSIGATTACH         | requests a signal when an RCIM device generates an interrupt |

Note that like ETIs, a distributed interrupt must be armed and enabled before an interrupt can be received.

RCIM User's Guide

# A RCIM III Registers

This section contains the address map and registers on the RCIM III board.

Note that some registers appear at two places in the physical address space. For these registers there is an associated *Xregister*. For example PCSAT and XPCSAT. The *Xregister* accommodates systems with a 64k, rather than the old 4k page size.

# **RCIM III Address Map**

| Address    | Function                               |         |              |
|------------|----------------------------------------|---------|--------------|
| 0xXXX00000 | Board Status/Control Register          | (BSCR)  |              |
| 0xXXX00004 | FirmwareRev/OptionsPresentRegister     | (FWOP)  |              |
| 0xXXX00010 | Interrupt Enable Register #1           | (IER1)  |              |
| 0xXXX00014 | Interrupt Enable Register #2           | (IER2)  |              |
| 0xXXX00020 | Interrupt Request Register #1          | (IRR1)  | (Write Only) |
| 0xXXX00024 | Interrupt Request Register #2          | (IRR2)  | (Write Only) |
| 0xXXX00020 | Interrupt Pending Register #1          | (IPR1)  | (Read Only)  |
| 0xXXX00024 | Interrupt Pending Register #2          | (IPR2)  | (Read Only)  |
| 0xXXX00030 | Interrupt Clear Register #1            | (ICR1)  |              |
| 0xXXX00034 | Interrupt Clear Register #2            | (ICR2)  |              |
| 0xXXX00040 | Interrupt Arm Register #1              | (IAR1)  |              |
| 0xXXX00044 | Interrupt Arm Register #2              | (IAR2)  |              |
| 0xXXX00050 | Interrupt Select Level Register #1     | (ISLR1) |              |
| 0xXXX00054 | Interrupt Select Level Register #2     | (ISLR2) |              |
| 0xXXX00060 | Interrupt Select Polarity Register #1  | (ISPR1) |              |
| 0xXXX00064 | Interrupt Select Polarity Register #2  | (ISPR2) |              |
| 0xXXX00070 | External Interrupt Routing Register #1 | (EIRR1) |              |
| 0xXXX00074 | External Interrupt Routing Register #2 | (EIRR2) |              |
| 0xXXX00078 | External Interrupt Routing Register #3 | (EIRR3) |              |
| 0xXXX00080 | Cable Interrupt Routing Register #1    | (CIRR1) |              |
| 0xXXX00084 | Cable Interrupt Routing Register #2    | (CIRR2) |              |
| 0xXXX00088 | Cable Interrupt Routing Register #3    | (CIRR3) |              |
| 0xXXX00200 | PPS Snapshot Register                  | (PPS)   | (Read Only)  |
| 0xXXX00210 | Cable Snapshot Register                | (CSR)   | (Read Only)  |
| 0xXXX00220 | Cable Master Time Register             | (CMTR)  | (Read Only)  |
| 0xXXX00400 | Clear Cable Errors                     | (CCERR) | (Write Only) |
| 0xXXX00410 | Output Cable Status Register           | (OCSR)  | (Read Only)  |
| 0xXXX00420 | Input Cable Status Register            | (ICSR)  | (Read Only)  |
| 0xXXX01000 | Tick Clock Upper                       | (TCU)   |              |
| 0xXXX10000 | Tick Clock Upper                       | (XTCU)  |              |
| 0xXXX01008 | Tick Clock Lower                       | (TCL)   |              |
| 0xXXX10008 | Tick Clock Lower                       | (XTCL)  |              |

| Address                  | Function                                                             |                    |                              |
|--------------------------|----------------------------------------------------------------------|--------------------|------------------------------|
| 0xXXX01010               | Tick Clock Status/Control                                            | (TCSC)             |                              |
| 0xXXX10010               | Tick Clock Status/Control                                            | (XTCSC)            |                              |
| 0xXXX01100               | POSIX Clock Seconds                                                  | (PCS)              |                              |
| 0xXXX10100               | POSIX Clock Seconds                                                  | (XPCS)             |                              |
| 0xXXX01108               | POSIX Clock Nanoseconds                                              | (PCN)              |                              |
| 0xXXX10108               | POSIX Clock Nanoseconds                                              | (XPCN)             |                              |
| 0xXXX01110<br>0xXXX10110 | POSIX Clock Status/Control<br>POSIX Clock Status/Control             | (PCSC)             |                              |
| 0xXXX01110               | POSIX Clock Status/Control POSIX Clock Skip/Add Time                 | (XPCSC)<br>(PCSAT) | (Write Only)                 |
| 0xXXX10114               | POSIX Clock Skip/Add Time                                            | (XPCSAT)           | (Write Only)                 |
| 0xXXX01120               | Clock Frequency Adjust Register                                      | (CFAR)             | (                            |
| 0xXXX10120               | Clock Frequency Adjust Register                                      | (XCFAR)            |                              |
| 0xXXX02000               | RTC #0 Control                                                       | (RTC0C)            |                              |
| 0xXXX02010               | RTC #0 Timer                                                         | (RTC0T)            |                              |
| 0xXXX02014               | RTC #0 Repeat                                                        | (RTC0R)            |                              |
| 0xXXX02020               | RTC #1 Control                                                       | (RTC1C)            |                              |
| 0xXXX02030               | RTC #1 Timer                                                         | (RTC1T)            |                              |
| 0xXXX02034               | RTC #1 Repeat                                                        | (RTC1R)            |                              |
| 0xXXX02040               | RTC #2 Control                                                       | (RTC2C)            |                              |
| 0xXXX02050               | RTC #2 Timer                                                         | (RTC2T)            |                              |
| 0xXXX02054               | RTC #2 Repeat                                                        | (RTC2R)            |                              |
| 0xXXX02060               | RTC #3 Control                                                       | (RTC3C)            |                              |
| 0xXXX02070               | RTC #3 Timer                                                         | (RTC3T)            |                              |
| 0xXXX02074               | RTC #3 Repeat                                                        | (RTC3R)            |                              |
| 0xXXX02080               | RTC #4 Control                                                       | (RTC4C)            |                              |
| 0xXXX02090               | RTC #4 Timer                                                         | (RTC4T)            |                              |
| 0xXXX02094               | RTC #4 Repeat                                                        | (RTC4R)            |                              |
| 0xXXX020A0               | RTC #5 Control                                                       | (RTC5C)            |                              |
| 0xXXX020B0               | RTC #5 Timer                                                         | (RTC5T)            |                              |
| 0xXXX020B4               | RTC #5 Repeat                                                        | (RTC5R)            |                              |
| 0xXXX020C0               | RTC #6 Control                                                       | (RTC6C)            |                              |
| 0xXXX020D0               | RTC #6 Timer                                                         | (RTC6T)            |                              |
| 0xXXX020D4               | RTC #6 Repeat                                                        | (RTC6R)            |                              |
| 0xXXX020E0               | RTC #7 Control                                                       | (RTC7C)            |                              |
| 0xXXX020F0               | RTC #7 Timer                                                         | (RTC7T)            |                              |
| 0xXXX020F4               | RTC #7 Repeat                                                        | (RTC7R)            |                              |
| 0xXXX03000<br>0xXXX30000 | Programmable Interrupt Generator<br>Programmable Interrupt Generator | (PIG)<br>(XPIG)    |                              |
| 0xXXX03010<br>0xXXX30010 | Programmable INTR Generator Set<br>Programmable INTR Generator Set   | (PIGS)<br>(XPIGS)  | (Write Only)<br>(Write Only) |
| 0xXXX03020               | Programmable INTR Generator Clear                                    | (PIGC)             | (Write Only)                 |
| 0xXXX30020               | Programmable INTR Generator Clear                                    | (XPIGC)            | (Write Only)                 |
| 0xXXX03100               | SPI Count Register                                                   | (SCR)              |                              |
| 0xXXX03200               | GPS Receive Pointers                                                 | (GRXP)             |                              |
| 0xXXX03204               | GPS Transmit Pointers                                                | (GTXP)             |                              |
| 0xXXX03208               | GPS Debug Control Register                                           | (GDCR)             |                              |

| Address                   | Function                         |        |  |
|---------------------------|----------------------------------|--------|--|
| 0xXXX0320C                | GPS Communication Error Register | (GCER) |  |
| 0xXXX03800-<br>0xXXX03FFF | SPI Data Buffer                  | (SDB)  |  |
| 0xXXX04000-<br>0xXXX047FF | GPS Receive Data Buffer          | (GRDB) |  |
| 0xXXX04800-<br>0xXXX04FFF | GPS Transmit Data Buffer         | (GTDB) |  |

# **RCIM III Registers**

RCIM III registers are illustrated in this section.

NOTE: Unless otherwise stated, a bit value of 1=on; 0=off

#### Figure A-1 RCIM III Board Status/Control Register (BSCR)

This register provides status and control of certain features of the RCIM III board.

Offset: 00000



## Figure A-2 RCIM III Firmware Revision/Options Present Register (FWOP)

This register provides information on what options are present on this RCIM board and the firmware revision.

#### Offset: 000004



# Figure A-3 RCIM III Interrupt Enable/Request/Pending/Clear/Arm/Level/Polarity Registers (IER, IRR, IPR, ICR, IAR, ISLR, ISPR)

The enable registers (IER) enable the selected interrupts.

The request registers (IRR) are software driven requests of the selected interrupts.

The pending registers (IPR) are pending requests.

The clear registers (ICR) clear the selected interrupts.

The arm registers (IAR) arm the selected interrupts for edge triggering.

The level registers (ISLR) set level (1) or edge (0) for the selected interrupts.

The polarity registers (ISPR) set polarity high (1) or low (0) for the selected interrupts.

# Offsets: IER1: 00010, IER2: 00014, IRR1/IPR1: 00020, IRR2/IPR2: 00024, ICR1: 00030, ICR2: 00034, IAR1: 00040, IAR2: 00044, ISLR1: 00050, ISLR2: 00054, ISPR1: 00060, ISPR2: 00064

| Re | gister    | #1                       |              |             |              |              |    |      |    |    |    |     |      |    |    |    |    |        |    |                          |          |            |             |            |   |     |      |    |   |   |
|----|-----------|--------------------------|--------------|-------------|--------------|--------------|----|------|----|----|----|-----|------|----|----|----|----|--------|----|--------------------------|----------|------------|-------------|------------|---|-----|------|----|---|---|
|    |           |                          |              |             |              |              |    |      |    |    |    |     |      | Bi | ts |    |    |        |    |                          |          |            |             |            |   |     |      |    |   |   |
| 31 | 30 29     | 28                       | 27           | 26          | 25           | 24           | 23 | 3 22 | 21 | 20 | 19 | 18  | 17   | 16 | 15 | 14 | 13 | 12     | 11 | 10                       | 9        | 8          | 7           | 6          | 5 | 4   | 3    | 2  | 1 | 0 |
|    |           | C                        | CI           |             | •            | •            |    | Al   | JX |    | R  | ese | erve | d  |    |    |    | E      | I  | •                        |          | •          |             | •          | • | R   | ГС   |    |   |   |
| 7  | 65        | 4                        | 3            | 2           | 1            | 0            | 3  | 2    | 1  | 0  |    |     |      |    | 7  | 6  | 5  | 4      | 3  | 2                        | 1        | 0          | 7           | 6          | 5 | 4   | 3    | 2  | 1 | 0 |
| Re | gister    | #2                       |              |             |              |              |    |      |    |    |    |     |      |    |    |    |    |        |    |                          |          |            |             |            |   |     |      |    |   |   |
|    |           |                          |              |             |              |              |    |      |    |    |    |     |      | Bi | ts |    |    |        |    |                          |          |            |             |            |   |     |      |    |   |   |
| 31 | 30 29     | 28                       | 27           | 26          | 25           | 24           | 23 | 3 22 | 21 | 20 | 19 | 18  | 17   | 16 | 15 | 14 | 13 | 12     | 11 | 10                       | 9        | 8          | 7           | 6          | 5 | 4   | 3    | 2  | 1 | 0 |
| R  | eserv     | ed                       |              | C           | CI           |              |    |      |    |    | R  | ese | erve | d  |    |    |    |        |    | E                        | I        |            |             |            | R | ese | erve | ed |   |   |
|    |           |                          | 11           | 10          | 9            | 8            |    |      |    |    |    |     |      |    |    |    |    |        | 11 | 10                       | 9        | 8          |             |            |   |     |      |    |   |   |
| EI | JX =<br>= | Cat<br>Aux<br>Ext<br>RT( | xilia<br>ern | ary<br>al I | Inte<br>Inte | erru<br>erru | up | t (G | PS | )  |    |     |      |    |    |    |    | A<br>A | UX | 0 =<br>1 =<br>2 =<br>3 = | GP<br>GP | S_T<br>S_E | -X_I<br>3X_ | EMF<br>FUL |   | ,   |      |    |   |   |

# Figure A-4 RCIM III External Interrupt Routing Registers (EIRR)

The external interrupt routing registers route selected interrupts to the external interrupt connector.

Offset: EIRR1: 00070, EIRR2: 00074, EIRR3: 00078

Г

|          | Interrupt Numl |                  |                                | Bi  | ts    |              |                         |       |                | ~       | er Numbe |
|----------|----------------|------------------|--------------------------------|-----|-------|--------------|-------------------------|-------|----------------|---------|----------|
| 31 30 20 | 28 27 26 25 24 | 23 22            | 21 20 19 18 1                  |     | 15 14 | 13 12        |                         | 0 9 8 | 76             | 5 4 3   | 2 1      |
| 51 30 23 |                | 25 22            |                                | 10  | 13 14 | 13 12        | - <u>  · ·   ·</u><br>1 | 0 9 0 | 10             | 5 4 5   | 0        |
|          | 3              | 4                | 2                              |     |       |              |                         |       |                |         | -        |
| Res.     | 7              | Res.             | 6                              |     | Res.  |              | 5                       |       | Res.           |         | 4        |
|          | 11             | Ţ                | 10                             |     |       |              | 9                       |       |                |         | 8        |
| 5        | 4 3 2 1 0      |                  | 5 4 3 2 1                      | 0   |       | 5 4          | 3 2                     | 2 1 0 |                | 5 4 3   | 2 1      |
|          |                |                  |                                | 1 1 |       |              |                         |       |                |         |          |
|          | Value          | Desc             | ription                        |     |       | Valu         | e                       | Des   | criptio        | n       |          |
|          | 0x00           | Rese             | rved                           |     | =     | 0x20         | <u>ົ</u>                | GPS   | S_PPS          |         |          |
|          | 0x01           | Rese             |                                |     |       | 0x2          |                         |       | erved          |         |          |
|          | 0x02           | Rese             |                                |     |       | 0x22         |                         |       | erved          |         |          |
|          | 0x03           | Rese             | erved                          |     |       | 0x23         |                         | Res   | erved          |         |          |
|          | 0x04           | RTC              | 0                              |     | ⊢     | 0x24         | 4                       | RTC   | : 4            |         | 1        |
|          | 0x05           | RTC              |                                |     |       | 0x2          |                         | RTC   |                |         |          |
|          | 0x06           | RTC              | 2                              |     |       | 0x26         |                         | RTC   |                |         |          |
|          | 0x07           | RTC              | 3                              |     |       | 0x27         | 7                       | RTC   |                |         |          |
|          | 0x08           | Edge             | e Interrupt 0                  |     |       | 0x28         | 3                       | Edg   | e Inter        | rupt 4  |          |
|          | 0x09           | Edge             | e Interrupt 1                  |     |       | 0x29         | 9                       | Edg   | e Inter        | rupt 5  |          |
|          | 0x0A           | Edge             | e Interrupt 2                  |     |       | 0x2/         | 4                       | Edg   | e Inter        | rupt 6  |          |
|          | 0x0B           | Edge             | e Interrupt 3                  |     |       | 0x2          | 3                       | Edg   | e Inter        | rupt 7  |          |
|          | 0x0C           | PIG (            |                                |     |       | 0x20         | С                       | PIG   | 4              |         |          |
|          | 0x0D           | PIG <sup>2</sup> |                                |     |       | 0x2[         |                         | PIG   |                |         |          |
|          | 0x0E           | PIG 2            |                                |     |       | 0x2          |                         | PIG   |                |         |          |
|          | 0x0F           | PIG 3            | 3                              |     |       | 0x2          |                         | PIG   |                |         |          |
|          | 0x10           |                  | e Interrupt 0                  |     |       | 0x30         |                         |       | erved          |         |          |
|          | 0x11           |                  | e Interrupt 1                  |     |       | 0x3          |                         |       | erved          |         |          |
|          | 0x12           |                  | e Interrupt 2                  |     |       | 0x32         |                         |       | erved          |         |          |
|          | 0x13           |                  | e Interrupt 3                  |     |       | 0x33<br>0x34 |                         |       | erved<br>erved |         |          |
|          | 0x14           |                  | e Interrupt 4                  |     |       | 0x34<br>0x35 |                         |       | erved<br>erved |         |          |
|          | 0x15<br>0x16   |                  | e Interrupt 5<br>e Interrupt 6 |     |       | 0x36         |                         |       | erved          |         |          |
|          | 0x16<br>0x17   |                  | e Interrupt 6                  |     |       | 0x37         |                         |       | erved          |         |          |
|          | 0x17<br>0x18   |                  | e Interrupt 8                  |     | ⊢     | 0x38         |                         |       |                | rupt 8  | -        |
|          | 0x19           |                  | e Interrupt 9                  |     |       | 0x39         |                         | -     |                | rupt 9  |          |
|          | 0x19<br>0x1A   |                  | e Interrupt 10                 |     |       | 0x3/         |                         | -     |                | rupt 10 |          |
|          | 0x1B           |                  | e Interrupt 11                 |     |       | 0x3E         |                         |       |                | rupt 11 |          |
|          | 0x1C           | Rese             |                                |     | F     | 0x30         |                         | PIG   |                | -       | 1        |
|          | 0x1D           | Rese             |                                |     |       | 0x3[         |                         | PIG   |                |         |          |
|          | 0x1E           | Rese             |                                |     |       | 0x3I         |                         | PIG   |                |         |          |
|          | 0x1F           | Rese             |                                | 1   |       | 0x3l         |                         | PIG   |                |         |          |

# Figure A-5 RCIM III Cable Interrupt Routing Registers (CIRR)

The cable interrupt routing registers route selected interrupts to the RCIM interconnecting cable.

Offsets: CIRR1: 00080, CIRR2: 00084, CIRR3: 00088

| Cable Interrupt Register 1               |         |            |                    |      |       |    |     |          | C   | Cabl         | e In  | iter | rupt | Nu  | mb | er               |
|------------------------------------------|---------|------------|--------------------|------|-------|----|-----|----------|-----|--------------|-------|------|------|-----|----|------------------|
|                                          |         |            | Bits               |      |       |    |     |          |     |              |       |      |      |     |    | ]                |
| 31 30 29 28 27 26 25 24 23 23            |         | 19 18 1    | 17 16 15           |      |       | 11 | 10  | 98       | 3 7 | 6            | 5     | 4    | 3    | 2 1 | 0  |                  |
| 7 6                                      | 5       | 4          |                    | 3    |       |    | 2   | 2        |     | ,            |       |      |      | 0   | _  |                  |
| 7 6 5 4 3 2 1 0 7 6                      | 5 4     | 3 2        | 1 0 7              | 6    | 5 4   | 3  | 2   | 1 (      | ) 7 | 6            | 5     | 4    | 3 2  | 2 1 | 0  |                  |
| Cable Interrupt Register 2               |         |            |                    |      |       |    |     |          |     |              |       |      |      |     |    |                  |
| Γ                                        |         |            | Bits               |      |       |    |     |          |     |              |       |      |      |     |    | ٦                |
| 31 30 29 28 27 26 25 24 23 22            | 21 20   | 19 18 1    |                    | 14   | 13 12 | 11 | 10  | 9 8      | 3 7 | 6            | 5     | 4    | 3 2  | 2 1 | 0  | -                |
| Reserved                                 | 2.12.   |            |                    | 1    |       |    | 1   |          |     |              | 9     | •    |      | 8   | Ŭ  |                  |
|                                          |         |            | 3                  | 2    | 1 0   | 3  | 2   | 1 (      | ) 3 | 2            | 1     | 0    | 3 2  | 2 1 | 0  |                  |
|                                          |         |            | I                  |      |       |    |     |          |     |              |       |      |      |     |    |                  |
| Cable Interrupt Register 3               |         |            |                    |      |       |    |     |          |     |              |       |      |      |     |    |                  |
|                                          |         |            | Bits               |      |       |    |     |          |     |              |       |      |      |     |    | ٦                |
| 31 30 29 28 27 26 25 24 23 23            | 2 21 20 | 19 18 1    |                    | 14   | 13 12 | 11 | 10  | 9 8      | 3 7 | 6            | 5     | 4    | 3    | 2 1 | 0  | -                |
| Reserved 11                              | 10      | 9          | 8 7                |      | 6     |    | 5   | 4        | _   | 3            | 2     |      | 1    |     | 0  | - <mark>↓</mark> |
| 5 4                                      |         | 5 4        | 5 4 5              | 4    | 5 4   | 5  | 4   | 5 4      | 15  | 4            | 5     | 4    | 5    | 4 5 | 4  | -                |
|                                          |         | - I I      |                    |      |       |    | 1 1 |          |     | 1            |       |      |      |     |    |                  |
| Value Description                        | V       | /alue      | Descri             | otio | on    |    | Val | ue       | D   | esc          | ript  | ior  | ו    |     |    |                  |
| 0x00 Reserved                            | -       | x10        | Reserv             |      |       |    | 0x  | 20       |     | PS_          | _     |      |      |     |    |                  |
| 0x01 Reserved                            | _       | x11        | Reserv             |      |       |    | 0x  | 21       | R   | ese          | rve   | d    |      |     |    |                  |
| 0x02 Reserved<br>0x03 Reserved           | -       | x12<br>x13 | Reserv<br>Reserv   |      |       |    | 0x  | <br>27   | R   | <br>ese      | rve   | d    |      |     |    |                  |
| 0x04 RTC 0                               |         | x14        | RTC 4              |      |       |    | -   | 28       |     |              | _     | -    | upt  | R   |    |                  |
| 0x05 RTC 1                               | -       | x15        | RTC 5              |      |       |    | -   | 29       |     | •            |       |      | upt  |     |    |                  |
| 0x06 RTC 2                               | 0       | x16        | RTC 6              |      |       |    | 0x  | 2A       |     | •            |       |      | upt1 |     |    |                  |
| 0x07 RTC 3                               | 0       | x17        | RTC 7              |      |       |    | 0x  | 2B       | E   | dge          | elnte | erru | upt1 | 1   |    |                  |
| 0x08 EdgeInterrup                        |         | x18        | Edgelr             |      |       |    |     | 2C       |     | IG 8         |       |      |      |     |    |                  |
| 0x09 Edge Interrup                       |         | x19        | Edgelr             |      |       |    |     | 2D       |     | IG 9         |       |      |      |     |    |                  |
| 0x0A Edge Interrup<br>0x0B Edge Interrup |         | x1A<br>x1B | Edge Ir<br>Edge Ir |      | •     |    |     | 2E<br>2F |     | IG 1<br>IG 1 |       |      |      |     |    |                  |
| 0x0C PIG 0                               |         | x1C        | PIG 4              |      |       |    |     | 30       |     | ese          |       | h    |      |     |    |                  |
| 0x0D PIG 1                               |         | x1D        | PIG 5              |      |       |    | 0.  |          |     |              |       | u    |      |     |    |                  |
| 0x0E PIG 2                               | 0       | x1E        | PIG 6              |      |       |    |     | Ì        |     | ĺ            |       |      |      |     |    |                  |
| 0x0F PIG 3                               | 0       | x1F        | PIG 7              |      |       |    | 0x  | 3F       | R   | ese          | rve   | d    |      |     |    |                  |

#### Figure A-6 RCIM III PPS Snapshot Register (PPS)

The PPS Snapshot register contains a snapshot of the nanoseconds field and two bits of the seconds field of the POSIX clock. The snapshot is taken every time the GPS PPS signal occurs.

Offset: 00200



#### Figure A-7 RCIM III Cable Snapshot Register (CSR)

The Cable Snapshot register contains a snapshot of the nanoseconds field and two bits of the seconds field of the POSIX clock. The snapshot is taken every time the cable master time is received.

Offset: 00210



#### Figure A-8 RCIM III Cable Master Time Register (CMTR)

The Cable Master Time register contains the seconds field of the master RCIM POSIX clock that is transmitted on the cable at every transition of the clock at the seconds boundary.

Offset: 00220



#### Figure A-9 RCIM III Clear Cable Errors Register (CCERR)

This is a Write Only register that clears any reported cable errors. The data field is don't care.

Offset: 00400



#### Figure A-10 RCIM III Output Cable Status Register (OCSR)

This register provides detailed hardware status information pertaining to the output cable.

Offset: 00410

| 31 30 | 29 28 | 27          | 26                                   | 25                   | 24                  | 23                 | 22         | 21          | 20          | 19  | 18  | 17 | 16 | 15 | 14 | 4 13 | 12  | 11  | 10   | 9  | 8  | 7    | 6  | 5 | 4 | 3        | 2 | 1 | 0 |
|-------|-------|-------------|--------------------------------------|----------------------|---------------------|--------------------|------------|-------------|-------------|-----|-----|----|----|----|----|------|-----|-----|------|----|----|------|----|---|---|----------|---|---|---|
|       |       | R           | ese                                  | rve                  | d                   |                    |            | 1           | i           | I   | 1   | 1  | 1  |    |    |      | Res | ser | rved |    |    |      |    |   |   | <u> </u> |   |   |   |
|       | ;     | SFP<br>Rece | Not<br>P Los<br>eiver<br>Rece<br>Rec | ss o<br>r Lo<br>eive | of S<br>oss<br>er L | Sig<br>s of<br>.os | nal<br>Sig | gna<br>f Sỵ | al —<br>ync | :   |     |    |    |    |    |      |     | Eı  | rror | Co | un | t (R | :) |   |   |          |   |   |   |
|       |       |             |                                      | Tr                   | 'an                 | em                 | it I       | os          | s 0         | flo | hck |    |    |    |    |      |     |     |      |    |    |      |    |   |   |          |   |   |   |

#### Figure A-11 RCIM III Input Cable Status Register (ICSR)

This register provides detailed hardware status information pertaining to the input cable.

Offset: 00420



#### Figure A-12 RCIM III Tick Clock Upper Register (TCU, XTCU)

This register contains the upper 32 bits of the tick clock.

Offsets: TCU: 01000, XTCU: 10000



#### Figure A-13 RCIM III Tick Clock Lower Register (TCL, XTCL)

This register contains the lower 32 bits of the tick clock.

Offsets: TCL: 01008, XTCL:10008

|    |    |    |    |    |    |    |    |    |    |    |    |     |      |     | В  | lits |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|-----|----|------|----|------|------|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18   | 17  | 16 | 6 15 | 14 | 13   | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    | Tio | ck ( | Clo | ck | low  | er | 32 k | oits | ;  |    |   |   |   |   |   |   |   |   |   |   |

### Figure A-14 RCIM III Tick Clock Status/Control Register (TCSC, XTCSC)

This register provides status and control of the tick clock.

Offsets: TCSC: 01010, XTCSC:10010

| Bits                                                               |      |      |       |      |      |      |     |     |
|--------------------------------------------------------------------|------|------|-------|------|------|------|-----|-----|
| 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8    | 7    | 6 5   | 5 4  | 4 3  | 3    | 2 1 | 0   |
| Reserved                                                           |      | R    | eser  | ved  |      |      |     |     |
| Cable Enable (R)-                                                  |      |      |       |      |      |      |     |     |
| No Reset When                                                      | Dis  | abl  | ed (I | R/W  | /)   |      |     |     |
| L                                                                  | ocal | I Ei | nable | e (R | ./W  | )—   | ]   |     |
| Selec                                                              | t Ca | able | e Ena | able | e (R | /W   | )—  |     |
| S                                                                  | ele  | ct ( | Cabl  | e C  | loc  | k (l | R/W | /)— |

#### Figure A-15 RCIM III POSIX Clock Seconds Register (PCS, XPCS)

This register contains the POSIX clock seconds.

Offsets: PCS: 01100, XPCS: 10100



#### Figure A-16 RCIM III POSIX Clock Nanoseconds Register (PCN, XPCN)

This register contains the POSIX clock nanoseconds.

Offsets: PCN: 01108, XPCN:10108

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Bi | ts |    |                 |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 <sup>-</sup> | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | ( |

## Figure A-17 RCIM III POSIX Clock Status/Control Register (PCSC, XPCSC)

This register provides status and control of the POSIX clock.

#### Offsets: PCSC: 01110, XPCSC: 10110

|       |     |     |     |    |    |    |    |    |   |     |     |    |    |      |      | В  | its  |      |     |    |    |    |      |     |     |      |     |     |     |     |     |      |   |
|-------|-----|-----|-----|----|----|----|----|----|---|-----|-----|----|----|------|------|----|------|------|-----|----|----|----|------|-----|-----|------|-----|-----|-----|-----|-----|------|---|
| 31 30 | 0 2 | 9 2 | 8 2 | 27 | 26 | 25 | 24 | 23 | 2 | 2 2 | 1 2 | 20 | 19 | 9 18 | 3 17 | 16 | 5 15 | 5 14 | I 1 | 13 | 12 | 11 | 10   | 9   | 8   | 7    | 6   | 5   | 4   | 3   | 2   | 1    | C |
| 1     |     |     |     |    |    |    | 1  |    |   | Re  | ese | er | ve | d    | 1    |    |      |      |     |    |    |    | 1    |     |     |      | Re  | ser | vec | ł   |     | <br> | 1 |
|       |     |     |     |    |    |    |    |    |   |     |     |    |    |      |      |    |      | Са   | ab  | le | En | ab | le ( | R)- |     |      |     |     |     |     |     |      |   |
|       |     |     |     |    |    |    |    |    |   |     |     |    |    |      |      |    |      |      |     |    |    |    |      | Lo  | oca | ΙE   | nat | ole | (R/ | W)- |     |      |   |
|       |     |     |     |    |    |    |    |    |   |     |     |    |    |      |      |    |      |      |     |    |    |    | Se   | lec | t C | abl  | e E | nał | ole | (R/ | W)  |      |   |
|       |     |     |     |    |    |    |    |    |   |     |     |    |    |      |      |    |      |      |     |    |    |    |      | s   | ele | ct ( | Cab | le  | Clo | ck  | (R/ | W)   |   |

#### Figure A-18 RCIM III POSIX Clock Skip/Add Time Register (PCSAT, XPCSAT)

This register skips/adds time to the POSIX clock in 400 nanosecond increments.

Offsets: PCSAT: 01114, XPCSAT:10114

| Bits                                                                                |                  |
|-------------------------------------------------------------------------------------|------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 1 C              |
| Reserved                                                                            | $\left  \right $ |
| Add Time (W)—                                                                       |                  |
| Skip Time (W                                                                        | )—               |
|                                                                                     |                  |

#### Figure A-19 RCIM III Clock Frequency Adjust Register (CFAR, XCFAR)

The clock frequency adjust register is used to control the frequency of the 10 Mhz master clock.

Offsets: CFAR: 01120, XCFAR:10120



#### Figure A-20 RCIM III RTC Timer Registers (RTCT)

The initial RTC timer value is loaded in the RTC timer registers. The current value of the timer is read from this register. NOTE: Loading this register also loads the RTC Repeat Register for compatibility with RCIM.

Offsets: RTC0T: 02010, RTC1T: 02030, RTC2T: 02050, RTC3T: 02070, RTC4T: 02090, RTC5T: 020B0, RTC6T: 020D0, RTC7T: 020F0



#### Figure A-21 RCIM III RTC Repeat Registers (RTCR)

The RTC repeat registers contain the repeat count value.

Offsets: RTC0R: 02014, RTC1R: 02034, RTC2R: 02054, RTC3R: 02074, RTC4R: 02094, RTC5R: 020B4, RTC6R: 020D4, RTC7R: 020F4



#### Figure A-22 RCIM III RTC Control Registers (RTCC)

This register provides control of the RTCs.

Offsets: RTC0C: 02000, RTC1C: 02020, RTC2C: 02040, RTC3C: 02060, RTC4C: 02080, RTC5C: 020A0, RTC6C: 020C0, RTC7C: 020E0



#### Figure A-23 RCIM III Programmable Interrupt Generator Register (PIG, XPIG)

This register identifies the programmable interrupts.

Offsets: PIG: 03000, XPIG:30000



#### Figure A-24 RCIM III Programmable Interrupt Set (PIGS, XPIGS) and Clear (PIGC, XPIGC) Registers

Writing to these registers sets/clears the unitary bits in the Programmable Interrupt Register without affecting the other bits.

Offsets: PIGS: 03010, XPIGS: 30010 PIGC: 03020, XPIGC: 30020

|    |    |    |    |    |    |    |    |    |     |     |    |    |    |    | <u> </u> |    |    |    |    |    |    |   |   |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----------|----|----|----|----|----|----|---|---|---|----|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |     |     |    |    |    |    | Bi       | ts |    |    |    |    |    |   |   |   |    |   |   |   |   |   |   |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21  | 20 | 19 | 18 | 17 | 16       | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    | Re | ese | rve | ed |    |    |    |          |    |    |    |    |    |    |   |   |   | PI | G |   |   |   |   |   |

#### Figure A-25 RCIM III SPI Count Register (SCR)

The SPI (serial peripheral interface) count register contains the count for SPI transfers. The SPI interface is used to program the FPGA serial prom.





### Figure A-26 RCIM III GPS Receive Pointers (GRXP)

The GPS receive pointers are used for communication with the optional GPS module.

|                |           |                |    |    |    |    |    | В  | its |     |      |      |     |      |     |     |      |    |   |   |   |   |   |   |
|----------------|-----------|----------------|----|----|----|----|----|----|-----|-----|------|------|-----|------|-----|-----|------|----|---|---|---|---|---|---|
| 31 30 29 28 27 | 26 25 24  | 23 22          | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14  | 13   | 12   | 11  | 10   | 9   | 8   | 7    | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved       |           |                |    |    |    |    |    |    | I   | Res | serv | /ed  |     |      |     | •   |      |    | 1 |   |   |   |   |   |
| Receive Hea    | ad Pointe | er (R <u>)</u> |    |    |    |    |    |    |     |     | R    | lece | eiv | e Ta | ail | Poi | inte | er |   |   |   |   |   |   |

#### Figure A-27 RCIM III GPS Transmit Pointers (GTXP)

The GPS transmit pointers are used for communication with the optional GPS module.

Offset: 03204

|                |                  | В                | its            |               |             |
|----------------|------------------|------------------|----------------|---------------|-------------|
| 31 30 29 28 27 | 26 25 24 23 22 2 | 1 20 19 18 17 16 | 15 14 13 12 11 | 10 9 8 7 6    | 5 4 3 2 1 0 |
| Reserved       |                  |                  | Reserved       | · _ · _ ·     |             |
| Transmit I     | Head Pointer     |                  | Transmit Tai   | I Pointer (R) |             |

### Figure A-28 RCIM III GPS Debug Control Register (GDCR)

The GPS debug control register contains bits used during testing and debug. Setting any of these bits will disable RCIM communication with the GPS module.

| Bits<br>31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>Reserved<br>Enable GPS External Communication<br>Enable UART Loopback |                                                       |              |        |     |   |   |   |   |   |   |   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------|--------|-----|---|---|---|---|---|---|---|
| Reserved<br>Enable GPS External Communication                                                                                                                          | Bits                                                  |              |        |     |   |   |   |   |   |   |   |
| Enable GPS External Communication                                                                                                                                      | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 | 4 13 12 1    | 1 10 9 | 8 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                                                                                                                                                        | Reserved                                              | <b>1 1 1</b> |        | 1 E |   |   |   |   |   | 1 | 1 |
|                                                                                                                                                                        | _                                                     | nable GF     |        |     |   |   |   |   |   |   |   |

#### Figure A-29 RCIM III GPS Communication Error Register (GCER)

The GPS communication error register contains information regarding communication errors with the GPS module.

Any write to this register will reset the communication interface to the GPS module.

Offset: 0320C



#### Figure A-30 RCIM III SPI Data Buffer (SDB)

This is the SPI Data buffer.

Offset: 03800 to 03FFF



#### Figure A-31 RCIM III GPS Receive Data Buffer (GRDB)

This is the GPS receive data buffer.

Offset: 04000 to 047FF



## Figure A-32 RCIM III GPS Transmit Data Buffer (GRDB)

This is the GPS trasmit data buffer.

Offset: 04800 to 04FFF



RCIM User's Guide

## B RCIM II Registers

This section contains the address map and registers on the RCIM II board.

## **RCIM II Address Map**

| Address    | Function                               |         |              |
|------------|----------------------------------------|---------|--------------|
| 0xXXXX0000 | Board Status/Control Register          | (BSCR)  |              |
| 0xXXXX0004 | FirmwareRev/OptionsPresentRegister     | (FWOP)  |              |
| 0xXXXX0010 | Interrupt Enable Register #1           | (IER1)  |              |
| 0xXXXX0014 | Interrupt Enable Register #2           | (IER2)  |              |
| 0xXXXX0020 | Interrupt Request Register #1          | (IRR1)  | (Write Only) |
| 0xXXXX0024 | Interrupt Request Register #2          | (IRR2)  | (Write Only) |
| 0xXXXX0020 | Interrupt Pending Register #1          | (IPR1)  | (Read Only)  |
| 0xXXXX0024 | Interrupt Pending Register #2          | (IPR2)  | (Read Only)  |
| 0xXXXX0030 | Interrupt Clear Register #1            | (ICR1)  |              |
| 0xXXXX0034 | Interrupt Clear Register #2            | (ICR2)  |              |
| 0xXXXX0040 | Interrupt Arm Register #1              | (IAR1)  |              |
| 0xXXXX0044 | Interrupt Arm Register #2              | (IAR2)  |              |
| 0xXXXX0050 | Interrupt Select Level Register #1     | (ISLR1) |              |
| 0xXXXX0054 | Interrupt Select Level Register #2     | (ISLR2) |              |
| 0xXXXX0060 | Interrupt Select Polarity Register #1  | (ISPR1) |              |
| 0xXXXX0064 | Interrupt Select Polarity Register #2  | (ISPR2) |              |
| 0xXXXX0070 | External Interrupt Routing Register #1 | (EIRR1) |              |
| 0xXXXX0074 | External Interrupt Routing Register #2 | (EIRR2) |              |
| 0xXXXX0078 | External Interrupt Routing Register #3 | (EIRR3) |              |
| 0xXXXX0080 | Cable Interrupt Routing Register #1    | (CIRR1) |              |
| 0xXXXX0084 | Cable Interrupt Routing Register #2    | (CIRR2) |              |
| 0xXXXX0088 | Cable Interrupt Routing Register #3    | (CIRR3) |              |
| 0xXXXX00A0 | PCI Interrupt A Routing Register #1    | (PARR1) |              |
| 0xXXXX00A4 | PCI Interrupt A Routing Register #2    | (PARR2) |              |
| 0xXXXX00B0 | PCI Interrupt B Routing Register #1    | (PBRR1) |              |
| 0xXXXX00B4 | PCI Interrupt B Routing Register #2    | (PBRR2) |              |
| 0xXXXX00C0 | PCI Interrupt C Routing Register #1    | (PCRR1) |              |
| 0xXXXX00C4 | PCI Interrupt C Routing Register #2    | (PCRR2) |              |
| 0xXXXX00D0 | PCI Interrupt D Routing Register #1    | (PDRR1) |              |
| 0xXXXX00D4 | PCI Interrupt D Routing Register #2    | (PDRR2) |              |
| 0xXXXX0100 | DDS Adjust Register #1                 | (DDS)   |              |
| 0xXXXX0200 | PPS Snapshot Register                  | (PPS)   | (Read Only)  |
| 0xXXXX0300 | GPS Transmit/Receive Register          | (GPS)   |              |
|            |                                        |         |              |

| Address    | Function                             |         |              |
|------------|--------------------------------------|---------|--------------|
| 0xXXXX0400 | Clear Cable Errors                   | (CCERR) | (Write Only) |
| 0xXXXX1000 | Tick Clock Upper                     | (TCU)   |              |
| 0xXXXX1008 | Tick Clock Lower                     | (TCL)   |              |
| 0xXXXX1010 | Tick Clock Status/Control            | (TCSC)  |              |
| 0xXXXX1100 | POSIX Clock Seconds                  | (PCS)   |              |
| 0xXXXX1108 | POSIX Clock Nanoseconds              | (PCN)   |              |
| 0xXXXX1110 | POSIX Clock Status/Control           | (PCSC)  |              |
| 0xXXXX1114 | POSIX Clock Skip/Add Time            | (PCSAT) | (Write Only) |
| 0xXXXX2000 | RTC #0 Control                       | (RTC0C) |              |
| 0xXXXX2010 | RTC #0 Timer                         | (RTC0T) |              |
| 0xXXXX2014 | RTC #0 Repeat                        | (RTC0R) |              |
| 0xXXXX2020 | RTC #1 Control                       | (RTC1C) |              |
| 0xXXXX2030 | RTC #1 Timer                         | (RTC1T) |              |
| 0xXXXX2034 | RTC #1 Repeat                        | (RTC1R) |              |
| 0xXXXX2040 | RTC #2 Control                       | (RTC2C) |              |
| 0xXXXX2050 | RTC #2 Timer                         | (RTC2T) |              |
| 0xXXXX2054 | RTC #2 Repeat                        | (RTC2R) |              |
| 0xXXXX2060 | RTC #3 Control                       | (RTC3C) |              |
| 0xXXX2070  | RTC #3 Timer                         | (RTC3T) |              |
| 0xXXXX2074 | RTC #3 Repeat                        | (RTC3R) |              |
| 0xXXX2080  | RTC #4 Control                       | (RTC4C) |              |
| 0xXXXX2090 | RTC #4 Timer                         | (RTC4T) |              |
| 0xXXXX2094 | RTC #4 Repeat                        | (RTC4R) |              |
| 0xXXXX20A0 | RTC #5 Control                       | (RTC5C) |              |
| 0xXXXX20B0 | RTC #5 Timer                         | (RTC5T) |              |
| 0xXXXX20B4 | RTC #5 Repeat                        | (RTC5R) |              |
| 0xXXXX20C0 | RTC #6 Control                       | (RTC6C) |              |
| 0xXXXX20D0 | RTC #6 Timer                         | (RTC6T) |              |
| 0xXXXX20D4 | RTC #6 Repeat                        | (RTC6R) |              |
| 0xXXXX20E0 | RTC #7 Control                       | (RTC7C) |              |
| 0xXXXX20F0 | RTC #7 Timer                         | (RTC7T) |              |
| 0xXXXX20F4 | RTC #7 Repeat                        | (RTC7R) |              |
| 0xXXXX3000 | Programmable Interrupt Generator     | (PIG)   |              |
| 0xXXXX3010 | Programmable Interrupt Generator Set | (PIGS)  | (Write Only) |
| 0xXXXX3020 | ProgrammableInterruptGeneratorClear  | (PIGC)  | (Write Only) |

## **RCIM II Registers**

RCIM II registers are illustrated in this section.

**NOTE**: Unless otherwise stated, a bit value of 1=on; 0=off.

#### Figure B-1 RCIM II Board Status/Control Register (BSCR)

This register provides status and control of certain features of the RCIM II board.



## Figure B-2 RCIM II Firmware Revision/Options Present Register (FWOP)

This register provides information on what options are present on this RCIM board and the firmware revision.



|                                  |             | Bits                                                                                       |
|----------------------------------|-------------|--------------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 | 20 19 18 17 | 7 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                 |
| Reserved                         | 1           | Reserved                                                                                   |
| Firmware Revision (F             | <u>x)</u>   | External Oscillator Present ( <del>R)</del><br>Optional Oscillator Present ( <del>R)</del> |
|                                  |             | GPS Present (R)                                                                            |
|                                  |             |                                                                                            |
|                                  |             |                                                                                            |

# Figure B-3 RCIM II Interrupt Enable/Request/Pending/Clear/Arm/Level/Polarity Registers (IER, IRR, IPR, ICR, IAR, ISLR, ISPR)

The enable registers (IER) enable the selected interrupts.

The request registers (IRR) are software driven requests of the selected interrupts.

The pending registers (IPR) are pending requests.

The clear registers (ICR) clear the selected interrupts.

The arm registers (IAR) arm the selected interrupts for edge triggering.

The level registers (ISLR) set level (1) or edge (0) for the selected interrupts.

The polarity registers (ISPR) set polarity high (1) or low (0) for the selected interrupts.

# Offsets: IER1: 0010, IER2: 0014, IRR1/IPR1: 0020, IRR2/IPR2: 0024, ICR1: 0030, ICR2: 0034, IAR1: 0040, IAR2: 0044, ISLR1: 0050, ISLR2: 0054, ISPR1: 0060, ISPR2: 0064

| Re | gister    | #1         |                                   |              |             |     |    |    |    |    |    |     |      |    |    |    |    |        |    |                          |          |            |             |            |   |     |      |    |   |   |
|----|-----------|------------|-----------------------------------|--------------|-------------|-----|----|----|----|----|----|-----|------|----|----|----|----|--------|----|--------------------------|----------|------------|-------------|------------|---|-----|------|----|---|---|
|    |           |            |                                   |              |             |     |    |    |    |    |    |     |      | Bi | ts |    |    |        |    |                          |          |            |             |            |   |     |      |    |   |   |
| 31 | 30 29     | 28         | 27 2                              | 26 2         | 25 2        | 24  | 23 | 22 | 21 | 20 | 19 | 18  | 17   | 16 | 15 | 14 | 13 | 12     | 11 | 10                       | 9        | 8          | 7           | 6          | 5 | 4   | 3    | 2  | 1 | 0 |
|    |           | C          | CI                                |              |             |     |    | Αl | JX |    | R  | ese | erve | ed |    |    |    | E      | 1  | <u> </u>                 |          |            |             | <b>-</b>   |   | R   | тс   |    |   |   |
| 7  | 6 5       | 4          | 3                                 | 2            | 1           | 0   | 3  | 2  | 1  | 0  |    |     |      |    | 7  | 6  | 5  | 4      | 3  | 2                        | 1        | 0          | 7           | 6          | 5 | 4   | 3    | 2  | 1 | 0 |
| Re | gister    | #2         |                                   |              |             |     |    |    |    |    |    |     |      |    |    |    |    |        |    |                          |          |            |             |            |   |     |      |    |   |   |
|    |           |            |                                   |              |             |     |    |    |    |    |    |     |      | Bi | ts |    |    |        |    |                          |          |            |             |            |   |     |      | _  |   |   |
| 31 | 30 29     | 28         | 27 2                              | 26 2         | 25 2        | 24  | 23 | 22 | 21 | 20 | 19 | 18  | 17   | 16 | 15 | 14 | 13 | 12     | 11 | 10                       | 9        | 8          | 7           | 6          | 5 | 4   | 3    | 2  | 1 | 0 |
| R  | eserv     | ed         |                                   | CI           |             |     |    |    |    |    | R  | ese | erve | ed |    |    |    |        |    | E                        | 1        |            |             |            | R | ese | erve | ed |   |   |
|    |           |            | 11 1                              | 0            | 9           | 8   |    |    |    |    |    |     |      |    |    |    |    |        | 11 | 10                       | 9        | 8          |             |            |   |     |      |    |   |   |
| ΕI | JX =<br>= | Aux<br>Ext | ole Ir<br>xiliar<br>erna<br>C Int | y Ir<br>I In | nte<br>iter | rru | •  | (G | PS | )  |    |     |      |    |    |    | -> | A<br>A | UX | 0 =<br>1 =<br>2 =<br>3 = | GP<br>GP | S_1<br>S_E | ΓΧ_Ι<br>3Χ_ | EMF<br>FUL |   | ,   |      |    |   |   |

## Figure B-4 RCIM II External Interrupt Routing Registers (EIRR)

The external interrupt routing registers route selected interrupts to the external interrupt connector.

Offset: EIRR1: 0070, EIRR2: 0074, EIRR3: 0078

Г

| zxterr | al Interrupt Numb | Jer   |                      |        |      | D:+- |      |            |      |    |     |                |      | ĸ              | egi | ste | r Nu | d (111 |
|--------|-------------------|-------|----------------------|--------|------|------|------|------------|------|----|-----|----------------|------|----------------|-----|-----|------|--------|
|        |                   |       |                      |        | -    | Bits |      |            |      |    |     |                |      |                |     |     | -    |        |
| 31 30  | 29 28 27 26 25 24 | 23 22 | 21 20                | 19 18  | 8 17 | 16 1 | 5 14 | 13 1       | 2 11 | 10 | 98  | 3 7            | 6    | 5              | 4   | 3   | 2    | 1      |
|        | 3                 |       |                      | 2      |      |      |      |            |      | 1  |     |                |      |                |     |     | 0    |        |
| Res.   | 7                 | Res.  |                      | 6      |      | F    | Res. |            |      | 5  |     | R              | es.  |                |     |     | 4    |        |
|        | 11                | -     |                      | 10     |      |      |      |            |      | 9  |     | _              |      |                |     |     | 8    |        |
|        |                   |       |                      |        | _    |      |      |            |      |    |     |                |      |                | 1   |     |      |        |
|        | 5 4 3 2 1 0       |       | 5 4                  | 3 2    | 1    | 0    |      | 5 4        | 4 3  | 2  | 1 ( | )              |      | 5              | 4   | 3   | 2    | 1      |
|        | Value             | Doco  | ription              |        |      |      |      | Val        |      |    | Dec | crip           | tio  | <b>n</b>       |     |     | 1    |        |
|        | Value             | Dest  | inpuor               |        |      |      |      | vai        | ue   |    | Des | crip           |      |                |     |     |      |        |
|        | 0x00              | Rese  | erved                |        |      |      |      | 0x2        | 20   |    | GP  | S_PI           | PS   |                |     |     |      |        |
|        | 0x01              | Rese  |                      |        |      |      |      | 0x2        |      |    | Res | erve           | ed   |                |     |     |      |        |
|        | 0x02              | Rese  |                      |        |      |      |      | 0x2        |      |    |     | erve           |      |                |     |     |      |        |
|        | 0x03              | Rese  | erved                |        |      |      |      | 0x2        | 23   |    | Res | erve           | ed   |                |     |     |      |        |
|        | 0x04              | RTC   |                      |        |      |      |      | 0x2        | 24   |    | RT  | 24             |      |                |     |     |      |        |
|        | 0x05              | RTC   |                      |        |      |      |      | 0x2        | 25   |    | RT  |                |      |                |     |     |      |        |
|        | 0x06              | RTC   |                      |        |      |      |      | 0x2        | 26   |    | RTC |                |      |                |     |     |      |        |
|        | 0x07              | RTC   | 3                    |        |      |      |      | 0x2        | 27   |    | RT  | 27             |      |                |     |     |      |        |
|        | 0x08              | Edge  | Interr               | upt 0  | )    |      |      | 0x2        | 28   |    | Edg | je In          | teri | rup            | t 4 | ŀ   |      |        |
|        | 0x09              | •     | Interr               |        |      |      |      | 0x2        | 29   |    | Edg | je In          | teri | rup            | t 5 | 5   |      |        |
|        | 0x0A              | -     | Interr               |        |      |      |      | 0x2        |      |    |     | je In          |      |                |     |     |      |        |
|        | 0x0B              | Edge  | Interr               | upt 3  |      |      |      | 0x2        | 2B   |    | Edg | je In          | teri | rup            | t 7 | 7   |      |        |
|        | 0x0C              | PIG ( | )                    |        |      |      |      | 0x2        | 2C   |    | PIG | 4              |      |                |     |     |      |        |
|        | 0x0D              | PIG 1 |                      |        |      |      |      | 0x2        | 2D   |    | PIG | 5              |      |                |     |     |      |        |
|        | 0x0E              | PIG 2 |                      |        |      |      |      | 0x2        |      |    | PIG |                |      |                |     |     |      |        |
|        | 0x0F              | PIG 3 | 3                    |        |      |      |      | 0x2        | 2F   |    | PIG | 7              |      |                |     |     |      |        |
|        | 0x10              | Cabl  | e Interi             | rupt ( | )    |      |      | 0x3        |      |    | Res | erve           | ed   |                |     |     |      |        |
|        | 0x11              |       | e Interi             | -      |      |      |      | 0x3        |      |    |     | erve           |      |                |     |     |      |        |
|        | 0x12              |       | e Inter              |        |      |      |      | 0x3        |      |    |     | erve           |      |                |     |     |      |        |
|        | 0x13              |       | e Interi             |        |      |      |      | 0x3        |      |    |     | erve           |      |                |     |     |      |        |
|        | 0x14              |       | e Interi             | •      |      |      |      | 0x3        |      |    |     | erve           |      |                |     |     |      |        |
|        | 0x15              |       | e Interi             |        |      |      |      | 0x3<br>0x3 |      |    |     | erve           |      |                |     |     |      |        |
|        | 0x16              |       | e Interi             | •      |      |      |      | 0x3<br>0x3 |      |    |     | erve           |      |                |     |     |      |        |
|        | 0x17<br>0x18      |       | e Interi<br>e Interi | -      |      |      |      | 0x3        |      |    |     | je In          |      |                | t c | 2   | -    |        |
|        | 0x18<br>0x19      |       | e Interi<br>e Interi | •      |      |      |      | 0x3        |      |    | -   | je in<br>je In |      | -              |     |     |      |        |
|        | 0x19<br>0x1A      |       | e Interi             | -      |      |      |      | 0x3        |      |    | -   | je in<br>je in |      | -              |     |     |      |        |
|        | 0x1A<br>0x1B      |       | e Interi             | -      |      |      |      | 0x3        |      |    | -   | je In          |      | -              |     |     |      |        |
|        | 0x1C              | Rese  |                      | ~~~    |      |      |      | 0x3        |      |    | PIG |                |      | r <sup>2</sup> |     | -   | 1    |        |
|        | 0x1C              | Rese  |                      |        |      |      |      | 0x3        |      |    | PIG |                |      |                |     |     |      |        |
|        | 0x1E              | Rese  |                      |        |      |      |      | 0x3        |      |    | PIG |                |      |                |     |     |      |        |
|        | 0x1F              | Rese  |                      |        |      |      |      | 0x3        |      |    | PIG |                |      |                |     |     | 1    |        |

## Figure B-5 RCIM II Cable Interrupt Routing Registers (CIRR)

The cable interrupt routing registers route selected interrupts to the RCIM interconnecting cable.

Offsets: CIRR1: 0080, CIRR2: 0084, CIRR3: 0088

| Cable Inte | errupt R | egister 1    |          |          |       |    |      |      |      |     |      |    |      |    |   | Cal | ole I | nte  | ərr | upt   | Nu       | nb | er |
|------------|----------|--------------|----------|----------|-------|----|------|------|------|-----|------|----|------|----|---|-----|-------|------|-----|-------|----------|----|----|
|            |          |              |          |          |       |    | Bi   | ts   |      |     |      |    |      |    |   |     |       |      |     |       |          |    | ר  |
| 31 30 2    | 9 28 27  | 26 25 24     | 22 22 24 | 20       | 10 19 | 17 |      |      | 11   | 13  | 12   | 11 | 10   | 9  | 8 | 7 6 | 6 5   | 4    |     | 3 2   | 2 1      | 0  | -  |
|            | .9 20 21 |              |          | 20       |       |    | 10   | 15   |      |     | 12   | 11 |      |    | 0 |     |       | 4    | •   | 5     |          | 0  | -  |
| 7          |          | 6            | 5        |          | 4     | 4  | -    |      | 3    | 3   |      |    | 2    |    |   |     | 1     | _    |     |       | 0        |    | _  |
| 7 6 5      | 5 4 3    | 2 1 0        | 7 6 5    | 4        | 3 2   | 1  | 0    | 7    | 6    | 5   | 4    | 3  | 2    | 1  | 0 | 7 6 | 5 5   | 4    | ;   | 3 2   | 2 1      | 0  |    |
|            |          |              |          |          |       |    |      |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    |    |
| Cable Inte | errupt R | egister 2    |          |          |       |    |      |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    |    |
|            |          |              |          |          |       |    | ;    |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    | ٦  |
|            |          | <del> </del> |          | 1        |       | -  | Bi   |      |      |     |      |    |      |    |   |     |       | -    | -   | -     |          | 1  | _  |
| 31 30 2    | 28 27    | 26 25 24     | 23 22 2  | 20       | 19 18 | 17 | 7 16 | 15   | 14   | 13  | 12   | 11 | 10   | 9  | 8 | 7 6 | 5 5   | 4    | :   | 3 2   | 2 1      | 0  |    |
|            |          | Rese         | erved    |          |       |    |      |      | 1    | 1   |      |    | 1(   | )  |   |     | 9     |      |     |       | 8        |    | ◄  |
|            |          |              |          |          |       |    |      | 3    | 2    | 1   | 0    | 3  | 2    | 1  | 0 | 3 2 | 2 1   | 0    | ) ( | 3 2   | 2 1      | 0  |    |
|            |          |              |          |          |       |    |      |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    |    |
| Cable Inte | arrunt R | Panistar 3   |          |          |       |    |      |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    |    |
|            | sinuptin | legister 5   |          |          |       |    |      |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    |    |
|            |          |              |          |          |       |    | Bi   | ts   |      |     |      |    |      |    |   |     |       |      |     |       |          |    | ٦  |
| 31 30 2    | 0 20 27  | 26 25 24     | 22 22 2  | 20       | 10 10 | 17 |      |      | 11   | 10  | 10   | 11 | 10   | 9  | 8 | 7 6 | 3 5   | 4    |     | 3 2   | 2 1      | 0  | -  |
|            |          |              |          |          |       | _  |      |      |      |     |      |    |      |    | 0 |     | _     |      | • • |       | <u> </u> |    |    |
|            | Reserve  | ed           | 11       | 10       | 9     |    | 8    | 7    | ,    | 6   | 5    | 5  | 5    | 4  |   | 3   |       | 2    |     | 1     |          | 0  |    |
|            |          |              | 5 4 5    | 4        | 54    | 5  | 4    | 5    | 4    | 5   | 4    | 5  | 4    | 5  | 4 | 5 4 | 4 5   | 4    | •   | 5 4   | 1 5      | 4  |    |
|            |          |              |          |          |       |    |      |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    | _  |
| ,          | Value    | Descript     | ion      | ,        | Value |    | Des  | crit | otic | on  |      | ,  | Valu | Ie |   | Des | crip  | otic | on  |       |          |    |    |
|            |          |              |          |          |       |    |      | -    |      |     |      |    |      |    |   |     |       |      |     |       |          |    |    |
|            | 0x00     | Reserve      |          |          | )x10  |    | Res  |      |      |     |      |    | 0x   | 20 |   |     | S_P   |      |     |       |          |    |    |
|            | 0x01     | Reserve      | d        | 0        | )x11  |    | Res  | erv  | ed   |     |      |    | 0x   | 21 |   | Res | erv   | ed   |     |       |          |    |    |
| (          | 0x02     | Reserve      | d        | C        | )x12  |    | Res  | erv  | ed   |     |      |    |      |    |   |     |       |      |     |       |          |    |    |
|            | 0x03     | Reserve      | d        | 0        | )x13  |    | Res  | erv  | ed   |     |      |    | 0x   | 27 |   | Res | erv   | ed   |     |       |          |    |    |
| (          | 0x04     | RTC 0        |          | 0        | )x14  |    | RTC  | 24   |      |     |      |    | 0x   | 28 |   | Edg | je In | te   | rru | ipt 8 | 3        |    |    |
|            | 0x05     | RTC 1        |          | C        | )x15  |    | RTC  | 5    |      |     |      |    | 0x   | 29 |   | Edg | je In | te   | rru | ipt 9 | 9        |    |    |
| (          | 0x06     | RTC 2        |          | 0        | )x16  |    | RTC  | 6    |      |     |      |    | 0x   | 2A |   | Edg | gelni | ter  | ru  | pt1(  | )        |    |    |
|            | 0x07     | RTC 3        |          | 0        | )x17  |    | RTC  | 7    |      |     |      |    | 0x   | 2B |   | Edg | geln  | ter  | ru  | pt1   | 1        |    |    |
|            | 0x08     | EdgeInte     | errupt 0 | 0        | )x18  |    | Edg  | eIn  | ter  | ruc | ot 4 |    | 0x   | 2C |   | PIG | 8     |      |     |       |          |    |    |
|            | 0x09     | EdgeInte     | -        |          | )x19  |    | Edg  |      |      | -   |      |    |      | 2D |   | PIG |       |      |     |       |          |    |    |
|            | 0x0A     | EdgeInte     |          |          | )x1A  |    | Edg  |      |      |     |      |    | 0x   |    |   |     | 10    |      |     |       |          |    |    |
|            | 0x0B     | EdgeInte     | •        |          | )x1B  |    | Edg  |      |      |     |      |    | 0x   |    |   | PIG |       |      |     |       |          |    |    |
|            | 0x0C     | PIG 0        |          | 6        | )x1C  |    | PIG  | 4    |      |     |      | +  | 0x   | 30 |   | Res | erv   | ed   |     |       |          |    |    |
|            | 0x0D     | PIG 1        |          |          | )x1D  |    | PIG  |      |      |     |      |    | 57   |    |   |     |       | ~ ~  |     |       |          |    |    |
|            | 0x0E     | PIG 2        |          |          | )x1E  |    | PIG  |      |      |     |      |    |      | i  |   |     | i     |      |     |       |          |    |    |
|            | 0x0F     | PIG 3        |          |          | )x1F  |    | PIG  |      |      |     |      |    | 0x   | 3F |   | Res | erv   | ed   |     |       |          |    |    |
| L          |          |              |          | <u> </u> |       |    |      |      |      |     |      |    |      |    |   |     |       |      |     |       |          |    |    |

#### Figure B-6 RCIM II PCI Interrupt Routing Registers (PARR, PBRR, PCRR, PDRR)

Setting a bit in a PCI interrupt routing register routes selected interrupts to the designated PCI interrupt. The default power-up value is everything routed to PCI A. Setting bits in multiple registers will drive multiple PCI interrupt lines.

Offsets: PARR1: 00A0, PARR2: 00A4, PBRR1: 00B0, PBRR2: B4, PCRR1: 00C0, PCRR2: 00C4, PDRR1: 00D0, PDRR2 00D4

|    |    |     |      |      |    |      |    |    |    |    |    |    |    |    | Bi | its |    |    |     |      |    |   |   |   |   |   |   |    |   |   |   |
|----|----|-----|------|------|----|------|----|----|----|----|----|----|----|----|----|-----|----|----|-----|------|----|---|---|---|---|---|---|----|---|---|---|
| 31 | 3  | ) 2 | 9 28 | 3 27 | 20 | 6 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12  | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1 | ( |
| R  | es | er  | ved  |      |    |      |    |    | E  | ΞI |    | •  | •  | •  |    |     |    | R  | ese | erve | ed |   |   |   |   | • | R | ТС |   | • |   |
|    |    |     |      | 11   | 1( | 9    | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |     |    |    |     |      |    |   |   | 7 | 6 | 5 | 4 | 3  | 2 | 1 | ( |

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

## Figure B-7 RCIM II DDS Adjust Register (DDS)

Writing to the Direct Digital Synthesizer Adjust register loads the 32-bit frequency control word into the onboard AD9851 DDS.



## Figure B-8 RCIM II PPS Snapshot Register (PPS)

The PPS Snapshot register contains a snapshot of the nanoseconds field and two bits of the seconds field of the POSIX clock. The snapshot is taken every time the GPS PPS signal occurs.



## Figure B-9 RCIM II GPS Transmit/Receive Register (GPS)

The GPS Transmit/Receive register is used for serial communication with the GPS module via the PCI bus interface.

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

### Figure B-10 RCIM II Clear Cable Errors Register (CCERR)

This is a Write Only register that clears any reported cable errors. The data field is don't care.



## Figure B-11 RCIM II Tick Clock Upper Register (TCU)

This register contains the upper 32 bits of the tick clock.

Offset: 1000

 Bits

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

 Tick Clock upper 32 bits

## Figure B-12 RCIM II Tick Clock Lower Register (TCL)

This register contains the lower 32 bits of the tick clock.



## Figure B-13 RCIM II Tick Clock Status/Control Register (TCSC)

This register provides status and control of the tick clock.

| Bits                                                                |      |      |       |                  |     |    |     |   |
|---------------------------------------------------------------------|------|------|-------|------------------|-----|----|-----|---|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8    | 7    | 6 5   | 4                | 3   | 2  | 1   | 0 |
| Reserved                                                            |      | R    | eserv | ed               |     |    |     |   |
| Cable Enable (R)-                                                   |      |      |       |                  |     |    |     |   |
| No Reset When                                                       | Dis  | abl  | ed (F | ₹/₩ <del>)</del> |     |    |     |   |
| L                                                                   | ocal | ΙE   | nable | (R/              | W)  |    |     |   |
| Selec                                                               | t Ca | able | e Ena | ble              | (R/ | W) |     |   |
| S                                                                   | Sele | ct ( | Cable | Clo              | ock | (R | /W) | - |

## Figure B-14 RCIM II POSIX Clock Seconds Register (PCS)

This register contains the POSIX clock seconds.



## Figure B-15 RCIM II POSIX Clock Nanoseconds Register (PCN)

This register contains the POSIX clock nanoseconds.

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

## Figure B-16 RCIM II POSIX Clock Status/Control Register (PCSC)

This register provides status and control of the POSIX clock.



## Figure B-17 RCIM II POSIX Clock Skip/Add Time Register (PCSAT)

This register skips/adds time to the POSIX clock in 400 nanosecond increments.



#### Figure B-18 RCIM II RTC Timer Registers (RTCT)

The initial RTC timer value is loaded in the RTC timer registers. The current value of the timer is read from this register. NOTE: Loading this register also loads the RTC Repeat Register for compatibility with RCIM.

Offsets: RTC0T: 2010, RTC1T: 2030, RTC2T: 2050, RTC3T: 2070, RTC4T: 2090, RTC5T: 20B0, RTC6T: 20D0, RTC7T: 20F0



## Figure B-19 RCIM II RTC Repeat Registers (RTCR)

The RTC repeat registers contain the repeat count value.

Offsets: RTC0R: 2014, RTC1R: 2034, RTC2R: 2054, RTC3R: 2074, RTC4R: 2094, RTC5R: 20B4, RTC6R: 20D4, RTC7R: 20F4

| Bits<br>31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|-----------------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0         |
|                                                                                               |
| RTC timer repeat value                                                                        |

#### Figure B-20 RCIM II RTC Control Registers (RTCC)

This register provides control of the RTCs.

Offsets: RTC0C: 2000, RTC1C: 2020, RTC2C: 2040, RTC3C: 2060, RTC4C: 2080, RTC5C: 20A0, RTC6C: 20C0, RTC7C: 20E0



## Figure B-21 RCIM II Programmable Interrupt Generator Register (PIG)

This register identifies the programmable interrupts.

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

## Figure B-22 RCIM II Programmable Interrupt Set/Clear Registers (PIGS, PIGC)

Writing to these registers sets/clears the unitary bits in the Programmable Interrupt Register without affecting the other bits.

Offsets: PIGS: 3010, PIGC: 3020



RCIM User's Guide

# C RCIM I Registers

This section contains the address map and registers on the RCIM I board.

## **RCIM I Address Map**

| Address    | Function                           |        |              |
|------------|------------------------------------|--------|--------------|
| 0xXXXX0000 | Board Status/Control Register      | (BSCR) |              |
| 0xXXXX0010 | Interrupt Enable Register          | (IER)  |              |
| 0xXXXX0020 | Interrupt Request Register         | (IRR)  | (Write Only) |
| 0xXXXX0020 | Interrupt Pending Register         | (IPR)  | (Read Only)  |
| 0xXXXX0030 | Interrupt Clear Register           | (ICR)  |              |
| 0xXXXX0040 | Interrupt Arm Register             | (IAR)  |              |
| 0xXXXX0050 | Interrupt Select Level Register    | (ISLR) |              |
| 0xXXXX0060 | Interrupt Select Polarity Register | (ISPR) |              |
| 0xXXXX0070 | ExternalInterruptRoutingRegister   | (EIRR) |              |
| 0xXXXX0080 | Cable Interrupt Routing Register   | (CIRR) |              |
| 0xXXXX1000 | Tick Clock Upper                   | (TCU)  |              |
| 0xXXXX1008 | Tick Clock Lower                   | (TCL)  |              |
| 0xXXXX1010 | Tick Clock Status/Control          | (TCSC) |              |
| 0xXXXX1100 | POSIX Clock Seconds                | (PCS)  |              |
| 0xXXXX1108 | POSIX Clock Nanoseconds            | (PCN)  |              |
| 0xXXXX1110 | POSIX Clock Status/Control         | (PCSC) |              |
| 0xXXXX2000 | RTC #0 Control                     |        |              |
| 0xXXXX2010 | RTC #0 Timer                       |        |              |
| 0xXXXX2020 | RTC #1 Control                     |        |              |
| 0xXXXX2030 | RTC #1 Timer                       |        |              |
| 0xXXXX2040 | RTC #2 Control                     |        |              |
| 0xXXXX2050 | RTC #2 Timer                       |        |              |
| 0xXXXX2060 | RTC #3 Control                     |        |              |
| 0xXXX2070  | RTC #3 Timer                       |        |              |
| 0xXXXX3000 | ProgrammableInterruptGenerator     | (PIG)  |              |

## **RCIM I Registers**

RCIM Iregisters are illustrated in this section.

NOTE: Unless otherwise stated, a bit value of 1=on; 0=off.

### Figure C-1 RCIM I Board Status/Control Register (BSCR)

This register provides status and control of certain features of the RCIM I board.

|                    |                  |                               | тт    | тг           | Bits      |          |                 |      |                 |                 |             |     |            |                               |                              |      |        |
|--------------------|------------------|-------------------------------|-------|--------------|-----------|----------|-----------------|------|-----------------|-----------------|-------------|-----|------------|-------------------------------|------------------------------|------|--------|
| 29 28 2            | 27 26 25 2       | 24 23 22 21                   | 20 19 | 9 18 17      | 16 15     | 14       | 13 12           | 11   | 10              | 9               | 8           | 7   | 6          | 5                             | 4                            | 3    | 2      |
|                    | RCIM \           | /ersion (R)                   | )     |              |           | Re       | eserve          | əd   |                 | I               |             | F   | Res        |                               |                              | Re   | s.     |
|                    |                  |                               | C     | able Cl      | ock St    | top (    | (R/W)           | (dia | ag <del>)</del> |                 |             |     |            |                               |                              |      |        |
|                    |                  |                               |       |              | able C    | -        |                 |      | -               |                 |             |     |            |                               |                              |      |        |
|                    |                  |                               |       | -            |           |          |                 | ble  |                 |                 |             | eei | na         | (D)                           |                              |      |        |
|                    |                  |                               |       |              |           |          |                 |      |                 |                 |             |     |            |                               |                              |      |        |
|                    |                  |                               |       |              |           |          | Ca              | DIE  |                 |                 | IVII:       |     | RC         | M                             | Moo<br>ble l                 |      |        |
| RCIN<br>Bits       | 1 Mode Bi        |                               |       | Inpu<br>Cabl |           |          | Dutput          |      |                 | Ca              | ible        | 1   | RC<br>(see | IM<br>e tal                   | Мо                           | belo | w      |
| Bits<br>1 0        | Desc             | ription                       |       | Cabl         |           | C        | Dutput<br>Cable | t    |                 | Ca<br>Cl        | ıble<br>ock |     | RC<br>(see | IM<br>e tal<br>Ca<br>erm      | Mod<br>ble l<br>able<br>inat | belo | w      |
| Bits<br>1 0<br>0 0 | Desc<br>Master R | ription<br>CIM                |       | Cab<br>Open  | e         | Co       | Dutput<br>Cable | t    |                 | Ca<br>Cl        | ible<br>ock | Ig  | RC<br>(see | IM<br>e tal<br>Ca<br>erm      | able<br>inat                 | belo | )<br>W |
| Bits<br>1 0        | Desc<br>Master R | ription                       | IM    | Cabl         | e         | Co       | Dutput<br>Cable | t    |                 | Ca<br>Cl        | ıble<br>ock | Ig  | RC<br>(see | IM<br>e tal<br>Ca<br>erm      | Mod<br>ble l<br>able<br>inat | belo | w      |
| Bits<br>1 0<br>0 0 | Desc<br>Master R | ription<br>CIM<br>u Slave RCI | IM    | Cab<br>Open  | e<br>cted | Co<br>Co | Dutput<br>Cable | t    | S               | Ca<br>Cl<br>Sou | ible<br>ock | ig  | RC<br>(see | IM<br>e tal<br>Ca<br>erm<br>( | able<br>inat                 | belo | )<br>W |

# Figure C-2 RCIM I Interrupt Enable/Request/Pending/Clear/ARM/Level/Polarity Registers (IER, IRR, IPR, ICR, IAR, ISLR, ISPR)

The enable register (IER) enables the selected interrupt. The request register (IRR) is a software driven request of the selected interrupt. The pending register (IPR) is a pending request. The clear register (ICR) clears the selected interrupt. The arm register (IAR) arms the selected interrupt for edge triggering. The level register (ISLR) sets level (1) or edge (0) for the selected interrupt. The polarity register (ISPR) sets polarity high (1) or low (0) for the selected interrupt.

Offsets: IER: 0010, IRR/IPR: 0020, ICR: 0030, IAR: 0040, ISLR: 0050, ISPR: 0060

|    |         |      |          |            |     |             |             |             |     |      |      |     |     |     | Bi | ts |     |     |    |    |    |   |   |   |     |      |    |   |   |    |   |
|----|---------|------|----------|------------|-----|-------------|-------------|-------------|-----|------|------|-----|-----|-----|----|----|-----|-----|----|----|----|---|---|---|-----|------|----|---|---|----|---|
| 31 | 30      | ) 29 | 28       | 27         | 26  | 25          | 24          | 23          | 22  | 21   | 20   | 19  | 18  | 17  | 16 | 15 | 14  | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5    | 4  | 3 | 2 | 1  | 0 |
|    |         |      | C        | CI         |     |             |             | R           | ese | erve | ed   |     | Р   | G   |    | R  | ese | rve | d  |    | E  | 1 |   | R | ese | erve | ed |   | R | ТС |   |
| 7  | 6       | 5    | 4        | 3          | 2   | 1           | 0           |             |     |      |      | 3   | 2   | 1   | 0  |    |     |     |    | 3  | 2  | 1 | 0 |   |     |      |    | 3 | 2 | 1  | 0 |
| Е  | IG<br>I | =    | Pi<br>Ex | rog<br>xte | rna | nm:<br>I In | abi<br>teri | e In<br>rup |     | rup  | ot G | ien | era | tor |    |    |     |     |    |    |    |   |   |   |     |      |    |   |   |    |   |

## Figure C-3 RCIM I External Interrupt Routing Register (EIRR)

The external interrupt routing register routes selected interrupts to the external interrupt connector.

|             |                      |       |       | Bi | ts   |      |      |      |   |   |   |   |   |   |   |   |   |
|-------------|----------------------|-------|-------|----|------|------|------|------|---|---|---|---|---|---|---|---|---|
| 31 30 29 28 | 27 26 25 24 23 22 21 | 20 19 | 18 17 | 16 | 15 1 | 4 13 | 12 1 | 1 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| 3           | 3                    | 2     |       |    | I    |      | 1    |      |   |   |   |   |   | ( | ) |   |   |
| 7 6 5 4     | 3 2 1 0 7 6 5        | 4 3   | 2 1   | 0  | 76   | 5 5  | 4 (  | 3 2  | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
|             |                      | -     |       | _  |      |      |      |      |   | - |   |   | - |   | _ |   |   |
| Value       | Description          |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x00        | None                 |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x01        | Reserved             |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x02        | Reserved             |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x03        | Reserved             |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x04        | RTC 0                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x05        | RTC 1                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x06        | RTC 2                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x07        | RTC 3                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x08        | Edge Interrupt 0     |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x09        | Edge Interrupt 1     |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x0A        | Edge Interrupt 2     |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x0B        | Edge Interrupt 3     |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x0C        | PIG 0                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x0D        | PIG 1                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x0E        | PIG 2                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x0F        | PIG 3                |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x10        | Cable Interrupt 0    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x11        | Cable Interrupt 1    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x12        | Cable Interrupt 2    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x13        | Cable Interrupt 3    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x14        | Cable Interrupt 4    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x15        | Cable Interrupt 5    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x16        | Cable Interrupt 6    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x17        | Cable Interrupt 7    |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| 0x18        | Reserved             |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |
| :<br>0xFF   | :<br>Reserved        |       |       |    |      |      |      |      |   |   |   |   |   |   |   |   |   |

# Figure C-4 RCIM I Cable Interrupt Routing Register (CIRR)

The cable interrupt routing register routes selected interrupts to the RCIM I interconnecting cable.

|    |      |     |    |    |    |     |     |     |      |    |    |     |   |   |    |   |   |    | В  | its |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|------|-----|----|----|----|-----|-----|-----|------|----|----|-----|---|---|----|---|---|----|----|-----|---|----|----|------|---|----|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 2 | 9 2 | 28 | 27 | 26 | 2   | 25  | 24  | 23   | 3  | 22 | 21  | 2 | 0 | 19 | 1 | 8 | 17 | 16 | 1   | 5 | 14 | 13 | 3 1: | 2 | 11 | 1 | 0 | 9 | 8 | 5 | 7 | 6 | T | 5 | 4 | 3 | 2 |   |
|    | 7    |     |    |    |    | 6   |     |     |      |    | 5  | 5   |   |   |    |   | 4 |    |    |     |   | 3  | 3  |      |   |    |   | 2 | 2 |   |   |   |   | 1 |   |   |   |   | ( |
| 3  | 2 1  |     | 0  | 3  | 2  |     | 1   | 0   | 3    |    | 2  | 1   | 0 | ) | 3  | 2 | 2 | 1  | 0  | 3   |   | 2  | 1  | С    | ) | 3  | 1 | 2 | 1 | 0 | ) | 3 | 2 |   | 1 | 0 | 3 | 2 |   |
|    |      |     |    |    |    |     |     |     |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | Valu | е   |    |    | D  | )e  | sc  | rip | otic | n  |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x0  | )   |    |    | Ν  | 10  | ne  | ł   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x1  |     |    |    | R  | le  | se  | rv  | ed   |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x2  | 2   |    |    | R  | le  | se  | rv  | ed   |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x3  | 3   |    |    | R  | le  | se  | rv  | ed   |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x4  | ŀ   |    |    | R  | ۲   | С   | 0   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x5  | 5   |    |    | R  | ۲   | С   | 1   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x6  | 5   |    |    | R  | RΤ  | С   | 2   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x7  | ,   |    |    | R  | ۲   | С   | 3   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x8  | }   |    |    | Е  | d   | ge  | In  | tei  | r١ | Jp | t C | ) |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x9  | )   |    |    | E  | d   | ge  | In  | tei  | rı | Jp | t 1 |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0xA  | ١   |    |    | E  | d   | ge  | In  | tei  | rı | Jp | t 2 | 2 |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0xE  | 3   |    |    | E  | d   | ge  | In  | tei  | rı | Jþ | t 3 | 3 |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0x0  | )   |    |    | Ρ  | PIC | G ( | )   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0xD  | )   |    |    | Р  | PIC | G 1 |     |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0xE  | =   |    |    | Р  | 20  | G 2 | 2   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |
|    | 0xF  |     |    |    | Р  | 210 | 3 3 | ;   |      |    |    |     |   |   |    |   |   |    |    |     |   |    |    |      |   |    |   |   |   |   |   |   |   |   |   |   |   |   |   |

## Figure C-5 RCIM I Tick Clock Upper Register (TCU)

This register contains the upper 32 bits of the tick clock.

Offset: 1000



## Figure C-6 RCIM I Tick Clock Lower Register (TCL)

This register contains the lower 32 bits of the tick clock.

Offset: 1004

|    |    |    |    |      |     |      |      |    |       |      |    |      | В    | its |      |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|------|-----|------|------|----|-------|------|----|------|------|-----|------|------|------|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 2 | 6 2 | 5 24 | 4 23 | 22 | 21 20 | ) 19 | 18 | 3 17 | 16   | 15  | 14   | 13   | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |      |     |      |      |    |       | Tio  | ck | Clo  | ck I | low | er 3 | 32 k | oits |    |    |   |   |   |   |   |   |   |   |   |   |

# Figure C-7 RCIM I Tick Clock Status/Control Register (TCSC)

This register provides status and control of the tick clock.



#### Figure C-8 RCIM I POSIX Clock Seconds Register (PCS)

This register contains the POSIX clock seconds.

Offset: 1100



#### Figure C-9 RCIM I POSIX Clock Nanoseconds Register (PCN)

This register contains the POSIX clock nanoseconds.

Offset: 1104



#### Figure C-10 RCIM I POSIX Clock Status/Control Register (PCSC)

This register provides status and control of the POSIX clock.

| Bits                                                                |   |     |   |   |   |   |   |   |  |
|---------------------------------------------------------------------|---|-----|---|---|---|---|---|---|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 | 8 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Reserved Reserved                                                   |   |     |   |   |   |   |   |   |  |
| Cable Enable (R)                                                    |   |     |   |   |   |   |   |   |  |
| Local Enable (R/W)                                                  |   |     |   |   |   |   |   |   |  |
| Select Cable Enable (R/W                                            |   |     |   |   |   |   |   |   |  |
| Select Cable Clock (F                                               |   |     |   |   |   |   |   |   |  |
|                                                                     |   |     |   |   |   |   |   |   |  |

#### Figure C-11 RCIM I RTC Control Registers

This register provides control of the RTCs.

#### Offsets: RTC #0: 2000, RTC #1: 2020, RTC #2: 2040, RTC #3: 2060



#### Figure C-12 RCIM I RTC Timer Registers

The initial RTC timer value is loaded in the RTC timer registers. The current value of the timer is read from this register.

Offsets: RTC #0: 2010, RTC #1: 2030, RTC #2: 2050, RTC #3: 2070

| Bits<br>31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 |     |
|-------------------------------------------------------------------------------------------|-----|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2         |     |
|                                                                                           | 1 0 |
| RTC timer count value                                                                     |     |

# Figure C-13 RCIM I Programmable Interrupt Generator Register (PIG)

The PIG register identifies the programmable interrupts.



RCIM User's Guide

# Calculating RCIM Cable Propagation Delays

This appendix provides calculations to determine if your cable connections introduce signal delays.

# RCIM III

The maximum cable length between each interconnected RCIM III board is 30 meters (~100 feet).

The clock runs at 400ns per tick. If the clock signal takes more than 400ns to make it to any given slave in the chain, clock skew will occur from that point on. The clock is redriven by each pass-through slave.

Due to synchronization and re-drive of the serial data on the cable, each RCIM III added to an RCIM chain adds about 50ns of delay in addition to approximately ~7ns for each meter of the cable, or ~200ns per 30 meter cable.

Two systems in an RCIM chain with the 30 meter cable will operate within a 400ns clock tick. Having more than two results in less precise synchronization.

Note that if a pass-through slave system is powered off, the cable clock will not be propagated to the slaves downstream from it. In this case, the downstream slaves will use their local oscillator instead of the cable clock.

The user just needs to be aware of the delays associated with each RCIM and cable in a chain to determine if the level of clock skew is acceptable for the application.

# **RCIM II**

The maximum cable length between each interconnected RCIM II board is 30 feet.

The clock runs at 400ns per tick. If the clock signal takes more than 400ns to make it to any given slave in the chain, clock skew will occur from that point on. The clock is redriven by each pass-through slave.

Due to synchronization and redrive of the serial data on the cable, each RCIM II added to an RCIM chain adds about 150ns of delay in addition to approximately 2ns for each foot of the cable, or 60ns per 30 foot cable.

Three systems in an RCIM chain will operate within the desired 400ns. Having more than three results in less precise synchronization.

D

Note that if a pass-through slave system is powered off, the cable clock will not be propagated to the slaves downstream from it. In this case, the downstream slaves will use their local oscillator instead of the cable clock.

If chaining is to be done through different locations using different grounds, talk to your Concurrent Real-Time representative about the risk of ground loops.

# **RCIM** I

Synchronization cable lengths are constrained by the worst case propagation delay of the cable clock signal from the master RCIM to the final slave. The clock runs at 400ns per tick. If the clock signal takes more than 400ns to make it to any given slave in the chain, clock skew will occur from that point on. The clock is redriven by each pass-through slave. If you consider receive + transmit as taking equal time, it takes about 8.5ns for each half of the operation, or 17ns per RCIM to redrive the signal.

The propagation delay of the signal traveling through the cable is 2ns per foot. It would take 20ns to travel ten feet:

2ns/ft \* 10ft = 20ns

Cable lengths should be minimized when possible. They do not need to have equal length.

The equation below describes how to calculate cable length limitations:

total\_propagation\_delay(cables)+ total\_propagation\_delay(rcims) <= 400ns

where:

```
total_propagation_delay(rcims) = (number of RCIMs in the chain - 1) * 17ns
total_propagation_delay(cables) = (total length in feet of all cables in the chain) * 2ns
```

The following example illustrates the calculations for an RCIM chain with 6 systems:

| total_propagation_delay(rcims) = (number of RCIMs in the chain - 1) * 17ns<br>= (6-1) * 17ns<br>= 5 * 17ns<br>= 85ns |
|----------------------------------------------------------------------------------------------------------------------|
| total_propagation_delay(cables) <= 400ns - total_propagation_delay(rcims)<br><= 400ns - 85ns<br><= 315ns             |
| In 365ns, the signal has traveled 315ns/2ns/ft = 315/2 feet<br>= 157.5 feet                                          |
| Conclusion: For six systems, the total length of cable can not exceed 157.5 feet.                                    |

These calculations are theoretical and may vary with the environment. They are intended as a "rule of thumb". The closer the total propagation delay is to 400ns, the greater the risk of introducing clock skew.

It is recommended that systems be placed as close together as practical in order to minimize propagation delays. Extremely long runs through high RF noise or high temperature environments should be avoided when planning RCIM cable routes.

Note that if a pass-through slave system is powered off, the cable clock will not be propagated to the slaves downstream from it. In this case, the downstream slaves will use their local oscillator instead of the cable clock.

RCIM User's Guide

# Index

#### Paths

/dev/rcim\_uart 3-7 /etc/init.d/rcim\_clocksync 3-6 /etc/sysconfig/rcim\_clocksync 3-6 /proc/driver/rcim 0 3-11 /usr/include/linux/rcim\_ctl.h 3-11 /usr/include/linux/rcim.h 3-3

# Α

address map RCIM I C-1 RCIM II B-1 RCIM III A-1 arming interrupts 3-13, 3-19

# В

board illustration RCIM I 2-13 RCIM II 2-8 RCIM III 2-2 board specifications 1-2 Board Status/Control Register RCIM I C-2 RCIM II B-4 RCIM III A-4

# С

cable clock 2-18 cable error messages 2-7, 2-12 Cable Interrupt Routing Registers RCIM I C-5 RCIM II B-8 RCIM III A-8 cable length calculations D-1 cables 2-10, 2-15, 2-18–2-19 RCIM I 2-16 RCIM II 2-10 RCIM II 2-4 clock registers A-12, B-16, C-6 clock synchronization 3-3 clocks description 3-1 direct access 3-3 GPS 2-22, 3-7 clocksource 2-20 close system call 3-1 configuration information 3-11 configuration requirements 2-20 connection modes 2-18 connectors RCIM I 2-14–2-17 RCIM II 2-8–2-12 RCIM II 2-4–2-7

# D

Debug Visibility Connector P5 (RCIM I) 2-17 device files DI 3-19 ETI 3-13 PIG 3-16 RTC 3-14 device ID, see PCI vendor/device ID DIs arming 3-19 configuration 2-22, 3-18 device files 3-19 disarming 3-19 example 3-10 guidelines 3-10 interrupt requests 3-19 overview 3-17 signal processing 3-8-3-9 user interface 3-19 disarming interrupts 3-19 distributed interrupts, see also DIs ETIs 3-14 PIGs 3-17 RTCs 3-14

# Е

edge-triggered interrupts, see ETIs ETIs arming 3-13 configuration 3-12 device files 3-13 disarming 3-13 distributed 3-14 example 3-10 interrupt requests 3-13 overview 3-12 signal processing 3-8-3-9 user interface 3-13 external interrupt I/O connector RCIM I 2-14, 2-16-2-17 RCIM II 2-10-2-12 RCIM III 2-5-2-7 External Interrupt Routing Registers RCIM I C-4 RCIM II B-7 RCIM III A-7 external output signals configuration 3-16 example 3-10 overview 3-15

# F

final slave 2-18 functional description 3-1

# G

GPS 2-2, 2-5, 2-8, 2-10, 2-20, 2-22, 3-7

# Н

hardware RCIM I 2-13 RCIM II 2-8 RCIM III 2-2 hardware overview 2-1

# I

initialization 2-20 input cable connector RCIM I 2-14, 2-16 RCIM II 2-8, 2-10 RCIM III 2-4 installation instructions 2-19 In-System Programming Interface Connector P6 (RCIM I) 2-17 interrupt handling 3-8 registers A-6, B-6, C-3 introduction 1-1 ioctl system call 3-1, 3-11 isolated mode 2-18

#### L

LEDs 2-14 RCIM I 2-14 RCIM II 2-8–2-9 RCIM III 2-3

#### Μ

master mode 2-18 message signaled Interrupts (MSI) 2-22 mmap 3-11

## Ν

NTP 2-22, 3-7

# 0

OCXO (Oven Controlled Crystal Oscillator) 2-2, 2-4, 2-8, 2-10 open system call 3-1 oscillator 2-2, 2-4, 2-8, 2-10 output cable connector RCIM I 2-14–2-15 RCIM II 2-8, 2-10 RCIM III 2-4

#### Ρ

pass-through slave 2-18 PCI vendor/device ID RCIM I 2-17 RCIM II 2-7, 2-12 RCIM III 2-7 PIGs device files 3-16 distributed 3-17 example 3-10 overview 3-16 registers A-17, B-24–B-25, C-9 POSIX clock GPS 2-20 overview 3-2 registers A-14, B-19, C-7 set time 3-3 synchronizing 3-6 POSIX Clock Status/Control Register RCIM I C-7 RCIM II B-19 RCIM III A-14 programmable interrupt generators (PIGs), *see* PIGs

# R

RCIM chain 2-18, 3-1, 3-10, 3-17 RCIM values 3-11 RCIM\_CLOCKSOURCE 2-20 rcim\_clocksync utility 3-3 RCIM\_IRQ\_EXTENSIONS 2-20 RCIM PPS 2-20 real-time clocks (RTC), see RTCs Registers RCIM I C-2 RCIM II B-3 RCIM III A-4 registers 3-11 related publications iv RTCs device files 3-14 distributed 3-14 example 3-10 overview 3-14 registers A-15-A-16, B-21-B-23, C-8 user interface 3-15

# S

signal processing logic 3-8 overview 3-8 recognition logic 3-9 slave modes 2-18 synchronization cable 2-18–2-19, D-1 RCIM I 2-15–2-16 RCIM II 2-10, 2-12 RCIM III 2-4, 2-7 syntax notation iii

# Т

TCXO (Temperature Compensated Crystal Oscillator) 2-4 tick clock GPS 2-20 overview 3-2 registers A-12, B-16, C-6 synchronizing 3-5 Tick Clock Status/Control Registers RCIM I C-6 RCIM II B-16 RCIM III A-12

# U

unpacking instructions 2-18

RCIM User's Guide