# **QB-DB** Firmware Specification

*Firmware version 0x41* E. Hazen, J. Raaf, S.X. Wu Updated June 9, 2008

This document describes the firmware operation of the Ethernet Daughterboard for the QB for Super-K (QB-DB). The DB is controlled using a 100BaseT Ethernet interface implemented using SiTCP[SiTCP]. The QB-DB communicates with the QB using a variation of TKO protocol[TKO]. See Illustration 1 for a view of the DB layout facing the QB.

Note: This document describes firmware versions 0x41 and higher, which can only be used for daughterboard version 3 (final production version). This version of the document is based on firmware revision 0x41. Previous test versions are significantly different.

## **Table of Contents**

| Ethernet Communication                                                      | 2 |
|-----------------------------------------------------------------------------|---|
| Ethernet Addresses                                                          | 2 |
| UDP Protocol                                                                | 3 |
| TCP Protocol                                                                | 4 |
| Sparse Data Scan (SDS)                                                      | 4 |
| QB Data Format Reference                                                    |   |
|                                                                             |   |
| QB Data Format Reference<br>Appendix A - Control Registers on Daughterboard |   |

## **Illustration Index**

| Illustration 1: QB-DB layout (side facing QB) | 3 |
|-----------------------------------------------|---|
| Illustration 2: QB-DB Block Diagram           |   |
| Illustration 3: Sample Data Stream            |   |

## **Index of Tables**

| Table 1: I/P Address Switch Assignments.                          | 2 |
|-------------------------------------------------------------------|---|
| Table 2: Board Control Protocol                                   |   |
| Table 3: Command Registers (Addresses 00-04)                      |   |
| Table 4: SDS Control/Status Registers (addresses 100-106)         |   |
| Table 5: Test Registers (Addresses 108, 10c)                      |   |
| Table 6: DB Status Registers (Address 10a, 140-153)               |   |
| Table 7: Firmware Revisions and Serial Number (Addresses 10e-11f) |   |
| Table 8: Counter Registers (Addresses 120-125, 200-27f)           |   |
|                                                                   |   |

### **Ethernet Communication**

#### Ethernet Addresses

**MAC Address** - Each QB-DB provides its own unique Ethernet MAC address by means of a Dallas Semiconductor Silicon Serial Number<sup>TM</sup> (SSN) device. MAC addresses have the following format:

00-50-51-xx-yy-zz

where the final 3 bytes come from the SSN (the low two bits of zz are '0' as required by IEEE standard) QB-DB MAC addresses are in the range assigned to Iwatsu Electric (upper 24 bits 00-50-51 hex) which should avoid conflicts with commercial NICs, switches, etc).

**I/P Address** - Each QB-DB uses an IP address that is set using a combination of a fixed value of 192.168 programmed in firmware for the upper 16 bits, and DIP switches to assign the lower 16 bits (except bits 12-15, which are fixed to '0'). For the lower 16 bits, bits 0-11 are set by DIP switches on the QB-DB. Switch assignments are given in Table 1. In this scheme, switch #1 corresponds to the switch above silkscreen marking 'S1' and switch #7 corresponds to the switch above silkscreen marking 'S2' (both shown in Illustration 1). Please note that switch #1 corresponds to the right-most switch if viewing the QB-DB in the orientation shown in Illustration 1.

| Switch # | Function     | I/P Bit |
|----------|--------------|---------|
| 12       | Slot# bit 0  | 0       |
| 11       | Slot# bit 1  | 1       |
| 10       | Slot# bit 2  | 2       |
| 9        | Slot# bit 3  | 3       |
| 8        | Slot# bit 4  | 4       |
| 7        | Crate# bit 0 | 5       |
| 6        | Crate# bit 1 | 6       |
| 5        | Crate# bit 2 | 7       |
| 4        | Crate# bit 3 | 8       |
| 3        | Hut# bit 0   | 9       |
| 2        | Hut# bit 1   | 10      |
| 1        | Hut# bit 2   | 11      |

Table 1: I/P Address Switch Assignments.



Illustration 1: QB-DB layout (side facing QB)

#### **UDP** Protocol

Two protocols are supported by QB-DB. UDP datagrams may be sent to port  $0 \times 1234$  to perform single register read/write operations. Each packet sent causes the QB-DB to send a return packet. Packets must conform to the BCP (board control protocol) defined in Table 2 below

| Byte<br>Number | Name                         | Description                                                                                                                                           |
|----------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0              | Ver.[3:0] /<br>Type [3:0]    | Should be 0xFF<br>(test version)                                                                                                                      |
| 1              | Command[3:0] /<br>Flag [3:0] | Command<br>0xC = Read operation<br>0x8 = Write operation<br>Flag, valid only ACK packet<br>[3] = ACK packet<br>[2:1] = always zero<br>[0] = Bus error |
| 2              | ID                           | Number to identify packet, any number can be used.                                                                                                    |

| 3   | Length           | Length of read / write access |
|-----|------------------|-------------------------------|
| 4   | Address [31:24]  | Read / Write Address          |
| 5   | Address [23:16]  | Read / Write Address          |
| 6   | Address [15: 8]  | Read / Write Address          |
| 7   | Address [7: 0]   | Read / Write Address          |
| 8   | Write data [7:0] | 1st write data                |
| :   |                  |                               |
| 7+N | Write data [7:0] | The last (N-th) write data    |

Table 2: Board Control Protocol

Address bits 31:16 are ignored. Addresses in the range 0x0000-0x7fff are reserved for on-board registers, while addresses in the range 0x8000-0xffff are used for TKO bus access (see Appendix A for details).

The data are always sent with most significant byte first (network byte order) in UDP operations. TCP operations are switchable to have either most significant byte first or least significant byte first.

#### **TCP** Protocol

A single TCP connection to port 0x17 may be opened to the QB-DB. Data are transmitted by the QB-DB under control of the SDS logic described below. Byte ordering of TCP data may be controlled by writing a bit in the DB status register 0x10a.

#### Sparse Data Scan (SDS)

SDS (sparse data scan) refers to the automatic transfer of data from QB FIFO via TKO read to the SiTCP transmit FIFO. It will be the primary means of data readout for the QB in normal operation.

A block diagram of the QB-DB emphasizing the data path is shown in Illustration 2 below. Data are transferred by SDS logic from the QB using TKO protocol and stored in the SDRAM buffer. Data are automatically copied from the SDRAM buffer to SiTCP transmit FIFO whenever a TCP connection is active and the SiTCP is not asserting the TX\_FIFO\_AFULL signal.

The SDRAM buffer provides a "buffer almost full" signal which is asserted when the buffer has a small amount of space remaining ( $\sim$ 24 words), and de-asserted when the remaining space is large enough to contain a typical full QB worth of data ( $\sim$ 1M words). For the remainder of this text this is referred to as the "buffer full" signal for simplicity.



Illustration 2: QB-DB Block Diagram

SDS can be started by 4 methods:

- Periodic timer (programmable period ~ 1ms)
- Trigger counter (every n G\_TRIG from QB)
- QB FIFO Threshold (dedicated SDSREQ signal from QB)
- UDP command (write bit in control register 0x104)

Once started, SDS logic will perform TKO read operations with (F=0, SA=0). As long as TKO Q=1, data are transferred to SDRAM buffer for TCP transmission via SiTCP. If an additional SDS start condition occurs while SDS is in progress, no action is taken. SDS will stop when one of the following occurs:

- TKO Q=0
- UDP command (write to bit 1 in control register 0x104, for test only)

When SDS is enabled (any bit set in SDS enable register, address 0x106) or SDS transfer is in progress, TKO single action with F=0 or F=8 by UDP are prohibited. Any attempt to perform single action with F=0 or F=8 will fail and result in an error bit set (see page 11). Other TKO single action may be performed during SDS.

Note that when SDS is not enabled, TKO single action with F=0 may be used to read QB FIFO.

All data from QB are read out in 3-word cells. Each SDS transfer from QB will terminate (by Q=0) only after the end of a cell. If an SDS transfers a number of words which is not a multiple of 3, an error bit is set (see page 11).

One SDS may not exceed  $2^{32}$ -1 words. If this occurs, the SDS is terminated and an error bit is set (see page 11).

Special cells are inserted in the data stream by the DB to flag start of SDS (header), end of SDS (trailer) or buffer full condition (warning).

Whenever an 'SDS start' condition occurs, all data are read from QB until Q=0 (or SDS is stopped by UDP operation). If there is space in the SDRAM buffer, data are stored in buffer, with header and trailer cells inserted before and after data. If there is no space in buffer, a warning cell is inserted in the buffer, and QB data is discarded. For a single SDS transfer one of the following actions may be taken:

| 1. | Header, all data, trailer stored in buffer                           | [normal case]                                                 |
|----|----------------------------------------------------------------------|---------------------------------------------------------------|
| 2. | Header cell and Warning cell stored in buffer, all data discarded    | [buffer full at start of SDS]                                 |
| 3. | Header, some data, trailer, warning cell stored, some data discarded | [buffer full occurs during SDS]                               |
| 4. | All data discarded, nothing stored in buffer                         | [buffer full at start of SDS,<br>warning cell already stored] |

After a warning cell is stored in the buffer, nothing else is stored until the buffer full signal turns off. The next cell stored will be the header for the start of the next SDS.

Illustration 3 below shows an example where there are four SDS start conditions. During the first, data is transferred to the buffer as usual. During the second, the buffer full signal becomes active during the transfer. Data is discarded until the end of the SDS, where a trailer and warning cell are inserted. Then another SDS occurs where all data (including header and trailer) are discarded. Finally, the buffer full condition is cleared, and another SDS proceeds as usual.

| TKO Bus  | Data     | Notes           |
|----------|----------|-----------------|
|          | Header   | SDS Start       |
| Read Q=1 | ATM Data |                 |
| Read Q=1 | ATM Data |                 |
| Read Q=1 |          |                 |
| Read Q=1 | ATM Data |                 |
| Read Q=0 | Trailer  | SDS End         |
|          | Header   | SDS Start       |
| Read Q=1 | ATM Data |                 |
| Read Q=1 | ATM Data | Buffer full = 1 |
| Read Q=1 |          | Discard data    |
| Read Q=0 | Trailer  | SDS End         |
|          | Warning  |                 |
| Read Q=1 |          | SDS Start       |
| Read Q=1 |          | Discard data    |
| Read Q=0 |          | SDS End         |
|          |          | Buffer full = 0 |
|          | Header   | SDS Start       |
| Read Q=1 | ATM Data |                 |
| Read Q=1 | ATM Data |                 |
| Read Q=1 |          |                 |
| Read Q=1 | ATM Data |                 |
| Read Q=0 | Trailer  | SDS End         |
| 711      |          |                 |

Illustration 3: Sample Data Stream

## **QB Data Format Reference**

All QB data consists of 3-word cells in the format shown below. The *header* field (bits 12-15) indicates the cell type.

|          | 15 | 14  | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|----|-----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1st Word |    | Hea | der |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 2nd Word |    |     |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 3rd Word |    |     |     |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Header Value | Cell Type           |
|--------------|---------------------|
| 0000-1011B   | Hit data cell       |
| 1100B        | Spacer cell         |
| 1110B        | Status message cell |
| 1111B        | Cell inserted by DB |

The QB cells (hit data, spacer and status message) are described in more detail in the QB documentation (add reference here). Cells with header = "1111" are generated by the daughterboard as described below.

|   |    |    |    |    | Hea |    |   |   |   |   | , |   |   |   |
|---|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| ſ | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 |

|          | 15   14   13   12   .                 | 11 10 9 8     | 7 6 5 4         |             |  |  |  |  |  |  |  |  |  |
|----------|---------------------------------------|---------------|-----------------|-------------|--|--|--|--|--|--|--|--|--|
| 1st Word | Header                                | Туре          | Status          | SeqNo[3:0]  |  |  |  |  |  |  |  |  |  |
| 2nd Word |                                       | SeqNo[19:4]   |                 |             |  |  |  |  |  |  |  |  |  |
| 3rd Word |                                       | SeqNo         | [35:20]         |             |  |  |  |  |  |  |  |  |  |
|          |                                       |               |                 |             |  |  |  |  |  |  |  |  |  |
| Header   | 1 1 1 1                               | Indicates cel | l inserted by D | В           |  |  |  |  |  |  |  |  |  |
|          |                                       |               |                 |             |  |  |  |  |  |  |  |  |  |
| Туре     | 0 $0$ $0$ $1$                         | Indicates sur | nmary informat  | ion from DB |  |  |  |  |  |  |  |  |  |
|          | · · · · · · · · · · · · · · · · · · · |               |                 |             |  |  |  |  |  |  |  |  |  |
| Status   | 0  0  0  1                            | Indicates SD  | IS start        |             |  |  |  |  |  |  |  |  |  |
|          |                                       |               |                 |             |  |  |  |  |  |  |  |  |  |
| SeqNo    |                                       | Incremented   | once for each   | SDS         |  |  |  |  |  |  |  |  |  |

A header cell is inserted in the buffer at the start of each SDS transfer (if the buffer is not full). The 36bit SDS sequence number is incremented once for each SDS. If data are missing due to buffer overflow, the number of missing SDS can be determined by examining the sequence number.

#### Generic ATM Data Cell

|            | 15 | 14  | 13  | 12 | 11   | 10    | 9     | 8     | 7     | 6     | 5                   | 4         | 3     | 2    | 1   | 0 |
|------------|----|-----|-----|----|------|-------|-------|-------|-------|-------|---------------------|-----------|-------|------|-----|---|
| 1st Word   |    | Hea | der |    |      | Ty    | pe    |       |       | Sta   | lus                 |           | Se    | eque | nce | # |
| 2nd Word   |    |     |     | V  | Vord | cou   | int f | or Sl | DS (  | upp   | <mark>er 1</mark> 6 | bits bits | 6)    |      |     |   |
| 3rd Word   |    |     |     | I  | Nord | l coi | int f | or S  | DS    | (lowe | er 16               | bits      | ;)    |      |     |   |
|            |    |     |     |    |      |       |       |       |       |       |                     |           |       |      |     |   |
| Header     | 1  | 1   | 1   | 1  |      | Indi  | cate  | s cel | l ins | serte | d by                | DB        |       |      |     |   |
|            |    |     |     |    | ,    |       |       |       |       |       |                     |           |       |      |     |   |
| Туре       | 0  | 0   | 0   | 1  | ]    | Indi  | cate  | s sui | mma   | ry i  | nforr               | natio     | on fi | om   | DB  |   |
|            |    |     |     |    |      |       |       |       |       |       |                     |           |       |      |     |   |
| Status     | 0  | 0   | 1   | 0  |      | Indi  | cate  | s SI  | OS d  | eomp  | oleteo              | ł         |       |      |     |   |
|            | •  |     |     |    |      |       |       |       |       |       |                     |           |       |      |     |   |
| Sequence # | -  | -   | -   | -  |      | Incr  | eme   | nted  | one   | e fo  | r ea                | ch S      | DS    |      |     |   |
|            |    |     |     |    |      |       |       |       |       |       |                     |           |       |      |     |   |

#### Format of Trailer ("SDS Completed") Cell

At the end of SDS, a trailer cell is inserted. The word count field contains a count of total words read in SDS. If buffer becomes full, some data may not be transferred to SiTCP, so the word count may not match the number of data words contained between header and trailer. Sequence number (4 bits only) should match low 4 bits of sequence number in header.

## Format of Warning ("Nearly Full") Cell

|            | 15 14 13 12                               | 11 10 9 8    | 7 6         | 5 4      | 3 2     | 1    | 0 |
|------------|-------------------------------------------|--------------|-------------|----------|---------|------|---|
| 1st Word   | Header                                    | Туре         | Stat        | us       | Sequ    | ence | # |
| 2nd Word   |                                           | Rese         | erved       |          |         |      |   |
| 3rd Word   |                                           | Rese         | erved       |          |         |      |   |
|            |                                           |              |             |          |         |      |   |
| Header     | 1 1 1 1                                   | Indicates ce | ll inserted | by DB    |         |      |   |
|            |                                           |              |             |          |         |      |   |
| Туре       | 0 $0$ $0$ $1$                             | Indicates su | mmary in    | formatio | on fron | ı DB |   |
|            |                                           |              |             |          |         |      |   |
| Status     | $\begin{vmatrix} 1 & 0 & 0 \end{vmatrix}$ | Indicates bu | ffer nearly | y full   |         |      |   |
|            |                                           |              |             |          |         |      |   |
| Sequence # |                                           | Not used?    |             |          |         |      |   |

A Warning cell is inserted when the buffer full signal becomes active (SDRAM buffer on daughterboard is almost full).

## **Appendix A - Control Registers on Daughterboard**

Local registers on the QB-DB are located in addresses from 0x0000-0x7fff. Note that all addresses not listed below are reserved, and any access to them may cause unexpected behavior.

All registers may be accessed using any length BCP operation, but most registers are 16 or 64 bits. All register data are transferred most significant byte first. All numbers are *hex* unless otherwise noted.

| r/w | bit(s)                                                                                                                                                                                                                                                                    | Description                                                                                                                                    |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| W   | 0                                                                                                                                                                                                                                                                         | (mom) reset QB-DB (same as bits 1, 2, 3)                                                                                                       |
| W   | 1                                                                                                                                                                                                                                                                         | (mom) reset TKO interface, SDRAM FIFO and counters 0x240-247                                                                                   |
| W   | 2                                                                                                                                                                                                                                                                         | (mom) reset error status bits (bits 12-15 of register 0x104)                                                                                   |
| w   | 3                                                                                                                                                                                                                                                                         | (mom) reset counters in range 0x120-125 and 0x200-27f except registers 0x240-247                                                               |
|     | 4-6                                                                                                                                                                                                                                                                       | reserved                                                                                                                                       |
| W   | 7                                                                                                                                                                                                                                                                         | (mom) reset QB board                                                                                                                           |
| W   | 8                                                                                                                                                                                                                                                                         | enable memory test mode (test only)                                                                                                            |
| W   | 9                                                                                                                                                                                                                                                                         | enable SDS debug mode (test only)                                                                                                              |
| W   | 10                                                                                                                                                                                                                                                                        | enable access to SPI interface on QB                                                                                                           |
|     | 11-15                                                                                                                                                                                                                                                                     | reserved                                                                                                                                       |
| W   | n/a                                                                                                                                                                                                                                                                       | start flash operation (data ignored)                                                                                                           |
| W   | 0-15                                                                                                                                                                                                                                                                      | FPGA reload from flash<br>write 0x00a5 to configure FPGA from default<br>sector<br>write 0x01a5 to configure FPGA from backup sector           |
|     | W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W           W | w     0       w     1       w     2       w     3       4-6       w     7       w     8       w     9       w     10       11-15     w     n/a |

Table 3: Command Registers (Addresses 00-04)

Note: Bits marked (mom) are momentary. When written as '1', they perform the specified action. These bits always read as '0'.

| Address | r/w | bit(s) | Description                                                                   |
|---------|-----|--------|-------------------------------------------------------------------------------|
| 100     | r/w | 0-15   | SDS start timer period (units of 100us).<br>Period starts at end of last SDS. |
| 100     |     | 0.15   |                                                                               |
| 102     | r/w | 0-15   | SDS start after N+1 GTRG from QB.<br>Count starts at end of last SDS.         |
| 104     | r   | 0      | SDS stopped by Q=0                                                            |
|         | r   | 1      | SDS stopped by UDP command                                                    |
|         | r   | 2      | SDS started by UDP command                                                    |
|         | r   | 3      | SDS started by G_trig                                                         |
|         | r   | 4      | SDS started by timer                                                          |
|         | r   | 5      | SDS started by SDSREQ                                                         |
|         | r   | 6      | last SDS cycle TKO operation Q response                                       |
|         | r   | 7      | last SDS cycle TKO operation YSSIR response                                   |
|         | r   | 8      | last single TKO operation Q response                                          |
|         | r   | 9      | last single TKO operation YSSIR response                                      |
|         | r   | 10     | SDRAM FIFO (almost) full                                                      |
|         | r   | 11     | SDS in progress                                                               |
|         | r   | 12     | SDS burst length counter has overflowed                                       |
|         | r   | 13     | Q=0 occurred in middle of cell                                                |
|         | r   | 14     | UDP read/write QB FIFO attempted while SDS enabled                            |
|         | r   | 15     | missing YSSIR response registered during SDS cycle                            |
| 104     | w   | 0      | reserved, write as '0'                                                        |
|         | w   | 1      | stop SDS (test only)                                                          |
|         | w   | 2      | start SDS                                                                     |
|         | w   | 3-15   | not used                                                                      |
| 106     |     | 0-3    | reserved, write as '0'                                                        |
|         | r/w | 4      | enable start SDS on G_trig (is set to '0' at power-up)                        |
|         | r/w | 5      | enable start SDS on timer (is set to '0' at power-up)                         |
|         | r/w | 6      | enable start SDS on UDP command (is set to '0' at power-up)                   |
|         | r/w | 7      | enable start SDS on SDSREQ from QB (is set to '0' at power-up)                |
|         |     | 8-15   | reserved, write as '0'                                                        |

Table 4: SDS Control/Status Registers (addresses 100-106)

| Address | r/w | bit(s) | Description                                             |
|---------|-----|--------|---------------------------------------------------------|
| 108     | r/w | 0-15   | Test register for exercising UDP read/write (test only) |
| 10c     | r   | 0-7    | SDRAM DCM phase shift (test only)                       |
|         | r   | 8-11   | reserved, read as '0'                                   |
|         | r   | 12     | SDRAM FIFO output empty (test only)                     |
|         | r   | 13     | SDRAM DCM phase control ready (test only)               |
|         | r   | 14     | SDRAM initialization done (test only)                   |
|         | r   | 15     | SDRAM FIFO ready (test only)                            |

Table 5: Test Registers (Addresses 108, 10c)

| Address | r/w | bit(s) | Description                                                                                                                                                                                                                                                          |
|---------|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10a     | r   | 0      | DB FPGA configured from backup sector                                                                                                                                                                                                                                |
|         | r   | 1      | DB is in SDS debug mode (see Note 1)                                                                                                                                                                                                                                 |
|         | r   | 2      | DB is in memory test mode (see Note 2)                                                                                                                                                                                                                               |
|         | r   | 3      | DB is in SPI access mode. Access QB flash via SPI instead of DB flash                                                                                                                                                                                                |
|         | r   | 4      | SDRAM FIFO (almost) full                                                                                                                                                                                                                                             |
|         | r   | 5      | UDP acknowledge timeout occurred                                                                                                                                                                                                                                     |
|         | r   | 6-7    | reserved, read as '0'                                                                                                                                                                                                                                                |
|         | r   | 8-10   | inverted lock signal of DCM status on FPGA. Should be '0'                                                                                                                                                                                                            |
|         | r   | 11-12  | reserved, read as '0'                                                                                                                                                                                                                                                |
|         | r/w | 13     | control TCP byte order<br>if '0' big-endian (most significant byte first)<br>if '1' little-endian (least significant byte first)                                                                                                                                     |
|         | r   | 14     | TX_FIFO_AFULL signal from SiTCP                                                                                                                                                                                                                                      |
|         | r   | 15     | TCP_ESTABLISH signal from SiTCP                                                                                                                                                                                                                                      |
| 140     | r/w | 0      | MII_MAC_FLOW_ENABLE                                                                                                                                                                                                                                                  |
|         | r/w | 1      | KEEP_ON                                                                                                                                                                                                                                                              |
|         | r/w | 2      | FAST_RETRANS_ON                                                                                                                                                                                                                                                      |
|         | r   | 3-15   | not used, read as '0'                                                                                                                                                                                                                                                |
| 142     | r/w | 0-15   | KEEP_INTVL_FILL                                                                                                                                                                                                                                                      |
| 144     | r/w | 0-15   | KEEP_INTVL_EMPTY                                                                                                                                                                                                                                                     |
| 146     | r/w | 0-15   | TOUT_ESTB                                                                                                                                                                                                                                                            |
| 148     | r/w | 0-15   | TOUT_DISCNCT                                                                                                                                                                                                                                                         |
| 14a     | r/w | 0-15   | MSL                                                                                                                                                                                                                                                                  |
| 14c     | r/w | 0-15   | Ethernet PHY data register                                                                                                                                                                                                                                           |
| 14e     | r/w | 0-4    | Ethernet PHY command register number to be accessed                                                                                                                                                                                                                  |
|         | r/w | 5      | <ul> <li>'1' for write operation:<br/>First write data to register 0x14c, then write '1' to bit 5 of 0x14e to start write operation. Registers allowed for write: 0, 4, 7, 16</li> <li>'0' for read operation: Registers allowed for read: 0-8, 16-20, 30</li> </ul> |
|         | r/w | 6      | '1' if last operation succeeded                                                                                                                                                                                                                                      |
|         | r/w | 7      | '1' if last operation failed                                                                                                                                                                                                                                         |
|         | r   | 8-15   | Not used                                                                                                                                                                                                                                                             |
| 150     | r/w | 0-15   | TOUT RETRANS in units of microseconds                                                                                                                                                                                                                                |

152 r/w 0-15 TX\_BUF\_TH

Table 6: DB Status Registers (Address 10a, 140-153)

| Address | r/w | bit(s) | Description                                                       |
|---------|-----|--------|-------------------------------------------------------------------|
| 10e     | r   | 0-15   | DB firmware version (0x0041 as of 2008-04-23)                     |
| 110     | r   | 0-15   | SiTCP firmware version (bits 0-7 are month, bits 8-15 are year)   |
| 112     | r   | 0-15   | SiTCP firmware version (bits 0-7 are revision, bits 8-15 are day) |
| 114     | r   | 0-7    | TKO clock loss event counter                                      |
|         | r   | 8-15   | not used, read as '0'                                             |
| 116     | r   | 0      | SSN readout done                                                  |
|         | r   | 1      | SSN CRC correct                                                   |
|         | r   | 2-7    | reserved, read as '0'                                             |
|         | r   | 8-15   | calculated SSN CRC                                                |
| 118-11f | r   | 0-63   | 64 bit SSN readout value. Used to set MAC address (Note 3)        |

Table 7: Firmware Revisions and Serial Number (Addresses 10e-11f)

All counters described in Table 8 below are 64 bits. They may be read with any length UDP operation with the data always sent in MSB...LSB order. Counters will wrap at 0xffff ffff ffff ffff.

| Address | r/w | bit(s) | Description                                                                      |
|---------|-----|--------|----------------------------------------------------------------------------------|
| 120-121 | r   | 0-3    | Current SDS sequential number bits 32-35                                         |
|         |     | 4-15   | All zero                                                                         |
| 122-123 | r   | 0-15   | Current SDS sequential number bits 16-31                                         |
| 124-125 | r   | 0-15   | Current SDS sequential number bits 0-15                                          |
| 126-127 | r   | 0-15   | CRC-16 (= $x^{16} + x^{15} + x^{2} + 1$ ) for data written to SiTCP              |
| 128-129 | r   | 0-15   | CRC-16(= $x^{16} + x^{15} + x^{2} + 1$ ) for data written to SDRAM FIFO          |
| 200-207 | r   | 0-63   | Number of words written to SDRAM FIFO                                            |
| 208-20f | r   | 0-63   | Total number of words SDS read from QB                                           |
| 210-217 | r   | 0-63   | Total number of SDS bursts                                                       |
| 218-21f | r   | 0-63   | Total number of words lost due to buffer full                                    |
| 220-227 | r   | 0-63   | number of SDS bursts completely lost due to buffer full                          |
| 228-22f | r   | 0-63   | number of SDS bursts partially lost due to buffer full                           |
| 230-237 | r   | 0-63   | Total number of UDP bytes read or written (excluding address 230-23f)            |
| 238-23f | r   | 0-63   | Total number of UDP bytes acknowledged (excluding address 230-23f)               |
| 240-247 | r   | 0-63   | number of words in SDRAM FIFO                                                    |
| 248-24f | r   | 0-63   | time SDRAM is empty from first write to SiTCP to last write (40 ns units)        |
| 250-257 | r   | 0-63   | time TX_FIFO_AFULL is high from first write to SiTCP to last write (40 ns units) |
| 258-25f | r   | 0-63   | total time elapsed from first write to SiTCP to last write (40 ns units)         |
| 260-267 | r   | 0-63   | total TCP connection time (40 ns units)                                          |
| 268-26f | r   | 0-63   | total time with TCP_ESTABLISH=1 and TX_FIFO_AFULL=0                              |
| 270-277 | r   | 0-63   | total number of bytes written to SiTCP                                           |
| 278-27f | r   | 0-63   | total number of errors detected on pseudo-random data written to<br>SiTCP        |

Table 8: Counter Registers (Addresses 120-125, 200-27f)

Notes:

- 1. In SDS debug mode, no flag cells are inserted. SDS halts when SDRAM FIFO is full.
- 2. In memory test mode, pseudo-random data written to SDRAM instead of SDS data. This data is generated by 16-bit (left-shift) LFSR, with bit 0 set to NOT( XOR( bits 15, 14, 12, 3)).
- MAC address is 00 50 51 + SSN(bits 29-8) + 00.
   00 50 51 is the prefix assigned to Iwatsu Corporation. Remaining bits will be unique for each daughter board.

#### **Flash Memory**

Addresses from 400-7ff are used for the flash memory command and data buffer.

#### **TKO Access**

Addresses from 0x8000-0xffff are used for single-action access to TKO. Address bits are used as follows:

| Address[15]    | '1' for TKO operations.                                     |
|----------------|-------------------------------------------------------------|
| Address[14:12] | TKO function code bits 2-0 (bit 3 is implied by read/write) |
| Address[11:1]  | TKO sub-address bits 10-0                                   |
| Address[0]     | Always '0'                                                  |

TKO function code bit '3' is set based on the type of operation requested using the BCP protocol.

For a write operation, bit '3' = 1For a read operation, bit '3' = 0

## Bibliography

SiTCP: T. Uchida, M. Tanaka, Development of a TCP/IP Processing Hardware, 2006, IEEE Nuclear Science Symposium, TKO: KEK Data Acquisition Development Working Group, TKO Specification, 1985