

| Spa                | aceWire CODEC IP            |
|--------------------|-----------------------------|
|                    | User Manual                 |
|                    |                             |
| Ref:               | Uod_Link_User               |
| Document Revision: | 2.4                         |
| Date:              | 27 <sup>th</sup> March 2009 |
|                    |                             |

Г



 Ref.:
 UoD-Link-User

 2.4
 27 March 2009

 Date:
 Page: 2 / 69

- Document Ref: UoD\_Link\_User
- Issue No: 2.4
- Issue Date: 27<sup>th</sup> March 2009
- Author: Chris McClements
- **VHDL Code:** tag "uodcodec\_cvsrel\_2\_3"

Number of pages in document: 69

## **Document History:**

| Date               | Issue | Description                                                           | Ref |
|--------------------|-------|-----------------------------------------------------------------------|-----|
| 6-Oct-2003         | draft | New UoD CODEC VHDL user manual                                        | cmc |
| 19-Apr-2004        | 1.1   | DDR output multiplexer synthesis description updated                  | cmc |
| 27-Oct-05          | 1.2   | Use Latches configuration removed                                     | cmc |
|                    |       | CFG_SLOWRATE_SYSCLK description updated                               |     |
| 2-July-2007        | 2.1   | Fixed serial reset problem of txencode and transmit clock generators. | cmc |
| -                  | 2.2   | Not released                                                          | cmc |
| 22 January<br>2008 | 2.3   | Update with CFG_SLOWCLK_10MHZ reference signal                        | cmc |
| 27 Mar 2009        | 2.4   | Corrections after ESTEC review                                        | cmc |



 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 3 / 69

## I CONTENTS

| I   | CONT   | ENTS                                     | 3    |
|-----|--------|------------------------------------------|------|
| II  | LIST O | F FIGURES                                | 6    |
| 111 | LIST O | F TABLES                                 | 8    |
| 1   | SCOD   | =                                        | 0    |
| '   | SCOPE  |                                          | 9    |
| 2   | APPLI  | CABLE DOCUMENTS                          | 10   |
| 3   | DEFIN  | ITIONS                                   | 11   |
|     | 3.1 Te | RMS AND DEFINITIONS                      | 11   |
|     | 3.2 V⊦ | IDL CODE TERMS AND DEFINITIONS           | 11   |
|     | 3.3 Do | DCUMENT TERMS AND DEFINITIONS            | 12   |
| 4   | CONFI  | GURATION MANAGEMENT                      | 13   |
|     | 41 Di  | RECTORY STRUCTURE                        | 13   |
|     | 4.1.1  | CODEC RTL files                          | 14   |
|     | 4.1.2  | VHDL File Hierachy                       | 15   |
| 5   | FUNCT  |                                          | 16   |
| J   |        |                                          |      |
|     | 5.1 SY |                                          | 16   |
|     | 5.2 FU | Configuration Overview                   | . 10 |
|     | 522    |                                          | . 17 |
|     | 523    | Receiver                                 |      |
|     | 524    | Receiver Credit Counter                  | . 17 |
|     | 525    | Receiver Error Recovery                  | 18   |
|     | 5.2.6  | Transmitter                              | 18   |
|     | 5.2.7  | Transmitter Clock Generator              | 18   |
|     | 5.2.8  | Transmitter Credit Counter               | 18   |
|     | 5.2.9  | Transmitter Error Recovery               | 18   |
| 6   | TOP L  | EVEL CLOCK AND CONFIGURATION INTERFACE   | 20   |
|     | 6.1 CF | G_RXBUF_ADDRLEN                          | 20   |
|     | 6.2 CF | <br>FG_RATE_NUMBITS                      | 20   |
|     | 6.3 Sy | STEM RESET                               | 20   |
|     | 6.4 Sy | STEM CLOCK                               | 21   |
|     | 6.5 Tr | ANSMIT BIT CLOCK                         | 21   |
|     | 6.5.1  | Transmit clock configuration SYS DEFAULT | 23   |



User Manual

 Ref.:
 UoD-Link-User

 2.4
 27 March 2009

 Date:
 Page: 4 / 69

| 0.5.Z                                                                                                                                                                | I ransmit clock configuration SYS_SLOWCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6.5.3                                                                                                                                                                | Transmit bit clock configuration SYS_SLOWCLK_DIV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.5.4                                                                                                                                                                | Transmit bit clock configuration SYS_DIV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.5.5                                                                                                                                                                | Transmit bit clock configuration SYS_EN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.5.6                                                                                                                                                                | Transmit bit clock configuration TXCLK_DEFAULT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.5.7                                                                                                                                                                | Transmit bit clock configuration TXCLK_SLOWCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.5.8                                                                                                                                                                | Transmit bit clock configuration TXCLK_SLOWCLK_DIV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.5.9                                                                                                                                                                | Transmit bit clock configuration TXCLK_DIV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.5.10                                                                                                                                                               | Transmit bit clock configuration TXCLK_EN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.5.11                                                                                                                                                               | Variable data rate and default 10Mbits/sec data rate generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.5.12                                                                                                                                                               | Double Data Rate outputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.5.13                                                                                                                                                               | Transmit clock configuration and signals overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6.6 10/5                                                                                                                                                             | MHZ REFERENCE CLOCK (SLOWCLK)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.7 Rec                                                                                                                                                              | EIVE BUFFER CLOCK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3.8 Pipe                                                                                                                                                             | ELINING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| .9 Dise                                                                                                                                                              | CARDING EMPTY PACKETS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.10 N                                                                                                                                                               | AXIMUM OUTSTANDING CREDIT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5.11 T                                                                                                                                                               | RANSMIT TIME-CODE HANDLING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5.12 IN                                                                                                                                                              | ITENAL RECEIVER DISCONNECT AND INIT FSM TIMEOUT COUNTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5.13 T                                                                                                                                                               | MING CYCLE SETTINGS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5.14 D                                                                                                                                                               | ISCONNECT TIMEOUT UNCERTAINTY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15 C                                                                                                                                                                 | ONEIGURATION SIGNALS OVERVIEW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5.15 C                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| INTERN                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 40<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| INTERN                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 40<br><b>42</b><br>.42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| INTERN<br>'.1 LINF<br>7.1.1                                                                                                                                          | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| INTERN<br>1 LINF<br>7.1.1<br>7.1.2                                                                                                                                   | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42<br>42<br>42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| INTERN<br>1 LINF<br>7.1.1<br>7.1.2<br>2 DAT                                                                                                                          | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42<br>43<br>43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| INTERN<br>.1 LINF<br>7.1.1<br>7.1.2<br>.2 DAT<br>7.2.1                                                                                                               | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42<br>43<br>43<br>43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| INTERN<br>.1 LINF<br>7.1.1<br>7.1.2<br>.2 DAT<br>7.2.1<br>7.2.2                                                                                                      | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| INTERN<br>7.1.1<br>7.1.2<br>7.2 DAT<br>7.2.1<br>7.2.2<br>7.2.3                                                                                                       | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| INTERN<br>7.1.1<br>7.1.2<br>7.2.1<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4                                                                                                | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| INTERN<br>7.1 LINF<br>7.1.1<br>7.1.2<br>7.2 DAT<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5                                                                         | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| INTERN<br>7.1 LINF<br>7.1.1<br>7.1.2<br>7.2.1<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5<br>7.2.6                                                                  | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| INTERN<br>7.1 LINF<br>7.1.1<br>7.1.2<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5<br>7.2.6<br>7.2.7                                                                  | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44<br>44<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| INTERN<br>7.1 LINF<br>7.1.1<br>7.1.2<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5<br>7.2.6<br>7.2.7<br>7.2.8                                                         | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| INTERN<br>7.1 LINF<br>7.1.1<br>7.1.2<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5<br>7.2.6<br>7.2.6<br>7.2.7<br>7.2.8<br>7.2.8<br>7.2.9                              | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44<br>44<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| INTERN<br>7.1 LINF<br>7.1.1<br>7.1.2<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5<br>7.2.6<br>7.2.7<br>7.2.8<br>7.2.9<br>7.2.10                                      | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| INTERN<br>7.1 LINF<br>7.1.1<br>7.1.2<br>7.2.1<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5<br>7.2.6<br>7.2.7<br>7.2.6<br>7.2.7<br>7.2.8<br>7.2.9<br>7.2.10<br>7.2.10 | AL INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 40<br>42<br>42<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>43<br>44<br>44<br>44<br>44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                      | 6.5.3<br>6.5.4<br>6.5.5<br>6.5.6<br>6.5.7<br>6.5.8<br>6.5.9<br>6.5.10<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.10<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.10<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.11<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.12<br>6.5.13<br>6.5.12<br>6.5.13<br>6.5.11<br>6.5.12<br>6.5.13<br>6.5.12<br>6.5.13<br>6.5.14<br>7<br>6.5.12<br>6.5.13<br>6.5.12<br>6.5.13<br>6.5.12<br>6.5.13<br>7<br>6.5.12<br>6.5.13<br>7<br>6.5.12<br>6.5.13<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7<br>7 | 6.5.4       Transmit bit clock configuration SYS_DIV         6.5.5       Transmit bit clock configuration SYS_EN         6.5.6       Transmit bit clock configuration TXCLK_DEFAULT         6.5.7       Transmit bit clock configuration TXCLK_SLOWCLK         6.5.8       Transmit bit clock configuration TXCLK_SLOWCLK         6.5.9       Transmit bit clock configuration TXCLK_SLOWCLK_DIV         6.5.9       Transmit bit clock configuration TXCLK_DIV         6.5.10       Transmit bit clock configuration TXCLK_EN         6.5.11       Variable data rate and default 10Mbits/sec data rate generation         6.5.12       Double Data Rate outputs         6.5.13       Transmit clock configuration and signals overview         6.6       10/5 MHz REFERENCE CLOCK (SLOWCLK)         7       RECEIVE BUFFER CLOCK         8       PIPELINING         9       DISCARDING EMPTY PACKETS         10       MAXIMUM OUTSTANDING CREDIT         11       TRANSMIT TIME-CODE HANDLING         12       INTENAL RECEIVER DISCONNECT AND INIT FSM TIMEOUT COUNTERS         13       TIMING CYCLE SETTINGS         14       DISCONNECT TIMEOUT UNCERTAINTY |



 Ref.:
 UoD-Link-User

 2.4
 Issue:
 27 March 2009

 Date:
 Page: 5 / 69

### User Manual

| 7.3.2               | Receive                       | 49 |  |
|---------------------|-------------------------------|----|--|
| 7.3.3               | Timecode Interface Signals    | 49 |  |
| 7.4 St/             | ATUS SIGNALS                  | 50 |  |
| 7.5 Eri             | ROR RECOVERY                  | 51 |  |
| 7.5.1               | Transmitter Error Recovery    | 51 |  |
| 7.5.2               | Transmitter Buffer Flushing   | 51 |  |
| 7.5.3               | Receiver Error Recovery       | 51 |  |
| 8 EXTER             | NAL INTERFACE                 | 53 |  |
| 8.1 DA <sup>-</sup> | TA STROBE ENCODING            | 53 |  |
| 8.1.1               | Single data rate outputs      | 53 |  |
| 8.1.2               | Double data rate outputs      | 53 |  |
| 8.1.3               | Data Strobe Timing            | 55 |  |
| 8.1.4               | Serial Interface signals      | 56 |  |
| 9 SYNTH             | ESIS                          |    |  |
| 9.1 Ge              | NERAL                         |    |  |
| 9.2 Me              | MORY                          | 57 |  |
| 9.3 Vei             | NDOR SPECIFIC INFORMATION     |    |  |
| 9.3.1               | XST                           |    |  |
| 10 STAT             | TIC TIMING ANALYSIS           | 59 |  |
|                     |                               |    |  |
| 10.1 (              |                               |    |  |
| 10.2 F              |                               | 60 |  |
| 10.2.1              | Liming Parameters             | 60 |  |
| 10.2.2              | Data Setup Check              |    |  |
| 10.2.3              | Strobe Setup Check            |    |  |
| 10.2.4              | Skow Toloropoo                | 03 |  |
| 10.2.0              |                               | 04 |  |
| 10.3 (              | Conoria DDB output method one | 05 |  |
| 10.3.1              |                               |    |  |
| 10.3.2              |                               | 0/ |  |
| 11 CON              | 11 CONFORMITY                 |    |  |
| 12 APPE             | ENDIX I – CLOCK MULTIPLEXER   | 69 |  |



 Ref.:
 UoD-Link-User

 2.4
 Issue:
 27 March 2009

 Date:
 Page: 6 / 69

# II LIST OF FIGURES

| Figure 4-2 VHDL files hierarchy       15         Figure 5-1 User Implementation with UoD Codec       16         Figure 6-1 SYS_DEFAULT transmit clock configuration       23         Figure 6-2 SYS_SLOWCLK transmit clock configuration       24         Figure 6-3 SYS_ELOWCLK_DIV transmit clock configuration       26         Figure 6-4 SYS_DIV transmit clock configuration       26         Figure 6-5 SYS_EN transmit clock configuration       27         Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK transmit clock configuration       28         Figure 6-7 TX_SLOWCLK transmit clock configuration       29         Figure 6-17 X_SLOWCLK_DIV transmit clock configuration       30         Figure 6-10 TXCLK_EN transmit clock configuration       31         Figure 6-11 Receive buffer data flow       36         Figure 6-13 Additional time added when loading state machine counter       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       44         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DOR register "                                    | Figure 4-1 CODEC directory structure                                            | 13 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----|
| Figure 5-1 User Implementation with UoD Codec       16         Figure 6-1 SYS_DEFAULT transmit clock configuration       23         Figure 6-2 SYS_SLOWCLK transmit clock configuration       24         Figure 6-3 SYS_DIV transmit clock configuration       25         Figure 6-4 SYS_DIV transmit clock configuration       26         Figure 6-5 SYS_EN transmit clock configuration       27         Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK transmit clock configuration       29         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-10 TXCLK_DIV transmit clock configuration       31         Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 8-1 CK_OUT Interface       49         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-4 Vendor specific DVDT and SOUT DDR encode       53                                             | Figure 4-2 VHDL files hierarchy                                                 | 15 |
| Figure 6-1 SYS_DEFAULT transmit clock configuration       23         Figure 6-2 SYS_SLOWCLK transmit clock configuration       24         Figure 6-3 SYS_SLOWCLK_DIV transmit clock configuration       25         Figure 6-4 SYS_DIV transmit clock configuration       26         Figure 6-5 SYS_EN transmit clock configuration       27         Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK transmit clock configuration       29         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_DIV transmit clock configuration       30         Figure 6-10 TXCLK_EN transmit clock configuration       31         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-5 TICK_IN Interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txdrreg.vhd"       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         <                                | Figure 5-1 User Implementation with UoD Codec                                   | 16 |
| Figure 6-2 SYS_SLOWCLK transmit clock configuration       24         Figure 6-3 SYS_SLOWCLK_DIV transmit clock configuration       25         Figure 6-4 SYS_DIV transmit clock configuration       26         Figure 6-5 SYS_EN transmit clock configuration       27         Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK_DIV transmit clock configuration       29         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_DIV transmit clock configuration       31         Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       44         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Stxddreg_noenable.vhd double data rate generation logic and waveform       54         Figure 8-1 Stxddreg_noenable.vhd double data rate generation logic and waveform       54         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-1 Receive Clock Data Recovery | Figure 6-1 SYS_DEFAULT transmit clock configuration                             | 23 |
| Figure 6-3 SYS_SLOWCLK_DIV transmit clock configuration       25         Figure 6-4 SYS_DIV transmit clock configuration       26         Figure 6-5 SYS_EN transmit clock configuration       27         Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK_transmit clock configuration       29         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_DIV transmit clock configuration       30         Figure 6-10 TXCLK_EN transmit clock configuration       31         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/xddrreg.vhd"       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-2 Lata                                    | Figure 6-2 SYS_SLOWCLK transmit clock configuration                             | 24 |
| Figure 6-4 SYS_DIV transmit clock configuration       26         Figure 6-5 SYS_EN transmit clock configuration       27         Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK transmit clock configuration       29         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_DIV transmit clock configuration       30         Figure 6-10 TXCLK_EN transmit clock configuration       31         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-2 Data and Strobe Setup Time violation       62         Figure 10-5                                    | Figure 6-3 SYS_SLOWCLK_DIV transmit clock configuration                         | 25 |
| Figure 6-5 SYS_EN transmit clock configuration       27         Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK transmit clock configuration       30         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_DIV transmit clock configuration       31         Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock del                                    | Figure 6-4 SYS_DIV transmit clock configuration                                 | 26 |
| Figure 6-6 TX_DEFAULT transmit clock configuration       28         Figure 6-7 TX_SLOWCLK transmit clock configuration       29         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_EN transmit clock configuration       31         Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-1 Kxdorreg_noenable.vhd double data rate generation logic and waveform       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock delay setup time violation       62         Figure 10-5 Data and Strobe Setup Time When no Skew       63                                              | Figure 6-5 SYS_EN transmit clock configuration                                  | 27 |
| Figure 6-7 TX_SLOWCLK transmit clock configuration       29         Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_DIV transmit clock configuration       31         Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-1 Receive Clock Data Recovery.       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-4 Latest Strobe Setup Time When no Skew       63         Figure 10                                    | Figure 6-6 TX_DEFAULT transmit clock configuration                              | 28 |
| Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration       30         Figure 6-9 TXCLK_DIV transmit clock configuration       31         Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-1 Receive Clock Data Recovery.       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock delay setup time violation       62         Figure                                     | Figure 6-7 TX_SLOWCLK transmit clock configuration                              | 29 |
| Figure 6-9 TXCLK_DIV transmit clock configuration       31         Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-1 top concable.vhd double data rate generation logic and waveform       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 8-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-1 Receive Clock Data Recovery.       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-4 Latest Strobe Setup Time violation       62         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time       63                                                                                                   | Figure 6-8 TX_SLOWCLK_DIV transmit clock configuration                          | 30 |
| Figure 6-10 TXCLK_EN transmit clock configuration       32         Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-1 Generic DOUT and SOUT DDR encode       55         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-3 Large clock delay setup time violation       62         Figure 10-4 Latest Strobe Setup Time When no Skew       63         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time.       63                                                                                                                                                              | Figure 6-9 TXCLK_DIV transmit clock configuration                               | 31 |
| Figure 6-11 Receive buffer data flow       36         Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-3 Large clock delay setup time violation       62         Figure 10-4 Latest Strobe Setup Time When no Skew       63         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time       63                                                                                                                                                                                                                     | Figure 6-10 TXCLK_EN transmit clock configuration                               | 32 |
| Figure 6-12 CFG_SLOW_CE_SEL configuration signals       38         Figure 6-13 Additional time added when loading state machine counter       40         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock delay setup time violation       62         Figure 10-4 Latest Strobe Setup Time When no Skew       63         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time       63                                                                                                                                                                                                                       | Figure 6-11 Receive buffer data flow                                            | 36 |
| Figure 6-13 Additional time added when loading state machine counter       40         Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock delay setup time violation       62         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time       63                                                                                                                                                                                                                                                                                                                                                                                                              | Figure 6-12 CFG_SLOW_CE_SEL configuration signals                               | 38 |
| Figure 6-14 Disconnect timeout uncertainty (100ns period)       40         Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 7-6 TICK_OUT interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd.       58         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock delay setup time violation       62         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time.       63                                                                                                                                                                                                                                                                                                                                                                              | Figure 6-13 Additional time added when loading state machine counter            | 40 |
| Figure 7-1 Initialisation state machine       42         Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock delay setup time violation       62         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time       63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Figure 6-14 Disconnect timeout uncertainty (100ns period)                       | 40 |
| Figure 7-2 Transmit Timing Specification       44         Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 7-6 TICK_OUT interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-1 Receive Clock Data Recovery       60         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-4 Latest Strobe Setup Time When no Skew       63         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time       63                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Figure 7-1 Initialisation state machine                                         | 42 |
| Figure 7-3 Receive timing specification       45         Figure 7-4 Minimum Receive buffer clock frequency.       46         Figure 7-5 TICK_IN interface       49         Figure 7-6 TICK_OUT interface       49         Figure 8-1 Generic DOUT and SOUT DDR encode       53         Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"       54         Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform       54         Figure 8-4 Vendor specific DOUT and SOUT DDR encode       55         Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd       58         Figure 10-2 Data Setup Time Timing Diagram       62         Figure 10-3 Large clock delay setup time violation       62         Figure 10-4 Latest Strobe Setup Time When no Skew       63         Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time       63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Figure 7-2 Transmit Timing Specification                                        | 44 |
| Figure 7-4 Minimum Receive buffer clock frequency.46Figure 7-5 TICK_IN interface49Figure 7-6 TICK_OUT interface49Figure 8-1 Generic DOUT and SOUT DDR encode53Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"54Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform54Figure 8-4 Vendor specific DOUT and SOUT DDR encode55Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd58Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Figure 7-3 Receive timing specification                                         | 45 |
| Figure 7-5 TICK_IN interface49Figure 7-6 TICK_OUT interface49Figure 8-1 Generic DOUT and SOUT DDR encode53Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"54Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform54Figure 8-4 Vendor specific DOUT and SOUT DDR encode55Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd58Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Figure 7-4 Minimum Receive buffer clock frequency                               | 46 |
| Figure 7-6 TICK_OUT interface49Figure 8-1 Generic DOUT and SOUT DDR encode53Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"54Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform54Figure 8-4 Vendor specific DOUT and SOUT DDR encode55Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd58Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Figure 7-5 TICK_IN interface                                                    | 49 |
| Figure 8-1 Generic DOUT and SOUT DDR encode53Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"54Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform54Figure 8-4 Vendor specific DOUT and SOUT DDR encode55Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd58Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Figure 7-6 TICK_OUT interface                                                   | 49 |
| Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"54Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform54Figure 8-4 Vendor specific DOUT and SOUT DDR encode55Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd58Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Figure 8-1 Generic DOUT and SOUT DDR encode                                     | 53 |
| Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"                        | 54 |
| Figure 8-4 Vendor specific DOUT and SOUT DDR encode55Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd58Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Figure 8-3 txddrreg_noenable.vhd double data rate generation logic and waveform | 54 |
| Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd58Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Figure 8-4 Vendor specific DOUT and SOUT DDR encode                             | 55 |
| Figure 10-1 Receive Clock Data Recovery60Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Figure 9-1 ISE coregent settings for rxnchar_resync_ff.vhd                      | 58 |
| Figure 10-2 Data Setup Time Timing Diagram62Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Figure 10-1 Receive Clock Data Recovery                                         | 60 |
| Figure 10-3 Large clock delay setup time violation62Figure 10-4 Latest Strobe Setup Time When no Skew63Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Figure 10-2 Data Setup Time Timing Diagram                                      | 62 |
| Figure 10-4 Latest Strobe Setup Time When no Skew                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Figure 10-3 Large clock delay setup time violation                              | 62 |
| Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Figure 10-4 Latest Strobe Setup Time When no Skew                               | 63 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time                   | 63 |



 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 7 / 69

User Manual

| Figure 10-6 Minimum Pulse Width                          | .64 |
|----------------------------------------------------------|-----|
| Figure 10-7 Data Skew Tolerance                          | .64 |
| Figure 10-8 Maximum Strobe Skew                          | .65 |
| Figure 10-9 DDR output encoding (Method one)             | .65 |
| Figure 10-10 DDR output multiplexer select               | .66 |
| Figure 10-11 DDR output multiplexer timing specification | .66 |
| Figure 10-12 Method Two DDR output encoding              | .67 |
| Figure 12-1 Glitch Free clock multiplexer                | .69 |



User Manual

Ref.: UoD-Link-User 2.4 Issue: 27 March 2009 Date: Page: 8 / 69

## III LIST OF TABLES

| 10 |
|----|
| 14 |
| 15 |
| 21 |
| 22 |
| 35 |
| 41 |
| 43 |
| 48 |
| 48 |
| 50 |
| 51 |
| 52 |
| 56 |
| 59 |
| 61 |
| 61 |
| 64 |
|    |



 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 9 / 69

## 1 SCOPE

This document defines how the University of Dundee SpaceWire CODEC VHDL code shall be used.



 Ref.:
 UoD-Link-User

 2.4
 Issue:
 27 March 2009

 Date:
 Page: 10 / 69

User Manual

# 2 APPLICABLE DOCUMENTS

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

| Document Reference               | Ref   | Document name                                                                                                   |
|----------------------------------|-------|-----------------------------------------------------------------------------------------------------------------|
| ECSS-E-ST-50-12C<br>(31July2008) | [AD1] | European Cooperation for Space Standardization,<br>SpaceWire – Links, Nodes, Routers and Networks<br>March 2003 |

Table 2-1 Applicable Documents



# 3 **DEFINITIONS**

In this Document the following conventions are used.

## 3.1 Terms and definitions

| Bit rate | Number of bits transmitted/received every second                                                               |  |
|----------|----------------------------------------------------------------------------------------------------------------|--|
| byte     | Eight bits of information                                                                                      |  |
| DDR      | Double data rate. Two bits of data transmitted for each transmit clock period.                                 |  |
| FCT      | Flow control token. Transmitter sends one FCT when room in receive buffer for eight more N-chars.              |  |
| Init FSM | SpaceWire exchange level initialisation state machine which controls start-up and link connection.             |  |
| Jitter   | The time uncertainty of a low to high or high to low edge measured with respect to other edges in that signal. |  |
| N-char   | Data character, EOP or EEP.                                                                                    |  |
| Null     | Character transmitted by SpaceWire link to keep connection with other end.                                     |  |
| SDR      | Single data rate. One bit of data transmitted for each transmit clock period.                                  |  |
| Skew     | The timing difference between two signals due to differences in the signal path length.                        |  |
| UoD      | University of Dundee                                                                                           |  |
| ECSS     | European cooperation for space standardization                                                                 |  |

## 3.2 VHDL Code Terms and Definitions

In the VHDL code the following VHDL conventions are:

VHDL entity architecture pairs are placed in the same VHDL file. The filename is a lowercase equivalent of the entity name, e.g. The entity rxcredit is represented in the file "rxcredit.vhd".

All VHDL entity names can be mixed case or lower case.

All VHDL signal and port names are in UPPERCASE. Signals which have multi word names are split with an underscore character, e.g. credit error is represented as **CREDIT\_ERROR**.

For all signals the "ieee.std\_logic\_1164" **STD\_LOGIC** and **STD\_LOGIC\_VECTOR** types are used. This ensures that all types are consistent through all VHDL files and no conversions between **STD\_LOGIC** and **STD\_ULOGIC** are required or necessary.

For all vector signals the highest number index is the MSB and the lowest number index is the LSB. i.e. the (n downto 0) vector type is used

For all arithmetic signals the "ieee.numeric\_std" **UNSIGNED** type is used. Arithmetic functions such as +, - or = are implemented in the numeric\_std package.



Conversions from UNSIGNED to STD\_LOGIC\_VECTOR are implemented using type conversion e.g. STD\_LOGIC\_VECTOR (unsigned\_signal). Conversions from STD\_LOGIC\_VECTOR to UNSIGNED are implemented using type conversion e.g. UNSIGNED (std\_logic\_vector\_signal).

Conversions from **UNSIGNED** to integer are implemented using the numeric\_std function to\_integer(unsigned\_sig). Conversions from integers to **UNSIGNED** are implemented using the numeric\_std function to\_unsigned(integer\_val, sign\_length).

Active low signals are labelled **SIGNAL\_NAME\_N**.

Output signals from entities are often required internally for circuit feedback purposes. Redundant signals which are required for this purpose are labelled **PORT\_SIGNAL\_i** and assigned to the output in the code as **PORT\_SIGNAL\_<= PORT\_SIGNAL\_i** in the VHDL code.

### **3.3 Document Terms and Definitions**

In this Document the following conventions are used.

Signal and port names are written using the bold "courier new" font. e.g. **SIGNAL\_NAME**.



# 4 CONFIGURATION MANAGEMENT

## 4.1 Directory Structure

The directory structure of the SpaceWire CODEC directory structure is shown in the list below.



Figure 4-1 CODEC directory structure

A description of each directory is listed in the Table 4-1.

| Directory         | Function                                                                                              |
|-------------------|-------------------------------------------------------------------------------------------------------|
| docs              | Location of documentation files                                                                       |
| src/vhdl          | Location of RTL VHDL files                                                                            |
| src/vhdl/initfsm  | Initialisation state machine VHDL files                                                               |
| src/vhdl/other    | Generic and miscellaneous VHDL files                                                                  |
| src/vhdl/receive  | Data strobe decoder and receive credit counter VHDL files                                             |
| src/vhdl/transmit | Data strobe encoder VHDL files                                                                        |
| src/vhdl/txclk    | Transmit clock generation VHDL files                                                                  |
| src/vhdl/top      | SpaceWire CODEC top level VHDL files                                                                  |
| src/verif         | Location of verification files, scripts and test case commands                                        |
| src/verif/cmd     | Command files which perform the verification test cases of the SpaceWire CODEC                        |
| src/verif/scripts | Scripts to compile and run the verification of the SpaceWire CODEC.                                   |
| src/verif/gen-tb  | General testbench components and units VHDL files                                                     |
| src/verif/package | Testbench VHDL package files                                                                          |
| src/verif/spwr-tb | Control, status, data and time-code interface control for the testbench VHDL SpaceWire link           |
| src/verif/uut-tb  | Control, status, data and time-code interface control for the UUT SpaceWire link                      |
| src/verif/top     | Top level testbench components.                                                                       |
| verif/rtl         | RTL verification directory where the verification run is performed. (reference directory for scripts) |



**User Manual** 

 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 14 / 69

Table 4-1 Directory descriptions

#### 4.1.1 CODEC RTL files

The RTL files are found in the "codec\_actel/ip/codec\_actel/src/vhdl" directory.

| File                                            | Description                                                                                                                                       |  |  |  |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Initialisation state machine                    |                                                                                                                                                   |  |  |  |
| initfsm/init_fsm.vhd                            | Initialisation state machine                                                                                                                      |  |  |  |
| initfsm/initfsm_counter.vhd                     | Initialisation state machine counter                                                                                                              |  |  |  |
| initfsm/initfsm_sync.vhd                        | Synchronisation of receiver signals for initialisation state machine                                                                              |  |  |  |
| Generic files                                   |                                                                                                                                                   |  |  |  |
| other/clk10gen.vhd                              | Generation of 100 ns clock enable pulse                                                                                                           |  |  |  |
| other/clkmux.vhd                                | Clock multiplexer for multiplexing two clocks with an asynchronous signal                                                                         |  |  |  |
| Receive Files                                   |                                                                                                                                                   |  |  |  |
| receive/rxclock.vhd                             | Receiver clock recovery exclusive or gate                                                                                                         |  |  |  |
| receive/rxcredit.vhd                            | Receiver credit counter and receive buffer pointer management                                                                                     |  |  |  |
| receive/rxdecode.vhd                            | receive bit-stream decoder. Decodes the input bit-stream input SpaceWire character                                                                |  |  |  |
| receive/rxdataformat.vhd                        | Receive data formatter. Formats double<br>EOPs into a form which can be synchronised<br>between receive clock and receive buffer<br>successfully. |  |  |  |
| receive/rxnchar_resync_ff.vhd                   | Receive data resynchronisation to receive<br>buffer clock                                                                                         |  |  |  |
| receive/rxnchar_resync_ffstore.vhd              | Receive data resynchronisation data storage flip-flops                                                                                            |  |  |  |
| receive/rxnchar_resync_ffstore_inferfpgaram.vhd | Receive data resynchronisation data storage written to infer FPGA ram.                                                                            |  |  |  |
| receive/rxnchar_resync_ffcell.vhd               | Memory row built from flip-flops.                                                                                                                 |  |  |  |
| receive/rxnchar_resync_and.vhd                  | And gate for memory output multiplexer                                                                                                            |  |  |  |
| receive/rxnchar_resync_dataena.vhd              | Data enabled for memory output multiplexer                                                                                                        |  |  |  |
| receive/rxnchar_resync_demux.vhd                | De-multiplexer for writing to memory                                                                                                              |  |  |  |
| receive/rxnchar_resync_valid.vhd                | Presents valid data synchronised with the<br>empty flag                                                                                           |  |  |  |
| receive/rxdiscerr.vhd                           | Receiver disconnect detection                                                                                                                     |  |  |  |
| receive/rxtcode_resync.vhd                      | Receiver time-code resynchronisation from receive clock to system clock                                                                           |  |  |  |
| Transmit files                                  |                                                                                                                                                   |  |  |  |
| transmit/txencode.vhd                           | Serial output bit-stream encoder                                                                                                                  |  |  |  |
| transmit/txtcode_send.vhd                       | Time-code input component                                                                                                                         |  |  |  |
| transmit/txddrreg.vhd                           | Transmit double data rate register                                                                                                                |  |  |  |



| User | Manual |
|------|--------|
|------|--------|

| transmit/txddrreg_noenable.vhd | Transmit double data rate register without clock enable generated data rate. |  |
|--------------------------------|------------------------------------------------------------------------------|--|
| Variable data rate files       |                                                                              |  |
| txclk/txclkgen.vhd             | Transmit clock generation and multiplexing<br>component                      |  |
| txclk/txclk_divider.vhd        | Transmit clock divider to generate different data rates                      |  |
| txclk/txclk_en_gen.vhd         | Generation of variable rate transmit data rate enable pulse                  |  |

Table 4-2 RTL file descriptions

### 4.1.2 VHDL File Hierachy

The hierarchy of the VHDL files is described in the following tree diagram.

```
top/spwrlink.vhd
\--+ others/clk10gen.vhd
\--+ initfsm/init_fsm.vhd
| \--+ initfsm/initfsm_counter.vhd
 \--+ initfsm/initfsm resync.vhd
\--+ receive/rxcredit.vhd
\--+ receive/rxdecode.vhd
\--+ receive/rxtcode resync.vhd
\--+ receive/rxnchar_resync_ff.vhd
| \--+ receive/rxnchar_resync_demux.vhd
| \--+ receive/rxnchar_resync_dataena.vhd
 \--+ receive/rxnchar_resync_valid.vhd
\--+ transmit/txencode.vhd
\--+ transmit/txtcode send.vhd
\--+ txclk/txclkgen.vhd
| \--+ txclk/txclk en gen.vhd
  \--+ txclk/txclk divider.vhd
\--+ others/clkmux.vhd
```

Figure 4-2 VHDL files hierarchy



# 5 FUNCTIONAL OVERVIEW

In this section an overview of the SpaceWire Codec architecture is provided.

## 5.1 System Overview

A block diagram of the SpaceWire CODEC and expected usage is given in Figure 5-1.



Figure 5-1 User Implementation with UoD Codec

## 5.2 Functions

The UoD CODEC is a high speed serial transmitter/receiver compliant with the SpaceWire standard [AD1]. The SpaceWire CODEC is responsible for making a connection with the SpaceWire interface



at the other end of a link and managing the flow of N-char across the link. The interface transmits and receives SpaceWire characters which can be link characters (L-Char) or normal characters (N-char). L-Chars are characters that are used to manage the flow of N-char across a link (NULL & FCT). N-chars are the characters that are used to pass information across the link (N-char characters, EOP, EEP and TIMECODEs).

The following sub-sections define the functional blocks which make up the SpaceWire interface are listed below.

### 5.2.1 Configuration Overview

The UoD SpaceWire codec can be configured to suit the users application as follows:

- Pipelined to increase transmission speed or non pipelined to save area.
- DDR outputs or SDR outputs depending the on required data rate and the users selected technology.
- Transmission clock configuration options to allow an independent transmit clock and default reference clock therefore greatly increasing the achievable data rate and decoupling the transmit logic from the system clock logic.
- Internal variable data rate generation.
- Configurable receive buffer size. Internal FCT credit counter operations are handled internally.

### 5.2.2 Initialisation State Machine

The CODEC state machine is responsible for initiating a connection on the link and performing related synchronisation.

The state machine determines its next state by monitoring receiver signals which indicate the type of characters received and any receiver errors. The state machine enables the transmitter to send NULLs, FCTs, N-char characters, time-codes and end of packet markers (EOP and EEP).

#### 5.2.3 Receiver

The receiver is responsible for decoding the received data-strobe encoded bit-stream into SpaceWire characters. The receiver reports the type of characters received and any errors encountered to the initialisation state machine which enables and disables the receiver as appropriate. The receiver is implemented in two parts, a decoder which decodes characters in the receiver clock domain and a synchroniser, which then synchronises receiver signals to the system clock domain. This method ensures all receiver outputs are synchronous to the system clock.



## 5.2.4 Receiver Credit Counter

The receiver credit counter keeps a record of the buffer space available in the receiver FIFO and the number of characters which have been requested from the link. This allows the CODEC to implement flow control.

The receiver credit counter implements the receiver buffer pointers. This makes the implementation of the receiver credit counter and the receiver buffer more efficient as the number of counters required is kept to a minimum.

### 5.2.5 Receiver Error Recovery

The receiver error recovery block recovers the receiver credit counters and the receiver FIFO after an error occurs. After an error an EEP marker is added to the receiver FIFO. The receiver credit counter must be updated because all previously transmitted FCTs are discarded at the other end of the link due to error recovery.

### 5.2.6 Transmitter

The transmitter is responsible for transmitting L-Chars and N-chars over a link using data-strobe encoding. The interface state machine determines which type of character the transmitter can send over the link. The transmitter accepts N-char characters and end of packet markers from the transmitter FIFO. N-char characters are transmitted when there is data in the FIFO and the transmitter has credit to send one more N-char. The transmitter sends an FCT character for each block of space for eight N-chars in the receive FIFO. As the host system reads out data from the receive FIFO so the transmitter sends more FCTs to indicate that the receiver has room to receive eight more N-chars. The transmitter sends NULLs when there is no other information to send.

#### 5.2.7 Transmitter Clock Generator

The transmitter clock enable generator is responsible for generating the variable transmitter bit-rate and default data signalling rate depending on the configuration.

### 5.2.8 Transmitter Credit Counter

The transmitter credit counter holds a count register which indicates the number of SpaceWire N-char characters which can be sent along the link.

### 5.2.9 Transmitter Error Recovery

The transmitter error recovery module recovers the transmitter FIFO after an error occurs. In a network situation the first byte of a packet is interpreted as the packet address, therefore the error recovery block reads from the transmitter FIFO until the next end of packet marker was read from the



User Manual

 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 19 / 69

FIFO. The transmitter is allowed to start up when error recovery is taking place but the transmitter is prevented from reading from the transmit FIFO until error recovery is complete



## 6 TOP LEVEL CLOCK AND CONFIGURATION INTERFACE

The following sections define the internal and external interfaces which are employed in the UoD SpaceWire CODEC. Each section has a detailed description of the signal functions and an overview table for each signal and the clock which the signal is synchronous to.

Note: The configuration constants mentioned in the following sections are defined in the package "top/spwrlink\_pkg.vhd".

## 6.1 CFG\_RXBUF\_ADDRLEN

The configuration constant **CFG\_RXBUF\_ADDRLEN** determines the length of the read and write addresses for the receive buffer and therefore the size of the receive buffer. The buffer size is defined as:

2 ^ rxbufaddrlen

For example, the receive buffer address length is 10, the receive buffer size will be 1 Kbytes. The SpaceWire CODEC will automatically handle FCT credit operations dependent on the size of the buffer.

## 6.2 CFG\_RATE\_NUMBITS

The configuration constant CFG\_RATE\_NUMBITS determines the signal length of slow rate and transmitter rate inputs. The signal length determines the size of the internal down counters used for variable data rate generation. The signals CFG\_SLOWRATE\_TXCLK, CFG\_SLOWRATE\_SYSCLK and TXRATE are affected by the generic ratenumbits.

### 6.3 System Reset

The interface signal **RST\_N** is an active low asynchronous reset of the UoD CODEC. The **RST\_N** signal should be asserted for at least two system clock cycles to ensure synchronous reset elements register the reset.

The transmitter is reset synchronously to ensure no simultaneous transitions occur of DOUT/SOUT.

The reset values are listed in Table 6-1.

| Signal | Reset Value | Comments                   |
|--------|-------------|----------------------------|
| DOUT   | '0'         | Reset in controlled manner |
| DOUT_F | '0'         | Reset in controlled manner |
| SOUT   | '0'         | Reset in controlled manner |
| DOUT_F | '0'         | Reset in controlled manner |



 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 21 / 69

| XENR             | '0'       | Reset in controlled manner                                   |
|------------------|-----------|--------------------------------------------------------------|
| XENF             | ·0'       | Reset in controlled manner                                   |
| DOUT_CLR_N       | ·0'       | Reset in controlled manner                                   |
| SOUT_CLR_N       | ·0'       | Reset in a controlled manner                                 |
| TICK_OUT         | ·0'       |                                                              |
| TIME_OUT         | All '0'   |                                                              |
| RXBUF_DATA       | Undefined | Data storage is not reset. Data is valid<br>on RXBUF_WRVALID |
| RXBUF_WRADDR     | All '0'   |                                                              |
| RXBUF_RDADDR     | All 'O'   |                                                              |
| RXBUF_WRVALID    | ʻ0'       |                                                              |
| RXBUF_RDVALID    | ʻ0'       |                                                              |
| RXBUF_EMPTY      | '1'       |                                                              |
| RXBUF_PROGFLAG   | ʻ0'       |                                                              |
| TX_FIFO_READ     | ʻ0'       |                                                              |
| DISC_RUN_ERROR   | ·0'       |                                                              |
| PARITY_RUN_ERROR | ·0'       |                                                              |
| ESCAPE_RUN_ERROR | ·0'       |                                                              |
| CREDIT_RUN_ERROR | ·0'       |                                                              |
| STATUS(15:0)     | All 'O'   |                                                              |

Table 6-1 Output Reset Values

## 6.4 System clock

The interface signal **SYSCLK** clocks the interface state machine which controls link start-up and link reconnection after an error is detected. The system clock can also clock the receiver buffer and the transmitter dependent on the configuration signals.

### 6.5 Transmit bit clock

The UoD SpaceWire CODEC can be configured to implement a number of transmission clocking schemes.. The valid transmitter bit clock configurations can be selected by the user via the package constant CFG\_BITCLK. The valid configurations are listed in Table 6-2

- The transmit bit clock configuration determines the source or method used for the following:
- Baseline bit clock (system clock or independent transmit clock).
- 10MHz default data signalling rate (internally generated or input **SLOWCLK**)
- Variable data signalling rate (not enabled, clock enables or clock divider)



 Ref.:
 UoD-Link-User

 2.4
 27 March 2009

 Date:
 Page: 22 / 69

User Manual

| CFG_BITCLK  | Symbolic name(1)  | Input clock | Default 10/5MHz(2) | Variable data rate |
|-------------|-------------------|-------------|--------------------|--------------------|
| "0000" (0h) | SYS_DEFAULT       | SYSCLK      | SYSCLK             | SYSCLK             |
| "0001"(1h)  | SYS_SLOWCLK       | SYSCLK      | SLOWCLK            | SYSCLK             |
| "0010"(2h)  | SYS_SLOWCLK_DIV   | SYSCLK      | SLOWCLK            | Clock divider      |
| "0011" (3h) | SYS_DIV           | SYSCLK      | Clock divider      | Clock divider      |
| "0100" (4h) | SYS_EN            | SYSCLK      | Clock enable       | Clock enable       |
| "1000" (8h) | TXCLK_DEFAULT     | TXCLK       | TXCLK              | TXCLK              |
| "1001" (9h) | TXCLK_SLOWCLK     | TXCLK       | SLOWCLK            | TXCLK              |
| "1010" (Ah) | TXCLK_SLOWCLK_DIV | TXCLK       | SLOWCLK            | Clock divider      |
| "1011" (Bh) | TXCLK_DIV         | TXCLK       | Clock divider      | Clock divider      |
| "1100"(Ch)  | TXCLK_EN          | TXCLK       | Clock enable       | Clock enable       |

Table 6-2 CFG\_BITCLK options

Note 1: The symbolic names are defined as VHDL constants in the package "top/spwrlink\_pkg.vhd".

Note 2: 10MHz for single data rate or 5MHz for double data rate.

The following sub sections define the meaning of the configurations in Table 6-2.

Note: The following configurations reference the use a glitch free multiplexer to select between two asynchronous clocks. Appendix I, in section 12, details the design of the glitch free multiplexer.



## 6.5.1 Transmit clock configuration SYS\_DEFAULT

The SYS\_DEFAULT configuration is used when **SYSCLK** is equal to the default 10MHz data signalling rate. The **SYSCLK** frequency should be set to 10MHz when single data rate is used or 5MHz when DDR outputs are used.

Note: The data rate in this configuration is fixed to 10Mbits/s as the SYSCLK input is used as the timings reference (state machine timeout and receive disconnect timeout).

This configuration is the most efficient implementation of the UoD SpaceWire CODEC, as:

- No internal clock generation is required.
- Synchronisation of signals is not required between **SYSCLK** and the transmit bit clock.
- **SYSCLK** is used as the 10/5Mhz reference clock for disconnect detection and state machine timeouts.

Figure 6-1 shows the transmission scheme configuration



Figure 6-1 SYS\_DEFAULT transmit clock configuration



## 6.5.2 Transmit clock configuration SYS\_SLOWCLK

The SYS\_SLOWCLK configuration can be used when an independent 10MHz clock is used for the default 10Mbits/sec transmit rate and the transmitter clock is the system clock. No internal variable data rate generator is implemented. The **slowclk** frequency should be set to 10MHz when single data rate is used or 5MHz when DDR outputs are used.

This configuration can be implemented when:

- Only one system clock is used and no internal variable data rate generation is required. The system clock frequency can be changed externally if required..
- An external 10/5MHz reference clock is desired.

Figure 6-2 shows the clock configuration SYS\_SLOWCLK.



Figure 6-2 SYS\_SLOWCLK transmit clock configuration



## 6.5.3 Transmit bit clock configuration SYS\_SLOWCLK\_DIV

The transmit clock configuration SYS\_SLOWCLK\_DIV allows an independent 10/5MHz default transmit rate (**SLOWCLK**) and a generated variable transmit rate from **SYSCLK**. This configuration generates a new transmit clock tree asynchronous from **SYSCLK**. The SYS\_SLOWCLK\_DIV configuration can be used when.

- An internal variable data rate scheme is required and the transmit clock is SYSCLK.
- An external 10/5MHz reference clock is desired.

The configuration SYS\_DIV is shown in Figure 6-4.



#### Figure 6-3 SYS\_SLOWCLK\_DIV transmit clock configuration

The variable data rate is implemented using a programmable divider which enables a toggle flip-flop. When the SpaceWire CODEC is performing link start-up (FSM.SEL\_SLOW) the input SLOWCLK is selected. When link start-up has been performed and a link connection has been established the input TXRATE determines the data rate. When TXRATE is equal to zero (maximum rate) then XIMAX is asserted and SYSCLK is selected by the glitch free clock multiplexer. When TXRATE is not equal to zero the clock generator output XI\_CLK\_DIV is selected by the multiplexer.

Synchronisation is automatically performed by the SpaceWire CODEC as **TXBITCLK** is asynchronous to **SYSCLK** in this configuration.



## 6.5.4 Transmit bit clock configuration SYS\_DIV

The transmit clock configuration SYS\_DIV allows a variable rate and default 10MHz transmitter bit clock to be generated from **sysclk**. This configuration generates a new transmit clock tree asynchronous from **sysclk**. The SYS\_DIV configuration can be used when:

- A variable data rate scheme is required but the use of clock enables is not desired (typically clock enabled DDR outputs not supported when external vendor specific DDR outputs are used).
- An external 10MHz reference clock is not available.

The configuration SYS\_DIV is shown in Figure 6-4.



#### Figure 6-4 SYS DIV transmit clock configuration

The variable data rate and 10MHz default data rate are implemented using a programmable divider which enables a toggle flip-flop. When the SpaceWire CODEC is performing link start-up (FSM.SEL\_SLOW) the input CFG\_SLOWRATE\_TXCLK determines the frequency of TXBITCLK. When link start-up has been performed and a link connection has been established the input TXRATE determines the data rate. When TXRATE is equal to zero (maximum rate) then XIMAX is asserted and SYSCLK is selected by the glitch free clock multiplexer. When TXRATE is not equal to zero the clock generator output XI CLK DIV is selected by the multiplexer.

Synchronisation is automatically performed by the SpaceWire CODEC as **TXBITCLK** is asynchronous to **SYSCLK** in this configuration.



## 6.5.5 Transmit bit clock configuration SYS\_EN

The configuration SYS\_EN allows the default 10Mbits/s transmit rate and the variable transmission rate to be generated by an internal clock enable generator. This configuration can be used when:

- The number of clock nets available to the user is limited (only one clock net is required for this transmission scheme).
- **TXBITCLK** is synchronous with **SYSCLK**.

Figure 6-5 shows the block diagram for SYS\_EN.



Figure 6-5 SYS\_EN transmit clock configuration

When the internal state machine signal **FSM.SEL\_SLOW** is asserted the input **CFG\_SLOWRATE\_TXCLK** determines the final data-rate. When **FSM.SEL\_SLOW** is de-asserted then **TXRATE** determines the final data-rate.

The outputs XENR and XENF should be connected to the rising edge enable and falling edge enable of the transmit double data rate output register.

Note: When DDR outputs are selected and CFG\_SLOWRATE\_TXCLK or TXRATE is an odd number the duty cycle on DOUT/SOUT will not be 50/50. The worst case duty cycle, when TXRATE or CFG\_SLOWRATE\_TX = 1, will be 75/25 (i.e. 15ns/5ns for 2 transitions at a 20 ns period). This is still a valid configuration under the SpaceWire standard.



## 6.5.6 Transmit bit clock configuration TXCLK\_DEFAULT

The TXCLK\_DEFAULT can be used when:

- An independent transmit clock is required (asynchronous to **SYSCLK**)
- All transmit clock generation is implemented externally, e.g. external PLL.

The SpaceWire standard states a default 10Mbits/s transmit rate shall be used at start-up. To implement this requirement the user can monitor the link running status bit and determine the **TXCLK** input frequency. i.e. when the link is not running (not in run state) the **TXCLK** frequency should be 10/5 MHz. When the link is running then **TXCLK** can be set to any frequency up to the maximum frequency supported by the users implementation.



Figure 6-6 TX\_DEFAULT transmit clock configuration



## 6.5.7 Transmit bit clock configuration TXCLK\_SLOWCLK

The TXCLK\_SLOWCLK configuration can be used when:

- An independent transmit clock is required (asynchronous to **SYSCLK**)
- Transmit clock variable data rate is implemented externally or fixed.
- An independent 10/5MHz reference clock is desired.

The block diagram shown in Figure 6-7 describes the TX\_SLOWCLK configuration. When the FSM.SEL\_SLOW signal is asserted, the link is not running or is starting up, then **SLOWCLK** is selected by the glitch free multiplexer. When the link is running then **TXCLK** is selected as the transmit bit clock.



Figure 6-7 TX\_SLOWCLK transmit clock configuration



## 6.5.8 Transmit bit clock configuration TXCLK\_SLOWCLK\_DIV

The TXCLK\_SLOWCLK\_DIV configuration can be used when:

- An independent transmit clock is required (asynchronous to **SYSCLK**)
- Internal variable data rate generation is required.
- An independent 10/5MHz reference clock is required and available externally.

The variable data rate is implemented using a programmable divider which enables a toggle flip-flop. When the SpaceWire CODEC is performing link start-up (**FSM.SEL\_SLOW**) the input **TXCLK** is selected. When link start-up has been performed and a link connection has been established the input **TXRATE** determines the data rate. When **TXRATE** is equal to zero (maximum rate) then **XIMAX** is asserted and **TXCLK** is selected by the glitch free clock multiplexer. When **TXRATE** is not equal to zero the clock generator output **XI\_CLK\_DIV** is selected by the multiplexer.



Figure 6-8 TX SLOWCLK DIV transmit clock configuration



## 6.5.9 Transmit bit clock configuration TXCLK\_ DIV

The TXCLK\_DIV configuration can be used when:

- An independent transmit clock is required (asynchronous to **SYSCLK**)
- Internal variable data rate generation is required.
- Internal 10Mbits/s data rate generation is required..

The block diagram shown in Figure 6-8 describes the TXCLK\_DIV configuration. When either the FSM.SEL\_SLOW signal is asserted, the link is not running or it is starting up, then **TXCLK** is selected by the glitch free multiplexer. When the link is running the internally generated XI\_DIV\_CLK clock is selected.



#### Figure 6-9 TXCLK\_DIV transmit clock configuration

The variable data rate and the 10MHz default data rate are implemented using a programmable divider which enables a toggle flip-flop. When the SpaceWire CODEC is performing link start-up (FSM.SEL\_SLOW) the input CFG\_SLOWRATE\_TXCLK determines the frequency of TXBITCLK. When link start-up has been performed and a link connection has been established the input TXRATE determines the data rate. When TXRATE is equal to zero (maximum rate) then XIMAX is asserted and TXCLK is selected by the glitch free clock multiplexer. When TXRATE is not equal to zero the clock divider output XI\_CLK\_DIV is selected by the multiplexer.



## 6.5.10 Transmit bit clock configuration TXCLK\_EN

The configuration TXCLK\_EN can be used when:

- An independent transmit clock is required (asynchronous to **SYSCLK**)
- The number of clock nets available to the user is limited (TXCLK is used as the baseline transmit clock and synchronous clock enables are used to generate the variable data rate)

Figure 6-10 shows the block diagram for TXCLK\_EN.



Figure 6-10 TXCLK\_EN transmit clock configuration

When the internal state machine signal **FSM.SEL\_SLOW** is asserted the input **CFG\_SLOWRATE\_TXCLK** determines the final data-rate. When **FSM.SEL\_SLOW** is de-asserted then **TXRATE** determines the final data-rate.

The outputs XENR and XENF should be connected to the rising edge enable and falling edge enable of the transmit double data rate output register.

Note: When DDR output are selected and CFG\_SLOWRATE\_TXCLK or TXRATE is an odd number the duty cycle on DOUT/SOUT will not be 50/50. The worst case duty cycle, when TXRATE or CFG\_SLOWRATE\_TX = 1, will be 75/25 (i.e. 15ns/5ns for 2 transitions at a 20 ns period). This is still a valid configuration under the SpaceWire standard.



#### 6.5.11 Variable data rate and default 10Mbits/sec data rate generation

In the previous sections the signals CFG\_SLOWRATE\_TXCLK and TXRATE are used to determine the variable and default data rates. The following functions should be used to determine the value of each signal.

 $10MbitRate = \frac{TxMaxBitRate}{CFG\_SLOWRATE\_TXCLK+1}$ 

 $TxBitRate = \frac{TxMaxBitRate}{TXRATE + 1}$ 

The top level generic **CFG\_RATENUMBITS** should be set according to the maximum value which will be used to divide the value TxMaxBitRate.

Warning: **TXRATE** is used in the transmit clock domain therefore should be synchronous to the SpaceWire link signal **TXBITCLK**. In some configurations TXBITCLK is variable.

The following examples show values of CFG\_SLOWRATE\_TXCLK and TXCLK dependent on the maximum bit rate and also the generic ratenumbits.

Example 1 - TxMaxBitRate = 200Mbits/s

$$CFG\_SLOWRATE\_TXCLK = \frac{200Mbit/s}{10Mbit/s} - 1 = 19$$

If **TXRATE** is equal to 3 then:

$$TxBitRate = \frac{200Mbit/s}{3+1} = 50Mbit/s$$

If the slowest clock speed is 10Mbits/sec (CFG\_SLOWRATE\_TXCLK=19) the generic ratenumbits should be set to 5 (2^5 max value = 31)

 $\begin{array}{l} \underline{\mathsf{Example 2}}_{-} \mathsf{TxMaxBitRate} = 66 \mathsf{Mbits/s} \\ CFG\_SLOWRATE\_TXCLK = \frac{66 M bit/s}{10 M bit/s} - 1 = 5.6 \ (5 \ \mathrm{or} \ 6 \ \mathrm{can} \ \mathrm{be} \ \mathrm{used}) \\ \mathrm{If} \ \mathrm{CFG\_SLOWRATE\_TXCLK} = 5 \ \mathrm{then} \ 10 M bitRate = \frac{66 M bit/s}{5+1} = 11 M bit/s \\ \mathrm{If} \ \mathrm{CFG\_SLOWRATE\_TXCLK} = 6 \ \mathrm{then} \ 10 M bitRate = \frac{66 M bit/s}{6+1} = 9.428 M bit/s \\ \mathrm{Note:} \ \mathrm{both} \ \mathrm{values} \ \mathrm{above} \ \mathrm{are} \ \mathrm{inside} \ \mathrm{the} \ 10 M \mathrm{bits/s} + / - 10\% \ \mathrm{defined} \ \mathrm{in} \ \mathrm{the} \ \mathrm{SpaceWire} \ \mathrm{standard}. \end{array}$ 



## 6.5.12 Double Data Rate outputs

The configuration input **CFG\_DDROUT** determines if the transmit encoder outputs will be encoded as double data rate (DDR) or single data rate. Two bits per clock cycle are output for each bit clock period when CFG\_DDROUT is equal to '1'.

The UoD SpaceWire CODEC does not implement an internal DDR output register, but one is provided for reference in the file "transmit/txddrreg.vhd". This allows the user to implement a vendor specific DDR output register scheme, e.g. Virtex2 DDR output buffers, if appropriate. The usage of DDR output buffers is described in section 8.1.2.



### 6.5.13 Transmit clock configuration and signals overview

| signal/constant    | Туре | Description                                                                          | Sync To Clk                                                           |
|--------------------|------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| TXCLK              | In   | Independent transmit clock                                                           | n/a                                                                   |
| SLOWCLK            | In   | Independent 10/5 MHz reference clock.                                                | n/a                                                                   |
| CFG_BITCLK(3:0)    | In   | Configuration selection for<br>transmit clock                                        | n/a                                                                   |
| CFG_SLOWRATE_TXCLK | In   | Divider value to derive the<br>10Mbits/s default rate when<br>generated internally.  | TXCLK when CFG_BITCLK =<br>TXCLK_*, SYSCLK when<br>CFG_BITCLK = SYS_* |
| TXRATE             | In   | Divider value to derive the variable transmit rate, when it is generated internally. | TXCLK when CFG_BITCLK =<br>TXCLK_*, SYSCLK when<br>CFG_BITCLK = SYS_* |
| XENR               | Out  | Clock enable for rising edges<br>when CFG_BITCLK =<br>SYS/TXCLK_EN                   | TXBITCLK                                                              |
| XENF               | Out  | Clock enable for falling edges<br>when CFG_BITCLK =<br>SYS/TXCLK_EN                  | TXBITCLK                                                              |

Table 6-3 Transmit configuration and signals overview



## 6.6 10/5 MHz Reference Clock (SLOWCLK)

The interface signal **SLOWCLK** can be used to input a 10/5 MHz reference clock for the UoD SpaceWire CODEC. Depending on the transmit clock configuration, **SLOWCLK** can provide the default 10Mbits/s data signalling rate at start-up and connection.

**SLOWCLK** is also used as the reference clock for receive disconnect detection and state machine timeout detection. This is the most efficient implementation as no internal counter is required to generate a 10MHz reference clock enable signal, although extra synchronisation is required between the system clock domain and the 10MHz clock domain.

When a double data rate configuration is used the bit rate is twice the **SLOWCLK** clock speed, i.e. 5MHz clock and double data rate output gives 10Mbit/s. For better resolution of the disconnect and state machine timers a 10MHz reference clock rate can be used by setting **CFG\_SLOWCLK\_10MHz** to '1'. Internally the 10MHz signal is divided to give a 5MHz reference clock to the transmitter when initialisation is performed.

### 6.7 Receive buffer clock.

The user can select which clock is used to resynchronise N-chars from the receiver clock domain and write them to the receiver buffer. When the configuration signal CFG\_SYNCRDCLK = '1' then SYSCLK is used. When CFG\_SYNCRDCLK = '0' the input RDCLK is used.

The interface signal **RDCLK** can be used as an independent read clock for the receiver buffer. This can be useful if very high data rates are implemented and **RDCLK** should be partitioned from **SYSCLK**.

The receive buffer data flow is shown in Figure 6-11





## 6.8 Pipelining

The configuration signal **CFG\_PIPELINE** allows the UoD SpaceWire CODEC to insert pipeline registers where appropriate to decrease the delays between flip-flops and increase clock speed and transmission speed.

When CFG\_PIPELINE = '1' then an extra cycle of latency is required to transmit/receive one Timecode/N-char



An increase in area footprint can be expected when CFG\_PIPELINE is equal to '1'.

## 6.9 Discarding Empty Packets

The configuration input signal **CFG\_DISCARD\_EMPTY\_PACKET** when equal to '1' discards packets which have no cargo and consist only of an EOP/EEP.

## 6.10 Maximum Outstanding credit

The configuration input signal **CFG\_MAXCREDIT** should be set to the maximum number of outstanding N-chars which can be expected by the UoD SpaceWire CODEC. The maximum number of N-chars should be set in accordance with the generic **rxbufaddrlen**.

For example if a 16 byte buffer is used then CFG\_MAXCREDIT could be set to any value between 8 and 16. If CFG\_MAXCREDIT is set to greater than 16 the UoD SpaceWire link CODEC will not request more than 16 outstanding characters. Typically the user should set CFG\_MAXCREDIT to the maximum value their buffer will support up to the value 56.

The binary equivalent of the maximum outstanding credit value should be placed on CFG\_MAXCREDIT(5:0). i.e. Maximum outstanding N-chars is 32 then CFG\_MAXCREDIT should be set to "100000".

For SpaceWire compliant operation the following condition must be met:

 $8 \leq CFG_MAXCREDIT \leq 56.$ 

Note the CFG\_MAXCREDIT value does not have to be a factor of 8 and can be equal to 9,10 etc.

### 6.11 Transmit Time-code Handling

The configuration constant CFG\_TICK\_IN\_KEEP determines how the SpaceWire interface handles TICK IN requests when the link is not running.

The default behaviour of the link (CFG\_TICK\_IN\_KEEP=0) discards time-codes when the interface is not in the run state. When the link is running time-codes are transmitted with priority over other characters as normal.

The legacy behaviour of the link (CFG\_TICK\_IN\_KEEP=1) keeps time-codes in a 1 time-code storage buffer until the link enters the run state. If a new time-code is requested to be transmitted (TICK\_IN) the currently held time-code is discarded and the new time-code is the next time-code to be sent. When the link enters the run state the held time-code will be immediately sent.



## 6.12 Intenal receiver disconnect and Init FSM timeout Counters

If the CFG\_BITCLK configuration signal is set to a value which does not support an external 10/5MHz clock signal the internal receiver disconnect and state machine timeout counters will be enabled from an internal or external 10MHz clock enable pulse generator. The configuration signal CFG\_SLOW\_CE\_SEL determines if an internal or external clock enable pulse is used. If an internal clock enable generator is used the number of clock cycles to count is set to CFG\_SLOWRATE\_SYSCLK. Additional to CFG\_SLOWRATE\_SYSCLK the configuration signals TIMING\_6\_4, TIMING\_12\_8 and TIMING\_850ns determine the number of cycles of the clock enable pulse to count.

The diagram below shows the configuration steps between the configuration signals and the internal SpaceWire link blocks.



Figure 6-12 CFG\_SLOW\_CE\_SEL configuration signals

When the signal CFG\_SLOW\_CE\_SEL = '1' the input SLOW\_CE will be selected as the 10MHz clock enable pulse. When CFG\_SLOW\_CE\_SEL = '0' then an internal 10MHz pulse will be generated dependent on the signal CFG\_SLOWRATE\_SYSCLK. The CFG\_SLOWRATE\_SYSCLK value should be set via the function equation

$$CFG\_SLOWRATE\_SYSCLK = \left(\frac{SysClockFrequency}{10MHz}\right) - 1$$

Equation 6-1 CFG\_SLOWRATE\_SYSCLK (rounded down to nearest integer)

Example System Clock Frequency = 30MHz  

$$CFG\_SLOWRATE\_SYSCLK = \left(\frac{30MHz}{10MHz}\right) - 1 = 2$$

The system clock frequency may not provide an adequate 10MHz timeout rate for the initialisation state machine timeouts, i.e. a system clock is 25MHz gives a clock period of 40 ns and a



CFG\_SLOWRATE\_SYSCLK value of 1. This will give a clock enable rate of 80 ns, 40 ns \* (CFG\_SLOWRATE\_SYSCLK+1), for the 10MHz timeout rate counter which will give invalid timeout periods for the system clock.

## 6.13 Timing cycle settings

The configuration signals **TIMING\_6\_4**, **TIMING\_12\_8** and **TIMING\_850ns** are used to select the number of 10MHz clock cycles which are counted for the 6.4us, 12.8us and 850 ns timeouts. The default values are set to 64 and 128 respectively. The values should be set as follows

 $TIMING \_6\_4 = \frac{6.4\mu}{SlowClockRate}$ <u>Equation 6-2 Deriving TIMING 6 4</u>  $TIMING \_12\_8 = \frac{12.8\mu}{SlowClockRate}$ Equation 6-3 Deriving TIMING 12 8

Example System Clock Frequency = 25MHz (40 ns period)  

$$CFG\_SLOWRATE\_SYSCLK = \left(\frac{30MHz}{10MHz}\right) - 1 = 2$$
10 MHz clock enable period is =80 ns  

$$TIMING\_6\_4 = \frac{5.4\mu}{80ns} = 30$$

$$TIMING\_12\_8 = \frac{12.8\mu}{80ns} = 60$$

$$TIMING\_850ns = \frac{950ns}{80ns} = -1$$

When the configuration bit clock is **SYS\_SLOWCLK**, **SYS\_SLOWCLK\_DIV**, **TXCLK\_SLOWCLK** or **TXCLK\_SLOWCLK\_DIV** then the **TIMING\_6\_4** and **TIMING\_12\_8** settings should be adjusted to allow for the synchronisation time to load the initialisation state machine counter. The additional time to load the counter, as shown in Figure 6-13, is calculated as 1 system clock cycle plus 3 reference clock cycles.



Figure 6-13 Additional time added when loading state machine counter

Example System Clock Frequency = 30MHz (33.333 ns period), CFG\_BITCLK=SYS\_SLOWCLK.  $TIMING\_6\_4 = \frac{(6.4\mu s) - 333ns}{100ns} = 61$   $TIMING\_12\_8 = \frac{(12.8\mu s) - 333ns}{100ns} = 125$ 

### 6.14 Disconnect Timeout Uncertainty

The disconnect period of the SpaceWire link is specified to be from 727ns to 1000ns, see the SpaceWire Standard section 8.11.12. In the SpaceWire CODEC model the timeout period for the disconnect timeout counter has a one cycle uncertainty. For example, if the disconnect timer is set to 9 cycles of a 100ns period timeout clock the disconnect period will be from 800 ns to 900 ns as shown in Figure 6-14.



Figure 6-14 Disconnect timeout uncertainty (100ns period)

## 6.15 Configuration Signals Overview

| Signal                                                                                                                  | Туре | Description                                   | Sync To<br>Clk |
|-------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------|----------------|
| CFG_SYNCRDCLK                                                                                                           | In   | Is receive buffer clock synchronous to SYSCLK | n/a            |
| CFG_PIPELINE In Should pipelining flip-flops be inserted into the UoD SpaceWire CODEC to increase achievable data rate. |      | n/a                                           |                |



 Ref.:
 UoD-Link-User

 2.4
 Issue:
 27 March 2009

 Date:
 Page: 41 / 69

User Manual

| CFG_DISCARD_EMPTY_PKT | In | Should empty packets be discarded by the receiver                                  | n/a       |
|-----------------------|----|------------------------------------------------------------------------------------|-----------|
| CFG_MAXCREDIT         | In | Maximum outstanding credit the receive buffer credit counter can hold.             | RXBUF_CLK |
| CFG_SLOWRATE_SYSCLK   | In | Number of clock cycles for a 10MHz rate.                                           | n/a       |
| TIMING_6_4            | In | Number of 10MHz rate clock cycles to count for the 6.4µs timeout.                  | n/a       |
| TIMING_12_8           | In | Number of 10MHz rate clock cycles to count for the 12.8µs timeout.                 | n/a       |
| TIMING_850ns          | In | Number of 10MHz rate clock cycles to count for the 850 ns disconnect period timer. | n/a       |

Table 6-4 Configuration signals overview



# 7 INTERNAL INTERFACE

The following sub-sections define the operation of the UoD SpaceWire CODEC..

## 7.1 Link State Operation

The link state operation signals control the enabling and disabling of the SpaceWire CODEC. The SpaceWire link state machine is shown in Figure 7-1.



Figure 7-1 Initialisation state machine

### 7.1.1 Link Start-up

Link start-up is implemented as described in [AD1] (section 8.5). The CODEC attempts to make a connection with the other end of the link when in state *Started*. The interface state machine moves to *Started* when in state *Ready* and LINK\_ENABLED is asserted. The signal LINK\_ENABLED is defined below.

```
LINK_ENABLED = (not LINK_DISABLED) and (LINK_START or (AUTO_START and GOT_NULL))
```

When **LINK\_START** is asserted and **LINK\_DISABLED** is de-asserted the CODEC will always try to establish a connection with the other end of the link. If no connection is established, i.e. no NULLs received, after sending NULLs for 12.8 us the exchange of silence protocol is performed. If a NULL is received then an FCT character is expected before moving to the *Run* state where data and timecodes can be transmitted.



When **AUTO\_START** is asserted and **LINK\_START** and **LINK\_DISABLE** are de-asserted the CODEC will remain in state *Ready* until reception of a NULL.

### 7.1.2 Link Disable

Link Disable is implemented as described in [AD1] section 8.5. **LINK\_DISABLE** should be asserted to cause a safe link disconnection. Error recovery is performed when **LINK\_DISABLE** causes the state machine to move from **Run** to **ErrorReset**.

| Signal       | Туре | Description                                                                                                                                                                        | Sync To<br>Clk |
|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| LINK_START   | In   | Enable the CODEC to establish a connection.                                                                                                                                        | SYSCLK         |
| LINK_DISABLE | In   | Disable or stop the CODEC. When LINK_DISABLE is asserted it causes the initialisation state machine to move from <i>Run</i> to <i>ErrorReset</i> then error recovery is performed. | SYSCLK         |
| AUTOSTART    | In   | Auto start the CODEC. When set the CODEC will wait in state <i>Ready</i> until the first NULL character is received.                                                               | SYSCLK         |

Link start-up signals are listed in Table 7-1.

Table 7-1 Link control signals

## 7.2 Data Interface

The data interface consists of a transmit interface and a receive interface. As shown in Figure 5-1 a transmitter FIFO and receiver buffer should be placed between the UoD SpaceWire CODEC and the host data bus controller, or equivalent.

The transmit FIFO should be reset when the CODEC is reset.

### 7.2.1 Transmit

The transmit FIFO should be clocked by the UoD SpaceWire CODEC signal **TXBITCLK**. This ensures that the maximum data rate can be achieved by allowing the transmitter to read data characters synchronously from the transmit FIFO using the transmit clock. In cases where TXBITCLK can be variable the transmit FIFO should be capable of independent read and write clock operation.

## 7.2.2 Transmit FIFO signals operation.

When the host FIFO has data then it should de-assert the CODEC input signal **TX\_FIFO\_EMPTY** and place the data on the input **TX\_FIFO\_DATA(8:0)**. The transmitter asserts **TX\_FIFO\_READ** for one cycle to read the data into the transmitter for transmission over the link. The interface between the transmitter FIFO and the transmitter bus controller, or equivalent, is dependent on the application. The expected transmitter FIFO interface waveforms are shown in Figure 7-2.



Note:- If a read from the FIFO causes the FIFO to become empty on the next clock cycle the empty signal must be asserted before the next clock cycle. (e.g. cycle 4 above)

Note:- After an EOP transmit (4 serial bits) the next data character can be read immediately for transmission

#### 7.2.3 Receive

The receive port of the UoD SpaceWire CODEC implements the read, write and FCT pointers for the receive buffer. The user simply has to choose the size of the read buffer and implement the memory storage for received N-chars.

#### 7.2.4 Receive buffer signals operation

All receive buffer output signals as synchronous to **RXBUF\_CLK**.

Note: The receiver buffer pointers are implemented synchronously to **RXBUF\_CLK** as N-chars are resynchronised to the **RXBUF\_CLK** domain before being written to the receiver buffer. This allows EEPs to be written to the receive buffer when an error occurs

#### 7.2.5 Data Received

On reception of a data character the data is placed on the output signal **RXBUF\_DATA(8:0)** and **RXBUF\_WRVALID** is asserted for one cycle (see figures Figure 5-1 and Figure 7-3). **RXBUF\_WRVALID** should be connected to the write enable port of the receive buffer. If a credit error occurs, N-char(s) received when not expected/requested, the link is disconnected and the error bytes are written to the receive buffer if not full. If the receive buffer is full the N-chars are discarded. The output **RXBUF\_WRADDR** should be connected to the write address port of the memory storage used for the receive buffer.

#### 7.2.6 Host read

When the user reads an N-char from the receive buffer the signal **RXBUF\_READ** should be asserted for one **RXBUF\_CLK** cycle. The UoD CODEC will assert the signal **RXBUF\_RDVALID** if the read is



valid, i.e. the FIFO is not empty. The output **RXBUF\_RDVALID** can be connected to the enable port of the receive buffer storage output register if required. The output **RXBUF\_RDADDR** should be connected to the read address port of the storage method used for the receive buffer.

### 7.2.7 Flags

The receive port implements an empty flag, **RXBUF\_EMPTY**, and a programmable flag, **RXBUF\_PROGFLAG**, for the receive buffer. The empty flag is asserted when there are no N-chars in the buffer. The programmable flag is asserted when the number of characters in the buffer equals the input signal **RXBUF\_PROGVAL**. In this way a half full or almost full flag can be generated dependent on the user application needs.

Note: The **RXBUF\_PROGFLAG** has a one clock cycle latency before assertion and de-assertion therefore it should be used as a guide for half full and almost full



Figure 7-3 shows the timing specification for the receive buffer signals.

Figure 7-3 Receive timing specification

Note: **RXBUF\_READ** can be asserted when the receive buffer is empty. The read pointer will only be updated when **RXBUF\_RDVALID** is asserted (The FIFO is not empty).

### 7.2.8 Receive buffer clock frequency.

The minimum frequency of the receive buffer clock is dependent on the maximum data rate the SpaceWire CODEC will receive and the minimum size of packets which will be expected by the SpaceWire CODEC.



User Manual

 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 46 / 69

### Minimum read clock with different input bit rates

| BitRate | Tdata   | Теор     | MinNumData | Tpacket  | Taverage | MinRdClk    |
|---------|---------|----------|------------|----------|----------|-------------|
| 1.E+9   | 10.E-9  | 4.E-09   | 1          | 14.E-09  | 7.E-09   | 142.857E+06 |
| 500.E+6 | 20.E-9  | 8.E-09   | 1          | 28.E-09  | 14.E-09  | 71.429E+06  |
| 200.E+6 | 50.E-9  | 20.E-09  | 1          | 70.E-09  | 35.E-09  | 28.571E+06  |
| 100.E+6 | 100.E-9 | 40.E-09  | 1          | 140.E-09 | 70.E-09  | 14.286E+06  |
| 50.E+6  | 200.E-9 | 80.E-09  | 1          | 280.E-09 | 140.E-09 | 7.143E+06   |
| 25.E+6  | 400.E-9 | 160.E-09 | 1          | 560.E-09 | 280.E-09 | 3.571E+06   |

#### Minimum read clock with different minimum packet data sizes

| BitRate | Tdata  | Теор    | MinNumData | Tpacket  | Taverage | MinRdClk   |
|---------|--------|---------|------------|----------|----------|------------|
| 200.E+6 | 50.E-9 | 20.E-09 | 0          | 20.E-09  | 20.E-09  | 50.E+06    |
| 200.E+6 | 50.E-9 | 20.E-09 | 1          | 70.E-09  | 35.E-09  | 28.571E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 2          | 120.E-09 | 40.E-09  | 25.E+06    |
| 200.E+6 | 50.E-9 | 20.E-09 | 3          | 170.E-09 | 43.E-09  | 23.529E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 4          | 220.E-09 | 44.E-09  | 22.727E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 5          | 270.E-09 | 45.E-09  | 22.222E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 6          | 320.E-09 | 46.E-09  | 21.875E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 7          | 370.E-09 | 46.E-09  | 21.622E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 8          | 420.E-09 | 47.E-09  | 21.429E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 9          | 470.E-09 | 47.E-09  | 21.277E+06 |
| 200.E+6 | 50.E-9 | 20.E-09 | 10         | 520.E-09 | 47.E-09  | 21.154E+06 |

#### Legend

| MinNumData=0 |                                            | EOP         |                  | _          |         |
|--------------|--------------------------------------------|-------------|------------------|------------|---------|
| MinNumData=1 |                                            | DATA        | EOP              |            |         |
| MinNumData   | =2                                         | DATA        | DATA             | EOP        |         |
| MinNumData   | =3                                         | DATA        | DATA             | DATA       | EOP     |
| etc          |                                            |             |                  |            |         |
| Tdata        | Time for one                               | data byte t | o be received    |            |         |
| Теор         | Time for one                               | EOP byte f  | to be received   |            |         |
| Tpacket      | ket Time for one packet to be received     |             |                  |            |         |
| Taverage     | Average time for one N-Char to be received |             |                  |            |         |
| MinRdClk     | Minimum frec                               | quency of r | ead clock to res | ynchronise | n-chars |

Figure 7-4 Minimum Receive buffer clock frequency

From the table above the function for minimum read clock frequency is:

$$Min = \frac{1}{\left(\frac{(MinNumData \times T_{data}) + T_{eop}}{MinNumData + 1}\right)}$$
$$Tdata = \left(\frac{1}{BitTime}\right) \times 10$$



Ref.: UoD-Link-User 2.4 Issue: 27 March 2009 Date: Page: 47 / 69

#### User Manual

$$Teop = \left(\frac{1}{BitTime}\right) \times 4$$

and MinNumData is the minimum number of data bytes in a packet.

The table and functions above shows the absolute minimum frequency for **RXBUF\_CLK**. Dependent on the actual bit-rate (transmit clock +/- values) or the average jitter on **DIN/SIN** a tolerance should be added to the receive buffer clock e.g. +1%.

**Example:** If characters are received at the maximum rate then jitter on **DIN** and **SIN** and therefore **RXCLK** can cause the Taverage time to drop below the expected value. For example if jitter on DIN/SIN caused the bit rate to vary between 200 and 205 Mbits/sec then Taverage will vary between 34 and 35 ns therefore the minimum read clock should be 29.286 MHz.

### 7.2.9 Maximum input bit rate dependent on receive buffer clock frequency

Analysis of the maximum input bit-rate can be useful when the receive buffer clock frequency is fixed. E.g. receive buffer clock is tied to the system clock which is dependent on an external processor.

The function below shows the maximum input bit-rate dependent on the receive buffer clock:

$$MaxInputBitRate = \frac{1}{\left(\frac{T_{RXBUF\_CLK} \times NumPktNchars}{NumPktBits}\right)}$$
$$T_{RXBUFCLK} = \frac{1}{RxBufClkFrequency}$$
$$NumPktNchars = MinNumData + 1$$
$$NumPktBits = (MinNumData \times 10) + 4$$

Example: If the receive buffer frequency is 50MHz and the minimum packet expected is 1 N-char+ EOP then

Trxbuf\_clk = 20ns, and NumPktNchars = 2, and NumPktBits = 14,

therefore

$$MaxBitRate = \frac{1}{\left(\frac{20ns \times 2}{14}\right)} = 350Mbit/s$$

i.e. The maximum bit rate can be 7 times the receive buffer clock rate when MinNumData = 1



 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 48 / 69

User Manual

## 7.2.10 Data Interface Signals

Data interface signals are listed in Table 7-3

| Signal        | Туре | Description                                                                                                                                                                  | Sync To<br>Clk |
|---------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| TX_FIFO_DATA  | In   | Transmitter data which is read by the transmitter. The most significant bit is the data control flag which indicates if the character is an end of packet or data character. | TXBITCLK       |
| TX_FIFO_READ  | Out  | Asserted when the transmitter reads one N-char from the transmitter FIFO.                                                                                                    | TXBITCLK       |
| TX_FIFO_EMPTY | In   | Transmitter FIFO empty flag indicates the empty status of the transmitter. When high the transmitter is empty.                                                               | TXBITCLK       |

Table 7-2 Transmit data interface signals

*Note TXBITCLK may be = SYSCLK, SLOWCLK or divided clock.* 

| Signal         | Туре | Description                                                                                                                                                                                  | Sync To<br>Clk |
|----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| RXBUF_DATA     | Out  | Receiver data which is written from the receiver to the receiver FIFO. The most significant bit is the character control flag which indicates when the character is an end of packet marker. | RXBUF_CLK      |
| RXBUF_WRVALID  | Out  | Asserted when data is received and ready on <b>RXBUF_DATA</b> .                                                                                                                              | RXBUF_CLK      |
| RXBUF_WRADDR   | Out  | Address to write <b>RXBUF_DATA</b> to.                                                                                                                                                       | RXBUF_CLK      |
| RXBUF_EMPTY    | Out  | Empty flag for receive buffer. When asserted then no data is in the buffer                                                                                                                   | RXBUF_CLK      |
| RXBUF_READ     | In   | Read from receive buffer. Asserted for one <b>RXBUF_CLK</b> period                                                                                                                           | RXBUF_CLK      |
| RXBUF_RDVALID  | Out  | Asserted when <b>RXBUF_READ</b> is asserted and the buffer is not empty.                                                                                                                     | RXBUF_CLK      |
| RXBUF_RDADDR   | Out  | Address to read data from the receive buffer. Updated on a valid read                                                                                                                        | RXBUF_CLK      |
| RXBUF_PROGFLAG | Out  | Programmable flag which can be used to indicate a half-<br>full condition or as a level indicator                                                                                            | RXBUF_CLK      |
| RXBUF_PROGVAL  | Out  | Programmable flag value                                                                                                                                                                      | RXBUF_CLK      |

Table 7-3 Receive data interface signals

## 7.3 Timecode Interface

The timecode interface consists of a transmit and receive interface. Timecode signals are synchronous to the system clock.



User Manual

 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 49 / 69

## 7.3.1 Transmit

The host timecode controller will typically include a six bit counter which is incremented/decremented when a timecode is transmitted. The timecode value should be placed on the input **TIME\_IN(7:0)** and **TICK\_IN** should be asserted when a timecode is to be transmitted. **TICK\_IN** can be asserted for more than one clock cycle but only one timecode will be transmitted. The timecode value which is present on **TIME\_IN** on the rising edge of **SYSCLK** when **TICK\_IN** is asserted will be transmitted. The timecode timing specification is shown in Figure 7-5.



Figure 7-5 TICK\_IN interface

**Note**:- No timecode buffering is employed and if the CODEC is not in state Run the **TICK\_IN** request is ignored. This is consistent with the nature of timecode processing in a SpaceWire network.

### 7.3.2 Receive

On reception of a timecode the signal **TICK\_OUT** is asserted and the timecode value is placed on the output **TIME\_OUT** (7:0). The **TIME\_OUT** value is registered in the **RXCLK** clock domain and is valid only on the rising edge **SYSCLK** when **TICK\_OUT** is asserted. The **TIME\_OUT** interface is shown in Figure 7-6.



### 7.3.3 Timecode Interface Signals

Timecode interface signals are listed in

| Signal              | Туре | Description                                              | Sync<br>To Clk |
|---------------------|------|----------------------------------------------------------|----------------|
| <b>TIME_IN(7:0)</b> | In   | Timestamp which is sent over the SpaceWire link when the | SYSCLK         |



 Ref.:
 UoD-Link-User

 2.4
 Issue:
 27 March 2009

 Date:
 Page: 50 / 69

**User Manual** 

|               |     | control signal <b>TICK_IN</b> is asserted. The timecode is sent immediately after the transmitter has completed sending the previous character.         |        |
|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| TICK_IN       | In  | Tick-in strobe causes a timecode to be sent over the spacewire link. The signal is synchronous.                                                         | SYSCLK |
| TIME_OUT(7:0) | Out | Received timecode output. The timecode on <b>TIME_OUT</b> is valid when <b>TICK_OUT</b> is asserted.                                                    | RXCLK  |
| TICK_OUT      | Out | Asserted when a timecode is received and the timecode<br>on <b>TIME_OUT</b> is valid. The <b>TICK_OUT</b> signal is<br>synchronous to the system clock. | SYSCLK |

Table 7-4 Timecode interface signals

## 7.4 Status Signals

Status reporting is performed through the output signal **STATUS(15:0)**. Run errors are reported through the \*\_RUNERR output signals

| Signal              | Туре | Description                                                                                            | Sync to<br>Clk |
|---------------------|------|--------------------------------------------------------------------------------------------------------|----------------|
| DISC_RUN_ERR        | Out  | Disconnect error in run state                                                                          | SYSCLK         |
| PARITY_RUN_ERR      | Out  | Parity error in run state                                                                              | SYSCLK         |
| ESCAPE_RUN_ERR      | Out  | Escape error in run state                                                                              | SYSCLK         |
| CREDIT_RUN_ERR      | Out  | Transmit or receive credit error in run state                                                          | SYSCLK         |
| STATUS (15:0)       | Out  | SpaceWire interface status signals. All status signals are synchronous to CLK                          | SYSCLK         |
| STATUS (0)          | Out  | Disconnect error.                                                                                      | SYSCLK         |
| STATUS (1)          | Out  | Parity error.                                                                                          | SYSCLK         |
| STATUS (2)          | Out  | Escape error.                                                                                          | SYSCLK         |
| STATUS (3)          | Out  | Receiver credit error. The receiver has received more data characters then requested                   | SYSCLK         |
| STATUS (4)          | Out  | Transmitter credit error. The transmitter has credit to send more than the allowed 56 data characters. | SYSCLK         |
| <b>STATUS</b> (7:5) | Out  | Interface state encoded into three bits (6 states)                                                     | SYSCLK         |
| STATUS (8)          | Out  | Interface state machine is in the Run state.                                                           | SYSCLK         |
| STATUS (9)          | Out  | Receiver got NULL. Remains asserted after first NULL.                                                  | SYSCLK         |
| STATUS (10)         | Out  | Receiver got FCT. Remains asserted after first FCT                                                     | SYSCLK         |
| STATUS (11)         | Out  | Receiver got N-chars. Remains asserted after first N-Char                                              | SYSCLK         |
| STATUS (12)         | Out  | Receiver got Timecodes. Remains asserted after first Timecode                                          | SYSCLK         |
| STATUS (13)         | Out  | Transmitter has credit to send one more data character                                                 | SYSCLK         |
| STATUS (14)         | Out  | N-char sequence error (N-char received before link state is Run)                                       | SYSCLK         |
| STATUS (15)         | Out  | Timecode sequence error (Timecode received before link                                                 | SYSCLK         |

The status bits are listed in Table 7-5



|  | state is Run) |  |
|--|---------------|--|
|  |               |  |

#### Table 7-5 Status signals

The state encoding used for **STATUS** (7:5) is shown in the following table

| Interface state | STATUS (7:5)   |
|-----------------|----------------|
| ErrorReset      | <b>``</b> 000″ |
| ErrorWait       | "001 <i>"</i>  |
| Ready           | "010 <i>"</i>  |
| Started         | "011 <i>"</i>  |
| Connecting      | "100 <i>"</i>  |
| Run             | <b>`101</b>    |

### 7.5 Error Recovery

Error recovery is initiated when the CODEC state machine moves to state *ErrorReset* after an error or if **LINK\_DISABLE** is asserted.

### 7.5.1 Transmitter Error Recovery

Transmitter error recovery is performed when the CODEC state machine moves from state *Run* to state *ErrorReset*. Error recovery is performed as follows

If the previous character read from the transmitter FIFO was not an end of packet marker then each consecutive character is read until an end of packet marker is encountered. In this way the next character to be sent after a link disconnection is the header character of the next packet. Transmitter error recovery does not affect link start-up after an error.

### 7.5.2 Transmitter Buffer Flushing

The transmitter may hold more than one SpaceWire packet and it may be necessary to flush all packets from the transmitter buffer during operation or after error recovery. The input signal **FLUSH\_TX** cause the transmitter error recovery module to continually read packets from the transmitter buffer until the signal is de-asserted.

#### 7.5.3 Receiver Error Recovery

Receiver error recovery is performed when the CODEC state machine moves from state *Run* or *Connecting* to state *ErrorReset*. Error Recovery is performed as follows.

The error recovery module waits for space in the receiver FIFO to write an error end of packet character (EEP). If the receiver FIFO is full then link initialisation is stalled until the host reads at least nine data characters from the FIFO (8 data characters for one FCT and one data character for EEP). The receiver credit counters are updated accordingly before the next link initialisation procedure.



 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 52 / 69

#### Error Recovery signals are listed in table Table 7-6

| Signal   | Туре | Description                                                                                                                                                                  | Sync to<br>Clk |
|----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| FLUSH_TX | In   | Cause the transmitter error recovery controller to continually flush<br>the transmitter buffer (read from the buffer when data available)<br>independent of the CODEC state. | SYSCLK         |

Table 7-6 Error Recovery Signals



# 8 EXTERNAL INTERFACE

## 8.1 Data Strobe Encoding

The UoD CODEC uses Data-Strobe (DS) encoding as defined in the SpaceWire standard [AD1]. When transmitting DS encoding defines that the strobe signal keeps its value when data changes and strobe changes when data retains its value. In this way the receiver can recover the transmitter clock by an exclusive-or (XOR) operation between the data and strobe lines. The recovered clock is half the rate of transmitted bit-rate therefore rising and falling edges of the recovered clock are used to sample the data input.

The CODEC can encode the bit-stream using single data rate (SDR) or double data rate (DDR) encoding, depending on the configuration signal CFG\_DDROUT.

### 8.1.1 Single data rate outputs

When SDR outputs are used then **DOUT** and **SOUT** port output signals can be connected directly to the implementation technology output buffers.

### 8.1.2 Double data rate outputs

When CFG\_DDROUT is equal to '1' the outputs DOUT\_F and SOUT\_F are used as the falling edge data and DOUT and SOUT is the rising edge data.

The following diagrams show the configurations which can be used for DDR outputs.



Figure 8-1 Generic DOUT and SOUT DDR encode

The generic **DOUT** and **SOUT** DDR encode method is included in the file "transmit/txddrreg.vhd" and "transmit/txddrreg\_noenable.vhd"

The file "transmit/txddrreg.vhd' can be used for all configurations. It rebuilds the transmit clock into a multiplexer select signal for the output DDR multiplexer using clock enables if required to generate a variable data rate. The DDR output is shown in Figure 8-2.



Figure 8-2 Transmit DDR register "transmit/txddrreg.vhd"

The file "transmit/txddrreg\_noenable.vhd' can be used for configurations which do not use a clock enable to generate the variable data rate. This includes configurations; SYS\_DEFAULT, SYS\_SLOWCLK, SYS\_SLOWCLK\_DIV, SYS\_DIV, TXCLK\_DEFAULT, TXCLK\_SLOWCLK, TXCLK\_DIV and TXCLK\_DIV. It rebuilds the transmit clock into a multiplexer select signal for the output DDR multiplexer using clock enables if required to generate a variable data rate. The DDR output is shown in Figure 8-3.



Figure 8-3 txddrreg\_noenable.vhd double data rate generation logic and waveform



The advantages of using the generic DDR output buffer method include:

- Support for **SYS\_EN** and **TXCLK\_EN** transmit bit clock configurations where two clock enable signals **XENR** and **XENF** are used to control the data rate by enabling rising and falling clock edges independently (typically not supported in vendor specific DDR output buffers).
- Generic implementation which is suitable for all architectures.

Disadvantages of using the generic DDR output buffer method include:

- Delays between DOUT/SOUT and DOUT\_F/SOUT\_F and the select signals for the DDR output multiplexer must be delay matched to ensure no glitches occur on the outputs. (see section 10.3).
- Output skew may be introduced between **DOUT** and **SOUT** as the output is not directly at the output pad.



#### Figure 8-4 Vendor specific DOUT and SOUT DDR encode

The advantages of using the vendor specific DDR output buffer method include:

- Output select multiplexer is optimised to ensure no glitches occur on the outputs.
- The DDR output is directly at the output buffer therefore no output skew is introduced into DOUT and SOUT

The disadvantages of using the vendor specific DDR output buffer method include:

• Transmit clock configurations SYS\_EN and TXCLK\_EN may not be supported as independent clock enables for rising and falling edge data are required.

#### 8.1.3 Data Strobe Timing

To achieve the high data rates required in SpaceWire then output skew between DOUT/SOUT and DIN/SIN must be kept as low as possible.



## 8.1.4 Serial Interface signals

The following table gives an overview of the serial interface signals

| Signal     | Туре | Description                                                  | Sync To Clk |
|------------|------|--------------------------------------------------------------|-------------|
| DOUT       | Out  | Data part of data-strobe output                              | TXBITCLK    |
| DOUT_F     | Out  | Falling edge data when DDR outputs are used                  | TXBITCLK    |
| SOUT       | Out  | Strobe part of data-strobe output                            | TXBITCLK    |
| SOUT_F     | Out  | Falling edge strobe when DDR outputs are used                | TXBITCLK    |
| DIN        | In   | Data part of data-strobe input                               | n/a         |
| SIN        | In   | Strobe part of data-strobe input                             | n/a         |
| DOUT_CLR_N | Out  | Synchronous reset for DOUT DDR output registers.             | TXBITCLK    |
| SOUT_CLR_N | Out  | Synchronous reset for SOUT DDR output registers              | TXBITCLK    |
| XENR       | Out  | Clock enable for rising edge data when DDR outputs are used  |             |
| XENF       | Out  | Clock enable for falling edge data when DDR outputs are used | TXBITCLK    |

Table 8-1 Serial interface signals



Ref.: UoD-Link-User 2.4 Issue: 27 March 2009 Date: Page: 57 / 69

## 9 SYNTHESIS

### 9.1 General

The UoD CODEC was designed to be synthesised with hierarchy. Synthesising in this way allows simple analysis of the resulting gate description.

As multiple configurations of the UoD SpaceWire CODEC are supported in one model the synthesis tool should be set to perform maximum optimisation. This ensures that unused logic or constant input signals are removed/optimised by the synthesis tool. If hierarchy is used the synthesis tool must be capable of optimising constant signals (logic 1/0) across hierarchical boundaries.

## 9.2 Memory

The UoD CODEC is designed to support synthesis by multiple tool vendors. For this purpose no internal FIFO or buffering memory structure was implemented with the CODEC and the memory must be generated externally dependent on the application.

Typically ASIC and FPGA process vendors supply generic FIFO structures which can be built to suit the application, e.g. Internal RAM structures in the Xilinx Virtex series.

## 9.3 Vendor Specific Information

The following sections give information on specific vendor issues when synthesising the CODEC.

### 9.3.1 XST

When synthesising with XST the "Automatic FSM Extraction" option in the XST synthesis options dialog should be set to "NO".

XST does not synthesise the rxnchar\_resync\_ff.vhd buffer correctly. A simple option is to use a separate coregent module to implement the buffer as a dual port/clocked FIFO as shown in the coregen generation options dialogs in Figure 9-1. The buffer is implemented using LUT RAM resources which consume minimal area in the final design.

Once the XST coregent module has been generated the component should be inserted in path to codec>/src/vhdl/top/spwrlink.vhd so the port map is correct with the newly generated coregent module. The VHDL code is shown below.

```
-- receiver nchar resynchronisation with coregen module
rxnchar_resync_ff_1: rxnchar_resync_ff
        port map (
            wr_clk => RX_CLK,
            rd clk => RDCLK i,
```



 Ref.:
 UoD-Link-User

 2.4

 Issue:
 27 March 2009

 Date:
 Page: 58 / 69

**User Manual** 

rd\_en => NCHAR\_RESYNC\_READ,
rst => RST,
wr\_en => GOT\_DATA,
empty => NCHAR\_RESYNC\_EMPTY,
full => open,
din => FORMATTED\_DATA,
dout => NCHAR\_RESYNCED);







# **10 STATIC TIMING ANALYSIS**

## **10.1** Clock constraint analysis

Dependent on the interface configuration signals , a number of different clocks can be generated by the UoD SpaceWire CODEC.

| Clock Signal                  | Source   | Comments                                                                                                                                                                                                                                                                                                                  |
|-------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYSCLK                        | External | Always present. <b>SYSCLK</b> should be constrained to the desired system clock frequency of the internal control and status registers employed. If <b>CFG_SYNCRDCLK</b> is equal to '1' then <b>SYSCLK</b> should be constrained according to the guidelines provided in section 7.2.8 - Receive buffer clock frequency. |
| RX_CLK                        | Internal | Always present. <b>RX_CLK</b> should be constrained to half<br>the maximum bit-rate received. Section 10.2<br>discusses static timing analysis of <b>RX_CLK</b> .                                                                                                                                                         |
| SLOWCLK                       | External | The slow clock input should be constrained to 5MHz when CFG_DDROUT = '1' or 10MHz when CFG_DDROUT = '0'.                                                                                                                                                                                                                  |
| RDCLK                         | External | <b>RDCLK</b> should be constrained according to the guidelines provided in section 7.2.8 - Receive buffer clock frequency.                                                                                                                                                                                                |
| TXCLK                         | External | <b>TXCLK</b> should be constrained to the maximum bit rate when CFG_DDROUT = '0' or maximum bit rate divided by 2 when CFG_DDROUT = '1';                                                                                                                                                                                  |
| TXBITCLK                      | Internal | Should be constrained to the same frequency as <b>TXCLK</b> .                                                                                                                                                                                                                                                             |
| txclkgen_1/XCLKTX             | Internal | Should be constrained to the same frequency as <b>TXBITCLK</b> . ( <b>XCLKTX</b> is the transmit clock multiplexed with the <b>SLOWCLK</b> input)                                                                                                                                                                         |
| txclkgen_1/txdiv/<br>XICLKDIV | Internal | Should be constrained to the same frequency as<br><b>TXBITCLK</b> . ( <b>XICLKDIV</b> is the transmit clock<br>multiplexed with the divided clock)                                                                                                                                                                        |
| RXBUF_CLK                     | Internal | Present if <b>CFG_SYNCRDCLK</b> = '0'. <b>RXBUF_CLK</b> should<br>be constrained according to the guidelines provided in<br>section 7.2.8 - Receive buffer clock frequency                                                                                                                                                |

#### Table 10-1 Status timing clock analysis

Note: Clocks are used according to the configuration signals (see section 6). The baseline minimum number of clock nets required for the SpaceWire CODEC is **SYSCLK** and **RXCLK** for configurations **SYS DEFAULT** and **SYS EN**.



## 10.2 Receiver Clock Static Timing Analysis

The effects of skew and jitter in the SpaceWire point to point link are discussed in the SpaceWire standard [AD1] section 6.6.4. The specification  $T_{MARGIN}$  is the available timing margin for the input bit-stream unit interval,  $T_{UI}$ . The value  $T_{MARGIN}$  is defined as:

$$T_{MARGIN} = T_{UI} - (T_{SKEW} + 2 \times T_{JITTER} + T_{DCLK} + T_{DHOLD})$$

Analysis of the timing parameters  $T_{SKEW}$ ,  $T_{JITTER}$ ,  $T_{DCLK}$  and  $T_{HOLD}$  must be performed to determine the maximum bit rate which the receiver can accept. The maximum input data rate shall be set so that  $T_{MARGIN} > 0$ .

In terms of maximum skew and jitter input to the system the function below must be observed.

 $T_{SKEW} + (2 \times T_{JITTER}) < T_{UI} - (T_{RXSKEW} + T_{DCLK} + T_{HOLD})$ 

The receive clock data and recovery flip-flops are analysed to determine the setup time of the data recovery flip-flops and the skew tolerance of the design.

The clock recovery circuit is shown in Figure 10-1.



Figure 10-1 Receive Clock Data Recovery

Four checks are performed on the design.

- 1. A clock edge generated by a change in DIN captures the correct DIN value.
- 2. A clock edge generated by strobe captures the correct DIN value.
- 3. Skew does not cause the minimum clock pulse specification of the flip-flop to be violated.
- 4. Data recovery from flip-flop DF to DF\_1 is possible

The following sub-sections define how the terms above can be measured using static timing analysis.

### 10.2.1 Timing Parameters

The timings are described in Table 10-2



 Ref.:
 UoD-Link-User

 2.4
 27 March 2009

 Date:
 Page: 61 / 69

User Manual

| Timing Parameter      | Description                                                  |  |  |
|-----------------------|--------------------------------------------------------------|--|--|
| T <sub>DCLK_DR</sub>  | Time from DIN pin to rising edge flip-flop clock pin         |  |  |
| T <sub>SCLK_DR</sub>  | Time from SIN pin to rising edge flip-flop clock pin         |  |  |
| T <sub>DCLK_DF</sub>  | Time from DIN pin to falling edge flip-flop clock pin        |  |  |
| T <sub>SCLK_DF</sub>  | Time from SIN pin to falling edge flip-flop clock pin        |  |  |
| T <sub>MAX_DCLK</sub> | Maximum of $T_{DCLK_DR}$ and $T_{DCLK_DF}$                   |  |  |
| T <sub>MAX_SCLK</sub> | Maximum of $T_{\text{SCLK}_{DR}}$ and $T_{\text{SCLK}_{DF}}$ |  |  |
| T <sub>MIN_DCLK</sub> | Minimum of $T_{DCLK_DR}$ and $T_{DCLK_DF}$                   |  |  |
| T <sub>MIN_SCLK</sub> | Minimum of $T_{SCLK_DR}$ and $T_{SCLK_DF}$                   |  |  |
| T <sub>DR</sub>       | Time from DIN to rising edge capture flip-flop               |  |  |
| T <sub>DF</sub>       | Time from DIN to falling edge capture flip-flop              |  |  |
| T <sub>MAXD</sub>     | Maximum of $T_{DR}$ and $T_{DF}$                             |  |  |
| T <sub>MIND</sub>     | Minimum of T <sub>DR</sub> and T <sub>DF</sub>               |  |  |
| T <sub>SU_DR</sub>    | Rising edge flip-flop setup time                             |  |  |
| T <sub>SU_DF</sub>    | Falling edge flip-flop setup time                            |  |  |
| T <sub>HD</sub>       | Flip-flop hold time                                          |  |  |

Table 10-2 Data and Clock Recovery Timing Parameters

Other parameters which affect the receive clock recovery is the skew and jitter on data and strobe. Jitter is equal for data and strobe therefore it only has one timing parameter. The table below defines the extra timing parameters.

| Timing Parameter    | Description                 |
|---------------------|-----------------------------|
| T <sub>UI</sub>     | Unit interval or bit period |
| T <sub>DSKEW</sub>  | Data skew                   |
| T <sub>SSKEW</sub>  | Strobe skew                 |
| T <sub>JITTER</sub> | Data and strobe jitter      |

Table 10-3 Extra Clock Recovery Timing Parameters

## 10.2.2 Data Setup Check

The following timing diagram defines the correct placement for data at the D pin of the capturing flipflop.



Figure 10-2 Data Setup Time Timing Diagram

In Figure 10-2 the maximum delay from DIN to the data pin at the flip-flop must be less than the time from DIN edge 2 to the clock pin at the flip-flop for edge 2 minus the setup time of the flip-flop as shown below:

$$T_{MAXD} < T_{MINDCLK} - T_{SU}$$
 (eq 1)

The bit period is the bit period minus two times data jitter budget (jitter reduces the bit period). The clock edge generated by edge 1 must not capture the data at edge 2 therefore the clock delay must not be greater than the data delay plus the bit period minus the data jitter as shown below:

$$T_{MAXDCLK} < T_{MIND} + T_{SU} + T_{UI} - (2 \times T_{JITTER}) \quad \text{(eq 2)}$$

i.e. the clock delay should be less than the data delay plus the bit period. An example violating this rule is shown below.



Figure 10-3 Large clock delay setup time violation

Note: Usually the clock delay will be comparable with the data delay therefore more care needs to be taken with the first data setup time rule. Also for skew tolerance it is preferable to keep the data and clock edges relatively close together.

#### 10.2.3 Strobe Setup Check

An edge on strobe captures the correct DIN value only if DIN satisfies the setup and hold time of the clock generated by strobe changes. When there is no skew on the cable then the valid strobe clock delay is defined as the bit period, plus the DIN data delay to the D pin of the flip-flop plus the setup and hold time of the flip-flop as below.



 $T_{MAXSCLK} + T_{DH} < T_{UI} + T_{MIND} \quad (eq 3)$ 

This relationship can be seen in Figure 10-4.



Figure 10-4 Latest Strobe Setup Time When no Skew

When data or strobe are skewed and jitter is added then the bit period  $T_{UI}$  is adjusted accordingly. When data is skewed the period is larger therefore  $T_{DSKEW}$  is added to  $T_{UI}$ . When strobe is skewed the bit period  $T_{UI}$  is smaller therefore  $T_{SSKEW}$  is subtracted from  $T_{UI}$ . Therefore eq. 3 becomes:

$$T_{MAXSCLK} + T_{HD} < T_{UI} + T_{DSKEW} - T_{SSKEW} - (2 \times T_{JITTER}) + T_{MIND} \quad (eq 4)$$

Note when data is skewed then  $T_{SSKEW}$  is zero and when strobe is skewed  $T_{DSKEW}$  is zero for eq.4. Figure 10-5 shows the data and strobe skew relationships.



Figure 10-5 Data and Strobe Skew effects on Strobe Setup Time

#### 10.2.4 Minimum Pulse Width

The minimum pulse width of the data and strobe signals must be greater than the bit period. The minimum pulse width of the SpaceWire receive clock with no skew is defined as the minimum of the following.

$$T_{MAXDCLK} - T_{MINSCLK}$$
  
 $T_{MAXSCLK} - T_{MINDCLK}$  (eq 5)

When data and strobe are skewed and jitter is added the minimum pulse with is defined as follows.

$$T_{UI} - T_{DSKEW} - (2 \times T_{JITTER}) > T_{MAXD} - T_{MINSCLK} + T_{SU} + T_{HD} \quad (eq 6)$$
  
$$T_{UI} - T_{SSKEW} - (2 \times T_{JITTER}) > T_{MAXSCLK} - T_{MIND} + T_{SU} + T_{HD} \quad (eq 7)$$

The timing parameters are shown in Figure 10-6.



#### 10.2.5 Skew Tolerance

To define the tolerance of the data and strobe signals to skew the following timing parameters are defined for each SpaceWire system.

| Timing Parameter       | Description                                            |
|------------------------|--------------------------------------------------------|
| T <sub>MAX_DSKEW</sub> | Maximum data skew and jitter the system can tolerate   |
| T <sub>MAX_SSKEW</sub> | Maximum strobe skew and jitter the system can tolerate |

Table 10-4 Skew Tolerance Maximums

The calculation of the maximum data skew tolerance is depicted in Figure 10-7. The maximum data skew depends on the maximum time from Din to the data pin of the flip-flop and the minimum time from the next strobe edge to the clock pin at the flip-flop.



Figure 10-7 Data Skew Tolerance

The parameter  $T_{MAX_{DSKEW}}$  is evaluated as the bit period plus the minimum strobe clock delay minus the maximum time from Din to the data pin of the flip-flop and the setup and hold time.

$$T_{MAX\_DSKEW} = T_{UI} + T_{MINSCLK} - T_{MAXD} - T_{SU} - T_{HD}$$
(8)

The calculation of the maximum strobe skew tolerance is depicted in Figure 10-7.



Figure 10-8 Maximum Strobe Skew

The maximum strobe skew parameter  $T_{MAX\_SSKEW}$  is evaluated as shown below.

$$T_{MAX\_SSKEW} = T_{UI} + T_{MIND} - T_{MAXSCLK} - T_{SU} - T_{HD}$$
(9)

## 10.3 Generic Transmitter Double Data Rate Outputs

The generic double data rate output is implemented as a multiplexer which selects between rising and falling edge data on each clock cycle. The net delays which feed the multiplexer should be balanced to ensure no glitches occur on **DOUT** or **SOUT**.

The skew between **DOUT** and **SOUT** should be minimised as this affects the maximum data rate achievable.

Two methods can be considered for the generic DDR output encoding when using the UoD CODEC.

#### 10.3.1 Generic DDR output method one

The first DDR output method uses the CODEC generic DDR multiplexer to drive the outputs DOUT and SOUT. Figure 10-9 shows the block diagram for the first method of DDR encoding where two lines are output from the transmit shift register and are multiplexed on the output.



Figure 10-9 DDR output encoding (Method one)

This method requires delay balancing on the inputs to the multiplexer to avoid high speed glitches in the DOUT and SOUT signals. The following diagram shows the paths which must be constrained such that the LR/LF net delays are equal and the DR/DFD net delays are equal. The path delay from the multiplexer select flip-flops LR/LF to the output must be greater than the paths from multiplexer



Issue: 27 March 2009 Date: Page: 66 / 69

output signal. This is because the multiplexer select signal selects one output while the other output is changing as shown in the timing diagram below.



#### Figure 10-10 DDR output multiplexer select

The timing diagram below shows the operation of the DDR multiplexer





Typical ways of constraining the paths to ensure that no glitches can occur include.

- Timing delay constraints on the nets shown. •
- Area constraints to pack the outputs into a small area and therefore minimise and equalise . net delays.



## 10.3.2 Generic DDR Method Two

The second DDR method uses the combinational output from method one (see section 10.3.1 aboce) but adds an extra register to the output stage which is clocked by a clock which is twice the frequency of the transmitter clock. In this instance a DLL or PLL can be used to derive the two clocks in the same application.

This method requires no delay matching on the outputs of the transmitter and the only requirement is that the output O meets the setup time for the doubled clock. The scheme is shown in Figure 10-12



Figure 10-12 Method Two DDR output encoding

No changes need to be made to the UoD SpaceWire CODEC to use either of these methods.



## 11 CONFORMITY

The SpaceWire CODEC VHDL core is conformant with the SpaceWire standard [AD1].

The SpaceWire CODEC verification has been performed in accordance with [AD1] section 12.2.4.



## 12 APPENDIX I – CLOCK MULTIPLEXER

The glitch free clock multiplexer used by the UoD SpaceWire CODEC is shown in Figure 12-1.



#### Figure 12-1 Glitch Free clock multiplexer

Two flip-flop synchronisation of **SELA** is used to stop meta-stable events occurring. Therefore the inputs **SELA**, **CLKA** and **CLKB** can be completely asynchronous. The output clock **CLKOUT** is enabled by the falling edge of **CLKA** or **CLKB** only when the other clock has been disabled.

As no reset is used the flip-flops require a few clock cycles to reach a steady state. These cycles are consumed when the transmitter is not doing anything so glitches cannot occur. The maximum number of cycles which can be consumed occurs when all flip-flops come out of reset in a 1 state. As **SELA** is HIGH when reset then **CLKA** will be enabled and it will take one and a half **CLKB** cycles until **CLKB** is disabled and a further one and a half clock cycles until **CLKA** is properly enabled.