

Ref.:UoD\_SpW-10X\_DataSheetIssue:2.0Date:18<sup>th</sup> August 2006

# SpaceWire Router

# **Data Sheet**

| Ref:           | UoD_SpW-10X_DataSheet                                                        |
|----------------|------------------------------------------------------------------------------|
| Document Revis | ion: Issue 2.0                                                               |
| Date:          | 18 <sup>th</sup> August 2006                                                 |
|                |                                                                              |
| Prepared by -  | Chris McClements, University of Dundee<br>Steve Parkes, University of Dundee |
| Checked by -   | Steve Parkes, University of Dundee                                           |

ESA Manager - Pierre Fabry, ESTEC



Ref.: UoD\_SpW-10X\_ DataSheet Issue: 2.0

Data-Sheet

Date: 18<sup>th</sup> August 2006

# Document Change log

| Date                          | Issue     | Comments                                                                                        | Author           |
|-------------------------------|-----------|-------------------------------------------------------------------------------------------------|------------------|
| 19 <sup>th</sup> -March-2004  | Issue 1.0 | Initial draft version                                                                           | Chris McClements |
|                               |           |                                                                                                 |                  |
| 26 <sup>th</sup> -August-2004 | Issue 1.2 | Timing for FPGA model added                                                                     | Chris McClements |
| 16 November 2004              | Issue 1.3 | Register Definitions Updated                                                                    | Chris McClements |
| 27 April 2004                 | Issue 1.4 | Latency and Jitter Specifications added                                                         | Chris McClements |
| 2 May 2005                    | Issue 1.5 | Footer indicates "Preliminary."<br>Section 8.6 subject to change<br>notice added to front page. | Steve Parkes     |
| 21 December 2005              | Issue 1.6 | RMAP section added                                                                              | Chris McClements |
| 19 <sup>th</sup> July 2006    | Issue 1.7 | Corrections and clarifications                                                                  | Chris McClements |
| 18 <sup>th</sup> August 2006  | Issue 2.0 | Editorial changes and<br>clarifications                                                         | Steve Parkes     |



# CONTENTS

| CONTENTS                                 | 3  |
|------------------------------------------|----|
| I LIST OF FIGURES                        | 7  |
| II LIST OF TABLES                        | 8  |
| 1. INTRODUCTION                          | 10 |
| 1.1 TERMS AND ACRONYMS                   | 10 |
| 1.2 DOCUMENTS                            | 10 |
| 2. APPLICATIONS                          | 12 |
| 2.1 STAND-ALONE ROUTER                   | 12 |
| 2.2 NODE INTERFACE                       | 12 |
| 2.3 EMBEDDED ROUTER                      | 12 |
| 2.4 EXPANDING THE NUMBER OF ROUTER PORTS | 12 |
| 3. FUNCTIONAL OVERVIEW                   | 13 |
| 3.1 SPACEWIRE PORTS                      | 14 |
| 3.2 EXTERNAL PORTS                       | 14 |
| 3.3 CONFIGURATION PORT                   | 15 |
| 3.4 ROUTING TABLE                        | 15 |
| 3.5 ROUTING CONTROL LOGIC AND CROSSBAR   | 15 |
| 3.6 TIME-CODE PROCESSING                 | 16 |
| 3.7 CONTROL/STATUS REGISTERS             | 16 |
| 4. DEVICE INTERFACE                      | 17 |
| 4.1 GLOBAL SIGNALS                       | 17 |
| 4.2 SPACEWIRE SIGNALS                    | 18 |
| 4.3 EXTERNAL PORT DATA SIGNALS           | 20 |
| 4.4 TIME-CODE SIGNALS                    | 22 |
| 4.5 LINK ERROR INDICATION SIGNALS        | 23 |
| 4.6 RESET CONFIGURATION SIGNALS          | 24 |
| Prelimary                                | 3  |



| 4.7 POWER AND GROUND SIGNALS                                           | 27 |
|------------------------------------------------------------------------|----|
| 5. INTERFACE OPERATIONS                                                | 28 |
| 5.1 EXTERNAL PORT INTERFACE OPERATION                                  | 28 |
| 5.2 TIME-CODE INTERFACE OPERATION                                      | 29 |
| 5.3 ERROR/STATUS ERROR INDICATION INTERFACE OPERATION                  | 30 |
| 5.4 RESET CONFIGURATION INTERFACE OPERATION                            | 32 |
| 6. SWITCHING CHARACTERISTICS                                           | 33 |
| 6.1 CLOCK AND RESET TIMING PARAMETERS                                  | 33 |
| 6.2 SERIAL SIGNALS TIMING PARAMETERS                                   | 33 |
| 6.3 EXTERNAL PORT TIMING PARAMETERS                                    | 34 |
| 6.4 TIME-CODE INTERFACE TIMING PARAMETERS                              | 35 |
| 6.5 ERROR/STATUS INTERFACE TIMING PARAMETERS                           | 36 |
| 6.6 LATENCY AND JITTER                                                 | -  |
| 6.6.1 Clock Periods                                                    |    |
| <ul><li>6.6.2 Switching Latency</li><li>6.6.3 Router Latency</li></ul> |    |
| 6.6.4 Time-code Latency                                                |    |
| 6.6.5 Time-code Jitter                                                 |    |
| 6.6.6 200M bits/s Input and Output Bit Rate Example                    |    |
| 7. ELECTRICAL CHARACTERISTICS                                          | 40 |
| 7.1 ABSOLUTE MAXIMUM RATINGS                                           | 40 |
| 7.2 DC CHARACTERISTICS                                                 | 40 |
| 7.3 OPERATING TEMPERATURE RANGE                                        | 40 |
| 8. SPACEWIRE ROUTER PACKET TYPES                                       | 41 |
| 8.1 PACKET ADDRESSES                                                   | 41 |
| 8.2 PACKET PRIORITY                                                    | 41 |
| 8.3 PACKET HEADER DELETION                                             | 42 |
| 8.4 INVALID ADDRESSES                                                  | 43 |
| 8.5 DATA PACKETS                                                       | 43 |
| 8.6 COMMAND PACKETS                                                    |    |
| 8.6.1 Supported Commands                                               |    |
| 8.6.2 Read Command                                                     |    |
| Prelimary                                                              | 4  |



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

| 8.6.3   | Read Incrementing Command               | 49 |
|---------|-----------------------------------------|----|
| 8.6.4   | Read Modify Write Command               |    |
| 8.6.5   | Write Command                           |    |
| 8.6.6   | Command Error Response                  |    |
| 8.6.7   | Command Packet Cyclic Redundancy Check  |    |
| 8.6.8   | Local Source Path Address               |    |
| 8.6.9   | Source Path Address Field               |    |
| 8.6.10  | Command Packet Fill Bytes               |    |
|         |                                         |    |
| 9. CC   | ONTROL LOGIC AND OPERATIONAL MODES      | 68 |
| 9.1 S   | PACEWIRE LINK CONTROL                   | 68 |
| 9.1.1   | Default operating mode                  | 68 |
| 9.1.2   | Auto-Start                              | 68 |
| 9.1.3   | Link-Start                              | 68 |
| 9.1.4   | Link-Disable                            | 69 |
| 9.1.5   | Automatic tri-state enable mode         | 69 |
| 9.1.6   | Setting the data-rate                   | 69 |
| 9.1.7   | Setting the default 10Mbits/s data-rate | 70 |
| 9.1.8   | Data rate comparison table              | 71 |
| 9.2 G   | GLOBAL SPACEWIRE LINK CONTROL           | 71 |
| 9.2.1   | Automatic Link-Start mode               | 71 |
| 9.2.2   | Automatic Link-Disable mode             | 72 |
| 9.3 C   | CONTROL LOGIC AND ROUTING               | 73 |
| 9.3.1   | Packet address error                    |    |
| 9.3.2   | Arbitration                             |    |
| 9.3.2.1 |                                         |    |
| 9.3.2.2 |                                         |    |
| 9.3.2.3 |                                         |    |
| 9.3.2.4 |                                         |    |
| 9.3.3   | Group Adaptive Routing                  |    |
| 9.3.3.1 |                                         |    |
| 9.3.3.2 |                                         |    |
| 9.3.3.3 |                                         |    |
| 9.3.4   | Loop-back routing                       |    |
| 9.3.5   | Packet Blocking                         |    |
| 9.3.5.1 | 5                                       |    |
| 9.3.5.2 | 5                                       |    |
| 9.3.5.3 |                                         |    |
| 9.3.5.4 |                                         |    |
| 9.3.5.5 |                                         |    |
| 9.3.5.6 | -                                       |    |
|         |                                         |    |



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

| 10. REGISTER DEFINITIONS                                          | 91  |
|-------------------------------------------------------------------|-----|
| 10.1 INTERNAL MEMORY MAP                                          | 91  |
| 10.2 REGISTER ADDRESSES SUMMARY                                   | 92  |
| 10.3 GROUP ADAPTIVE ROUTING TABLE REGISTERS                       | 93  |
| 10.4 PORT CONTROL/STATUS REGISTERS                                | 95  |
| 10.4.1 Generic port control/status register fields.               | 96  |
| 10.4.2 Configuration port control/status register fields          | 96  |
| 10.4.3 SpaceWire link interface port control/status register bits | 99  |
| 10.4.4 External port control/status register bits                 | 102 |
| 10.5 ROUTER CONTROL/STATUS REGISTERS                              | 102 |
| 10.5.1 Network Discovery Register                                 | 102 |
| 10.5.2 Router Identity Register                                   | 103 |
| 10.5.3 Router Control Register                                    |     |
| 10.5.4 Error active Register                                      |     |
| 10.5.5 Time-Code Register                                         |     |
| 10.5.6 Device Manufacturer and Chip ID Register                   |     |
| 10.5.7 General Purpose Register                                   |     |
| 10.5.8 Time-Code Enable Register                                  |     |
| 10.5.9 Transmit Clock Control Register                            |     |
| 10.5.10 Destination Key Register                                  |     |
| 10.5.11 Unused Registers and Register Bits                        |     |
| 10.5.12 Empty packets                                             |     |
| 10.6 WRITING TO A READ-ONLY REGISTER                              | 113 |
| 11. DOCUMENT CHANGES                                              | 114 |
| 11.1 ISSUE 1.7 TO ISSUE 2.0                                       | 114 |
| 11.2 ISSUE 1.6 TO ISSUE 1.7                                       | 114 |
| 11.3 ISSUE 1.5 TO ISSUE 1.6                                       | 114 |
| 11.4 ISSUE 1.4 TO ISSUE 1.5                                       | 114 |
| 11.5 ISSUE 1.3 TO ISSUE 1.4                                       | 114 |
| 11.6 ISSUE 1.2 TO ISSUE 1.3                                       | 114 |
| 11.7 ISSUE 1.1 TO ISSUE 1.2                                       | 114 |
| 11.8 ISSUE 1.0 TO ISSUE 1.1                                       | 115 |



 Ref.:
 UoD\_SpW-10X\_

 DataSheet
 DataSheet

 Issue:
 2.0

 Date:
 18<sup>th</sup> August 2006

# I LIST OF FIGURES

| FIGURE 3-1 SPACEWIRE ROUTER BLOCK DIAGRAM                      | . 14 |
|----------------------------------------------------------------|------|
| FIGURE 4-1 CONFIGURATION INTERFACE TIMING SPECIFICATION        | . 26 |
| FIGURE 5-1 EXTERNAL PORT WRITE TIMING SPECIFICATION            | . 28 |
| FIGURE 5-2 EXTERNAL PORT READ TIMING SPECIFICATION             | . 28 |
| FIGURE 5-3 TIME-CODE INPUT INTERFACE                           | . 29 |
| FIGURE 5-4 TIME-CODE OUTPUT INTERFACE                          | . 29 |
| FIGURE 5-5 TIME-CODE RESET INTERFACE                           | . 30 |
| FIGURE 5-6 STATUS MULTIPLEXER OUTPUT INTERFACE                 | . 30 |
| FIGURE 5-7 RESET CONFIGURATION INTERFACE TIMING SPECIFICATION  | . 32 |
| FIGURE 6-1 DS MINIMUM CONSECUTIVE EDGE SEPARATION              | . 33 |
| FIGURE 6-2 EXTERNAL PORT INPUT FIFO TIMING PARAMETERS          | . 34 |
| FIGURE 6-3 EXTERNAL PORT OUTPUT FIFO TIMING PARAMETERS         | . 34 |
| FIGURE 6-4 TIME-CODE INPUT INTERFACE                           |      |
| FIGURE 6-5 TIME-CODE OUTPUT INTERFACE                          |      |
| FIGURE 6-6 TIME_CODE TIME_CTR_RST INTERFACE                    | . 35 |
| FIGURE 8-1 NORMAL ROUTER DATA PACKETS                          |      |
| FIGURE 8-2 COMMAND PACKET FORMAT                               | . 44 |
| FIGURE 8-3 READ SINGLE ADDRESS COMMAND FORMAT                  | . 46 |
| FIGURE 8-4 READ SINGLE ADDRESS REPLY PACKET FORMAT             | . 48 |
| FIGURE 8-5 READ INCREMENTING ADDRESS COMMAND FORMAT            |      |
| FIGURE 8-6 READ INCREMENTING ADDRESS REPLY PACKET FORMAT       |      |
| FIGURE 8-7 READ-MODIFY-WRITE COMMAND PACKET FORMAT             | . 55 |
| FIGURE 8-8 READ-MODIFY-WRITE EXAMPLE OPERATION                 | . 57 |
| FIGURE 8-9 READ-MODIFY-WRITE REPLY PACKET FORMAT               | . 58 |
| FIGURE 8-10 WRITE SINGLE ADDRESS COMMAND PACKET.               | . 60 |
| FIGURE 8-11 WRITE SINGLE ADDRESS REPLY PACKET                  | . 62 |
| FIGURE 8-12 SOURCE PATH ADDRESS FIELD DECODING                 | . 67 |
| FIGURE 8-13 SOURCE PATH ADDRESSES IN REPLY PACKET              | . 67 |
| FIGURE 8-14 NORMAL CONFIGURATION PACKET HEADER STRUCTURE       | . 67 |
| FIGURE 8-15 FILL BYTES CONFIGURATION HEADER STRUCTURE.         | . 67 |
| FIGURE 9-1 TRI-STATE ENABLE OPERATING MODE.                    | . 69 |
| FIGURE 9-2 TX10MBITDIV EQUATION                                | . 70 |
| FIGURE 9-3 AUTOMATIC LINK-START MODE                           | . 72 |
| FIGURE 9-4 AUTOMATIC LINK-DISABLE MODE                         | . 72 |
| FIGURE 9-5 ARBITRATION OF TWO PACKETS WITH MATCHING PRIORITY.  | . 74 |
| FIGURE 9-6 ARBITRATION OF THREE PACKETS WITH MATCHING PRIORITY | . 75 |
| FIGURE 9-7 ARBITRATION OF TWO PACKETS WITH DIFFERENT PRIORITY  |      |
| FIGURE 9-8                                                     | . 77 |
|                                                                |      |



Ref.: UoD\_SpW-10X\_

DataSheet

18<sup>th</sup> August 2006

Data-Sheet

Issue: 2.0

Date:

FIGURE 10-9 TIME-CODE ENABLE REGISTER FIELDS......110 FIGURE 10-10 TRANSMIT CLOCK CONTROL REGISTER ...... 111 

# II LIST OF TABLES



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

| TABLE 8-1 PACKET ADDRESS MAPPING                             |     |
|--------------------------------------------------------------|-----|
| TABLE 8-2 PACKET PRIORITY MAPPING                            |     |
| TABLE 8-3 PACKET HEADER DELETION MAPPING                     |     |
| TABLE 8-4 SUPPORTED RMAP COMMAND CODES                       |     |
| TABLE 8-5 READ SINGLE ADDRESS CHARACTERISTICS                |     |
| TABLE 8-6 READ SINGLE ADDRESS COMMAND PACKET FIELDS          | 47  |
| TABLE 8-7 READ SINGLE ADDRESS REPLY PACKET FIELDS            |     |
| TABLE 8-8 READ INCREMENTING ADDRESS CHARACTERISTICS          | 50  |
| TABLE 8-9 READ INCREMENTING ADDRESS COMMAND PACKET FIELDS    | 51  |
| TABLE 8-10 READ INCREMENTING ADDRESS REPLY PACKET FIELDS     | 53  |
| TABLE 8-11 READ-MODIFY-WRITE COMMAND CHARACTERISTICS         |     |
| TABLE 8-12 READ-MODIFY-WRITE COMMAND PACKET FIELDS           |     |
| TABLE 8-13 READ-MODIFY-WRITE REPLY PACKET FIELDS             |     |
| TABLE 8-14 WRITE COMMAND CHARACTERISTICS.                    | 59  |
| TABLE 8-15 WRITE SINGLE ADDRESS COMMAND PACKET FIELDS        | 60  |
| TABLE 8-16 WRITE SINGLE ADDRESS REPLY PACKET FIELDS.         |     |
| TABLE 8-17 CONFIGURATION PORT ERRORS SUMMARY                 | 63  |
| Table 8-18 Source Path Address Reference Table               | 66  |
| TABLE 9-1 PORT READY DEFINITIONS                             |     |
| TABLE 9-2 PACKET BLOCKING                                    |     |
| TABLE 10-1 TYPES OF REGISTER WITHIN CONFIGURATION PORT       |     |
| TABLE 10-2 CONFIGURATION REGISTER ADDRESSES                  |     |
| TABLE 10-3 GAR TABLE REGISTER DESCRIPTION                    |     |
| TABLE 10-4 CONFIGURATION PORT CONTROL/STATUS REGISTER FIELDS |     |
| TABLE 10-5 CONFIGURATION PORT CONTROL/STATUS REGISTER FIELDS |     |
| TABLE 10-6 SPACEWIRE PORT CONTROL/STATUS REGISTER FIELDS.    | 100 |
| TABLE 10-7 EXTERNAL PORT CONTOL/STATUS FIELDS                | 102 |
| TABLE 10-8 NETWORK DISCOVERY REGISTER FIELDS                 | 103 |
| TABLE 10-9 ROUTER IDENTITY REGISTER FIELD                    |     |
| TABLE 10-10 ROUTER CONTROL REGISTER FIELDS                   | 105 |
| TABLE 10-11 ERROR ACTIVE REGISTER FIELDS                     | 107 |
| TABLE 10-12 TIME-CODE REGISTER FIELDS                        | 108 |
| TABLE 10-13 DEVICE MANUFACTURER AND CHIP ID REGISTER FIELDS  | 109 |
| TABLE 10-14 TIME-CODE ENABLE REGISTER FIELDS                 | 110 |
| TABLE 10-15 TRANSMIT CLOCK CONTROL REGISTER BITS             |     |
| TABLE 10-16 DESTINATION KEY REGISTER                         |     |
|                                                              |     |



### 1. INTRODUCTION

This document defines a technical reference for the implementation and operation of the SpaceWire Router device, SpW-10X. Detailed timing information for the ASIC implementation is not yet available.

#### 1.1 TERMS AND ACRONYMS

| 3V3  | 3.3 volt interface levels.                                                    |
|------|-------------------------------------------------------------------------------|
| ACK  | Acknowledge                                                                   |
| AD   | Applicable Document                                                           |
| CLK  | Input clock to the SpaceWire router                                           |
| CRC  | Cyclic Redundancy Check                                                       |
| DC   | Direct Current                                                                |
| EEP  | Error end of packet, used to denote an error occurred during packet transfer. |
| EOP  | End of packet used to denote a normal end of packet in SpaceWire.             |
| FIFO | First in - First out buffer used to transfer data between logic.              |
| FPGA | Field Programmable Gate Array.                                                |
| LVDS | Low voltage differential signalling.                                          |
| NACK | Negative acknowledge (error acknowledge)                                      |
| RD   | Read                                                                          |
| RMAP | Remote Memory Access Protocol                                                 |
| RST  | Aysnchronous reset to the SpaceWire router.                                   |
| UoD  | University of Dundee.                                                         |
| WR   | Write                                                                         |

#### 1.2 DOCUMENTS

In this section the documents referenced in this document are listed.



Ref.: UoD\_SpW-10X\_ DataSheet Issue: 2.0

Data-Sheet

Date: 18<sup>th</sup> August 2006

| Table 1-1 Applicable Documents |                     |                                                 |  |
|--------------------------------|---------------------|-------------------------------------------------|--|
| REF                            | Document Number     | Document Title                                  |  |
| AD1                            | ECSS-E5O-12A        | SpaceWire - links, nodes, routers and networks. |  |
| AD2                            | ECSS-E50-11 Draft E | SpaceWire Remote Memory Access Protocol         |  |



### 2. APPLICATIONS

The SpaceWire router applications are defined in the following sections

### 2.1 STAND-ALONE ROUTER

The SpaceWire Router may be used as a stand-alone router with up to eight SpaceWire links connected to it. Configuration of the routing tables etc. may be done by sending SpaceWire packets containing configuration commands to the router.

#### 2.2 NODE INTERFACE

The SpaceWire Router has two external ports which enable the device to be used as a node interface. The equipment to be connected to the SpaceWire network is attached to one or both external ports. One or more SpaceWire ports are used to provide the connection into the SpaceWire network. Unused SpaceWire ports may be disabled and their outputs tri-stated to save power. In this arrangement configuration of the routing tables and other parameters may be done by sending configuration packets from the local host via an external port or from a remote network manager via a SpaceWire port.

#### 2.3 EMBEDDED ROUTER

The SpaceWire Router device can also be used to provide a node with an embedded router. In this case the external ports are used to provide the local connections to the node and the SpaceWire ports are used to make connections to other ports in the network. The difference between this configuration and that of section 2.2 is just a conceptual one with the Node interface configuration normally using fewer SpaceWire ports than the Embedded Router configuration.

### 2.4 EXPANDING THE NUMBER OF ROUTER PORTS

If a routing switch with a larger number of SpaceWire (or external) ports is required then this can be accomplished by joining together two or more routers using some of the SpaceWire links. For example using two SpaceWire links to join together two router devices would create an effective router with twelve SpaceWire ports and four external ports. Note, however, that an extra path addressing byte is needed to route packets between the two routers and that there is additional routing delay.



#### 3. FUNCTIONAL OVERVIEW

A SpaceWire routing switch is able to connect together many nodes, providing a means of routing packets between the nodes connected to it. It comprises a number of SpaceWire link interfaces and a routing matrix. The routing matrix enables packets arriving at one link interface to be transferred to and sent out of another link interface on the routing switch

The SpaceWire router comprises the following functional logic blocks:

- Eight SpaceWire bi-directional serial ports.
- Two external parallel input/output ports each comprising an input FIFO and an output FIFO.
- A non-blocking crossbar switch connecting any input port to any output port.
- An internal configuration port accessible via the crossbar switch from the external parallel input/output port or the SpaceWire input/output ports.
- A routing table accessible via the configuration port which holds the logical address to output port mapping.
- Control logic to control the operation of the switch, performing arbitration and group adaptive routing.
- Control registers than can be written and read by the configuration port and which hold control information e.g. link operating speed.
- An external time-code interface comprising tick\_in, tick\_out and current tick count value
- Internal status/error registers accessible via the configuration port
- External status/error signals

A block diagram of the routing switch is given in Figure 3-1.



Figure 3-1 SpaceWire router block diagram

The following paragraphs define the SpaceWire router functional logic blocks in more detail.

### 3.1 SPACEWIRE PORTS

The SpaceWire router has eight bi-directional SpaceWire links each conformant with the SpaceWire standard. Each SpaceWire link is controlled by an associated link register and routing control logic. Network level error recovery is performed when an error is detected on the SpaceWire link as defined in the SpaceWire standard. Packets received on SpaceWire links are routed by the routing control logic to the configuration port, other SpaceWire link ports or the external FIFO ports. Packets with invalid addresses are discarded by the SpaceWire router dependent on the packet address. The SpaceWire link status is recorded in the associated link register and error status is held by the router until cleared by a configuration command.

### 3.2 EXTERNAL PORTS

The SpaceWire router has two bi-directional parallel FIFO interfaces to an external host system. Each FIFO is written to or read from synchronously to the 30MHz system clock. An eight-bit data interface and an extra control bit for end of packet markers are provided by each external port FIFO. Packets

| HUNDRENT CA           |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
|                       |                  | Date:  | 18 <sup>th</sup> August 2006 |

received by the external port are routed by the routing control logic to the configuration port, SpaceWire link ports or the other external port dependent on the packet address. Packets with invalid addresses are discarded by the SpaceWire router.

# 3.3 CONFIGURATION PORT

The SpaceWire router has one configuration port which performs read and write operations to internal router registers. Packets are routed to the configuration port when a packet with a leading address byte of zero is received. The command packet format used in the SpaceWire Router is the Remote Memory Access Protocol (RMAP) [AD2]. A detailed description of the format of the RMAP command packets is defined in section 8.6. If an invalid command packet is received then the error is flagged to the associated status register and the packet is discarded. The internal router registers are described in section 0.

### 3.4 ROUTING TABLE

The SpaceWire router routing table is set by the router command packets to assign logical addresses to physical destination ports on the router. A group of destination ports can be set, in each routing table location, to enable group adaptive routing. In group adaptive routing a packet can be routed to its destination through one of a set of output ports dependent on which ports in the set are free to use. When a packet is received with a logical address the routing table is checked by the routing control logic and the packet is routed to the destination port when the port is ready.

Routing table locations are set to invalid at power on or at reset. An invalid routing address will cause the packet to be spilled by the control logic. The routing table logical addresses can also be set to support high priority and header deletion. High priority packets are routed before low priority packets and header deletion of logical addresses can be used to support regional logical addressing (see AD1).

### 3.5 ROUTING CONTROL LOGIC AND CROSSBAR

The routing control logic is responsible for arbitration of output ports, group adaptive routing and the crossbar switching. Arbitration is performed when two or more source ports are requesting to use the same destination port. A priority based arbitration scheme with two priority levels, high and low, is used where high priority packets are routed before low priority packets. Fair arbitration is performed on packets which have the same priority levels to ensure each packet gets equal access to the output port.

Group adaptive routing control selects one of a number of output ports for sending out the source packet.



### 3.6 TIME-CODE PROCESSING

An internal time-code register is used in the router to allow the router to be a time-code master or a time-code slave.

In master mode the time-code interface is used to provide a tick-in to the SpaceWire routing causing time-codes to be propagated through the network. Two modes of time master operation are supported, an automatic mode where a time-code is propagated on each external tick-in and a normal mode where the time-code is propagated dependent on the external time-in signal.

In time-code slave mode a valid received time-code, one plus the value of the router time-code register, causes a tick-out to be sent to the SpaceWire links and the external time-code interface. The time-code is propagated to all time-code ports except the port on which the time-code was received. If the time-code received is not one plus the value of the time-code register then the time-code register is updated but the tick-out is not performed. In this way circular network paths do not cause a constant stream of time-codes to be sent in a loop.

### 3.7 CONTROL/STATUS REGISTERS

The control and status registers in the SpaceWire router provide the means to control the operation of the router, set the router configuration and parameters or monitor the status of the device. The registers are accessed using RMAP [AD2] commands packets received by the configuration port.



#### 4. DEVICE INTERFACE

The device pins used by each interface are described in this section. There is a table for each type of interface listing the signals in that interface. These tables have the following fields:

- Pin No: The device pin number
- Signal: The name of the signal
- Dir: The direction of the signal; in, out or in/out
- Description: An explanation of what the signal does.
- Type: The type of signal

The sections below define the pin out of the SpaceWire router. Its interfaces are split into several types, separated by headings for clarity:

- Global signals: clock and reset
- SpaceWire interface signals
- External port signals
- Time-code interface signals
- Configuration signals
- Reset configuration signals
- Power and Ground

The following signal types are used in the SpaceWire Router:

- CMOS3V3 3.3 Volt CMOS logic
- LVDS Low Voltage Differential Signal
- 3V3 3.3 Volt power
- GND 0 Volt ground

#### 4.1 GLOBAL SIGNALS

The global system clock and reset signals are listed in Table 4-1.

|       | Table 4-1 Global Signals      |    |                                                                                            |         |  |  |  |  |  |
|-------|-------------------------------|----|--------------------------------------------------------------------------------------------|---------|--|--|--|--|--|
| PinNo | PinNoSignalDirDescriptionType |    |                                                                                            |         |  |  |  |  |  |
|       | CLK                           | In | System clock. Provides the reference clock for all modules except the interface receivers. | CMOS3V3 |  |  |  |  |  |
|       | RST_N                         | In | Asynchronous system reset (active low)                                                     | CMOS3V3 |  |  |  |  |  |

| EEADS<br>ASTRIUM |                   |     | SpaceWire Router                                                                                                                      | Ref.:<br>Issue: | UoD_SpW-10X_<br>DataSheet<br>2.0 |            |
|------------------|-------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------------------------|------------|
|                  | 🥘 Austrian Aerosp | ace | Data-Sheet                                                                                                                            | Date:           | 18 <sup>th</sup> Au              | igust 2006 |
|                  | FEEDBDIV(2:0)     | In  | Set the output clock rate of the internal F<br>"000" $\rightarrow$ 100MHz<br>"001" $\rightarrow$ 120MHz<br>"010" $\rightarrow$ 140MHz | PLL as fo       | llows:                           | CMOS3V3    |

"011" → 160MHz
"100" → 180MHz
"101" → 200MHz
"110" → 200MHz
"111" → 200MHz

#### 4.2 SPACEWIRE SIGNALS

The SpaceWire interface signals are listed in Table 4-2. For further details about SpaceWire see the SpaceWire standard [AD1].

See section 9.1.6 for setting the transmit rate.

|       | Table 4-2 Data and Strobe SpaceWire Signals |     |                                                    |                 |  |  |  |  |  |
|-------|---------------------------------------------|-----|----------------------------------------------------|-----------------|--|--|--|--|--|
| PinNo | Signal                                      | Dir | Description                                        | Туре            |  |  |  |  |  |
|       | DOUT+(1)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(1)                                    |     | SpaceWire link 1.                                  | LVDS - (N Side) |  |  |  |  |  |
|       | DOUT+(2)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(2)                                    |     | SpaceWire link 2.                                  | LVDS - (N Side) |  |  |  |  |  |
|       | DOUT+(3)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(3)                                    |     | SpaceWire link 3.                                  | LVDS - (N Side) |  |  |  |  |  |
|       | DOUT+(4)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(4)                                    |     | SpaceWire link 4.                                  | LVDS - (N Side) |  |  |  |  |  |
|       | DOUT+(5)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(5)                                    |     | SpaceWire link 5.                                  | LVDS - (N Side) |  |  |  |  |  |
|       | DOUT+(6)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(6)                                    |     | SpaceWire link 6.                                  | LVDS - (N Side) |  |  |  |  |  |
|       | DOUT+(7)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(7)                                    |     | SpaceWire link 7.                                  | LVDS - (N Side) |  |  |  |  |  |
|       | DOUT+(8)                                    | Out | Differential output pair, data part of Data-Strobe | LVDS+ (P Side)  |  |  |  |  |  |
|       | DOUT-(8)                                    |     | SpaceWire link 8.                                  | LVDS - (N Side) |  |  |  |  |  |



Ref.: UoD\_SpW-10X\_

DataSheet

### Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| SOUT+(1) | Out      | Differential output pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
|----------|----------|------------------------------------------------------|-----------------|
| SOUT-(1) |          | SpaceWire link 1.                                    | LVDS - (N Side) |
|          |          |                                                      | ``````          |
| SOUT+(2) | Out      | Differential output pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SOUT-(2) |          | SpaceWire link 2.                                    | LVDS - (N Side) |
| SOUT+(3) | Out      |                                                      | LVDS+ (P Side)  |
| SOUT-(3) |          | SpaceWire link 3.                                    | LVDS - (N Side) |
| SOUT+(4) | Out      | Differential output pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SOUT-(4) |          | SpaceWire link 4.                                    | LVDS - (N Side) |
| SOUT+(5) | Out      | Differential output pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SOUT-(5) |          | SpaceWire link 5.                                    | LVDS - (N Side) |
| SOUT+(6) | Out      | Differential output pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SOUT-(6) |          | SpaceWire link 6.                                    | LVDS - (N Side) |
| SOUT+(7) | Out      | Differential output pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SOUT-(7) |          | SpaceWire link 7.                                    | LVDS - (N Side) |
| SOUT+(8) | Out      | Differential output pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SOUT-(8) |          | SpaceWire link 8.                                    | LVDS - (N Side) |
| DIN+(1)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(1)  |          | SpaceWire link 1.                                    | LVDS - (N Side) |
| DIN+(2)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(2)  |          | SpaceWire link 2.                                    | LVDS - (N Side) |
| DIN+(3)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(3)  |          | SpaceWire link 3.                                    | LVDS - (N Side) |
| DIN+(4)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(4)  |          | SpaceWire link 4.                                    | LVDS - (N Side) |
| DIN+(5)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(5)  |          | SpaceWire link 5.                                    | LVDS - (N Side) |
| DIN+(6)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(6)  |          | SpaceWire link 6.                                    | LVDS - (N Side) |
| DIN+(7)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(7)  | <u> </u> | SpaceWire link 7.                                    | LVDS - (N Side) |
| DIN+(8)  | In       | Differential input pair, data part of Data-Strobe    | LVDS+ (P Side)  |
| DIN-(8)  |          | SpaceWire link 8.                                    | LVDS - (N Side) |
| SIN+(1)  | In       | Differential input pair, strobe part of Data-Strobe  | LVDS+ (P Side)  |
| SIN-(1)  | <u> </u> | SpaceWire link 1.                                    | LVDS - (N Side) |
| SIN+(2)  | In       | Differential input pair, strobe part of Data-Strobe  | LVDS+ (P Side)  |
| SIN-(2)  |          | SpaceWire link 2.                                    | LVDS - (N Side) |
| SIN+(3)  | In       | Differential input pair, strobe part of Data-Strobe  | LVDS+ (P Side)  |
| SIN-(3)  | <u> </u> | SpaceWire link 3.                                    | LVDS - (N Side) |
| SIN+(4)  | In       | Differential input pair, strobe part of Data-Strobe  | LVDS+ (P Side)  |



Ref.: UoD\_SpW-10X\_ DataSheet Issue: 2.0

Data-Sheet

Date: 18<sup>th</sup> August 2006

| SIN-(4) |    | SpaceWire link 4.                                   | LVDS - (N Side) |
|---------|----|-----------------------------------------------------|-----------------|
| SIN+(5) | In | Differential input pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SIN-(5) |    | SpaceWire link 5.                                   | LVDS - (N Side) |
| SIN+(6) | In | Differential input pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SIN-(6) |    | SpaceWire link 6.                                   | LVDS - (N Side) |
| SIN+(7) | In | Differential input pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SIN-(7) |    | SpaceWire link 7.                                   | LVDS - (N Side) |
| SIN+(8) | In | Differential input pair, strobe part of Data-Strobe | LVDS+ (P Side)  |
| SIN-(8) |    | SpaceWire link 8.                                   | LVDS - (N Side) |

# 4.3 EXTERNAL PORT DATA SIGNALS

The External port signals are listed in Table 4-3. The timing of these signals is shown in Figure 5-1 External port write timing specification and Figure 5-2 External port read timing specification.

|       | Table 4-3 External Port Interface Signals                                                                                                                                        |     |                                                                                                                                                                                                                                                                                           |         |  |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--|--|
| PinNo | Signal                                                                                                                                                                           | Dir | Description                                                                                                                                                                                                                                                                               | Туре    |  |  |  |
|       | EXT_OUT_DATA0(8)<br>EXT_OUT_DATA0(7)<br>EXT_OUT_DATA0(6)<br>EXT_OUT_DATA0(5)<br>EXT_OUT_DATA0(4)<br>EXT_OUT_DATA0(3)<br>EXT_OUT_DATA0(2)<br>EXT_OUT_DATA0(1)<br>EXT_OUT_DATA0(0) | Out | Output data from external port zero FIFO. Bit<br>eight determines the type - data, EOP or EEP.<br>The encodings are defined as:<br>(8)(70) – <b>Bits</b><br>(0)(ddddddd) - Data byte<br>(1)(XXXXXX0) - EOP.<br>(1)(XXXXXX1) - EEP.<br>Bit 7 is the most significant bit of the data byte. | CMOS3V3 |  |  |  |
|       | EXT_OUT_EMPTY_N0                                                                                                                                                                 | Out | FIFO ready signal for external output port zero.<br>When high the FIFO has data. When low the<br>FIFO is empty.                                                                                                                                                                           | CMOS3V3 |  |  |  |
|       | EXT_OUT_READ_N0                                                                                                                                                                  | In  | Asserted (low) to read from the external output port zero FIFO.                                                                                                                                                                                                                           | CMOS3V3 |  |  |  |
|       | EXT_IN_DATA0(8)<br>EXT_IN_DATA0(7)<br>EXT_IN_DATA0(6)                                                                                                                            | In  | Input data to external port zero FIFO. Bit eight determines the type - data, eop or eep. The encodings are defined as:                                                                                                                                                                    | CMOS3V3 |  |  |  |



Ref.: UoD\_SpW-10X\_

DataSheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| <br>EVT IN DATAO(5)  |     |                                                                                             |           |
|----------------------|-----|---------------------------------------------------------------------------------------------|-----------|
| EXT_IN_DATA0(5)      |     | (8)(70) - Bits                                                                              |           |
| EXT_IN_DATA0(4)      |     | (0)(ddddddd) - Data byte<br>(1)(xxxxxx0) - EOP.                                             |           |
| EXT_IN_DATA0(3)      |     | (1)(XXXXXX1) - EEP.                                                                         |           |
| EXT_IN_DATA0(2)      |     |                                                                                             |           |
| EXT_IN_DATA0(1)      |     | Bit 7 is the most significant bit of the data byte.                                         |           |
| EXT_IN_DATA0(0)      |     |                                                                                             |           |
| <br>EXT_IN_FULL_N0   | Out | FIFO ready signal for external input port zero.                                             | CMOS3V3   |
|                      |     | When high there is space in the FIFO so it can                                              |           |
|                      |     | be written to. When low the FIFO is full.                                                   |           |
| EXT_IN_WRITE_N0      | In  | Asserted (low) to write to the external input port                                          | CMOS3V3   |
| <br>EXT OUT DATA1(8) | 0   | zero FIFO.                                                                                  | CMOS3V3   |
| `,                   | Out | Output data from external port one FIFO . Bit eight determines the type - data, eop or eep. | CIVIO53V3 |
| EXT_OUT_DATA1(7)     |     | The encodings are defined as:                                                               |           |
| EXT_OUT_DATA1(6)     |     |                                                                                             |           |
| EXT_OUT_DATA1(5)     |     | (8)(70) – <b>Bits</b>                                                                       |           |
| EXT_OUT_DATA1(4)     |     | (0)(ddddddd) - Data byte                                                                    |           |
| EXT_OUT_DATA1(3)     |     | (1)(XXXXXX0) - EOP.                                                                         |           |
| EXT_OUT_DATA1(2)     |     | (1)(XXXXXX1) - EEP.                                                                         |           |
| EXT_OUT_DATA1(1)     |     | Bit 7 is the most significant bit of the data byte.                                         |           |
|                      |     |                                                                                             |           |
| EXT_OUT_DATA1(0)     |     |                                                                                             |           |
| EXT_OUT_EMPTY_N1     | Out | FIFO ready signal for external output port one.                                             | CMOS3V3   |
|                      |     | When high the FIFO has data. When low the                                                   |           |
| EXT OUT READ N1      | In  | FIFO is empty.                                                                              |           |
| EXT_OUT_READ_NT      | 111 | Asserted (low) to read from the external output port one FIFO.                              | CMOS3V3   |
| EXT_IN_DATA1(8)      | In  | Input data to external port one FIFO. Bit eight                                             | CMOS3V3   |
| EXT_IN_DATA1(7)      |     | determines the type - data, eop or eep. The                                                 |           |
| EXT_IN_DATA1(6)      |     | encodings are defined as:                                                                   |           |
| EXT_IN_DATA1(5)      |     | (8)(70) <b>– Bits</b>                                                                       |           |
|                      |     | (0)(ddddddd) - Data byte                                                                    |           |
| EXT_IN_DATA1(4)      |     | (1)(XXXXXX0) - EOP.                                                                         |           |
| EXT_IN_DATA1(3)      |     | (1)(XXXXXX1) - EEP.                                                                         |           |
| EXT_IN_DATA1(2)      |     |                                                                                             |           |
| EXT_IN_DATA1(1)      |     | Bit 7 is the most significant bit of the data byte.                                         |           |
| I                    |     |                                                                                             |           |



Issue: 2.0

Date: 18<sup>th</sup> August 2006

| EXT_IN_DATA1(0) |     |                                                    |         |
|-----------------|-----|----------------------------------------------------|---------|
| EXT_IN_FULL_N1  | Out | FIFO ready signal for external input port one.     | CMOS3V3 |
|                 |     | When high there is space in the FIFO so it can     |         |
|                 |     | be written to. When low the FIFO is full.          |         |
| EXT_IN_WRITE_N1 | In  | Asserted (low) to write to the external input port | CMOS3V3 |
|                 |     | one FIFO.                                          |         |

# 4.4 TIME-CODE SIGNALS

The time-code interface signals are listed in Table 4-4. The timing of this interface is shown in Figure 5-3 and Figure 5-4.

|       | Table 4-4 Time-Code Signals |     |                                                          |         |  |  |  |
|-------|-----------------------------|-----|----------------------------------------------------------|---------|--|--|--|
| PinNo | Signal                      | Dir | Description                                              | Туре    |  |  |  |
|       | EXT_TICK_IN                 | In  | The rising edge of the EXT_TICK_IN signal is used        | CMOS3V3 |  |  |  |
|       |                             |     | to indicate when a time-code is to be sent. On the       |         |  |  |  |
|       |                             |     | rising edge of the EXT_TICK_IN signal the                |         |  |  |  |
|       |                             |     | SEL_EXT_TIME signal is sampled to determine if           |         |  |  |  |
|       |                             |     | the time-code value is to be provided by the internal    |         |  |  |  |
|       |                             |     | time-counter or by the external time input               |         |  |  |  |
|       |                             |     | EXT_TIME_IN(7:0).                                        |         |  |  |  |
|       |                             |     | The SEL_EXT_TIME and the EXT_TIME_IN(7:0)                |         |  |  |  |
|       |                             |     | signals must be set up prior to the rising edge of       |         |  |  |  |
|       |                             |     | EXT_TICK_IN and must be held static sometime             |         |  |  |  |
|       |                             |     | afterwards.                                              |         |  |  |  |
|       | EXT_TIME_IN(7)              | In  | EXT_TIME_IN(7:0) provides the value of the time-         | CMOS3V3 |  |  |  |
|       | EXT_TIME_IN(6)              |     | code to be distributed by the router when an             |         |  |  |  |
|       | EXT_TIME_IN(5)              |     | external time-code source is selected i.e. when          |         |  |  |  |
|       | EXT_TIME_IN(4)              |     | SEL_EXT_TIME is high on the rising edge of               |         |  |  |  |
|       | EXT_TIME_IN(3)              |     | EXT_TICK_IN.                                             |         |  |  |  |
|       | EXT_TIME_IN(2)              |     |                                                          |         |  |  |  |
|       | EXT_TIME_IN(1)              |     | When <b>SEL_EXT_TIME</b> is high on the rising edge of   |         |  |  |  |
|       | EXT_TIME_IN(0)              |     | <b>EXT_TICK_IN</b> the value of the time-code counter is |         |  |  |  |
|       |                             |     | used for bits 5:0 of the time-code and bits 7:6 of the   |         |  |  |  |
|       |                             |     | EXT_TIME_IN(7:0) are used for the two control            |         |  |  |  |
|       |                             |     | signals, bits 7:6 of the time-code.                      |         |  |  |  |
|       | SEL_EXT_TIME                | In  | If SEL_EXT_TIME is high on the rising edge of            | CMOS3V3 |  |  |  |
|       |                             |     | EXT_TICK_IN the value on EXT_TIME_IN(7:0) is             |         |  |  |  |
|       |                             |     | loaded into the internal time-code register and          |         |  |  |  |



Ref.: UoD\_SpW-10X\_ DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|   |                 |     | propagated by the router.                              |         |
|---|-----------------|-----|--------------------------------------------------------|---------|
|   |                 |     |                                                        |         |
|   |                 |     | If <b>SEL_EXT_TIME</b> is low on the rising edge of    |         |
|   |                 |     | EXT_TICK_IN the value to be sent in the time-code      |         |
|   |                 |     | will be taken from the internal time-code counter in   |         |
|   |                 |     | the router. The two control-bits (bits 7:6) of the     |         |
|   |                 |     | time-code will come from bits 7:6 of the               |         |
|   |                 |     | EXT_TIME_IN(7:0)input.                                 |         |
|   | TIME_CTR_RST    | In  | This signal causes the internal time-code counter to   | CMOS3V3 |
|   |                 |     | be reset to zero.                                      |         |
|   |                 |     |                                                        |         |
|   |                 |     | The timing parameters used for <b>EXT_TICK_IN</b> also |         |
|   |                 |     | apply to the time-code counter reset signal            |         |
|   |                 |     | (TIME_CTR_RST).                                        |         |
|   | EXT_TICK_OUT    | Out |                                                        | CMOS3V3 |
|   |                 |     | indicated the reception of a time-code. The value of   |         |
|   |                 |     | this time-code is place on the                         |         |
|   |                 |     | EXT_TIME_OUT(7:0)outputs and is valid on the           |         |
|   |                 |     | rising edge of EXT_TICK_OUT.                           |         |
|   | EXT_TIME_OUT(7) | Out |                                                        | CMOS3V3 |
|   | EXT_TIME_OUT(6) |     | EXT_TICK_OUT is asserted.                              |         |
|   | EXT_TIME_OUT(5) |     |                                                        |         |
|   | EXT_TIME_OUT(4) |     | The value of a received time-code is output on the     |         |
|   | EXT_TIME_OUT(3) |     | falling edge of <b>EXT_TICK_OUT</b> . The              |         |
|   | EXT_TIME_OUT(2) |     | <b>EXT_TIME_OUT(7:0)</b> value is held until the next  |         |
|   | EXT_TIME_OUT(1) |     | time-code is output.                                   |         |
|   | EXT_TIME_OUT(0) |     |                                                        |         |
|   |                 |     |                                                        |         |
| L | I               | 1   |                                                        |         |

### 4.5 LINK ERROR INDICATION SIGNALS

The link error indication signals are listed in Table 4-5.

|       | Table 4-5 Link error indication Signals                  |     |                                                                                                         |                |  |  |
|-------|----------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------|----------------|--|--|
| PinNo | Signal                                                   | Dir | Description                                                                                             | Signal<br>Type |  |  |
|       | STAT_MUX_ADDR(3)<br>STAT_MUX_ADDR(2)<br>STAT_MUX_ADDR(1) | in  | Select the error indication status signals to be output on <b>STAT_MUX_OUT</b> as defined in Table 5-1. | CMOS3V3        |  |  |



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| STAT_MUX_ADDR(0) |       |                                                 |         |
|------------------|-------|-------------------------------------------------|---------|
| STAT_MUX_OUT(7)  | inout | Multi function pin.                             | CMOS3V3 |
| STAT_MUX_OUT(6)  |       | Power on Configuration                          |         |
| STAT_MUX_OUT(5)  |       | After reset the <b>STAT_MUX_OUT</b> pins are    |         |
| STAT_MUX_OUT(4)  |       | inputs which define the power on configuration  |         |
| STAT_MUX_OUT(3)  |       | status of the router. The pin mappings are      |         |
| STAT_MUX_OUT(2)  |       | listed in section 5.1.6.                        |         |
| ,                |       | Normal Operation                                |         |
| STAT_MUX_OUT(1)  |       | After the power on reset configuration of the   |         |
| STAT_MUX_OUT(0)  |       | router has been read from STAT_MUX_OUT          |         |
|                  |       | the pins are driven as outputs by the router.   |         |
|                  |       | The function of these output pins is defined by |         |
|                  |       | STAT_MUX_ADDR(3:0).                             |         |
|                  |       |                                                 |         |

# 4.6 RESET CONFIGURATION SIGNALS

The Reset Configuration signals are listed in Table 4-6. These signals are input on **STAT\_MUX\_OUT** after reset to initialise the router. They are not used at any other time except immediately after reset. The Reset Configuration signals set relevant bits in the configuration registers (see section 0). Following reset the values of these signals are synchronously loaded into the router. The timing of the Reset Configuration signals is illustrated in Figure 5-7.



Data-Sheet

Ref.: UoD\_SpW-10X\_

DataSheet



| Table 4-6 Reset Configuration Signals |                       |                                                  |                |  |
|---------------------------------------|-----------------------|--------------------------------------------------|----------------|--|
| Signal                                | Dir                   | Description                                      | Signal<br>Type |  |
| STAT_MUX_OUT(2:0)                     | In                    | Sets the transmitter maximum data rate after     | CMOS3V3        |  |
| [maps to -> POR_TX_RATE(2:0)]         |                       | reset. The data rate can subsequently be         |                |  |
|                                       |                       | changed during normal operation using port       |                |  |
|                                       |                       | configuration commands. The values are           |                |  |
|                                       |                       | listed below.                                    |                |  |
|                                       |                       | "111" – Full data rate after link start-up.      |                |  |
|                                       |                       | "110" – 1/2 data rate after link start-up.       |                |  |
|                                       |                       | "101" – 1/3 data rate after link start-up.       |                |  |
|                                       |                       | "100" – 1/4 data rate after link start-up.       |                |  |
|                                       |                       | "011" – 1/5 data rate after link start-up.       |                |  |
|                                       |                       | "010" – 1/6 data rate after link start-up.       |                |  |
|                                       |                       | "001" – 1/7 data rate after link start-up.       |                |  |
|                                       |                       | "000" – 1/8 data rate after link start-up.       |                |  |
|                                       |                       | Note: <b>POR_TX_RATE</b> affects all SpaceWire   |                |  |
|                                       |                       | ports in the router.                             |                |  |
|                                       |                       | Note: The data rate is dependent on              |                |  |
|                                       |                       | FEEDBDIV at reset                                |                |  |
| STAT_MUX_OUT(3)                       | In                    | If asserted (low) after reset allows a router    | CMOS3V3        |  |
| [maps to ->                           |                       | port to address itself and therefore cause an    |                |  |
| POR_ADDR_SELF_N                       |                       | input packet to be returned through the same     |                |  |
|                                       | input port. This mode |                                                  |                |  |
|                                       |                       | debug and test operations.                       |                |  |
|                                       |                       | This signal is active low.                       |                |  |
| STAT_MUX_OUT(4)                       | In                    | Power on reset signal which determines if        | CMOS3V3        |  |
| [maps to ->                           |                       | output port timeouts are enabled at start-up.    |                |  |
| POR_TIMEOUT_EN_N]                     |                       | When asserted (low) the port timeouts are        |                |  |
|                                       |                       | enabled. When de-asserted (high) they are        |                |  |
|                                       |                       | disabled.                                        |                |  |
|                                       |                       | This signal is active low.                       |                |  |
| STAT_MUX_OUT(5)                       | In                    | Power on reset value which determines the        | CMOS3V3        |  |
| [maps to ->                           |                       | initial timeout value. The following values      |                |  |
| POR_SEL_TIMEOUT0_N]                   |                       | determine which timeout is selected at power up. |                |  |
|                                       |                       |                                                  |                |  |
|                                       |                       | '1' => Timeout period is ~ 100 us.               |                |  |
|                                       |                       | '0' => Timeout period is ~ 1.3 s.                |                |  |



Ref.: UoD\_SpW-10X\_ DataSheet

DataSi

🔞 Austrian Aerospace

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|                         |    | Timeout Period is:<br>'1' => 200x(2^2)x(10 MHz clk period) |         |
|-------------------------|----|------------------------------------------------------------|---------|
|                         |    | '0' => 200x(2^16)x(10 MHz clk period)                      |         |
| STAT_MUX_OUT(6)         | In | Power on reset signal which determines if the              | CMOS3V3 |
| [maps to ->             |    | output ports automatically start up when they              |         |
| POR_START_ON_REQ_N]     |    | are the destination address of a packet.                   |         |
|                         |    | When asserted (low) the output port will                   |         |
|                         |    | automatically start on request.                            |         |
|                         |    | This signal is active low.                                 |         |
| STAT_MUX_OUT(7)         | In | Power on reset signal which determines if the              | CMOS3V3 |
| [maps to ->             |    | output ports are disabled when no activity is              |         |
| POR_DSBLE_ON_SILENCE_N] |    | detected on an output port for the current                 |         |
|                         |    | timeout period.                                            |         |
|                         |    | When asserted (low) an output port is                      |         |
|                         |    | disabled when it has not sent any information              |         |
|                         |    | for longer than the current timeout period.                |         |
|                         |    | This signal is active low.                                 |         |



Figure 4-1 Configuration interface timing specification

The POR configuration signals (POR\_SIGNALS) listed in Table 4-6 are loaded into the appropriate internal configuration registers of the router after **RST** is de-asserted. To make sure that the POR configuration signal values are loaded properly they should be held stable for at least three **CLK** cycles following **RST** being de-asserted. The status output **STAT\_MUX\_OUT** is driven on the fourth **CLK** cycle after **RST** is de-asserted.

Note: The recommended method for setting the POR signals is to use external pull up/down resistors in which case the timing of the POR signals is not critical.



Ref.:

UoD\_SpW-10X\_

18<sup>th</sup> August 2006 Date:

# 4.7 POWER AND GROUND SIGNALS

The Power and Ground connections are listed in Table 4-6.

|        | Table 4-7 Reset Configuration Signals |                                  |                |  |  |
|--------|---------------------------------------|----------------------------------|----------------|--|--|
| Signal | Dir                                   | Description                      | Signal<br>Type |  |  |
| Power  | -                                     | 3.3 V power for the device       | 3V3            |  |  |
| Ground | -                                     | Ground connection for the device | GND            |  |  |



#### 5. INTERFACE OPERATIONS

#### 5.1 EXTERNAL PORT INTERFACE OPERATION

In this section the external port interface operation is defined.



Figure 5-1 External port write timing specification

The operation of the External port during write operations starts with the EXT\_IN\_FULL\_N signals being de-asserted by the router (at clock cycle 2 in Figure 5-1) to indicate to the external system that the router has room for more data and is ready to receive it through the External port. The External system then puts data onto the EXT\_IN\_DATA data lines and asserts EXT\_IN\_WRITE\_N to transfer data into the External port on the next rising edge of SYSCLK. As long as there is room for new data (EXT\_IN\_FULL\_N is inactive) the writer access is performed as long as EXT\_IN\_WRITE\_N is active. If no room is available the write access is ignored (cycle 9 and 10 in Figure 5-1) and will be performed when room has become available if EXT\_IN\_WRITE\_N is still active. Therefore the data (EXT\_IN\_DATA) must be valid at that time.



Figure 5-2 External port read timing specification

Reading of the External port is illustrated in Figure 5-2. When data is available in the External port FIFO then it is placed on the **EXT\_OUT\_DATA** bus and the **EXT\_OUT\_EMPTY\_N** signal is asserted to signal to the external system that data is available. This is done synchronously to the **SYSCLK** signal (e.g. clock cycle 2 in Figure 5-2). When it is ready the external system asserts the

| ANT WARMENT OF     |                  | Ref.:  | UoD_SpW-10X_                 |
|--------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM    | SpaceWire Router |        | DataSheet                    |
| Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
|                    |                  | Date:  | 18 <sup>th</sup> August 2006 |

**EXT\_OUT\_READ\_N** signal synchronously with the **SYSCLK** signal (e.g. clock cycle 3) and the data is then read out of the external port on the next rising edge of the **SYSCLK** (e.g. start of clock cycle 4). If there is no more data available in the FIFO then the **EXT\_OUT\_EMPTY\_N** is de-asserted once the data has been read. If the FIFO contains more data to transfer then the **EXT\_OUT\_EMPTY\_N** remains asserted, the new data is placed on the **EXT\_OUT\_DATA** bus and the external system can read it as soon as it is ready. The read access is ignored if there is no data available (**EXT\_OUT\_EMPTY\_N** is active).

# 5.2 TIME-CODE INTERFACE OPERATION

In this section the time-code interface operation is defined.



#### Figure 5-3 Time-Code Input Interface

Time-codes can be generated by the router on request of the external system to which it is attached. A time-code is generated whenever the router detects a rising edge on the. The value of the time-code to be transmitted is either taken from the inputs or from the time-code counter inside the router. The time-code source used depends on the value of the SEL\_EXT\_TIME signal when EXT\_TICK\_IN signal has a rising edge. If SEL\_EXT\_TIME is 1 then the EXT\_TIME\_IN(7:0) inputs are used to provide the contents of the time-code. If SEL\_EXT\_TIME is 0 then the internal time-code counter provides the least-significant 6-bits of the time-code and the EXT\_TIME\_IN(7:6) inputs provide the most-significant 2-bits. When using the EXT\_TIME\_IN(7:0) inputs to provide the complete time-code, the time-code is only broadcast if it is a valid time-code i.e. is one more than the internal time register of the router (see SpaceWire standard [AD1]). Note that only one router or node in a SpaceWire network should operate as a time master generating time codes (see SpaceWire standard [AD1]).



Figure 5-4 Time-Code Output Interface

When a valid time-code is received by the router the value of this time-code (flags plus time value) will be placed on the **EXT\_TIME\_OUT** outputs and the **EXT\_TICK\_OUT** signal will be set to zero. The **EXT\_TICK\_OUT** signal is set to one a short time later, once the **EXT\_TIME\_OUT** outputs have

| different of          |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
|                       | Data-Sheet       | Issue: | 2.0                          |
| () Austrian Aerospace | Data-Sheet       | Date:  | 18 <sup>th</sup> August 2006 |
|                       |                  |        |                              |

stabilised, to indicate that these outputs are valid. They then remain valid until the next time-code is received and the **EXT\_TICK\_OUT** signal will be set to zero.



#### Figure 5-5 Time-code reset interface

When a rising edge is detected on **TIME\_CTR\_RST** then the time-code register is reset to zero.

#### 5.3 ERROR/STATUS ERROR INDICATION INTERFACE OPERATION

The **STAT\_MUX\_ADDR** signal determines the output status on **STAT\_MUX\_OUT** as shown in Figure 5-6 and in Table 5-1.



Figure 5-6 Status Multiplexer output interface

When **STAT\_MUX\_ADDR** is stable **STAT\_MUX\_OUT** is output from after each clock edge.



Ref.: UoD\_SpW-10X\_

DataSheet

Issue: 2.0

🔞 Austrian Aerospace

Data-Sheet

Date: 18<sup>th</sup> August 2006

|             | Table 5-1 Mul      | tiplexed Status Pins Bit Assign | ment                    |                          |
|-------------|--------------------|---------------------------------|-------------------------|--------------------------|
| Mux Address | Status Register    | Status Signal                   | Status<br>Register Bits | Status<br>Output<br>Bits |
| 0           | Configuration Port | Packet return address error     | 1                       | 0                        |
|             |                    | Output port timeout error       | 2                       | 1                        |
|             |                    | Checksum error                  | 3                       | 2                        |
|             |                    | Packet too short error          | 4                       | 3                        |
|             |                    | Packet too long error           | 5                       | 4                        |
|             |                    | Packet EEP termination          | 6                       | 5                        |
|             |                    | Protocol byte error             | 7                       | 6                        |
|             |                    | Invalid address/data error      | 8                       | 7                        |
| 1 - 8       | SpaceWire Ports    | Packet Address Error            | 1                       | 0                        |
|             | 1 - 8 respectively | Output Port Timeout             | 2                       | 1                        |
|             |                    | Disconnect Error                | 3                       | 2                        |
|             |                    | Parity Error                    | 4                       | 3                        |
|             |                    | Escape Error                    | 5                       | 4                        |
|             |                    | State A                         | 8                       | 5                        |
|             |                    | State B                         | 9                       | 6                        |
|             |                    | State C                         | 10                      | 7                        |
| 9 - 10      | External Ports     | Error Active                    | 0                       | 0                        |
|             | 0 - 1 respectively | Packet Address Error            | 1                       | 1                        |
|             |                    | Output Port Timeout             | 2                       | 2                        |
|             |                    | Input Buffer Empty              | 3                       | 3                        |
|             |                    | Input Buffer Full               | 4                       | 4                        |
|             |                    | Output Buffer Empty             | 5                       | 5                        |
|             |                    | Output Buffer Full              | 6                       | 6                        |
| 11          | Network Discovery  | Return port                     | 7:4                     | 7:4                      |
|             | Router Identity    | Least-significant 4-bits        | 3:0                     | 3:0                      |
| 12          | Router Control     | Timeout Enable                  | 0                       | 0                        |

| EADS   | DUNDER    | Applied Computing |
|--------|-----------|-------------------|
| 🚳 Aust | rian Aero | ospace            |

Issue: 2.0 Date: 18<sup>th</sup> August 2006

|    |                 | Timeout Selection         | 3:1   | 3:1  |
|----|-----------------|---------------------------|-------|------|
|    |                 | Enable Disable-on-Silence | 4     | 4    |
|    |                 | Enable Start-on-Request   | 5     | 5    |
|    |                 | Enable Self-Addressing    | 6     | 6    |
| 13 | Error Active    | Configuration Port Error  | 0     | 0    |
|    |                 | SpaceWire Ports 1-5 Error | 5 :1  | 5 :1 |
|    |                 | External Ports 1,2 Error  | 10 :9 | 7 :6 |
| 14 | Time-code       | Time-code                 | 7:0   | 7:0  |
| 15 | General Purpose | Least Significant 8-bits  | 7:0   | 7:0  |

# 5.4 RESET CONFIGURATION INTERFACE OPERATION



#### Figure 5-7 Reset configuration interface timing specification

The POR configuration signals (POR\_SIGNALS) listed above are loaded into the appropriate internal configuration registers of the router on the first rising edge of the system clock, **SYSCLK**, after **RST** is de-asserted. To make sure that the POR configuration signal values are loaded properly they should be held stable for at least two **CLK** cycles following **RST** being de-asserted.



### 6. SWITCHING CHARACTERISTICS

### 6.1 CLOCK AND RESET TIMING PARAMETERS

The global clock and asynchronous reset timing parameters are listed below.

| Table 6-1 Clock and reset timing parameters |                      |         |         |  |
|---------------------------------------------|----------------------|---------|---------|--|
| Description                                 | Symbol               | Value   | Units   |  |
| Clock period minimum value                  | T <sub>CL</sub>      |         | ns, min |  |
| Clock period maximum value                  | Т <sub>СН</sub>      |         | ns, max |  |
| Clock input jitter                          | T <sub>CJITTER</sub> | +/- 300 | ps, max |  |
| Reset minimum period                        | T <sub>ARST</sub>    |         | ns, min |  |

#### 6.2 SERIAL SIGNALS TIMING PARAMETERS

The data strobe minimum consecutive edge separation timing parameter is defined as shown in the figure below.





The serial signal timing parameters are defined in the table below.

| Table 6-2 Serial signal timing parameters |                      |       |              |  |
|-------------------------------------------|----------------------|-------|--------------|--|
| Description                               | Symbol               | Value | Units        |  |
| DS maximum input bit rate                 | T <sub>DS</sub>      | 200   | Mbits/s, max |  |
| DS minimum consecutive edge separation    | T <sub>DSINS</sub>   | 1.5   | ns, min      |  |
| Data Strobe output skew                   | T <sub>DSOSKEW</sub> | 0.5   | ns, max      |  |



### 6.3 EXTERNAL PORT TIMING PARAMETERS

The external port input timing parameters can be viewed below



#### Figure 6-2 External port input FIFO timing parameters

The external port input timing parameters can be viewed below



#### Figure 6-3 External port output FIFO timing parameters

| Table 6-3 External port timing parameters    |                         |       |         |  |
|----------------------------------------------|-------------------------|-------|---------|--|
| Description                                  | Symbol                  | Value | Units   |  |
| Write enable setup time to CLK rising edge   | T <sub>EXTWRSU</sub>    | 3.6   | ns, min |  |
| Write enable hold time after CLK rising edge | T <sub>EXTWRHLD</sub>   | 0     | ns, min |  |
| Write data setup time to CLK rising edge     | T <sub>EXTIDATSU</sub>  | 3     | ns, min |  |
| Write data hold time after CLK rising edge   | T <sub>EXTIDATHLD</sub> | 1.5   | ns, min |  |
| CLK rising edge to full flag output          | T <sub>EXTFFCKO</sub>   | 11    | ns, max |  |
| Read enable setup time to CLK rising edge    | T <sub>EXTRDSU</sub>    | 3     | ns, min |  |
| Read enable hold time after CLK rising edge  | T <sub>EXTRDHLD</sub>   | 0.8   | ns, min |  |
| CLK rising edge to read data output          | T <sub>EXTODATCKO</sub> | 8.7   | ns, max |  |
| CLK rising edge to empty flag output         | T <sub>EXTEFCKO</sub>   | 11.2  | ns, max |  |

| Stateman of the stateman |                  | Ref.:  | UoD_SpW-10X_                 |
|--------------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM          | SpaceWire Router |        | DataSheet                    |
|                          | Data-Sheet       | Issue: | 2.0                          |
| 🕘 Austrian Aerospace     | Data-Oneet       | Date:  | 18 <sup>th</sup> August 2006 |

### 6.4 TIME-CODE INTERFACE TIMING PARAMETERS

The following diagrams define the timing parameters for the time-code input and output



#### Figure 6-4 Time-Code Input Interface



#### Figure 6-5 Time-Code Output Interface



#### Figure 6-6 Time-code TIME\_CTR\_RST interface

The Time-code timing parameters are shown below.

| Table 6-4 Time-code interface timing parameters   |                       |       |         |  |  |
|---------------------------------------------------|-----------------------|-------|---------|--|--|
| Description                                       | Symbol                | Value | Units   |  |  |
| Tick-in and time reset low time                   | T <sub>TCLKIL</sub>   | 500   | ns, min |  |  |
| Tick-in and time reset high time                  | T <sub>TCLKIH</sub>   | 500   | ns, min |  |  |
| Select external time and Time-code in set-up time | T <sub>TCLKISU</sub>  | 2.7   | ns, max |  |  |
| Select external time and Time-code in hold time   | T <sub>TCLKIHLD</sub> | 0.1   | ns, max |  |  |
| Tick-out low time                                 | T <sub>TCLKOL</sub>   | 500   | ns, min |  |  |
| Tick-out high time                                | T <sub>TCLKOH</sub>   | 500   | ns, min |  |  |



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet Issue: 2.0

Date: 18<sup>th</sup> August 2006

| Time-code output valid delay time | T <sub>TCLKOE</sub> | 1 | ns, max |
|-----------------------------------|---------------------|---|---------|
|-----------------------------------|---------------------|---|---------|

# 6.5 ERROR/STATUS INTERFACE TIMING PARAMETERS

The timing parameters for the status multiplexer port are show below.

| Table 6-5 Status Multiplexer timing parameters |                    |       |         |  |  |
|------------------------------------------------|--------------------|-------|---------|--|--|
| Description                                    | Symbol             | Value | Units   |  |  |
| Status address change to status output change  | T <sub>STMUX</sub> | 20.6  | ns, max |  |  |



**Data-Sheet** 

# 6.6 LATENCY AND JITTER

The timing parameters for the data and time-code latency and the time-code jitter are derived from the receive clock, transmit clock and system clock period. The worst case number of clock cycles required is used in each equation.

In the SpaceWire router the system clock is a known frequency and the transmitter and receiver frequency are derived from the input and output bit rates. The clock frequencies are defined as follows.

Note: All figures are worst case. Due to the uncertainty of synchronisation between clock domains the measured time may be less than indicated.

In the following sections the clock periods are defined and the latency and jitter timing parameter definitions are detailed.

### 6.6.1 Clock Periods

### System Clock Period

T<sub>SYSPERIOD</sub> = 33.333 ns (Clock Frequency = 30 MHz)

### **Transmit Clock Period**

 $T_{TXPERIOD}$  = Transmit bit rate period \* 2 (Where Transmit bit rate period is the output bit rate selected by the user configuration)

### **Receive Clock Period**

T<sub>RXPERIOD</sub> = Receive bit rate period \* 2 (Where Receive bit rate period is the period of the input bit rate)

### 6.6.2 Switching Latency

Switching latency is the time it takes the router to connect a waiting input port to an output port that has just finished sending a packet. It includes any time for group adaptive routing and arbitration of two or more input ports competing for the same output port.

Switching latency for the router is defined as follows

 $T_{SWITCH} = 4 \times T_{SYSPERIOD}$ 

### 6.6.3 Router Latency

Router latency is the time taken for a character in a packet to pass through the router assuming that the packet has already been switched to an output port and that there is no blocking of the output port. Router latency for the SpaceWire router is defined for port to port data transfer operations as follows:

### SpaceWire port to SpaceWire port



Last bit of data into receiver to last bit of data out of transmitter (Worst case where transmitter is sending a time-code and FCT character before data)

 $T_{SSDATA} = (5 \times T_{RXPERIOD}) + (8 \times T_{SYSPERIOD}) + (23 \times T_{TXPERIOD})$ 

### SpaceWire port to External port

Last bit of data into receiver to external port not empty flag

 $T_{SEDATA} = (5 \times T_{RXPERIOD}) + (8 \times T_{SYSPERIOD})$ 

### External port to SpaceWire port

External port write enable to last bit of data out of transmitter (Worst case where transmitter is sending a time-code and FCT character before data)

 $T_{ESDATA} = (4 \times T_{SYSPERIOD}) + (23 \times T_{TXPERIOD})$ 

### External port to External port

External port write enable to external port not empty flag.

$$T_{EEDATA} = (5 \times T_{SYSPERIOD})$$

### 6.6.4 Time-code Latency

The maximum time taken to propagate a time code through a routing switch

### SpaceWire port to SpaceWire port

Last bit of time-code into receiver to last bit of time-code out of transmitter (worst case where transmitter has started sending a before time-code data character)

 $T_{SSTC} = (5 \times T_{RXPERIOD}) + (6 \times T_{SYSPERIOD}) + (16 \times T_{TXPERIOD})$ 

### SpaceWire port to External port

Last bit of time-code into receiver to external port EXT\_TICK\_OUT rising edge

 $T_{SETC} = (5 \times T_{RXPERIOD}) + (8 \times T_{SYSPERIOD})$ 

### External port to SpaceWire port

EXT\_TICK\_IN rising edge to last bit of time-code out of transmitter (worst case where transmitter has started sending a before time-code data character)

 $T_{ESTC} = (6 \times T_{SYSPERIOD}) + (16 \times T_{TXPERIOD})$ 

| UNIVERSITY Q          |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
| W Austrian Aerospace  |                  | Date:  | 18 <sup>th</sup> August 2006 |

### 6.6.5 Time-code Jitter

The variation in time to propagate a time-code through a routing switch.

Time-code jitter occurs in the synchronisation handshaking circuits and the transmitter where the maximum delay time the time-code has to wait to be transmitted is one data character. The jitter is measured as

 $T_{TCJIT} = (2 \times T_{SYSPERIOD}) + (5 \times T_{TXPERIOD})$ 

### 6.6.6 200M bits/s Input and Output Bit Rate Example

The following table defines the latency and jitter measurements when the transmit bit rate and receive bit rate are 200M bits/s.

| Table 6-6 SpaceWire Router Latency and Jitter Measurements (Bit rate = 200Mbits/s |                     |       |         |  |  |  |
|-----------------------------------------------------------------------------------|---------------------|-------|---------|--|--|--|
| Description                                                                       | Symbol              | Value | Units   |  |  |  |
| Switching Latency                                                                 | T <sub>SWITCH</sub> | 133.3 | ns, max |  |  |  |
| Router Latency – SpaceWire to SpaceWire port                                      | T <sub>SSDATA</sub> | 546.6 | ns, max |  |  |  |
| Router Latency – SpaceWire to External port                                       | T <sub>SEDATA</sub> | 316.6 | ns, max |  |  |  |
| Router Latency – External to SpaceWire port                                       | T <sub>ESDATA</sub> | 363.3 | ns, max |  |  |  |
| Router Latency – External to External port                                        | T <sub>EEDATA</sub> | 166.6 | ns, max |  |  |  |
| Time-code Latency – SpaceWire to SpaceWire port                                   | T <sub>SSTC</sub>   | 409.3 | ns, max |  |  |  |
| Time-code Latency – SpaceWire to External port                                    | T <sub>SETC</sub>   | 316.6 | ns, max |  |  |  |
| Time-code Latency – External to SpaceWire port                                    | T <sub>ESTC</sub>   | 359.9 | ns, max |  |  |  |
| Time-code Jitter                                                                  | T <sub>TCJIT</sub>  | 116.6 | ns, max |  |  |  |

[1] Note all figures are worst case



### Data-Sheet

# 7. ELECTRICAL CHARACTERISTICS

The electrical characteristics for the SpaceWire router are defined in this section

### 7.1 ABSOLUTE MAXIMUM RATINGS

TBD

### 7.2 DC CHARACTERISTICS

TBD

### 7.3 OPERATING TEMPERATURE RANGE

TBD



Data-Sheet

### 8. SPACEWIRE ROUTER PACKET TYPES

This section defines how the routing control logic interprets packets.

# 8.1 PACKET ADDRESSES

The routing control logic interprets the first byte of each received packet as the packet address. The packet address defines the physical ports through which the routing control logic will use to route the packet towards its destination.

Packets which have a path address (0-31) as the first byte are always routed to the corresponding physical port number on the router. Packets which have a logical address (32-255) are routed to physical ports dependent on the contents of the routing table. The internal SpaceWire router routing table can be set up to assign logical addresses to the physical ports, except the configuration port (port 0) which can only be accessed by path addressing

The physical port addresses for the SpaceWire router and the expected packet type is defined in the table below. The packet types can be viewed in section 5.

| Table 8-1 Packet Address Mapping |                      |                       |  |  |  |
|----------------------------------|----------------------|-----------------------|--|--|--|
| Packet Address                   | Expected Packet Type | Physical Port type    |  |  |  |
| 0                                | Command packet       | Configuration port    |  |  |  |
| 1                                | Any type             | SpaceWire link port 1 |  |  |  |
| 2                                | Any type             | SpaceWire link port 2 |  |  |  |
| 3                                | Any type             | SpaceWire link port 3 |  |  |  |
| 4                                | Any type             | SpaceWire link port 4 |  |  |  |
| 5                                | Any type             | SpaceWire link port 5 |  |  |  |
| 6                                | Any type             | SpaceWire link port 6 |  |  |  |
| 7                                | Any type             | SpaceWire link port 7 |  |  |  |
| 8                                | Any type             | SpaceWire link port 8 |  |  |  |
| 9                                | Any type             | External FIFO port 1  |  |  |  |
| 10                               | Any type             | External FIFO port 2  |  |  |  |
| 11-31                            | N/A                  | Invalid addresses     |  |  |  |
| 32-255                           | Any type             | Logical addresses     |  |  |  |

Note that logical address 255 is reserved in the SpaceWire standard [AD1].

### 8.2 PACKET PRIORITY

Each packet which is input to the router has an associated priority level, either as a result of the packet address or the internal routing table. Two priority levels HIGH and LOW are supported.



Data-Sheet

The table below defines the priority levels for packet addresses

| Table 8-2 Packet Priority Mapping |                                       |                       |  |  |  |
|-----------------------------------|---------------------------------------|-----------------------|--|--|--|
| Packet Address                    | Packet Priority                       | Physical Port type    |  |  |  |
| 0                                 | HIGH                                  | Configuration port    |  |  |  |
| 1                                 | HIGH                                  | SpaceWire link port 1 |  |  |  |
| 2                                 | HIGH                                  | SpaceWire link port 2 |  |  |  |
| 3                                 | HIGH                                  | SpaceWire link port 3 |  |  |  |
| 4                                 | HIGH                                  | SpaceWire link port 4 |  |  |  |
| 5                                 | HIGH                                  | SpaceWire link port 5 |  |  |  |
| 6                                 | HIGH                                  | SpaceWire link port 6 |  |  |  |
| 7                                 | HIGH                                  | SpaceWire link port 7 |  |  |  |
| 8                                 | HIGH                                  | SpaceWire link port 8 |  |  |  |
| 9                                 | HIGH                                  | External FIFO port 1  |  |  |  |
| 10                                | HIGH                                  | External FIFO port 2  |  |  |  |
| 11-31                             | N/A                                   | Invalid addresses     |  |  |  |
| 32-255                            | Dependent on routing table            | Logical addresses     |  |  |  |
|                                   | - Default LOW                         |                       |  |  |  |
|                                   | - May be configured HIGH (see section |                       |  |  |  |
|                                   | 10.3)                                 |                       |  |  |  |

### 8.3 PACKET HEADER DELETION

Header deletion is performed on packets dependent on the packet address. Packets which have path addresses or logical addresses which have the header deletion bit set in the routing table have the header address byte removed before the packet is routed to the destination.

The table below defines the header deletion settings for each address.



Ref.: UoD\_SpW-10X\_

DataSheet

2.0

Issue:

Austrian Aerospace

Data-Sheet

Date: 18<sup>th</sup> August 2006

| Packet Address | Header Deletion                                  | Physical Port type    |
|----------------|--------------------------------------------------|-----------------------|
| 0              | Enabled                                          | Configuration port    |
| 1              | Enabled                                          | SpaceWire link port 1 |
| 2              | Enabled                                          | SpaceWire link port 2 |
| 3              | Enabled                                          | SpaceWire link port 3 |
| 4              | Enabled                                          | SpaceWire link port 4 |
| 5              | Enabled                                          | SpaceWire link port 5 |
| 6              | Enabled                                          | SpaceWire link port 6 |
| 7              | Enabled                                          | SpaceWire link port 7 |
| 8              | Enabled                                          | SpaceWire link port 8 |
| 9              | Enabled                                          | External FIFO port 1  |
| 10             | Enabled                                          | External FIFO port 2  |
| 11-31          | N/A                                              | Invalid addresses     |
| 32-255         | Dependent on routing table (default not enabled) | Logical addresses     |

Note that header deletion is always enabled for path addresses and cannot be changed by configuration. Header deletion for logical addresses can be enabled or disabled via a configuration register (see section 10.3).

### 8.4 INVALID ADDRESSES

Packets which have invalid addresses are discarded by the routing control logic. Path addresses which are in the range 11-31, logical addresses which are set as invalid in the routing table and empty packets (packets with no address or cargo) input to the external port are flagged as invalid packet addresses.

A packet address error is also generated when a packet address causes the packet to be routed back through the port on which the packet was received, i.e. a loop-back, and the router control register bit address self is not enabled.

When an invalid address packet is received by the router then the routing control logic flags the error to the corresponding port status register, spills the packet address, data and end of packet marker and waits for the next packet.

### 8.5 DATA PACKETS

Packets which have addresses in the range 1 to 255 are routed to the SpaceWire ports and the external ports dependent on the packet address. Data packets have an address header byte a cargo field and an end of packet marker. The normal packet structure is show below.

|   |                  | plied Computing<br>ace | SpaceWire Router Data-Sheet |  | Ref.:<br>Issue<br>Date: | UoD_SpW-10X_<br>DataSheet<br>2.0<br>18 <sup>th</sup> August 2006 |
|---|------------------|------------------------|-----------------------------|--|-------------------------|------------------------------------------------------------------|
| ← | ADDRESS<br>1-255 |                        | CARGO                       |  | EOP/EEP                 |                                                                  |

Figure 8-1 Normal router data packets

### 8.6 COMMAND PACKETS

Command packets are routed to the internal configuration port when the packet address is zero. Command packets perform write and read operations to registers in the SpaceWire router. Command packets accepted by the SpaceWire router are in the form shown in Figure 8-2.

Configuration read packets are in the form:

| ← | ADDRESS<br>0 | COMMAND | EOP |  |
|---|--------------|---------|-----|--|
|---|--------------|---------|-----|--|

### Figure 8-2 Command Packet Format

The SpaceWire router supports the Remote Memory Access Protocol (RMAP) [AD2] for configuration of the internal router control registers and monitoring of the router status.

The following sections define the RMAP commands which are supported and the format of the RMAP commands used by the SpaceWire Router.

### 8.6.1 Supported Commands

The RMAP Command set is listed in Table 8-4 and the supported RMAP commands are defined. The commands which are not used are depicted with a grey background.



Ref.: UoD\_SpW-10X\_

DataSheet

2.0

Issue:

🚳 Austrian Aerospace

Data-Sheet

Date: 18<sup>th</sup> August 2006

| RMAP Command<br>Code | Description                                                | Supported in SpaceWire<br>Router |  |
|----------------------|------------------------------------------------------------|----------------------------------|--|
| "0000"               | Not used                                                   | -                                |  |
| "0001"               | Not used                                                   | -                                |  |
| "0010"               | Read single address                                        | Yes                              |  |
| "0011"               | Read incrementing address                                  | Yes                              |  |
| "0100"               | Not used                                                   | -                                |  |
| "0101"               | Not used                                                   | -                                |  |
| "0110"               | Not used                                                   | -                                |  |
| "0111"               | Read-modify-write incrementing address                     | Yes                              |  |
| "1000"               | Write single address, no verify, no acknowledge            | No                               |  |
| "1001"               | Write incrementing address, no verify, no acknowledge.     | No                               |  |
| "1010"               | Write single address, no verify, send acknowledge          | No                               |  |
| "1011"               | Write incrementing address, no verify, send acknowledge.   | No                               |  |
| "1100"               | Write single address, verify data, no acknowledge          | No                               |  |
| "1101"               | Write incrementing address, verify data, no acknowledge.   | No                               |  |
| "1110"               | Write single address, verify data, send acknowledge        | Yes                              |  |
| "1111"               | Write incrementing address, verify data, send acknowledge. | No                               |  |

# 8.6.2 Read Command

The read single address characteristics of the SpaceWire router are defined in Table 8-5.



Ref.: UoD\_SpW-10X\_

DataSheet

🔞 Austrian Aerospace

Data-Sheet

Date: 18<sup>th</sup> August 2006

2.0

Issue:

| Action                     | Supported/                      | Maximum number | Non-aligned access |  |  |
|----------------------------|---------------------------------|----------------|--------------------|--|--|
|                            | Not Supported                   | of bytes       | accepted           |  |  |
| 8-bit read                 | NS                              | -              | -                  |  |  |
| 16-bit read                | NS                              | -              | -                  |  |  |
| 32-bit read                | S                               | 4              | No                 |  |  |
| 64-bit read                | NS                              | -              | -                  |  |  |
| Word or byte address       | 32-bit aligned                  |                |                    |  |  |
| Accepted Logical Addresses | 0xFE                            |                |                    |  |  |
| Accepted destination keys  | 0x20 at power on.               |                |                    |  |  |
| Accepted address ranges    | 0x00 0000 0000 – 0x00 0000 0109 |                |                    |  |  |
| Address Incrementation     | No                              |                |                    |  |  |

The RMAP read single address command is supported in the SpaceWire router. The single address command is used to read a single 32 bit register location from the router registers.

In Figure 8-3 the format of a read single address command is illustrated. The first byte received by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional.

|                      |                        |                 |                               |                               |                             | First Byte Re        |             |
|----------------------|------------------------|-----------------|-------------------------------|-------------------------------|-----------------------------|----------------------|-------------|
|                      |                        |                 |                               |                               |                             | Config Port A<br>00h | ddress      |
| Destination Lo<br>FE | gical Address<br>Eh    | Protocol<br>01  |                               | Packet Type<br>Source Pat     | e, Command<br>h Addr Len    | Destination          | Key         |
| Source Pa            | th Address             | Source Pa       | th Address                    | Source Pa                     | th Address                  | Source Path A        | ddress      |
| Source Logi          | Source Logical Address |                 | Transaction Identifier (MS) T |                               | Transaction Identifier (LS) |                      | Address     |
| Read Add<br>00       |                        | Read A<br>00    |                               | Read Address Read Address (L3 |                             | Read Address (LS)    |             |
| Data Len<br>0(       |                        |                 | .ength<br>)h                  | Data Ler<br>04                | ngth (LS)<br>Ih             | Header CRC           |             |
| EOP                  |                        |                 |                               |                               |                             | Last Byte Red        | ceived      |
|                      |                        |                 |                               |                               |                             |                      |             |
| Bits in Packet       | Type / Comma           | nd / Source Pat | h Address Leng                | gth Byte                      |                             |                      |             |
| MSB                  |                        |                 |                               |                               |                             |                      | LS          |
|                      | 1                      | 0               | 0                             | 1                             | 0                           | Source Path          | Source Path |

Figure 8-3 Read Single Address Command Format



Ref.: UoD\_SpW-10X\_ DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| Table 8-6 Read Single Address Command Packet Fields |                                                                               |          |  |  |
|-----------------------------------------------------|-------------------------------------------------------------------------------|----------|--|--|
| Field                                               | Description                                                                   | Bytes    |  |  |
| Config Port                                         | The configuration port address field routes the packet to the configuration   | 1        |  |  |
| Address                                             | port of the router. The configuration port address (00h) is always present    |          |  |  |
|                                                     | when configuring the SpaceWire Router.                                        |          |  |  |
| Destination                                         | The destination logical address field is not used in the SpaceWire Router.    | 1        |  |  |
| Logical                                             | The SpaceWire router accepts packets which have the default destination       |          |  |  |
| Address                                             | logical address of 254h (FEh).                                                |          |  |  |
| Protocol                                            | The RMAP protocol identifier is 01h.                                          | 1        |  |  |
| Identifier                                          |                                                                               |          |  |  |
| Command                                             | The command byte indicates a read single address packet. The Source path      | 1        |  |  |
| Byte                                                | address length fields are set to the number of source path addresses          |          |  |  |
|                                                     | required as defined in section 8.6.9.                                         |          |  |  |
| Destination                                         | The destination key identifier must match the contents of the destination key | 1        |  |  |
| Key                                                 | register, see section 10.5.10. The default (power-on) destination key is 20h. |          |  |  |
| Source                                              | The source path address field is used to add source path addresses to the     | 0,4,8,12 |  |  |
| Path                                                | head of the reply packet. The expected number of source path addresses is     |          |  |  |
| Address                                             | specified in the command byte. See section 8.6.9 for source path address      |          |  |  |
|                                                     | decoding.                                                                     |          |  |  |
| Source                                              | The source logical address should be set to the logical address of the node   | 1        |  |  |
| Logical                                             | which sent the command.                                                       |          |  |  |
| Address                                             |                                                                               |          |  |  |
| Transaction                                         | The transaction identifier identifies the command packet and reply packet     | 2        |  |  |
| Identifier                                          | with a unique number.                                                         |          |  |  |
| Extended                                            | The extended read address is not used in the SpaceWire router and shall       | 1        |  |  |
| Read                                                | always be set to zero.                                                        |          |  |  |
| Address                                             |                                                                               |          |  |  |
| Read                                                | The read address identifies the register address to read from. The valid read | 4        |  |  |
| Address                                             | addresses are defined in section 0.                                           |          |  |  |
| Data                                                | The data length of a read single address command shall be set to 4 to read    | 3        |  |  |
| Length                                              | one 32 bit register location.                                                 |          |  |  |

| JUST BEELTT GA       |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🔇 Austrian Aerospace | Data-Oneet       | Date:  | 18 <sup>th</sup> August 2006 |
|                      |                  |        |                              |

| Header | The header CRC is the eight bit CRC code used to detect errors in the | 1 |
|--------|-----------------------------------------------------------------------|---|
| CRC    | command packet. The CRC code is checked before the command is         |   |
|        | executed                                                              |   |
|        |                                                                       |   |

In Figure 8-4 the format of the reply to a read single address command is illustrated. The first byte sent by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional. Note that the reply is always sent out of the same port as the command was received on. The Source Path Address should not include the output port of the router being commanded as the reply will be automatically sent out of the same port that the command arrived on. See section 8.6.8.

|                                    | First byte t | ransmitted           |                                               |                     |
|------------------------------------|--------------|----------------------|-----------------------------------------------|---------------------|
| •                                  | Source       | Path Address         | Source Path Address                           | Source Path Address |
| Source Logical Address             |              | ol Identifier<br>01h | Packet Type, Command,<br>Source Path Addr Len | Status              |
| Destination Logical Address<br>FEh | Transactio   | n Identifier (MS)    | Transaction Identifier (LS)                   | Reserved = 0        |
| Data Length (MS)<br>00h            |              | a Length<br>00h      | Data Length (LS)<br>04h                       | Header CRC          |
| Data (Word 0 MSB)                  |              | Data                 | Data                                          | Data (Word 0 LSB)   |
| Data CRC                           | EOP          |                      |                                               |                     |
|                                    | Last by      | te transmitted       |                                               |                     |
|                                    |              |                      |                                               |                     |

| Bits in Packet Type / Command / Source Address Path Length Byte |                     |   |   |   |   |                               |                               |  |
|-----------------------------------------------------------------|---------------------|---|---|---|---|-------------------------------|-------------------------------|--|
| MSB                                                             |                     |   |   |   |   |                               | LSB                           |  |
| 0                                                               | 0                   | 0 | 0 | 1 | 0 | Source Path<br>Address Length | Source Path<br>Address Length |  |
| Packe                                                           | Packet Type Command |   |   |   |   | Source Path A                 | ddress Length                 |  |

### Figure 8-4 Read Single Address Reply Packet Format

| Field      | Description                                                                  | Bytes |
|------------|------------------------------------------------------------------------------|-------|
| Source     | Optional source path addresses specified in the command packet. If no source | >=0   |
| Path       | path addresses are specified then the first byte will be the source logical  |       |
| Address    | address.                                                                     |       |
| Source     | The source logical address specified in the command packet. If source path   | 1     |
| Logical    | addresses are not used then the source logical address is the address of the |       |
| Address    | return packet.                                                               |       |
| Protocol   | The RMAP protocol identifier value 01h.                                      | 1     |
| Identifier |                                                                              |       |



Ref.: UoD\_SpW-10X\_ DataSheet

### Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| Command     | Read single address reply command byte. The packet type bits in the              | 1 |
|-------------|----------------------------------------------------------------------------------|---|
| Byte        | command byte indicate this packet is a response packet.                          |   |
| Status      | The command status is returned in this field. The command status can be          | 1 |
|             | command successful or an RMAP error code as defined in section 8.6.6.            |   |
| Destination | The destination logical address is set to the default value FEh as the           | 1 |
| logical     | SpaceWire router does not have a logical address.                                |   |
| address     |                                                                                  |   |
| Transaction | The transaction identifier identifies the command packet and reply packet with a | 2 |
| Identifier  | unique number. The transaction identifier in the reply packet is copied from the |   |
|             | command packet and returned in this field, so that the command and the           |   |
|             | corresponding reply have the same transaction identifier value.                  |   |
| Data        | The data length field is set to 4 bytes as this is a single read command.        | 3 |
| Length      |                                                                                  |   |
| Header      | The header CRC used to detect errors in the header part of the command           | 1 |
| CRC         | packet. See section 8.6.7 for CRC generation.                                    |   |
| Data        | The data read from the registers in the device.                                  | 4 |
| Data CRC    | The data CRC used to detect errors in the data part of the reply packet. See     | 1 |
|             | section 8.6.7 for CRC generation.                                                |   |

# 8.6.3 Read Incrementing Command

The read incrementing address characteristics of the SpaceWire router are defined in Table 8-8.



**Data-Sheet** 

Ref.: UoD\_SpW-10X\_

DataSheet

🔞 Austrian Aerospace

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| Table 8-8 Read Incrementing Address Characteristics |                                 |                            |                             |  |  |  |
|-----------------------------------------------------|---------------------------------|----------------------------|-----------------------------|--|--|--|
| Action                                              | Supported/<br>Not Supported     | Maximum number<br>of bytes | Non-aligned access accepted |  |  |  |
| 8-bit read                                          | NS                              | -                          | -                           |  |  |  |
| 16-bit read                                         | NS                              | -                          | -                           |  |  |  |
| 32-bit read                                         | S                               | 1064                       | No                          |  |  |  |
| 64-bit read                                         | NS                              | -                          | -                           |  |  |  |
| Word or byte address                                | 32-bit aligned                  |                            |                             |  |  |  |
| Accepted Logical Addresses                          | 0xFE                            |                            |                             |  |  |  |
| Accepted destination keys                           | 0x20 at power on                | 0x20 at power on           |                             |  |  |  |
| Accepted address ranges                             | 0x00 0000 0000 – 0x00 0000 0109 |                            |                             |  |  |  |
| Incrementing address                                | Incrementing address only       |                            |                             |  |  |  |

The RMAP read incrementing address command is supported in the SpaceWire router. The read incrementing address is used to read a continuous block of registers from the SpaceWire router, e.g. the complete group adaptive routing table can be read in one command or all the status registers for the SpaceWire links can be read in one command.

| APRIL AND A |                  | Ref.:  | UoD_SpW-10X_                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SpaceWire Router |        | DataSheet                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Data-Sheet       | Issue: | 2.0                          |
| 🕘 Austrian Aerospace                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Data-Oneet       | Date:  | 18 <sup>th</sup> August 2006 |

In Figure 8-5 the first byte received by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional.

|                                    |                             |                                              | First Byte Received          |
|------------------------------------|-----------------------------|----------------------------------------------|------------------------------|
|                                    |                             |                                              | Config Port Address<br>00h   |
| Destination Logical Address<br>FEh | Protocol Identifier<br>01h  | Packet Type, Command<br>Source Path Addr Len | Destination Key              |
| Source Path Address                | Source Path Address         | Source Path Address                          | Source Path Address          |
| Source Logical Address             | Transaction Identifier (MS) | Transaction Identifier (LS)                  | Extended Read Address<br>00h |
| Read Address (MS)<br>00h           | Read Address<br>00h         | Read Address                                 | Read Address (LS)            |
| Data Length (MS)<br>00h            | Data Length                 | Data Length (LS)                             | Header CRC                   |
| ЕОР                                |                             |                                              | Last Byte Received           |

Bits in Packet Type / Command / Source Path Address Length Byte

| MSB     |        |   |     |          |   |                | LSB            |
|---------|--------|---|-----|----------|---|----------------|----------------|
| 0       | 4      | 0 | 0   | 4        | 4 | Source Path    | Source Path    |
| U       | I.     | U | U   | I.       | 1 | Address Length | Address Length |
| A Packe | t Type | • | Com | mand ——— |   | Source Path A  | ddress Length  |

Figure 8-5 Read Incrementing Address Command Format

| Field       | Description                                                                 | Bytes |
|-------------|-----------------------------------------------------------------------------|-------|
| Config Port | The configuration port address field routes the packet to the configuration | 1     |
| Address     | port of the router. The configuration port address is always present when   |       |
|             | configuring the SpaceWire Router.                                           |       |
| Destination | The destination logical address is not used in the SpaceWire Router. The    | 1     |
| Logical     | SpaceWire router accepts packets which have the default destination logical |       |
| Address     | address of 254h (FEh).                                                      |       |
| Protocol    | The RMAP protocol identifier is 01h.                                        | 1     |
| Identifier  |                                                                             |       |
| Command     | The command byte indicates a read incrementing packet. The Source path      | 1     |
| Byte        | address length fields are set to the number of source path addresses        |       |
|             | required as defined in section 8.6.9.                                       |       |



Ref.: UoD\_SpW-10X\_ DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| Destination | The destination key identifier must match the contents of the destination key  | 1        |
|-------------|--------------------------------------------------------------------------------|----------|
| Key         | register, see section 10.5.10.                                                 |          |
| Source      | The source path address field is used to add source path addresses to the      | 0,4,8,12 |
| Path        | head of the reply packet. The expected number of source path addresses is      |          |
| Address     | specified in the command byte. See section 8.6.9 for source path address       |          |
|             | decoding.                                                                      |          |
| Source      | The source logical address should be set to the logical address of the node    | 1        |
| Logical     | which sent the command or it should be set to the default value of FEh.        |          |
| Address     |                                                                                |          |
| Transaction | The transaction identifier identifies the command packet and reply packet      | 2        |
| Identifier  | with a unique number.                                                          |          |
| Extended    | The extended read address is not used in the SpaceWire router and shall        | 1        |
| Read        | always be set to zero.                                                         |          |
| Address     |                                                                                |          |
| Read        | The read address identifies the start address for the read incrementing        | 4        |
| Address     | command. The valid starting read addresses are defined in section 0.           |          |
| Data        | The data length defines the number of bytes to read from the router. Valid     | 3        |
| Length      | data lengths are in the range 4-1064. 1064 allows the all the router registers |          |
|             | to be read in one command. If the data length field is not a multiple of four  |          |
|             | bytes then the command is rejected by the SpaceWire router.                    |          |
| Header      | The header CRC is the eight bit CRC code used to detect errors in the          | 1        |
| CRC         | command packet. The CRC code is checked before the command is                  |          |
|             | executed.                                                                      |          |

| SHIVERSIT Q           |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace | Data-Sheet       | Issue: |                              |
|                       |                  | Date:  | 18 <sup>th</sup> August 2006 |

In Figure 8-6 the format of the reply to a read incrementing address command is illustrated. The first byte sent by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional. Note that the reply is always sent out of the same port as the command was received on. The Source Path Address should not include the output port of the router being commanded as the reply will be automatically sent out of the same port that the command arrived on. See section 8.6.8.

| •                                 | Source Path Address           | Source Path Address                           | Source Path Address |  |  |  |
|-----------------------------------|-------------------------------|-----------------------------------------------|---------------------|--|--|--|
| Source Logical Address            | Protocol Identifier<br>01h    | Packet Type, Command,<br>Source Path Addr Len | Status              |  |  |  |
| estination Logical Address<br>FEh | Transaction Identifier (MS)   | Transaction Identifier (LS)                   | Reserved = 0        |  |  |  |
| Data Length (MS)<br>00h           | Data Length                   | Data Length (LS)                              | Header CRC          |  |  |  |
| Data (Word 0 MSB)                 | Data                          | Data Data                                     |                     |  |  |  |
| Data (Word 1 MSB)                 | Data                          | Data                                          | Data (Word 1 LSB)   |  |  |  |
|                                   |                               |                                               |                     |  |  |  |
| Data (Word n-1 MSB)               | Data                          | Data                                          | Data (Word n-1 LSB) |  |  |  |
| Data (Word n MSB)                 | Data                          | Data                                          | Data (Word n LSB)   |  |  |  |
| Data CRC EOP                      |                               |                                               |                     |  |  |  |
|                                   | Last byte transmitted         |                                               |                     |  |  |  |
| Bits in Packet Type / Comma       | nd / Source Address Path Leng | pth Byte                                      |                     |  |  |  |

| MSB     |         |   |     |          |   |                               | LSB                           |
|---------|---------|---|-----|----------|---|-------------------------------|-------------------------------|
| 0       | 0       | 0 | 0   | 1        | 1 | Source Path<br>Address Length | Source Path<br>Address Length |
| A Packe | et Type | • | Com | mand ——— |   | Source Path A                 | ddress Length                 |

### Figure 8-6 Read Incrementing Address Reply Packet Format

| Field      | Description                                                                  | Bytes |
|------------|------------------------------------------------------------------------------|-------|
| Source     | Optional source path addresses specified in the command packet. If no source | 0-12  |
| Path       | path addresses are specified then the first byte will be the source logical  |       |
| Address    | address.                                                                     |       |
| Source     | The source logical address specified in the command packet. If source path   | 1     |
| Logical    | addresses are not used then the source logical address is the address of the |       |
| Address    | return packet.                                                               |       |
| Protocol   | The RMAP protocol identifier value 01h.                                      | 1     |
| Identifier |                                                                              |       |



Ref.: UoD\_SpW-10X\_ DataSheet

# Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| Command     | Read incrementing address reply command byte. The packet type bits in the         | 1   |
|-------------|-----------------------------------------------------------------------------------|-----|
| Byte        | command byte indicate this packet is a reply packet.                              |     |
| Status      | The command status is returned in this field. The command status can be           | 1   |
|             | command successful or an RMAP error code as defined in section 8.6.6.             |     |
| Destination | The destination logical address is set to the default value FEh as the            | 1   |
| logical     | SpaceWire router does not have a logical address.                                 |     |
| address     |                                                                                   |     |
| Transaction | The transaction identifier identifies the command packet and reply packet with a  | 2   |
| Identifier  | unique number. The transaction identifier in the reply packet is copied from the  |     |
|             | command packet and returned in this field, so that the command and the            |     |
|             | corresponding reply have the same transaction identifier value.                   |     |
| Data        | The data length field is the number of bytes read from the router as specified in | 3   |
| Length      | the data length field of the command packet.                                      |     |
| Header      | The header CRC used to detect errors in the header part of the command            | 1   |
| CRC         | packet. See section 8.6.7 for CRC generation.                                     |     |
| Data        | The data read from the registers in the device. The data is returned in 32 bit    | >=4 |
|             | words starting from the address specified in read address in the command          |     |
|             | packet.                                                                           |     |
| Data CRC    | The data CRC used to detect errors in the data part of the reply packet. See      | 1   |
|             | section 8.6.7 for CRC generation.                                                 |     |

## 8.6.4 Read Modify Write Command

The read-modify-write command characteristics are defined in Table 8-8.

| Table 8-11 Read-Modify-Write Command Characteristics |               |                |                    |  |  |
|------------------------------------------------------|---------------|----------------|--------------------|--|--|
| Action                                               | Supported/    | Maximum number | Non-aligned access |  |  |
|                                                      | Not Supported | of bytes       | accepted           |  |  |
| 8-bit read-modify-write                              | NS            | -              | -                  |  |  |
| 16-bit read-modify-write                             | NS            | -              | -                  |  |  |
| 32-bit read-modify-write                             | S             | 4              | No                 |  |  |



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| 64-bit read-modify-write   | NS                              | - |  | - |  |
|----------------------------|---------------------------------|---|--|---|--|
| Word or byte address       | 32-bit aligned                  |   |  |   |  |
| Accepted Logical Addresses | 0xFE                            |   |  |   |  |
| Accepted destination keys  | 0x20 at power on                |   |  |   |  |
| Accepted address ranges    | 0x00 0000 0000 - 0x00 0000 0109 |   |  |   |  |
| Incrementing address       | No                              |   |  |   |  |

The RMAP read-modify-write command is supported by the SpaceWire router. The read modify write command is used to set or reset a single or number of bits in a router register. The Read-Modify-Write command is useful when it is desirable to set a link register setting without upsetting the other settings in one command, i.e. set the start bit without modifying the data rate.

In Figure 8-7 the first byte received by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional.

|                                    | First byte transmitted      |                                              |                             |
|------------------------------------|-----------------------------|----------------------------------------------|-----------------------------|
|                                    |                             |                                              | Config Port Address<br>00h  |
| Destination Logical Address<br>FEh | Protocol Identifier<br>01h  | Packet Type, Command<br>Source Path Addr Len | Destination Key             |
| Source Path Address                | Source Path Address         | Source Path Address                          | Source Path Address         |
| Source Logical Address             | Transaction Identifier (MS) | Transaction Identifier (LS)                  | Extended RMW Address<br>00h |
| RMW Address (MS)<br>00h            | RMW Address<br>00h          | RMW Address                                  | RMW Address (LS)            |
| Data +Mask Length (MS)<br>00h      | Data + Mask Length<br>00h   | Data + Mask Length (LS)<br>08h               | Header CRC                  |
| Data (MS)                          | Data                        | Data                                         | Data (LS)                   |
| Mask (MS)                          | Mask                        | Mask                                         | Mask (LS)                   |
| Data/Mask CRC                      | EOP                         |                                              |                             |
| Last byte transmitted              |                             |                                              |                             |

Bits in Packet Type / Command / Source Address Path Length Byte

| MSB   |        |   |     |          |   |                               | LSB                           |
|-------|--------|---|-----|----------|---|-------------------------------|-------------------------------|
| 0     | 1      | 0 | 1   | 1        | 1 | Source Path<br>Address Length | Source Path<br>Address Length |
| Packe | t Туре |   | Com | mand ——— |   | Source Path A                 | ddress Length                 |

### Figure 8-7 Read-Modify-Write Command Packet Format



Ref.: UoD\_SpW-10X\_ DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|             | Table 8-12 Read-Modify-Write Command Packet Fields                            |          |
|-------------|-------------------------------------------------------------------------------|----------|
| Packet      | Description                                                                   | Bytes    |
| Field       |                                                                               |          |
| Config Port | The configuration port address field routes the packet to the configuration   | 1        |
| Address     | port of the router. The configuration port address is always present when     |          |
|             | configuring the SpaceWire Router.                                             |          |
| Destination | The destination logical address is not used in the SpaceWire Router. The      | 1        |
| Logical     | SpaceWire router accepts packets which have the default destination logical   |          |
| Address     | address of 254h (FEh).                                                        |          |
| Protocol    | The RMAP protocol identifier is 01h.                                          | 1        |
| Identifier  |                                                                               |          |
| Command     | The command byte indicates a read-modify-write command. The Source path       | 1        |
| Byte        | address length fields are set to the number of source path addresses          |          |
|             | required as defined in section 8.6.9.                                         |          |
| Destination | The destination key identifier must match the contents of the destination key | 1        |
| Key         | register, see section 10.5.10.                                                |          |
| Source      | The source path address field is used to add source path addresses to the     | 0,4,8,16 |
| Path        | head of the reply packet. The expected number of source path addresses is     |          |
| Address     | specified in the command byte. See section 8.6.9 for source path address      |          |
|             | decoding.                                                                     |          |
| Source      | The source logical address should be set to the logical address of the node   | 1        |
| Logical     | which sent the command.                                                       |          |
| Address     |                                                                               |          |
| Transaction | The transaction identifier identifies the command packet and reply packet     | 2        |
| Identifier  | with a unique number.                                                         |          |
| Extended    | The extended read address is not used in the SpaceWire router and shall       | 1        |
| RMW         | always be set to zero.                                                        |          |
| Address     |                                                                               |          |
| RMW         | The read-modify-write address identifies the SpaceWire router register        | 4        |
| Address     | address to modify. Valid RMW addresses are defined in section 0.              |          |
| Data +      | The data length of the read-modify-write command is 8, 4 bytes for data and   | 3        |
| Mask        |                                                                               |          |



Data-Sheet

Date: 18<sup>th</sup> August 2006

| 4 bytes for the mask to modify a 32-bit register.                      |                                                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The header CRC used to detect errors in the header part of the command | 1                                                                                                                                                                                                                                                                               |
| packet.                                                                |                                                                                                                                                                                                                                                                                 |
| The data and mask values to write to the SpaceWire router. The data is | 8                                                                                                                                                                                                                                                                               |
| written dependent on the mask as shown in Figure 8-8.                  |                                                                                                                                                                                                                                                                                 |
| The data and mask CRC used to detect errors in the data part of the    | 1                                                                                                                                                                                                                                                                               |
| command packet.                                                        |                                                                                                                                                                                                                                                                                 |
|                                                                        | The header CRC used to detect errors in the header part of the command packet. The data and mask values to write to the SpaceWire router. The data is written dependent on the mask as shown in Figure 8-8. The data and mask CRC used to detect errors in the data part of the |

A Read-Modify-Write command modifies the bits of a SpaceWire router register dependent on the contents of the register (Register Data), the command data (Command Data) and the command mask value (Mask) as follows:

Register Value = (Mask AND Command Data) OR (NOT Mask AND Register Data)

An example is shown below, the highlighted bits are set or reset by the command.



Figure 8-8 Read-Modify-Write example operation

| ANT REAL TO A        |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🚳 Austrian Aerospace | Data-Oncer       | Date:  | 18 <sup>th</sup> August 2006 |

In Figure 8-9 the format of the reply to a Read-Modify-Write command is illustrated. The first byte received by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional. Note that the reply is always sent out of the same port as the command was received on. The Source Path Address should not include the output port of the router being commanded as the reply will be automatically sent out of the same port that the command arrived on. See section 8.6.8.

|                                    | First byte transmitted      |             |                             |                     |                                               |        |
|------------------------------------|-----------------------------|-------------|-----------------------------|---------------------|-----------------------------------------------|--------|
|                                    | Source Pa                   | ath Address | Source Path Address         | Source Path Address |                                               |        |
| Source Logical Address             | Protocol Identifier<br>01h  |             |                             |                     | Packet Type, Command,<br>Source Path Addr Len | Status |
| Destination Logical Address<br>FEh | Transaction Identifier (MS) |             | Transaction Identifier (LS) | Reserved<br>00h     |                                               |        |
| Data Length (MS)<br>00h            | Data Length<br>00h          |             | Data Length (LS)<br>04h     | Header CRC          |                                               |        |
| Data (MSB)                         | Data                        |             | Data                        | Data (LSB)          |                                               |        |
| Data CRC                           | EOP                         |             |                             |                     |                                               |        |

Last byte transmitted

Bits in Packet Type / Command / Source Path Address Length Byte

| MSB   |          |   |     |      |   |                | LSB            |
|-------|----------|---|-----|------|---|----------------|----------------|
| •     | •        | • | 4   | 4    | 4 | Source Path    | Source Path    |
| U     | U        | U | 1   | 1    | 1 | Address Length | Address Length |
|       |          | 1 |     |      |   |                |                |
| Packe | t Type 🔔 | • | Com | mand |   | Source Path A  | ddress Length  |

### Figure 8-9 Read-Modify-Write Reply Packet Format

| Field                     | Description                                                                                                                                                            | Bytes |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Source Path<br>Address    | Optional source path addresses specified in the command packet. If no source path addresses are specified then the first byte will be the source logical address.      | 0-12  |
| Source Logical<br>Address | The source logical address specified in the command packet. If source path addresses are not used then the source logical address is the address of the return packet. | 1     |
| Protocol Identifier       | The RMAP protocol identifier value 01h.                                                                                                                                | 1     |
| Command Byte              | Read-Modify-Write reply command byte. The packet type bits in the command byte indicate this packet is a response packet.                                              | 1     |
| Status                    | The command status is returned in this field. The command status can be command successful or an RMAP error code as defined in section 8.6.6.                          | 1     |
| Destination               | The destination logical address is set to the default value FEh as the                                                                                                 | 1     |



Ref.: UoD\_SpW-10X\_ DataSheet

### Data-Sheet

Date: 18<sup>th</sup> August 2006

2.0

Issue:

| logical address | SpaceWire router does not have a logical address.                         |   |
|-----------------|---------------------------------------------------------------------------|---|
| Transaction     | The transaction identifier identifies the command packet and reply packet | 2 |
| Identifier      | with a unique number. The transaction identifier in the reply packet is   |   |
|                 | copied from the command packet and returned in this field, so that the    |   |
|                 | command and the corresponding reply have the same transaction             |   |
|                 | identifier value.                                                         |   |
| Data Length     | The data length field is set to 4 bytes as 4 bytes are returned in the    | 3 |
|                 | Read-Modify-Write command.                                                |   |
| Header CRC      | The header CRC used to detect errors in the header part of the            | 1 |
|                 | command packet. See section 8.6.7 for CRC generation.                     |   |
| Data            | The data read from the SpaceWire router registers before the modify       | 4 |
|                 | operation is performed.                                                   |   |
| Data CRC        | The data CRC used to detect errors in the data part of the reply packet.  | 1 |
|                 | See section 8.6.7 for CRC generation.                                     |   |

### 8.6.5 Write Command

The write command characteristics of the SpaceWire router are defined in Table 8-14.

| Action                     | Supported/         | Maximum number | Non-aligned access |
|----------------------------|--------------------|----------------|--------------------|
|                            | Not Supported      | of bytes       | accepted           |
| 8-bit write                | NS                 | -              | -                  |
| 16-bit write               | NS                 | -              | -                  |
| 32-bit write               | S                  | 4              | No                 |
| 64-bit write               | NS                 | -              | -                  |
| Word or byte address       | 32-bit aligned     |                |                    |
| Accepted Logical Addresses | 0xFE               |                |                    |
| Accepted destination keys  | 0x20 at power on   |                |                    |
| Accepted address ranges    | 0x00 0000 0000 - 0 | x00 0000 0109  |                    |
| Incrementing address       | No                 |                |                    |

| APPLICATION OF        |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
| W Austrian Aerospace  | Data Officer     | Date:  | 18 <sup>th</sup> August 2006 |

The RMAP write single address, with data verify and acknowledgement command is supported in the SpaceWire router. The RMAP write command is used to write a 32 bit value into one of the SpaceWire router registers.

In Figure 8-10 the first byte received by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional.

|                                    |                             |                      |                                               | Config Port Address<br>00h    |
|------------------------------------|-----------------------------|----------------------|-----------------------------------------------|-------------------------------|
| Destination Logical Address<br>FEh |                             | ol Identifier<br>D1h | Packet Type, Command,<br>Source Path Addr Len | Destination Key               |
| Source Path Address                | Source F                    | Path Address         | Source Path Address                           | Source Path Address           |
| Source Logical Address             | Transaction Identifier (MS) |                      | Transaction Identifier (LS)                   | Extended Write Address<br>00h |
| Write Address (MS)<br>00h          |                             | Address<br>DOh       | Write Address                                 | Write Address (LS)            |
| Data Length (MS)<br>00h            |                             | Length<br>DOh        | Data Length (LS)<br>04h                       | Header CRC                    |
| Data (MSB)                         | Data                        |                      | Data                                          | Data (LSB)                    |
| Data CRC                           | EOP                         |                      |                                               |                               |

| Bits in Packet Type / Command / Source Path Address Length Byte |         |   |     |      |   |                               |                               |  |
|-----------------------------------------------------------------|---------|---|-----|------|---|-------------------------------|-------------------------------|--|
| MSB                                                             |         |   |     |      |   |                               |                               |  |
| 0                                                               | 1       | 1 | 1   | 1    | 0 | Source Path<br>Address Length | Source Path<br>Address Length |  |
| Pack                                                            | et Type |   | Com | mand |   | Source Path A                 | ddress Length                 |  |

### Figure 8-10 Write Single Address Command Packet

|                                   | Table 8-15 Write Single Address Command Packet Fields                                                                                                                                   |       |  |  |  |  |  |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|--|--|--|--|
| Field                             | Description                                                                                                                                                                             | Bytes |  |  |  |  |  |
| Config Port<br>Address            | The configuration port address field routes the packet to the configuration port of the router. The configuration port address is always present when configuring the SpaceWire Router. | 1     |  |  |  |  |  |
| Destination<br>Logical<br>Address | The destination logical address is not used in the SpaceWire Router. The SpaceWire router accepts packets which have the default destination logical address of 254h (FEh).             | 1     |  |  |  |  |  |
| Protocol<br>Identifier            | The RMAP protocol identifier is 01h.                                                                                                                                                    | 1     |  |  |  |  |  |
| Command<br>Byte                   | The command byte indicates a write single address, with verification and acknowledgement packet. The Source path address length fields are set to                                       | 1     |  |  |  |  |  |



Ref.: UoD\_SpW-10X\_ DataSheet

# Data-Sheet

Issue: **2.0** Date: **18<sup>th</sup> August 2006** 

|             | the number of source path addresses required as defined in section 8.6.9.     |          |
|-------------|-------------------------------------------------------------------------------|----------|
| Destination | The destination key identifier must match the contents of the destination key | 1        |
| Key         | register, see section 10.5.10.                                                |          |
| Source      | The source path address field is used to add source path addresses to the     | 0,4,8,12 |
| Path        | head of the reply packet. The expected number of source path addresses is     |          |
| Address     | specified in the command byte. See section 8.6.9 for source path address      |          |
|             | decoding.                                                                     |          |
| Source      | The source logical address should be set to the logical address of the node   | 1        |
| Logical     | which sent the command.                                                       |          |
| Address     |                                                                               |          |
| Transaction | The transaction identifier identifies the command packet and reply packet     | 2        |
| Identifier  | with a unique number.                                                         |          |
| Extended    | The extended write address is not used in the SpaceWire router and is         | 1        |
| Write       | always expected to be zero.                                                   |          |
| Address     |                                                                               |          |
| Write       | The write address identifies the register to write the RMAP data. The valid   | 4        |
| Address     | write addresses are defined in section 0.                                     |          |
| Data        | The data length of a write single address command is expected to be 4 bytes,  | 3        |
| Length      | to write to a 32 bit register location                                        |          |
| Header      | The header CRC is the eight bit CRC code used to detect errors in the         | 1        |
| CRC         | command packet. The CRC code is checked before the command is                 |          |
|             | executed                                                                      |          |
| Data        | The 32 bit data value to write to the SpaceWire router register.              | 4        |
| Data CRC    | The data CRC used to detect errors in the data part of the command packet.    | 1        |

| APPLERAL TY OF       |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🔞 Austrian Aerospace |                  | Date:  | 18 <sup>th</sup> August 2006 |

In Figure 8-11 the format of the reply to a write command is illustrated. The first byte sent by the SpaceWire router configuration logic is the port address followed by the destination logical address. Fields which are depicted in bold text are expected values. Fields which are shaded are optional. Note that the reply is always sent out of the same port as the command was received on. The Source Path Address should not include the output port of the router being commanded as the reply will be automatically sent out of the same port that the command arrived on. See section 8.6.8.



### Figure 8-11 Write Single Address Reply Packet

| Table 8-16 Write Single Address Reply Packet Fields |                                                                                                                                                          |       |  |  |  |
|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|--|--|
| Field                                               | Description                                                                                                                                              | Bytes |  |  |  |
| Source<br>Path                                      | Optional source path addresses specified in the command packet. If no source path addresses are specified then the first byte will be the source logical | 0-12  |  |  |  |
| Address                                             | address.                                                                                                                                                 |       |  |  |  |
| Source                                              | The source logical address specified in the command packet. If source path                                                                               | 1     |  |  |  |
| Logical                                             | addresses are not used then the source logical address is the address of the                                                                             |       |  |  |  |
| Address                                             | return packet.                                                                                                                                           |       |  |  |  |
| Protocol                                            | The RMAP protocol identifier value 01h.                                                                                                                  | 1     |  |  |  |
| Identifier                                          |                                                                                                                                                          |       |  |  |  |
| Command                                             | Write single address reply command byte. The packet type bits in the command                                                                             | 1     |  |  |  |
| Byte                                                | byte indicate this packet is a reply packet.                                                                                                             |       |  |  |  |
| Status                                              | The command status is returned in this field. The command status can be                                                                                  | 1     |  |  |  |
|                                                     | command successful or an RMAP error code as defined in section 8.6.6.                                                                                    |       |  |  |  |
| Destination                                         | The destination logical address is set to the default value FEh as the                                                                                   | 1     |  |  |  |
| logical                                             | SpaceWire router does not have a logical address.                                                                                                        |       |  |  |  |



Data-Sheet

Ref.: UoD\_SpW-10X\_ DataSheet

Issue: **2.0** 

Date: 18<sup>th</sup> August 2006

| address     |                                                                                  |   |
|-------------|----------------------------------------------------------------------------------|---|
| Transaction | The transaction identifier identifies the command packet and reply packet with a | 2 |
| Identifier  | unique number. The transaction identifier in the reply packet is copied from the |   |
|             | command packet and returned in this field, so that the command and the           |   |
|             | corresponding reply have the same transaction identifier value.                  |   |
| llaadar     | The beader CDC used to detect errors in the beader part of the command           | 4 |
| Header      | The header CRC used to detect errors in the header part of the command           | 1 |
| CRC         | packet. See section 8.6.7 for CRC generation.                                    |   |
|             |                                                                                  |   |

### 8.6.6 Command Error Response

A summary of the error conditions and the action taken is given in Table 8-17. The error conditions are recorded in the configuration port status register.

| Table 8-17 Configuration Port Errors Summary |                                                                                 |                 |                                       |                                    |  |
|----------------------------------------------|---------------------------------------------------------------------------------|-----------------|---------------------------------------|------------------------------------|--|
| Register Bits                                | Description                                                                     | Reply<br>Packet | Returned As                           | Returned<br>RMAP<br>Status<br>Code |  |
| Invalid Header<br>CRC                        | The header CRC was invalid<br>therefore the header is<br>corrupted              | No              | No Reply Packet.                      | -                                  |  |
| Unsupported<br>Protocol Error                | The protocol byte is not the RMAP protocol identifier                           | No              | No Reply Packet.                      | -                                  |  |
| Source Logical<br>Address Error              | The source logical address is<br>invalid (outside the range<br>20h-FFh)         | No              | No Reply Packet.                      | -                                  |  |
| Source Path<br>Address<br>Sequence Error     | The source path address<br>sequence is invalid as<br>specified in section 8.6.9 | No              | No Reply Packet.                      | -                                  |  |
| Unused RMAP<br>command or<br>packet type     | The command code is an<br>unused command code or<br>the packet type is invalid. | Yes             | Unused RMAP command<br>or packet type | 2                                  |  |
| Invalid<br>Destination Key                   | The destination key in the command packet is invalid.                           | Yes             | Invalid Destination Key               | 3                                  |  |
| Invalid Data<br>CRC                          | The Data CRC is invalid therefore the data part of the                          | Yes             | Invalid Data CRC                      | 4                                  |  |



Ref.: UoD\_SpW-10X\_

DataSheet

### Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|                                | packet is corrupted                                                                                                                                                                                                                                                              |     |                                                                                                                                                                                                                                                                                                   |    |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Early EOP                      | The command packet was<br>terminated early with an<br>EOP. A reply packet is sent if<br>the early EOP error occurs<br>on the data part of the packet                                                                                                                             | Yes | Early EOP                                                                                                                                                                                                                                                                                         | 5  |
| Cargo too Large                | The expected amount of<br>SpaceWire cargo has been<br>received without receiving an<br>EOP marker                                                                                                                                                                                | Yes | Cargo too large                                                                                                                                                                                                                                                                                   | 6  |
| Early EEP                      | The command packet was<br>terminated early with an<br>EEP. A reply packet is sent if<br>the early EEP error occurs<br>on the data part of the packet                                                                                                                             | Yes | Early EEP                                                                                                                                                                                                                                                                                         | 7  |
| Verify Buffer<br>Overrun Error | The data length field is<br>invalid when performing a<br>verified write command. The<br>valid length is 4 bytes of<br>data.                                                                                                                                                      | Yes | Verify Buffer Overrun                                                                                                                                                                                                                                                                             | 9  |
| Command not<br>implemented     | A command code was<br>received which is not<br>supported by the SpaceWire<br>router. Supported command<br>codes are listed in F1-18.                                                                                                                                             | Yes | RMAP Command not<br>implemented or not<br>authorised                                                                                                                                                                                                                                              | 10 |
| Invalid Data<br>Length         | <ul> <li>The data length field is invalid. A data length error is recorded when:</li> <li>1. The data length is not a multiple of 4.</li> <li>2. The data length is zero</li> <li>3. The data length is outside the range 4-1064 when performing an incrementing read</li> </ul> | Yes | RMAP Command not<br>implemented or not<br>authorised<br>(ote 1: a Verify Buffer<br>Overrun error shall be<br>returned when the data<br>length is not 4 in a<br>verified write command.<br>Note 2: a Read Modify<br>Write Data Length error<br>shall be returned when<br>the data length is not 8. | 10 |



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|                                           | <ul> <li>4. The data length is not 4 in a verified write command.</li> <li>5. The data length is not 8 in a read modify write command.</li> </ul> |     |                                                      |    |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------------------------------------|----|
| Invalid Register<br>Address               | The address field is<br>addressing an unknown<br>register for a read command<br>or a read only register in a<br>write command.                    | Yes | RMAP Command not<br>implemented or not<br>authorised | 10 |
| Read Modify<br>Write Data<br>Length Error | The read modify write data<br>length is not 8                                                                                                     | Yes | RMW Data Length Error                                | 11 |
| Invalid<br>Destination<br>Logical Address | The destination logical<br>address is invalid. The<br>destination logical address is<br>expected to be the default<br>254 value                   | Yes | Invalid Destination<br>Logical Address               | 12 |

# 8.6.7 Command Packet Cyclic Redundancy Check

The header and data part of an RMAP packet are protected from errors by the use of an 8 bit CRC code. The header and data CRC is formed using the CRC-8 code used in ATM (Asynchronous Transfer Mechanism). CRC-8 has the polynomial:  $X^8 + X^2 + X^1 + 1$  wait a starting value of 00h.

Command packets received by the SpaceWire router which have an invalid header CRC are discarded and the Invalid Header CRC bit is set in the configuration port register.

# 8.6.8 Local Source Path Address

The configuration reply packet shall be routed out of the router port the packet arrived on. For example, if SpaceWire port 1 passed a configuration command to the configuration port then the reply packet is returned to port 1.



### 8.6.9 Source Path Address Field

The RMAP command field "source path address length" indicates the number of source path addresses which are expected in the packet. Up to 12 source path addresses can be accepted by the router configuration port. The source path addresses shall be decoded by the SpaceWire router as follows.

- Leading zero source path address bytes are not returned in the RMAP reply packet.
- If the source path address contains only zero bytes the Source Path Address Sequence error is reported, see section 8.6.6.
- After the first non zero byte in the packet any following zeros shall be treated as an error. A source path address sequence is reported, see section 8.6.6.

The table below shows how to set the source path address length and packet address fields for the required path addresses

| Table 8-18 Source Path Address Reference Table |                                 |                      |  |  |  |
|------------------------------------------------|---------------------------------|----------------------|--|--|--|
| Source Path Address                            | RMAP Source Path Address fields | Reply Path Address   |  |  |  |
| Length                                         | (First→Last Transmitted)        | (First→Last Reply)   |  |  |  |
| 0                                              | None                            | None                 |  |  |  |
| 1                                              | [00 00 00 20]                   | 20                   |  |  |  |
| 1                                              | [00 02 08 09]                   | 02 08 09             |  |  |  |
| 1                                              | [01 02 03 04]                   | 01 02 03 04          |  |  |  |
| 2                                              | [00 00 00 00] [00 00 00 02]     | 02                   |  |  |  |
| 2                                              | [00 00 00 00] [01 02 03 02]     | 01 02 03 02          |  |  |  |
| 2                                              | [00 00 12 01] [02 B2 03 05]     | 12 01 02 B2 03 05    |  |  |  |
| 2                                              | [00 32 01 02] [07 02 05 08]     | 32 01 02 07 02 05 08 |  |  |  |
| 1                                              | [00 00 00 00]                   | Invalid              |  |  |  |
| 2                                              | [00 00 00 ] [00 00 00]          | Invalid              |  |  |  |
| 1                                              | [00 02 00 01]                   | Invalid              |  |  |  |
| 1                                              | [00 A3 00 00]                   | Invalid              |  |  |  |
| 2                                              | [00 02 03 00] [01 00 00 00]     | Invalid              |  |  |  |
| 2                                              | [00 00 00 02] [00 00 01 00]     | Invalid              |  |  |  |
| 2                                              | [00 00 00 00] [02 03 00 01]     | Invalid              |  |  |  |

| and the second second |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
|                       |                  | Date:  | 18 <sup>th</sup> August 2006 |

Figure 8-12 and Figure 8-13 illustrate how source path addresses are returned in relation to the RMAP packet description.

| Dest Logical   | Protocol ID | Command     | Dest Key   |
|----------------|-------------|-------------|------------|
| 00             | 00          | 04          | 02         |
| Source Logical | Trans ID(1) | Trans ID(0) | Address(4) |
|                |             |             |            |

### Figure 8-12 Source Path Address field decoding

|                | Local Source<br>Path Address | 04      | 02     |
|----------------|------------------------------|---------|--------|
| Source Logical | Protocol ID                  | Command | Status |
|                |                              |         |        |

### Figure 8-13 Source Path Addresses in Reply Packet

### 8.6.10 Command Packet Fill Bytes

The Configuration port accepts packets which are addressed to port 0. In the RMAP command the next byte after the destination address 0 is the destination logical address byte (which in the router is expected to be the default 254 value). The format is shown in Figure 8-14.



### Figure 8-14 Normal Configuration Packet Header Structure

To allow source nodes which have a 16, 24 or 32 bit access port then the configuration port accepts up to three null bytes at the start of the packet. The null bytes must be zero otherwise they will be treated as the destination logical address and an invalid destination logical address shall be recorded if the byte is not 254. The header with fill bytes is shown in the Figure 8-15.



### Figure 8-15 Fill Bytes Configuration Header Structure



Data-Sheet

### 9. CONTROL LOGIC AND OPERATIONAL MODES

In this section the SpaceWire router control logic and operational modes are defined. The router control logic determines how the SpaceWire link ports operate, how received packets are routed to their destination and how the timeout mechanism detects packet blockages in the router.

### 9.1 SPACEWIRE LINK CONTROL

Each of the eight SpaceWire links has an associated SpaceWire control register. The register records status information from each link including link error information, link state and run status (see section 10.4.3).

The SpaceWire link control bits determine how the SpaceWire link operates. The link control bits are Auto-start (default), Link-Start, Link-Disable and Tri-State. The SpaceWire link data rate divider can also be set in the link control register.

The following paragraphs define each of the link control functions

### 9.1.1 Default operating mode

The default operating mode is Auto-Start. This is the mode setting for each link after power on or reset.

### 9.1.2 Auto-Start

In auto-start mode the SpaceWire port will remain inactive until a connection attempt is made by the SpaceWire device at the other end of the SpaceWire link. The port will then start-up and make the connection

The Auto-Start mode in conjunction with the automatic Link-Start and disable modes can help reduce power consumption by only activating SpaceWire links when packet data is transferred. See section 9.1.7.

### 9.1.3 Link-Start

The link-start control bit commands the SpaceWire port to try to make a connection with a SpaceWire device at the other end of the link. Assuming a SpaceWire device is connected to the other end of the link the SpaceWire port will move to state Run. Data transfer can take place when the link is started and the Link state is Run.

| SHUBBERITY OF                |                  | Ref.:  | UoD_SpW-10X_                 |
|------------------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM              | SpaceWire Router |        | DataSheet                    |
| <b>()</b> Austrian Aerospace | Data-Sheet       | Issue: | -                            |
|                              |                  | Date:  | 18 <sup>th</sup> August 2006 |

### 9.1.4 Link-Disable

The SpaceWire port can be disabled therefore rendering the link unusable. When a SpaceWire link which is running is disabled it will disconnect from the far end and refuse connection attempts by the far end of the link. Caution should be used when using this command for a stand alone router as disabling all the links will leave the router unusable, except through a reset operation.

WARNING: If the link that is being used to configure the router is disabled then it will not be possible to configure the router, unless there is another not disabled connection that can be used.

### 9.1.5 Automatic tri-state enable mode

The SpaceWire link tri-state bit can be set to cause the data and strobe outputs for the link to be disabled when the link is inactive. The tri-state mode takes effect dependent on the state of the Auto-start or the Link-Disabled control bits.

When Auto-start is enabled and the tri-state bit is set then the data and strobe LVDS drivers are tristated until the interface receives a connection attempt by an external SpaceWire device. The drivers are then enabled until the external device disconnects the link or the SpaceWire link control bit setup is changed.

When Link-disable is asserted and the tri-state bit is set then the data and strobe LVDS drivers are always tri-stated as the link is not in use.

The figure below shows the effect of the tri-state bit when the link setting is Auto-start only.



### Figure 9-1 Tri-state enable operating mode

Note the DOUT tri-state enable/disable is performed one CLK cycle before the SOUT tri-state, avoiding any simultaneous transitions on Data or Strobe.

### 9.1.6 Setting the data-rate

The SpaceWire link data-rate is dependent on the input signal FEEDBDIV (See section 4.1), the PLL output clock divider value TXDIV (See section 10.5.9) and the data-rate divider value in each

| ALL DE LE DE |                  | Ref.:  | UoD_SpW-10X_                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SpaceWire Router |        | DataSheet                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Data-Sheet       | Issue: | 2.0                          |
| 🔞 Austrian Aerospace                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Data-Oncer       | Date:  | 18 <sup>th</sup> August 2006 |

SpaceWire link control register (See section 10.4.3). The resultant data rate is determined by the function.

$$DataRate = \left(\frac{\left(\frac{(100MHz + (20MHz * FEEDBDIV))}{2^{TXDIV+1}}\right)}{TXRATE + 1}\right) * 2$$

Where **FEEDBDIV** is in the range 0-5.

Note: If (**TXRATE**+1) is an even number then the duty cycle will not be 50/50 on the output bit-stream. The worst case is when **TXRATE** =1 (i.e. **TXRATE**+1=2) then the duty cycle will be 75/25.

### Setting the Transmit Data-Rate:

- 1. Set the FEEDBDIV pins to give the required PLL clock rate.
- 2. Set the base transmit data-rate using the TXDIV divider. Do this once only.

3. Set the required transmit data-rate of each link individually using the TXRATE divider. The resulting transmit data-rate must be equal to or higher than 2 Mbits/s.

# WARNING: If a data-rate of less than 2 Mbits/s is set then the link will repeatedly connect and disconnect.

### 9.1.7 Setting the default 10Mbits/s data-rate

The input signal **FEEDBDIV** and the transmit control register value **TxDiv** select the input clock frequency to the link transmitters. At link start-up and initialisation the default data-rate is set by the transmit clock control register value **TX10MBitDiv** where TX10MbitDIV should be set such that:



### Figure 9-2 Tx10MBitDIV equation

Where FEEDBDIV is in the range 0-5.

| SUITERALT Q           |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
|                       |                  | Date:  | 18 <sup>th</sup> August 2006 |

Note: If Tx10MbitDIV is an odd number then the duty cycle on DOUT and SOUT will not be 50/50. In the worst case when Tx10MbitDIV=1 the duty cycle will be 75/25.

### 9.1.8 Data rate comparison table

|      |   |         |      | TXDIV |      |     |      |     |
|------|---|---------|------|-------|------|-----|------|-----|
|      |   |         | 0    | 0     | 1    | 1   | 2    | 2   |
|      |   | PLLFreq | Min  | Max   | Min  | Max | Min  | Max |
|      | 0 | 100     | 0.78 | 100   | 0.39 | 50  | 0.20 | 25  |
| BDIV | 1 | 120     | 0.94 | 120   | 0.47 | 60  | 0.23 | 30  |
| B    | 2 | 140     | 1.09 | 140   | 0.55 | 70  | 0.27 | 35  |
| ED   | 3 | 160     | 1.25 | 160   | 0.63 | 80  | 0.31 | 40  |
|      | 4 | 180     | 1.41 | 180   | 0.70 | 90  | 0.35 | 45  |
|      | 5 | 200     | 1.56 | 200   | 0.78 | 100 | 0.39 | 50  |

All Numbers in Mbits/s

The maximum numbers are the data rates that are achieved when the TXRATE divider is 0. The minimum values are those achieved when TXRATE divider is set to 7. See section 10.4.3.

# 9.2 GLOBAL SPACEWIRE LINK CONTROL

The following modes are global to all SpaceWire links. The modes can be set in the SpaceWire router control register. (see section 10.5).

### 9.2.1 Automatic Link-Start mode

The automatic link start mode is set in the router control register bit setting **CFG\_START\_ON\_REQ**. The input signal **POR\_START\_ON\_REQ\_N** determines the power on or reset state of the register bit.

The SpaceWire router automatic Link-Start mode is used to instruct a link to automatically attempt startup when a packet is received whose destination is a SpaceWire link which is not ready (i.e. not Running).



Figure 9-3 Automatic Link-Start mode

### 9.2.2 Automatic Link-Disable mode

The automatic Link-Disable mode is set in the router control register bit setting CFG\_DISABLE\_ON\_SILENCE. The input signal POR\_DISABLE\_ON\_SILENCE\_N determines the power on or reset state of the register bit.

The figure below defines the usage of the automatic link-disable mode.



### Figure 9-4 Automatic Link-Disable mode

The SpaceWire router automatic Link-Disable mode is used to disable a link after it has been used to send packet data. The Automatic Link-Disable mode is enabled only when the router timeout setting has been enabled. The link is disabled if no packet activity has been detected for the timeout period set in the router control register.

| AP TO A TO |                  | Ref.:  | UoD_SpW-10X_                 |
|------------------------------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM                          | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace                    | Data-Sheet       | Issue: | 2.0                          |
|                                          |                  | Date:  | 18 <sup>th</sup> August 2006 |

The SpaceWire router will only disable the SpaceWire link when the SpaceWire router is the source of the data transfer. If an external device starts the SpaceWire link or sends packet data to the router through the link then the link will not be disabled.

# 9.3 CONTROL LOGIC AND ROUTING

This section defines the function of the SpaceWire routing logic and how packets are handled dependent on the router control modes of operation. The modes of operation which affect the router are the router control register settings, timeout enable, address self, and start on request.

## 9.3.1 Packet address error

A packet address error is detected when a packet with an invalid address, see section 8.4, is received. The packet is discarded by the router independent of the current mode settings and the router is set up to receive the next packet after the invalid address packet has been spilt. The next input port to transfer data to an output port is the next highest port number (modulo number of ports) that has data to send. For example, if port 2 is sending data out of port 1 and ports 5 and 7 are waiting to send data through port 1, then port 5 will selected next.

## 9.3.2 Arbitration

Arbitration is performed by the SpaceWire router when two or more packets are to be routed through the same destination port.

Packets which have high priority are always selected before low priority packets in the router. If two or more packets of the same priority level are attempting to use the same destination port then the packets are arbitrated in a fair manner.

The router chooses the next packet to be routed to the destination port dependent on the previous port which had access to the router. Therefore the port which previously had access to the output port will be selected last by the router control logic.

Note that configuration packets, both commands and replies, are treated the same as any other packet as far as arbitration is concerned. The arbitration scheme is equally applicable to all types of packets with no exceptions. When sending long packets, arbitration can cause substantial delays in transferring information.

The following sections illustrate the scenarios described above.

| SHIVERALTY OF        |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🚺 Austrian Aerospace | Data-Sheet       | Date:  | 18 <sup>th</sup> August 2006 |
|                      |                  |        |                              |

### 9.3.2.1 Arbitration of packets with matching priority (1)

In the figure below only router ports 1-5 are shown for clarity.

At stage one ports 1 and 3 have packets to be routed to port 5. The previous port to use port 5 was port 3 therefore the next port to be selected by port 5 will be port 1 (assuming ports 6, 7, 8, 9, 10 and 0 are not requesting to use the port).

At stage two the router selects the packet arriving at port 1 and the packet is routed through port 5. Port 3 waits until all of the packet from port 1 has been transferred.

At stage three all port 1's packet data has been transferred, therefore port 3 is selected and the packet data is routed through port 5.



Figure 9-5 Arbitration of two packets with matching priority.

| UNITERALITY OF       |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🚺 Austrian Aerospace | Data-Sileet      | Date:  | 18 <sup>th</sup> August 2006 |
| ·                    |                  |        |                              |

### 9.3.2.2 Arbitration of packets with matching priority (2)

In the figure below only router ports 1-5 are shown for clarity.

At stage one ports 1 and 3 have packets to be routed to port 5. The previous port to use port 5 was port 3 therefore the next port to be selected by port 5 will be port 1 (assuming ports 6, 7, 8, 9, 10 and 0 are not requesting to use the port).

At stage two the router selects the packet at port one and the packet is routed through port 5. Port number 3 waits until all of that packet has been transferred. While the packet from port 1 is routed to port 5 another packet arrives at port 2 to be routed to port 5.

At stage three the packet from port 1 has been forwarded and the packet from port 2 is selected by the router to be routed through port 5. Port number two is selected before port 3 as it is the next port to be considered by the routing control logic after port 1.

At stage four port 2's packet data has been transferred to port 5 therefore port 3 is selected and its packet data is routed through port 5.



Figure 9-6 Arbitration of three packets with matching priority

| SHIPERET P.          |                                   | Ref.:                        | UoD_SpW-10X_ |
|----------------------|-----------------------------------|------------------------------|--------------|
| EADS<br>ASTRIUM      | SpaceWire Router                  |                              | DataSheet    |
|                      | Data-Sheet                        | Issue:                       | 2.0          |
| 🔘 Austrian Aerospace | Data-Sheet Date: 18 <sup>th</sup> | 18 <sup>th</sup> August 2006 |              |
|                      |                                   |                              |              |

### 9.3.2.3 Arbitration of packets with different priority (1)

In the figure below only router ports 1-5 are shown for clarity.

At stage one ports 1 and 3 have packets with logical addresses 80 and 52 which are both to be routed to port 5. The previous port selected by port 5 was port 2 but logical address 80 has HIGH priority therefore will be selected before address 52 which has LOW priority.

At stage two the router selects the packet arriving at port 1 and the packet is routed through port 5.

At stage three the packet from port 1 has been transferred and the packet from port 3 is selected by the router to be routed through port 5.



Figure 9-7 Arbitration of two packets with different priority

| SHALE BULLES OF      |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🔞 Austrian Aerospace | Data-Sileet      | Date:  | 18 <sup>th</sup> August 2006 |
|                      |                  | ·      | •                            |

### 9.3.2.4 Arbitration of packets with different priority (2)

In the figure below only router ports 1-5 are shown for clarity.

At stage one ports 1 and 3 have packets with logical addresses 80 and 52 which are both to be routed to port 5. The previous port selected by port 5 was port 4 therefore the packet waiting at port 1 is routed, but logical address 80 has HIGH priority therefore will be selected before address 52 which has LOW priority.

At stage two the router selects the packet arriving at port 1 and this packet is routed through port 5. In the meantime a packet with HIGH priority logical address 80 arrives at port 4.

At stage three the packet from port 1 has been forwarded and the packet with HIGH priority at port 4 is selected by the routing control logic as the next packet to be routed to port 5.

At stage number four the high priority packet has been forwarded and the routing control logic must arbitrate again for port 5. The previous low priority packet that was routed through port 5 is 1 therefore the next packet selected by the routing control logic is port 3.

At stage number five the packet from port 3 has completed and the packet waiting at port 1 gets its chance to access port 5 and is forwarded.



Figure 9-8

| MALINE ROLLING       |                  | Ref.:     | UoD_SpW-10X_                 |
|----------------------|------------------|-----------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |           | DataSheet                    |
|                      | Data-Sheet       | Issue:    | 2.0                          |
| 🚺 Austrian Aerospace | Data-Sheet       | Date:     | 18 <sup>th</sup> August 2006 |
|                      |                  | · · · · · |                              |

## 9.3.3 Group Adaptive Routing

The SpaceWire router routing table can be set up to support group adaptive routing of packets. Setting the routing table contents is described in section 10.3.

In group adaptive routing a set of output ports can be assigned to a logical address. When a packet arrives with the logical address the routing table is checked for the set of output ports which the packet can use. The routing control logic then checks the possible router ports to determine if they are free and ready to use. When one of the possible ports associated with the logical address of the packet is free and ready to use then the packet is routed through the port.

If all the set of ports which the logical address packet can use are free then the router chooses the lowest numerical destination port number to route the packet. The figures below detail the group adaptive routing scenarios defined above.

Arbitration is performed on group adaptive routing packets as defined in section 9.3.2.

### 9.3.3.1 Normal Group adaptive routing

In normal group adaptive routing then the lowest numerical output port is assigned to the packet.



Figure 9-9 Normal group adaptive routing

### 9.3.3.2 Group adaptive routing when busy

In this scenario, two of the ports which address 76 can use to route towards the destination are busy. The packet is assigned to the free port 6 and the packet is routed out of port number 6.



Figure 9-10 Group adaptive routing when other ports busy

### 9.3.3.3 Group adaptive routing when ports not ready

In this scenario, two of the ports which address 76 can use to route towards the destination are not ready for use (i.e. the links are not running). The packet is assigned to link number 6 by the routing control logic as it can be used immediately to route the packet to the destination.



### Figure 9-11 Group adaptive routing when ports not ready

Note if the automatic link-start mode is enabled then the ports which are not ready will attempt to make a connection. In this way the group adaptive routing packet will be routed to the port which is ready first.

| CHIVE BALL TO A      |                  | Ref.:                                 | UoD_SpW-10X_                 |
|----------------------|------------------|---------------------------------------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |                                       | DataSheet                    |
| 🔞 Austrian Aerospace | Data-Sheet       | Issue:                                | 2.0                          |
| W Austrian Aerospace | Data-Oneet       | Date:                                 | 18 <sup>th</sup> August 2006 |
|                      |                  | · · · · · · · · · · · · · · · · · · · |                              |

## 9.3.4 Loop-back routing

The router control register "address-self" bit determines if the router supports loop-back connections. Loop-back connections can be useful for debugging or ping operations where a packet is "bounced" of the router and returned to the source. If the address self bit is disabled then the packet is discarded and a packet address error is recorded.

Command reply packets which are returned through the same port they arrived on are not affect by the value of the "address-self" register bit.



The diagram below shows the "address-self" mode when enabled and when disabled.

Figure 9-12 Packet address self mode

| SPRINGER ST. OF    |                  | Ref.:  | UoD_SpW-10X_                 |
|--------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM    | SpaceWire Router |        | DataSheet                    |
|                    | Data-Sheet       | Issue: | 2.0                          |
| Austrian Aerospace | Data-Oneet       | Date:  | 18 <sup>th</sup> August 2006 |

## 9.3.5 Packet Blocking

As described in the arbitration and group adaptive routing sections above, sections 9.3.2 and 9.3.3, a packet is routed to the destination port dependent on the packet address and the state of the router. A packet is only routed to the destination port when the destination port is ready. The definition of ready for each type of port is listed in the table below.

| Table 9-1 Port ready definitions |                                                                             |  |
|----------------------------------|-----------------------------------------------------------------------------|--|
| Physical Port type               | Ready when                                                                  |  |
| Configuration port               | Port data buffer is not full.                                               |  |
| SpaceWire link port              | Port data buffer is not full <b>and</b> SpaceWire link is in the run state. |  |
| External FIFO port               | Port data buffer is not full.                                               |  |

When a router port is ready, a packet can be routed towards its destination and the routed resources are freed. When a router port is not ready then a packet is blocked in the router as the packet cannot be routed towards the destination.

The scenarios which can cause packet blocking are defined below.

| Table 9-2 Packet blocking                                                                           |                                                                                                          |  |  |
|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--|--|
| Types of blocking                                                                                   | Effect of blocking                                                                                       |  |  |
| Packet has been routed to destination but packet destination stalls and stops accepting data before | Packet is blocked in router and destination port<br>will not become free until packet destination starts |  |  |
| the complete packet has passed through router.                                                      | accepting data again.                                                                                    |  |  |
| Packet has been routed to destination port but the                                                  | Destination port is blocked waiting for end of                                                           |  |  |
| source of the packet stalls and the complete                                                        | packet. Destination port will not become free until                                                      |  |  |
| packet has not passed through the router.                                                           | packet source supplies the end of packet.                                                                |  |  |
| Packet destination port is a SpaceWire port which                                                   | Packet cannot be routed by router as physical link                                                       |  |  |
| is not connected to an external device.                                                             | connection does not exist.                                                                               |  |  |
| Packet destination port is a SpaceWire port which                                                   | Packet cannot be routed by router unless                                                                 |  |  |
| is not started                                                                                      | automatic Link-Start is enabled                                                                          |  |  |

For the packet blocking types listed above the router may become blocked for an indefinite period of time and a reset of the router would be required to free the blockage. Packets which are blocked may also cause blockages through an entire network as the packet data buffering on the router is small therefore the tail of a packet may be spread over a number of routers or the entire network. The packet timeout mechanism defined below provides a method of ensuring that prolonged packet blocking does not occur in the router.

| SHIVER IF Q          |                  | Ref.: | UoD_SpW-10X_                 |
|----------------------|------------------|-------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |       | DataSheet                    |
|                      | Issue:           | 2.0   |                              |
| 🔞 Austrian Aerospace |                  | Date: | 18 <sup>th</sup> August 2006 |

Two modes of blocking are be supported in the SpaceWire router, "Blocking allowed" and "Blocking Watchdog Timer".

### 9.3.5.1 Blocking Allowed

In the blocking allowed mode packets wait indefinitely on other packets to complete. When a packet of infinite length is being routed then no other packets can access that channel and the packets will block for an infinite time. The disadvantage of this method is that if a destination node stops reading a packet then the packet will block the network indefinitely.

An exception to this occurs when the router output port to be used is a SpaceWire port and the port is not started. In this case the packet waits as long as the timeout period and is then discarded. If group adaptive routing is used and at least one of the destination ports is running then the packet waits indefinitely.

### 9.3.5.2 Blocking Watchdog Timer

In the watchdog timer mode a watchdog timer is used to clear packets from the network when they become blocked. The watchdog blocking timer is restarted on each byte of a packet that is transferred. The complete duration of the packet is not checked but instead the timer checks if a packet has blocked (i.e. no data transfers).

The following sections consider various routing scenarios where blocking occurs. Blocking allowed and watchdog timer modes are examined for each scenario.

#### 9.3.5.3 Scenario 1 Destination Node Blocked

In scenario 1 the destination node is blocked therefore packet data builds up through the routers. In this case the tail of the packet is distributed across multiple routers and other network paths become blocked waiting on the blocked packet to complete.

- In blocking allowed mode the network path is blocked until the destination node starts to accept data again. Packets waiting to use the network path will wait indefinitely.
- In watchdog timer mode the routers will timeout and the network path will be cleared so other packets can use the path. Packets waiting to use the network path will wait for as long as the timeout period.

The two figures below illustrate the actions of the router in the blocking allowed mode and the blocking watchdog timer mode.



Figure 9-13 Scenario 1 Destination blocked (Blocking allowed mode)



## Figure 9-14 Scenario 1 Destination blocked (Watchdog Timer Mode)

### 9.3.5.4 Scenario 2 Source Node Stalled

In scenario 2 the source node stalls after the head of packet is routed to the destination node. The network path is blocked as the routers are waiting for the end of packet to be supplied by the source node.

- In blocking allowed mode the network path is blocked until the source node supplies the end of packet. Other packets waiting to use the network path will wait indefinitely.
- In watchdog timer mode the routers will timeout and the network path will be cleared so other packets can use the path. Other packets waiting to use the network path will wait as long as the timeout period.

| AND THE REAL PARTY OF |                  | Ref.:  | UoD_SpW-10X_                 |
|-----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM       | SpaceWire Router |        | DataSheet                    |
| () Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
|                       |                  | Date:  | 18 <sup>th</sup> August 2006 |

The two figures below illustrate the actions of the router in the blocking allowed mode and the blocking watchdog timer mode.



After an undetermined time the source node supplies the end of packet and the packet waiting at R1-2 can be routed

### Figure 9-15 Scenario 2 Source node stalled (Blocking allowed mode)



## Figure 9-16 Scenario 2 Source node stalled (Watchdog timer mode)

### 9.3.5.5 Scenario 3 Destination node slow, Source node waiting

In this scenario the destination node slowly accepts data from the source node through the network.

- In blocking allowed mode, other packets waiting to use the network path will wait indefinitely for the slow packet to complete.
- In watchdog timer mode, packets which are waiting to use the network path will wait as long as the timeout period as they cannot be routed to the destination node. Other packets waiting to use the network path will wait as long as the timeout period.

The two figures below illustrate the actions of the router in the blocking allowed mode and the blocking watchdog timer mode.



R1-5 completes and R1-3 can be routed

Figure 9-17 Scenario 3 Destination slow (Blocking Allowed Mode)



The packet from R1-3 can complete as the network path is free.



### 9.3.5.6 Scenario 4 Destination port not ready

In this scenario the destination port in the router is not ready to accept a new packet. If the destination port is an external port or the configuration port then it is not ready when the destination FIFO is full (cannot accept mode data). If the destination port is a SpaceWire port then the destination port is not ready when the destination FIFO is full (transmit FIFO) or the SpaceWire link is not started.

- In blocking allowed mode the input packet will wait indefinitely until the destination port is ready. An exception to this is when the router output port is a SpaceWire port and the port is not started, in this case the packet waits as long as the timeout period and then discards the packet. If group adaptive routing is used and at least one of the destination ports is running then the packet waits indefinitely.
- In watchdog timer mode the input packet will wait as long as the timeout period to be routed to the destination port.

The two modes of operation are illustrated in the figures below (note the identical operation when a port is not started).



Packet completes

Figure 9-19 scenario 4 Destination Port Not Ready (Blocking allowed mode)



Packet completes

### Figure 9-20 scenario 4 Destination Port Not Ready (Blocking watchdog timer)



## **10. REGISTER DEFINITIONS**

This section describes the internal registers and the internal memory map of the SpaceWire Router.

The internal register size is 32 bits unless otherwise specified in the register summary. There are 263 registers in the configuration port addresses. The necessary 9-bit register address is provided by the one byte address field (A7-A0) in the command packet structure together with bit-2 of the command field (A8).

The following subsections contain register bit description tables which hold the following information:

- The bit numbers of each field
- A descriptive name for each field
- The reset value for each field
- A description of what the each field in the register is used for
- An indication of whether the field is readable and/or writeable by a configuration command.

Registers that are shorter than 32-bits or that have unused fields will return zero in all the unused bit positions when read. The unused bit positions are ignored during writing but should in any case be set to zero.

### 10.1 INTERNAL MEMORY MAP

The memory map for the SpaceWire Router is shown in Figure 10-1.



Figure 10-1 Router Internal Memory Map

| UNITERAL PO          |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
| 🔞 Austrian Aerospace | Data-Sheet       | Issue: | 2.0                          |
| W Austrian Aerospace |                  | Date:  | 18 <sup>th</sup> August 2006 |

The Group Adaptive Routing (GAR) registers map SpaceWire logical addresses 32-255 to the physical ports – SpaceWire ports or External ports. The link control/status registers allow the internal physical ports to report status information to a network manager and allow control bits to be set to determine the state of the physical ports. The router control/status registers allow the router management control and status information to be accessed by a network manager using configuration commands.

Table 10-1 provides an overview of each of the different type of register within the configuration port. Each register type is then described in detail in the following subsections.

|                       | Table 10-1 Types of Register within Configuration Port           |          |
|-----------------------|------------------------------------------------------------------|----------|
| Register Name         | Description                                                      | Address  |
| Group Adaptive        | Allows the setting of group adaptive routing logical addresses   | 32-255   |
| Routing Table         | by assigning the output ports which should be accessed when      | (0x20 –  |
| Registers             | a packet is received with logical address.                       | 0xFF)    |
| Port Control/Status   | Controls the Configuration, SpaceWire and External Ports.        | 0 – 31   |
| Registers             | Provides the status of the ports.                                | (0x00 –  |
|                       |                                                                  | 0x1F)    |
| Router Control/Status | Controls the overall operation of the router. Reports the router | 256-265  |
| Registers             | status.                                                          | (0x100 – |
|                       |                                                                  | 0x109)   |

## 10.2 REGISTER ADDRESSES SUMMARY

Table 10-2 lists all the registers in the configuration memory space.



**Data-Sheet** 

Ref.: UoD\_SpW-10X\_

DataSheet

🔞 Austrian Aerospace

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| Т                   | Table 10-2 Configuration Register Addresses |  |  |  |  |
|---------------------|---------------------------------------------|--|--|--|--|
| Address             | Register                                    |  |  |  |  |
| 31–0 (1Fh–00h)      | Port control/status registers               |  |  |  |  |
| 255–32 (FFh –20h)   | Group adaptive routing table registers      |  |  |  |  |
| 256 (100h)          | Network discovery register                  |  |  |  |  |
| 257 (101h)          | Router identity register                    |  |  |  |  |
| 258 (102h)          | Router control register                     |  |  |  |  |
| 259 (103h)          | Error active register                       |  |  |  |  |
| 260 (104h)          | Time-code register                          |  |  |  |  |
| 261 ( <i>105h</i> ) | Device Manufacturer and Chip ID register    |  |  |  |  |
| 262 (106h)          | General Purpose register                    |  |  |  |  |
| 263 (107h)          | Time-Code Enable register                   |  |  |  |  |
| 264 (108h)          | Clock Control register                      |  |  |  |  |
| 265 (109h)          | Destination Key Register                    |  |  |  |  |

## 10.3 GROUP ADAPTIVE ROUTING TABLE REGISTERS

The Group Adaptive Routing (GAR) table is accessed through configuration memory addresses 32-255 (20h-FFh).

The fields in the GAR registers are illustrated in Figure 10-2.



Figure 10-2 GAR Register Fields

| SHIVERENT Q          |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🔇 Austrian Aerospace |                  | Date:  | 18 <sup>th</sup> August 2006 |

The GAR table holds the routing table information that maps logical addresses to one or more port addresses. There is one entry (register) in the GAR table for each possible logical address. The configuration memory address range of the GAR table is 32-255 (20h – FFh). The configuration memory address corresponds to the logical address; hence the GAR table entry at address 39 corresponds to logical address 39.

The logical address to port mapping is held in the REQUEST field. Each bit in this field represents a physical output port; thus up to 28 possible output ports can be specified using the GAR register. When a bit is set in the REQUEST field packets may be routed to the corresponding output ports. The port number corresponds to the bit position in the GAR register. For example, if configuration memory address 39 has bit 2 set then a packet with logical address 39 may be routed out of port 2. If bits 2 and 4 are both set then the packet may be routed out of either port 2 or 4. Port 0, the configuration port, is a special port which can only be accessed using address 0 so this bit position in the GAR table registers is reserved and will always be set to zero.

Note that the SpaceWire ports are port numbers 1 to 8 and the External ports are ports 9 and 10.

The DEL\_HEAD bit, when set, causes the leading byte (header) of a packer to be deleted.

The PRIORITY bit determines the priority of the logical address when packets waiting at two input ports wish to use the same output port (1 = high priority, 0 = low priority).

The INVALID\_ADDR bit is set to indicate that the corresponding logical address is not valid.

Table 10-3 describes each field in the GAR register.



Ref.: UoD\_SpW-10X\_

DataSheet

🗿 Austrian Aerospace

### Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|       | Table 10-3 GAR Table Register Description |                             |                                                                                                                                                                                                                                                                  |            |  |
|-------|-------------------------------------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|
|       |                                           | Ad                          | ldress Range: 32-255 (20h – FFh)                                                                                                                                                                                                                                 |            |  |
| Bits  | Name                                      | Reset<br>Value              | Description                                                                                                                                                                                                                                                      | Read/Write |  |
| 0     | RESERVED                                  | '0'                         | Reserved bit – always set to zero.                                                                                                                                                                                                                               | R          |  |
| 10:1  | REQUEST                                   | All bits<br>set to<br>zero. | The request bits determine which output ports the logical address will arbitrate for. When bit one is set then SpaceWire port one will be requested. When bit two is set then SpaceWire port two will be accessed and so on.                                     | R/W        |  |
|       |                                           |                             | By setting more than one bit then group adaptive<br>routing can be used by allowing the input packet<br>to arbitrate for more than one output port.                                                                                                              |            |  |
|       |                                           |                             | If a write is performed and bits 10:1 are set to zero<br>then the INVALID_ADDR bit will be set and all<br>other bits will be set to zero                                                                                                                         |            |  |
|       |                                           |                             | Note: The configuration port (port 0) is not accessible through logical addresses.                                                                                                                                                                               |            |  |
| 28:11 | NOT USED                                  | -                           | -                                                                                                                                                                                                                                                                | -          |  |
| 29    | DEL_HEAD                                  | ʻ0'                         | Delete header: when set the leading header byte<br>of the input packet will be removed before it is<br>transferred to the output port.                                                                                                                           | R/W        |  |
| 30    | PRIORITY                                  | ·0'                         | When a packet addresses a logical address with<br>the Priority bit set then the packet will arbitrate for<br>output ports with higher priority than packets with<br>Priority bit set to zero.                                                                    | R/W        |  |
| 31    | INVALID_ADDR                              | '1'                         | When the Invalid Address bit is set it indicates that<br>the corresponding logical address is invalid. In this<br>case, any packets arriving at the router with an<br>invalid address are spilt and an address error is<br>reported in the port status register. | R/W        |  |

## 10.4 PORT CONTROL/STATUS REGISTERS

The port control/status registers address range is 31-0(1Fh - 0)

The port control/status registers provide the means to configure and control the ports of the router and for reading the status of each port. There is a port control/status register for each SpaceWire port, each External port and for the configuration port. The address in configuration memory space of a port control/status register reflects the physical address of the port. For example, the register for port 0, the configuration port, is at address 0, and the register for a SpaceWire port number 3 is at address 3. Each port control/status register is a 32-bit register.

The fields within the port control/status register depend on the type of port that it is attached to. All port control/status registers have fields for port type and current port connection. These generic fields will



be described first followed by the specific fields for the configuration port, SpaceWire ports and External ports.

Port control/status register bits 31:24 are generic to all ports. Register bits 23:0 are specific to the type of port to which the register is attached.

## 10.4.1 Generic port control/status register fields.

|       | Table 10-4 Configuration Port Control/Status Register Fields |                             |                                                                                                                                          |            |  |
|-------|--------------------------------------------------------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|------------|--|
| Bits  | Name                                                         | Reset<br>Value              | Description                                                                                                                              | Read/Write |  |
| 28:24 | Current port connection                                      | All bits<br>set to<br>one.  | The current port connection bits indicate the input<br>port which this output port is currently connected<br>to.                         | R          |  |
|       |                                                              |                             | Port number 31 (bits 28:24 set to 11111) means that there is no port currently connected to the input port. This is the reset condition. |            |  |
| 31:29 | Port Type                                                    | All bits<br>set to<br>zero. | Indicates the port type which corresponds the port<br>number of this port register. The port types are<br>listed below.                  | R          |  |
|       |                                                              |                             | "000" – Configuration port.                                                                                                              |            |  |
|       |                                                              |                             | "001" – SpaceWire port.                                                                                                                  |            |  |
|       |                                                              |                             | "010" – External port.                                                                                                                   |            |  |

The configuration port control/status fields are described in Table 10-4.

### 10.4.2 Configuration port control/status register fields.

The configuration port control/status fields specific to the configuration port are described in Table 10-5. Any errors occurring in the configuration port are reported via status bits in this register and the configuration command that caused the error is replied to with a NACK (i.e. the status byte in the reply contains an error code so is non-zero).

Note: these bits are cleared by writing to the Error Active register, see section 10.5.4.



Ref.: UoD\_SpW-10X\_

DataSheet

🔞 Austrian Aerospace

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|      |                                        |                | guration Port Control/Status Register Fields                                                                                                                         |            |
|------|----------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| Bits | Name                                   | Reset<br>Value | Description                                                                                                                                                          | Read/Write |
| 0    | Error active                           | '0'            | The error active bit is set when one of the error bits is active                                                                                                     | R          |
| 1    | Port timeout error                     | '0'            | The port timeout error bit is set when a timeout<br>event is detected by the configuration port<br>routing logic. A timeout event can occur as<br>specified in F4-4. | R          |
| 2    | Invalid Header<br>CRC                  | ʻ0'            | The Invalid header CRC bit is set when the header CRC is invalid.                                                                                                    | R          |
| 3    | Invalid Data CRC                       | '0'            | The invalid data CRC is set when the data part<br>of the packet is corrupted and the CRC does<br>not match the internally generated CRC.                             | R          |
| 4    | Invalid Destination<br>Key             | '0'            | The invalid destination key bit is set when the destination key in the command packet is invalid.                                                                    | R          |
| 5    | Command not<br>implemented             | '0'            | The command not implemented bit is set when<br>the command code is a valid RMAP code but<br>the command is not supported by the<br>SpaceWire Router.                 | R          |
| 6    | Invalid Data Length                    | ʻ0'            | The invalid data length bit is set when a data length error is detected                                                                                              | R          |
| 7    | Invalid RMW Data<br>Length             | '0'            | The read modify write command data length is invalid. When a read modify write is performed the expected data length is 8.                                           | R          |
| 8    | Invalid Destination<br>Logical Address | '0'            | The invalid destination logical address bit is set<br>when the destination logical address in the<br>command packet is not the default value of<br>254.              | R          |
| 9    | Early EOP                              | '0'            | The early EOP bit is set when the command<br>packet is terminated before the end of packet<br>with an EOP                                                            | R          |
| 10   | Late EOP                               | '0'            | The late EOP bit is set when the command<br>packet is not terminated correctly and trailing<br>bytes are detected before the end of packet.                          | R          |
| 11   | Early EEP                              | '0'            | The early EEP bit is set when the command packet is terminated before the end of packet with an EEP                                                                  | R          |
| 12   | Late EEP                               | '0'            | The late EEP bit is set when the command packet is not terminated correctly and trailing bytes are detected before the end of packet.                                | R          |
| 13   | Verify Buffer<br>Overrun Error         | ʻ0'            | The verify buffer overrun error bit is set when a verified write command is performed and the data length is not 4.                                                  | R          |



Data-Sheet

Ref.: UoD\_SpW-10X\_

DataSheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| 4.4   | Invalid Desister                         | (O) | The involid register address bit is get when on                                                                                                                   | D |
|-------|------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 14    | Invalid Register<br>Address              | ʻ0' | The invalid register address bit is set when an<br>unknown register address is given in the<br>command packet or a write is attempted to a<br>read only register  | R |
| 15    | Unsupported<br>protocol error            | ʻ0' | The unsupported protocol error bit is set when<br>a command packet is received with a protocol<br>identifier which is not the RMAP protocol<br>identifier of 01h. | R |
| 16    | Source logical<br>address error          | ʻ0' | The source logical address error bit is set when an invalid source logical address is received.                                                                   | R |
| 17    | Source Path<br>Address Error             | ʻ0' | The source path address sequence is invalid.                                                                                                                      | R |
| 18    | Cargo too large                          | '0' | The RMAP command packet is too large                                                                                                                              | R |
| 19    | Unused RMAP<br>command or packet<br>type | '0' | The command code is an unused command code or the packet type is invalid as specified in F1-8.                                                                    | R |
| 23:20 | Not Used                                 | -   | -                                                                                                                                                                 | - |

| UNIVERSITY OF        |                  | Ref.:  | UoD_SpW-10X_                 |
|----------------------|------------------|--------|------------------------------|
| EADS<br>ASTRIUM      | SpaceWire Router |        | DataSheet                    |
|                      | Data-Sheet       | Issue: | 2.0                          |
| 🔞 Austrian Aerospace |                  | Date:  | 18 <sup>th</sup> August 2006 |

## 10.4.3 SpaceWire link interface port control/status register bits.

The port control/status fields specific to SpaceWire ports are shown in Figure 10-3 and Table 10-6.



## Figure 10-3 SpaceWire Port Control/Status Register Fields

Note: these bits are cleared by writing to the Error Active register, see section 10.5.4.



Data-Sheet

Issue: 2.0

18<sup>th</sup> August 2006 Date:

|      | Table 10-6 SpaceWire Port Control/Status Register Fields. |             |                                                                                                                                                                               |            |  |
|------|-----------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|
| Bits | Name                                                      | Reset Value | Description                                                                                                                                                                   | Read/Write |  |
| 0    | Error active                                              | ʻ0'         | The error active bit is set when one of the error bits are set.                                                                                                               | R          |  |
| 1    | Packet<br>address error                                   | ,0,         | The packet address error bit is set when a packet is received with an incorrect address.                                                                                      | R          |  |
| 2    | Output port<br>timeout error                              | ,0,         | The output timeout error bit set<br>when the output port has become<br>blocked for a period of time.                                                                          | R          |  |
| 3    | Disconnect<br>error                                       | ,0,         | The disconnect error bit is set<br>when a disconnect error occurs<br>on the SpaceWire link                                                                                    | R          |  |
| 4    | Parity error                                              | ,0,         | The parity error bit is set when a parity error occurs on the SpaceWire link                                                                                                  | R          |  |
| 5    | Escape error                                              | ,0,         | The escape error bit is set when<br>an escape error occurs on the<br>SpaceWire link                                                                                           | R          |  |
| 6    | Credit error                                              | ,0,         | The credit error bit is set when a credit error occurs on the SpaceWire link                                                                                                  | R          |  |
| 7    | Character<br>sequence<br>error                            | ,0,         | The character sequence error bit<br>is set when a character sequence<br>error occurs on the SpaceWire<br>link                                                                 | R          |  |
| 10:8 | Interface<br>state                                        | "000"       | The interface state bits indicate<br>the state of the interface state<br>machine in the SpaceWire link.                                                                       | R          |  |
|      |                                                           |             | "000" = Error Reset                                                                                                                                                           |            |  |
|      |                                                           |             | "001" = Error Wait                                                                                                                                                            |            |  |
|      |                                                           |             | "010" = Ready                                                                                                                                                                 |            |  |
|      |                                                           |             | "011" = Started                                                                                                                                                               |            |  |
|      |                                                           |             | "100" = Connecting                                                                                                                                                            |            |  |
|      |                                                           |             | "101" = Run                                                                                                                                                                   |            |  |
| 11   | Running                                                   | ,0,         | The running bit is set when the SpaceWire interface state machine is in the Run state.                                                                                        | R          |  |
| 12   | AutoStart                                                 | '1'         | When set the SpaceWire link will<br>autostart as defined in the<br>SpaceWire standard [AD1]: the<br>SpaceWire port will wait until the<br>other end of the link tries to make | R/W        |  |



Data-Sheet

Ref.: UoD\_SpW-10X\_

DataSheet

**Over the set of the s** 

Issue: 2.0

Date: 18<sup>th</sup> August 2006

| 13       Start       '0'       When set then the SpaceWire in the SpaceWire jort will try to make a connection with the other end of the link.       R/W         14       Disable       '0'       When set then the SpaceWire jort will try to make a connection with the other end of the link.       R/W         14       Disable       '0'       When set then the SpaceWire jort will not start and will not respond to any attempt to make a connection by the other end of the link.       R/W         15       Tri-state       '0'       When set the DOUT and SOUT serial SpaceWire jort will not start and will not respond to any attempt to make a connection by the other end of the link.       R/W         15       Tri-state       '0'       When set the DOUT and SOUT serial SpaceWire link interface. The DOUT and SOUT tri-state output state mappings are listed below:       R/W         22:16       Transmitter data signaling rate (DOP)       Bits 18 to 16 are set according to the spaceWire link data signaling rate to be set. Tri-state       R/W         22:16       Transmitter data signaling rate (TXRATE)       Bits 22:18 are set to zero.       Allows the SpaceWire link data signaling rate to be set. Tri-state = TXRATE(2:0) pins. Bits 22:18 are set to zero.       R/W         22:16       Not Used       -       -       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                 |                              | a connection and will then automatically start.                                                                                                                             |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Ink will be disabled as defined in<br>the SpaceWire standard [AD1]:<br>the SpaceWire istandard [AD1]:<br>the SpaceWire point to any<br>attempt to make a connection by<br>the other end of the link.       RW         15       Tri-state       0'       When set the DOUT and SOUT<br>serial SpaceWire point he state of<br>the SpaceWire point in the state of<br>the SpaceWire point is the state of<br>the SpaceWire point is the state of<br>the SpaceWire point is state on the state of<br>the SpaceWire point is the state of<br>the SpaceWire point is the state on the state of<br>the SpaceWire point is the state on the state of<br>the SpaceWire point is the state on the state of<br>the system clock cycle before SOUT<br>to ensure simultaneous edges<br>due to tris-stated on on coccur.       RW         22:16       Transmitter<br>data<br>signalling rate<br>(TXRATE)       Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.       Allows the SpaceWire link data<br>signalling rate to be set.<br>The transmit rate is<br><u>TXClkFreq * 2</u><br><u>TXRATE + 1</u><br>where TXClkFreq is the output<br>frequency of the transmit clock<br>PLL.<br>Note: bits 22:16 must not be set<br>to all ones. Its 22:16 must not be set<br>to all ones. Bits 22:16 must not be set to all ones. Bits 22:16 must not be set<br>to all ones. Bits 22:16 must not be set<br>to all one | 13    | Start           | ,0,                          | link will initiate start-up as defined<br>in the SpaceWire standard [AD1]:<br>the SpaceWire port will try to<br>make a connection with the other                            | R/W |
| Serial SpaceWire signals will be<br>reset dependent on the state of<br>the SpaceWire link interface.<br>The DOUT and SOUT tri-state<br>output state mappings are listed<br>below.Serial SpaceWire signals will be<br>reset dependent on the state of<br>the SpaceWire link interface.<br>The DOUT and SOUT tri-state<br>output state mappings are listed<br>below.ErrorReset $\rightarrow$ Tri-state<br>ErrorWait $\rightarrow$ Tri-state<br>Started $\rightarrow$ Enabled<br>Connecting $\rightarrow$ Enabled<br>Run $\rightarrow$ Enabled<br>Note: DOUT is tri-stated one<br>system clock cycle before SOUT<br>to ensure simultaneous edges<br>due to tris-state do not occur.22:16Transmitter<br>data<br>signalling rate<br>(TXRATE)Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.Allows the SpaceWire link data<br>signalling rate is<br>$\frac{TxClkFreq * 2}{TXRATE + 1}$<br>where TxClkFreq is the output<br>frequency of the transmit clock<br>PLL.<br>Note: bits 22:16 must not be set<br>to all ones. Bits 22:16 must not<br>be s                                                                                                | 14    | Disable         | ،0,                          | link will be disabled as defined in<br>the SpaceWire standard [AD1]:<br>the SpaceWire port will not start<br>and will not respond to any<br>attempt to make a connection by | R/W |
| $\begin{array}{ c c c c c c } \hline \begin{tabular}{ c c c c c } \hline \begin{tabular}{ c c c c } \hline \begin{tabular}{ c c c c c c c } \hline \begin{tabular}{ c c c c c c c } \hline \begin{tabular}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 15    | Tri-state       | ,0,                          | serial SpaceWire signals will be<br>reset dependent on the state of<br>the SpaceWire link interface.<br>The DOUT and SOUT tri-state<br>output state mappings are listed     | R/W |
| $\begin{array}{ c c c c c } \hline Ready & \rightarrow \text{Tri-state} \\ Started & \rightarrow \text{Enabled} \\ \hline Connecting & \rightarrow \text{Enabled} \\ \hline Run & \rightarrow \text{Enabled} \\ \hline Run & \rightarrow \text{Enabled} \\ \hline Note: DOUT is tri-stated one \\ system clock cycle before SOUT \\ to ensure simultaneous edges \\ due to tris-state do not occur. \\ \hline \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |                 |                              | ErrorReset → Tri-state                                                                                                                                                      |     |
| Started $\rightarrow$ EnabledConnecting $\rightarrow$ EnabledRun $\rightarrow$ EnabledRun $\rightarrow$ EnabledNote: DOUT is tri-stated one<br>system clock cycle before SOUT<br>to ensure simultaneous edges<br>due to tris-state do not occur.22:16Transmitter<br>data<br>signalling rate<br>(TXRATE)Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.Allows the SpaceWire link data<br>signalling rate to be set.<br>The transmit rate isR/W $\frac{TxClkFreq * 2}{TXRATE + 1}$<br>where TxClkFreq is the output<br>frequency of the transmit clock<br>PLL.<br>Note: bits 22:16 must not be set<br>to all ones. Bits 22:16 must not be set<br>to all ones. Bits 22:16 must not<br>be set to give a transmit rate of<br>less than 2 Mbits/s.R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |                 |                              | ErrorWait → Tri-state                                                                                                                                                       |     |
| $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |                 |                              | Ready → Tri-state                                                                                                                                                           |     |
| 22:16Run<br>Note:Enabled<br>Note:22:16Transmitter<br>data<br>signalling rate<br>(TXRATE)Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.Allows the SpaceWire link data<br>signalling rate to be set.<br>The transmit rate isR/W $\frac{TxClkFreq * 2}{TXRATE + 1}$<br>where TxClkFreq is the output<br>frequency of the transmit clock<br>PLL.<br>Note: bits 22:16 must not be set<br>to all ones. Bits 22:16 must not<br>be set to give a transmit rate of<br>less than 2 Mbits/s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                 |                              | Started $\rightarrow$ Enabled                                                                                                                                               |     |
| 22:16Transmitter<br>data<br>signalling rate<br>(TXRATE)Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.Allows the SpaceWire link data<br>signalling rate to be set.<br>The transmit rate isR/W22:16Transmitter<br>data<br>signalling rate<br>(TXRATE)Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.Allows the SpaceWire link data<br>signalling rate to be set.<br>The transmit rate isR/W22:16Transmitter<br>DOR_TX_RATE<br>(TXRATE)Mere TxClkFreq * 2<br>TXRATE + 1R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                 |                              | Connecting $\rightarrow$ Enabled                                                                                                                                            |     |
| 22:16Transmitter<br>data<br>signalling rate<br>(TXRATE)Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.Allows the SpaceWire link data<br>signalling rate to be set.<br>The transmit rate isR/W <i>Market Colspan="3"</i> 22:16Transmitter<br>data<br>signalling rate<br>(TXRATE)Bits 18 to 16 are set<br>according to the<br>POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.Allows the SpaceWire link data<br>signalling rate to be set.<br>The transmit rate isR/W <i>Market Colspan="3"&gt;Market Colspan="3"</i> 22:16Market Colspan="3">Market Colspan="3">Market Colspan="3"22:16Market Colspan="3">Market Colspan="3"23:16Market Colspan="3">Market Colspan="3"24:17Market Colspan="3">Market Colspan="3"25:18Market Colspan="3">Market Colspan="3"26:17Market Colspan="3">Market Colspan="3"27:18Market Colspan="3">Market Colspan="3"27:18Market Colspan="3">Market Colspan="3"28:18Market Colspan="3">Market Colspan="3"29:18Market Colspan="3"29:19Market Colspan="3"29:19Market Colspan="3"29:19Market Colspan="3"29:10Market Colspan="3"20:10Market Colspan="3"20:11Market Colspan="3"20:12Market Colspan="3"20:12Market Colspan="3"20:12Market Colspan="3"20:12Market Colspan="3"20:12Market Colspan="3"20:12Market Colspan="3"20:12Market Colspan=                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                 |                              | Run $\rightarrow$ Enabled                                                                                                                                                   |     |
| $ \begin{array}{c} \text{data}\\ \text{signalling rate}\\ (TXRATE) \end{array} \begin{array}{c} \text{according to the}\\ \text{POR_TX_RATE(2:0) pins.}\\ \text{Bits 22:18 are set to zero.} \end{array} \begin{array}{c} \text{signalling rate to be set.}\\ \text{The transmit rate is}\\ \frac{TxClkFreq * 2}{TXRATE + 1}\\ \text{where TxClkFreq is the output}\\ \text{frequency of the transmit clock}\\ \text{PLL.}\\ \text{Note: bits 22:16 must not be set}\\ \text{to all ones. Bits 22:16 must not}\\ \text{be set to give a transmit rate of}\\ \text{less than 2 Mbits/s.} \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |                 |                              | system clock cycle before SOUT to ensure simultaneous edges                                                                                                                 |     |
| signalling rate<br>(TXRATE)POR_TX_RATE(2:0) pins.<br>Bits 22:18 are set to zero.The transmit rate is $TXRATE$ $TXRATE$ $TxClkFreq * 2$<br>TXRATE +1where TxClkFreq is the output<br>frequency of the transmit clock<br>PLL.where TxClkFreq is the output<br>frequency of the transmit clock<br>PLL.Note: bits 22:16 must not be set<br>to all ones. Bits 22:16 must not<br>be set to give a transmit rate of<br>less than 2 Mbits/s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 22:16 |                 |                              | •                                                                                                                                                                           | R/W |
| $\frac{TxClkFreq * 2}{TXRATE + 1}$ where TxClkFreq is the output<br>frequency of the transmit clock<br>PLL. Note: bits 22:16 must not be set<br>to all ones. Bits 22:16 must not<br>be set to give a transmit rate of<br>less than 2 Mbits/s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | signalling rate | POR_TX_RATE(2:0) pins.       | <b>o o</b>                                                                                                                                                                  |     |
| TXRATE + 1         where TxClkFreq is the output         frequency of the transmit clock         PLL.         Note: bits 22:16 must not be set         to all ones. Bits 22:16 must not         be set to give a transmit rate of         less than 2 Mbits/s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       | (IARAIE)        | DILS 22. 10 dre Set to Zefo. | TxClkFrea * 2                                                                                                                                                               |     |
| frequency of the transmit clock<br>PLL.<br>Note: bits 22:16 must not be set<br>to all ones. Bits 22:16 must not<br>be set to give a transmit rate of<br>less than 2 Mbits/s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |                 |                              |                                                                                                                                                                             |     |
| to all ones. Bits 22:16 must not<br>be set to give a transmit rate of<br>less than 2 Mbits/s.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                 |                              | frequency of the transmit clock                                                                                                                                             |     |
| 23 Not Used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |                 |                              | to all ones. Bits 22:16 must not be set to give a transmit rate of                                                                                                          |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 23    | Not Used        | -                            | -                                                                                                                                                                           | -   |



### 10.4.4 External port control/status register bits.

The port control/status fields specific to the External port are described in Table 10-7.

|      | Table 10-7 External Port Contol/Status Fields |                |                                                                                                                                                                                                |            |  |
|------|-----------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|
| Bits | Name                                          | Reset<br>Value | Description                                                                                                                                                                                    | Read/Write |  |
| 0    | Error Active                                  | '0'            | This bit is set to one when any of the error bits are set.                                                                                                                                     | R          |  |
| 1    | Packet<br>Address<br>Error                    | ʻ0'            | The packet address error bit is set when a packet is<br>received with an incorrect address. A packet address<br>error is also generated when an empty packet is input<br>to the external port. | R          |  |
| 2    | Output port<br>timeout<br>error               | ʻ0'            | The output timeout error bit is set when the output port has become blocked for a period of time.                                                                                              | R          |  |
| 3    | Input Buffer<br>Empty                         | ʻ0'            | The external port input buffer is empty.<br>Note: The input buffer writes data to the SpaceWire<br>router.                                                                                     | R          |  |
| 4    | Input Buffer<br>Full                          | ʻ0'            | The external port input buffer is full.                                                                                                                                                        | R          |  |
| 5    | Output<br>Buffer<br>Empty                     | ʻ0'            | The external output port buffer is empty.<br>Note: The output buffer writes data to the external<br>device connected to the external port.                                                     | R          |  |
| 6    | Output<br>Buffer Full                         | ʻ0'            | The external output port buffer is full.                                                                                                                                                       | R          |  |
| 23:5 | Not used                                      | -              | -                                                                                                                                                                                              | -          |  |

Note: these bits are cleared by writing to the Error Active register, see section 10.5.4.

## 10.5 ROUTER CONTROL/STATUS REGISTERS

The router control/status registers are described below.

### 10.5.1 Network Discovery Register

The network discovery register address is 256 (100h).

The network discovery register allows a network manager to determine the layout of the network by reading the contents of the register. Its fields are shown in Figure 10-4 and described in Table 10-8.





|      | Table 10-8 Network Discovery Register Fields |                            |                                                                                                                                                                                                                                                       |            |  |
|------|----------------------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|
| Bits | Description                                  | Reset<br>Value             | Usage                                                                                                                                                                                                                                                 | Read/Write |  |
| 3:0  | Device Type                                  | "0001"                     | The device type field indicates the type of device<br>which is associated with this network discovery<br>register. At present there is only one device type<br>defined, the Router, along with the unknown device<br>type.<br>"0000" – Unknown Device | R          |  |
|      |                                              |                            | "0001" – Router                                                                                                                                                                                                                                       |            |  |
| 7:4  | Return Port                                  | All bits<br>set to<br>zero | Indicates the input port number which accessed this network discovery register.                                                                                                                                                                       | R          |  |
| 31:8 | Ports in Run state                           | All bits set to            | Indicates the SpaceWire ports which are in the run state. Bit 8 corresponds to SpaceWire port 1.                                                                                                                                                      | R          |  |
|      |                                              | zero                       | The external ports are the highest numbered port and<br>the corresponding register bits are set to one. In this<br>way a network manager can determine the number of<br>ports and the active ports in one register read.                              |            |  |

## 10.5.2 Router Identity Register

The router identity register address is 257 (101h).

The router identity register allows a network manager to assign a 32 bit ID to a SpaceWire router device by writing to this register. It may also be used for other purposes. The router identity register is described in Table 10-9.



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

Issue: 2.0 Date: 18<sup>th</sup> August 2006

| Table 10-9 Router Identity Register Field |                    |                         |                                                                                                                    |            |  |
|-------------------------------------------|--------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------|------------|--|
| Bits                                      | Description        | Reset<br>Value          | Usage                                                                                                              | Read/Write |  |
| 31:0                                      | Router<br>Identity | All bits set<br>to zero | A 32-bit read/write register which may be used to hold a unique router identity code for each router in a network. | R/W        |  |

## 10.5.3 Router Control Register

The router control register address is 258 (102h).

The router control register sets various control bits in the SpaceWire router. Router functions which can be controlled are:

- Request an output port to initiate start-up when an input packet addresses the port and the output port is not ready to receive data.
- Disable an input/output port when no activity is detected on the port for the timeout period duration.
- Enable output port timeouts which request the output port to flush when a packet becomes blocked for a timeout period.
- Enable the a router ports to address themselves i.e. provide a loop-back capability.

The router control register fields are shown in Figure 10-5 and described in Table 10-10.



Figure 10-5 Router Control Register Fields



Ref.: UoD\_SpW-10X\_

DataSheet

Data-Sheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|      |                                      | Table 10-10 Router Control R                                                           | egister Fields                                                                                                          |                |
|------|--------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------|
| Bits | Name                                 | Reset Value                                                                            | Description                                                                                                             | Read/<br>Write |
| 0    | Watchdog<br>Timer Mode<br>/ Blocking | Set by the input signal<br><b>POR_TIMEOUT_EN_N</b> .<br>When '0' – Watchdog Timer Mode | When set to '1' then the watchdog timer mode is enabled.                                                                | R/W            |
|      | Allowed<br>Mode                      | When '1' – Blocking Allowed Mode                                                       | When set to '0' then the<br>blocking allowed mode is<br>enabled.                                                        |                |
| 3:1  | Timeout<br>Selection                 | Set by the input signal <b>POR_SEL_TIMEOUT0_N</b> .                                    | Selects the blockage timeout period. Values as below:                                                                   | R/W            |
|      |                                      | When 0, timeout period is 100 us.                                                      | "000" => 60-100 us (N = 2)                                                                                              |                |
|      |                                      | When 1, timeout period is 1 ms.                                                        | "001" => ~1.3 ms (N = 6)                                                                                                |                |
|      |                                      |                                                                                        | "010" => ~10 ms (N = 9)                                                                                                 |                |
|      |                                      |                                                                                        | "011" => ~82 ms (N = 12)                                                                                                |                |
|      |                                      |                                                                                        | "100" => ~1.3 s (N = 16)                                                                                                |                |
|      |                                      |                                                                                        | "101" => ~1.3 s (N = 16)                                                                                                |                |
|      |                                      |                                                                                        | "110" => ~1.3 s (N = 16)                                                                                                |                |
|      |                                      |                                                                                        | "111" => ~1.3 s (N = 16)                                                                                                |                |
|      |                                      |                                                                                        | The actual value of the timeout period is given by:                                                                     |                |
|      |                                      |                                                                                        | 200 x (2^N) x TCLK                                                                                                      |                |
|      |                                      |                                                                                        | +/- 200 x TCLK                                                                                                          |                |
|      |                                      |                                                                                        | where TCLK is the period of the 10 MHz clock signal.                                                                    |                |
| 4    | Enable<br>disable on<br>silence      | Set by the input signal <b>POR_DISABLE_ON_SILENCE_N</b> .                              | When set the corresponding<br>port will be disabled if no activity<br>is detected over the timeout<br>period.           | R/W            |
|      |                                      |                                                                                        | The port will only be disabled if<br>the port was initially started by<br>the router using the start on<br>request bit. |                |
|      |                                      |                                                                                        | If an external device starts the link then the port will not be disabled.                                               |                |
|      |                                      |                                                                                        | Events which cause the disable<br>on silence timeout to be reset<br>are                                                 |                |
|      |                                      |                                                                                        | Input port data read.                                                                                                   |                |



**Data-Sheet** 

Ref.: UoD\_SpW-10X\_

DataSheet

🚳 Austrian Aerospace

Issue: 2.0

Date: 18<sup>th</sup> August 2006

|      |                            |                                                     | Output port data write.                                                                                                                                                                                                                                                                                                                                                                                                   |     |
|------|----------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 5    | Enable start<br>on request | Set by the input signal <b>POR_START_ON_REQ_N</b> . | When set the arbiter will request<br>the output port to start-up if an<br>input port receives a packet<br>which is destined for the output<br>port.                                                                                                                                                                                                                                                                       | R/W |
|      |                            |                                                     | Note: if the output port link disable bit is set then the link will not start.                                                                                                                                                                                                                                                                                                                                            |     |
| 6    | Enable Self<br>Addressing  | Set by the input signal<br>POR_ADDR_SELF_N          | When set input ports are<br>permitted to address<br>themselves.                                                                                                                                                                                                                                                                                                                                                           | R/W |
|      |                            |                                                     | If this bit is not set and a packet<br>is to be routed through the<br>same port then an address error<br>is reported and the packet is<br>discarded.                                                                                                                                                                                                                                                                      |     |
|      |                            |                                                     | When this bit is not set and a<br>group adaptive routing packet is<br>received (a packet which can be<br>routed through two or more<br>ports, dependent on the group<br>adaptive routing table contents)<br>which can be routed through the<br>port it arrived on then the packet<br>is routed through one of the<br>other ports and not the port on<br>which the packet arrived on. An<br>address error is not reported. |     |
| 31:7 | Not Used                   | All bits set to zero                                | -                                                                                                                                                                                                                                                                                                                                                                                                                         | R   |

## 10.5.4 Error active Register

The error active register address is 259 (103h).

The error active register indicates the Error Active bit of the port control/status registers. By reading from this register a network manager can determine which ports currently have errors. This register is also used to clear the error bits of the port control/status registers. To do this a write command is sent to the error active register with bits set for those errors that are to be cleared.

The error active register fields are shown in

Figure 10-6 and described in Table 10-11.



### Figure 10-6 Error Active Register Fields

|      | Table 10-11 Error Active Register Fields       |                            |                                                                                                                                                                                |            |  |  |
|------|------------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|--|
| Bits | Name                                           | Reset<br>Value             | Description                                                                                                                                                                    | Read/Write |  |  |
| 0    | Configuration Port<br>Error Active             | ʻ0'                        | Indicates that the Error Active bit in the configuration port is asserted.                                                                                                     | R/W        |  |  |
|      |                                                |                            | A write to this register with bit 0 set will clear all<br>the error flags in the configuration port<br>control/status register.                                                |            |  |  |
| 30:1 | SpaceWire and<br>External Port Error<br>Active | All bits<br>set to<br>zero | Indicates that the Error Active bit in the corresponding number SpaceWire or External port is asserted.                                                                        | R/W        |  |  |
|      |                                                |                            | A write to this register with one or more of<br>these bits set will clear all the error flags in the<br>corresponding SpaceWire and External port<br>control/status registers. |            |  |  |
|      |                                                |                            | When writing to this register with all bits set all error flags in all port control/status registers are cleared.                                                              |            |  |  |
| 31   | Not used                                       | All bits<br>set to<br>zero | Not used because there are a maximum of 30<br>SpaceWire / External ports supported by the<br>router design.                                                                    | R          |  |  |

## 10.5.5 Time-Code Register

The time-code register address is 260 (104h).

The time-code register contains the current value of the internal time-code register. Its fields are shown in Figure 10-7and described in Table 10-12.





| Table 10-12 Time-Code Register Fields |                 |                      |                       |            |  |
|---------------------------------------|-----------------|----------------------|-----------------------|------------|--|
| Bits                                  | Name            | Reset Value          | Description           | Read/Write |  |
| 5:0                                   | Time Value      | All bits set to zero | 6-bit time-code value | R          |  |
| 7:6                                   | Time-Code Flags | "00"                 | Two time-code flags   | R          |  |
| 31:8                                  | Not used        | All bits set to zero |                       | R          |  |

# 10.5.6 Device Manufacturer and Chip ID Register

The device manufacturer and chip ID register address is 261 (105h).

This register contains three eight-bit fields which hold a device manufacturer identity, chip identity and version number. The fields of the device manufacturer and chip ID register are shown in Figure 10-8 and described in Table 10-13.



Figure 10-8 Device Manufacturer and Chip ID Register Fields



Ref.: UoD SpW-10X

DataSheet

Austrian Aerospace

**Data-Sheet** 

Issue: 18<sup>th</sup> August 2006 Date:

2.0

| Bits Name Reset Value Description Read/W |                      |                                  |                                                                                                      |            |  |  |
|------------------------------------------|----------------------|----------------------------------|------------------------------------------------------------------------------------------------------|------------|--|--|
| DILS                                     | Name                 | Reset value                      | Description                                                                                          | Reau/wille |  |  |
| 7:0                                      | Version<br>Number    | Version Number of<br>chip design | Version number of the chip design                                                                    | R          |  |  |
| 15:8                                     | Chip ID Code         | Chip type                        | Identity code for the SpaceWire chip from the particular manufacturer                                | R          |  |  |
| 23:16                                    | Manufacturer<br>Code | Manufacturer identity code       | Manufacturer identity code<br>"00000000" = Unknown Manufacturer<br>"00000001" = University of Dundee | R          |  |  |
| 31:24                                    | Not used             | All bits set to zero             |                                                                                                      | R          |  |  |

## 10.5.7 General Purpose Register

The general purpose register address is 262 (106h).

The general purpose register contains 32-bits and may be set by a configuration write command to a user defined value as required. It may also be read with a configuration read command. The general purpose register has no effect on the operation of the router.

The least-significant 8-bits of the general purpose register are available on the multiplexed status pins, see section 5.3.

## 10.5.8 Time-Code Enable Register

The time-code enable register address is 263 (107h).

The time-code enable register enables the passing of time-codes out of individual ports on the router. Bits 1 to 8 of the time-code enable register are used to enable time-code distribution through SpaceWire ports 1 to 8 respectively. If one of these bits is set to 1 then the corresponding SpaceWire port is enable for time-code distribution and will send out a time-code when one is received by the router. For example, if bit-1 in the enable register is set to 1, time-codes are passed to SpaceWire port 1, whereas if bit-1 is set to 0, time-codes are not passed to SpaceWire port 1.

Bit-9 of the time-code enable register controls time-code distribution to the external time-code interface in a similar manner. Note that there is only one external time-code interface although there are two External ports.

The fields of the time-code enable register are shown in Figure 10-9 and described in Table 10-14.



### Figure 10-9 Time-Code Enable Register Fields

| Bits  | Name                                   | Reset<br>Value          | Description                                                                   | Read/Write |
|-------|----------------------------------------|-------------------------|-------------------------------------------------------------------------------|------------|
| 0     | Reserved                               | 0                       | Reserved bit                                                                  | R          |
| 8:1   | SpaceWire Time-Code<br>Enable          | 0                       | Time-code distribution enable bits for<br>SpaceWire ports 8 to 1 respectively | R/W        |
| 9     | External Time-Code<br>Interface Enable | 1                       | Time-code distribution enable for<br>External time-code port                  | R/W        |
| 31:10 | Not used                               | All bits set<br>to zero |                                                                               | R          |

## 10.5.9 Transmit Clock Control Register

The transmit clock control register address is 264 (108h).

The transmit clock control register is shown below. Bits 1 to 0 are used to determine the output divide ratio for the transmit clock internal PLL. Bits 15 to 8 are used to stop the transmitter clocks of SpaceWire interfaces that are not being used to save power. Bits 20 to 16 are used to set the default 10Mbits/s transmit data rate.

Note: The transmit clock should not be disabled when an output port is sending data or when the interface is in the run state. The port control/status registers can be used to determine if an output port is currently connected to an input port and therefore transferring data.

WARNING: If the link that is being used to configure the router is has its transmit clock turned off then it will not be possible to configure the router, unless there is another connection with an active clock and which is not disabled that can be used.



Figure 10-10 Transmit clock control register

The transmit clock control register



UoD\_SpW-10X\_ Ref.:

DataSheet

Issue: 2.0

18<sup>th</sup> August 2006 Date:

|       | Table 10-15 Transmit Clock Control Register Bits |                                     |                                                                                                                                                                                                                   |                                                                                   |     |  |
|-------|--------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----|--|
| Bits  | Name                                             | Reset Value                         | Description                                                                                                                                                                                                       | Read/Write                                                                        |     |  |
| 1:0   | TXDIV                                            | "01"                                | Transmit clock internal PLL output<br>divider. Selects the divided output from<br>the transmit clock as follows                                                                                                   | R/W                                                                               |     |  |
|       |                                                  |                                     | "00" → divide by 2                                                                                                                                                                                                |                                                                                   |     |  |
|       |                                                  |                                     | "01" → divide by 4                                                                                                                                                                                                |                                                                                   |     |  |
|       |                                                  |                                     | "10" → divide by 8                                                                                                                                                                                                |                                                                                   |     |  |
|       |                                                  |                                     | "11" $\rightarrow$ divide by 8                                                                                                                                                                                    |                                                                                   |     |  |
|       |                                                  |                                     | <b>Example</b> : If the PLL output frequency is 200MHz (set by FEEDBDIV, see section 4.1) and TXDIV = 01 then the transmit clock frequency will be 50MHz and the transmit data rate will be 100Mbit/s             |                                                                                   |     |  |
| 7:2   | Not used                                         | All bits set to zero                | -                                                                                                                                                                                                                 | R                                                                                 |     |  |
| 15:8  | Enable clock                                     | All bits set to 1                   | Enable the transmit clock trees. Setting a bit to zero disables the transmit clock for the corresponding interface, i.e. setting bit zero to zero causes the transmit clock for SpaceWire link one to be stopped. | R/W                                                                               |     |  |
| 20:16 | Tx10MbitDIV                                      |                                     | Dependent on<br>FEEDBDIV at reset                                                                                                                                                                                 | Set the default 10Mbit/s data rate divider value. The Tx10MbitDIV value should be | R/W |  |
|       |                                                  | <b>FEEDBDIV=</b> "000"<br>→ "00100" | set as shown in Figure 10-11.                                                                                                                                                                                     |                                                                                   |     |  |
|       |                                                  | <b>FEEDBDIV</b> ="001"<br>→ "00101" |                                                                                                                                                                                                                   |                                                                                   |     |  |
|       |                                                  | <b>FEEDBDIV=</b> "010"<br>→ "00110" |                                                                                                                                                                                                                   |                                                                                   |     |  |
|       |                                                  | <b>FEEDBDIV=</b> "011"<br>→ "00111" |                                                                                                                                                                                                                   |                                                                                   |     |  |
|       |                                                  | <b>FEEDBDIV=</b> "100"<br>→ "01000" |                                                                                                                                                                                                                   |                                                                                   |     |  |
|       |                                                  | <b>FEEDBDIV=</b> "101"<br>→ "01001" |                                                                                                                                                                                                                   |                                                                                   |     |  |
|       |                                                  | <b>FEEDBDIV</b> ="110"<br>→ "01001" |                                                                                                                                                                                                                   |                                                                                   |     |  |
|       |                                                  | <b>FEEDBDIV=</b> "111"<br>→ "01001" |                                                                                                                                                                                                                   |                                                                                   |     |  |
| 31:21 | Not used                                         | All bits set to zero                | -                                                                                                                                                                                                                 | R                                                                                 |     |  |

SpaceWire Router

Data-Sheet



112



Ref.: UoD\_SpW-10X\_ DataSheet Issue: 2.0 Date: 18<sup>th</sup> August 2006





### Figure 10-11 Tx10MBitDIV equation

Note: If Tx10MbitDIV is an odd number then the duty cycle on DOUT and SOUT will not be 50/50.

### 10.5.10 Destination Key Register

The Destination Key register address is 265 (109h).

The destination key register fields are listed in the table below.

|      | Table 10-16 Destination Key Register |                         |                                                                                                                               |            |  |  |  |
|------|--------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------|------------|--|--|--|
| Bits | Name                                 | Reset<br>Value          | Description                                                                                                                   | Read/Write |  |  |  |
| 7:0  | DESTKEY                              | 20h                     | The destination key is checked when a security key is required for RMAP configuration packets to access the router registers. | R/W        |  |  |  |
| 31:8 | Not used                             | All bits set<br>to zero | -                                                                                                                             |            |  |  |  |

## 10.5.11 Unused Registers and Register Bits

If an unused register address is referenced in a configuration command then the command will not be acted upon and a NACK will be sent in the reply to the command.

All unused bits in valid configuration registers will return '0' when read.

## 10.5.12 Empty packets

An empty packet received at the configuration port are discarded by the configuration port and no reply packet is sent. An empty packet has no address or cargo bytes and consists only of an EOP.

## 10.6 WRITING TO A READ-ONLY REGISTER

If a write command is sent with a register address that corresponds to a register whose entire contents is read only, then an error will be generated. See section 10.4.2.



### Data-Sheet

## 11. DOCUMENT CHANGES

### 11.1 ISSUE 1.7 TO ISSUE 2.0

| Section | Ref | Change                                                 |
|---------|-----|--------------------------------------------------------|
| All     |     | Final updates and editorial corrections before release |

### 11.2 ISSUE 1.6 TO ISSUE 1.7

| Section | Ref | Change                                 |
|---------|-----|----------------------------------------|
| All     |     | Corrections added following validation |

## 11.3 ISSUE 1.5 TO ISSUE 1.6

| Section | Ref | Change             |
|---------|-----|--------------------|
| 8       |     | RMAP section added |

### 11.4 ISSUE 1.4 TO ISSUE 1.5

| Section | Ref | Change                                                         |
|---------|-----|----------------------------------------------------------------|
| All     |     | Footer changed to indicate preliminary and a note added on the |
|         |     | front page to indicate that section 8.6 is subject to change   |

### 11.5 ISSUE 1.3 TO ISSUE 1.4

| Section | Ref | Change                                  |
|---------|-----|-----------------------------------------|
| 7       |     | Latency and jitter specifications added |

### 11.6 ISSUE 1.2 TO ISSUE 1.3

| Section | Ref | Change                                          |
|---------|-----|-------------------------------------------------|
| 8       |     | Section on fill bytes added                     |
| 10      |     | Registers updated to 3.3 specification document |

## 11.7 ISSUE 1.1 TO ISSUE 1.2

| Section       | Ref        | Change                 |
|---------------|------------|------------------------|
| 6.3, 6.4, 6.5 | Table 6-3, | FPGA timing data added |
|               | Table 6-4, |                        |
|               | Table 6-5  |                        |



Data-Sheet

Ref.: UoD\_SpW-10X\_ DataSheet

Issue: 2.0

Date: 18<sup>th</sup> August 2006

## 11.8 ISSUE 1.0 TO ISSUE 1.1

| Section | Ref       | Change                                                                                                          |
|---------|-----------|-----------------------------------------------------------------------------------------------------------------|
| 4.1     | Table 4-1 | FEEDBDIV PLL clock settings section added                                                                       |
| 4.5     | Table 4-5 | STAT_MUX_OUT changed to multi function pin                                                                      |
| 4.6     | Table 4-6 | Power on reset signals mapped to STAT_MUX_OUT pins                                                              |
| 9.1.6   |           | Setting the data rate takes account of <b>FEEDBDIV</b> and transmit clock control register setting <b>TXDIV</b> |
| 9.3.5   |           | Packet blocking correction does not cause disconnection of links.                                               |