# **VARAN Client Board**

# VEB 013-SPI

Versatile Automation Random Access Network

This client board is used to easily equip any periphery device with the VARAN bus. Data can be exchanged over alternating buffer and DPRAM.



## **Technical Data**

### Performance data

| Internal memory                | 4-Mbit serial Flash                                                                                      |
|--------------------------------|----------------------------------------------------------------------------------------------------------|
| Interface connections          | 1 x VARAN In (maximum length: 100 m)<br>1 x VARAN Out (maximum length: 100 m)<br>1 x Periphery interface |
| Connection to periphery device | 50-pin Board-to-Board connector plug<br>(Type ERNI Microstac, order Nr. 114713)                          |
|                                | 12-pin Board-to-Board connector plug<br>(Type ERNI Microstac, order Nr. 114712)                          |

#### **Electrical requirements**

| Internal power supply (VDD)  | Typically +3.3 V DC (±4 %)<br>(Provided from the periphery module over a 50-pin connector) |
|------------------------------|--------------------------------------------------------------------------------------------|
| Current consumption of volt- | Minimum 250 mA                                                                             |
| age supply                   | (Depending on the external circuit)                                                        |

#### Miscellaneous

| Article number   | 16-081-013-SPI |
|------------------|----------------|
| Hardware version | 1.x            |

#### **Environmental conditions**

| Storage temperature      | -20 – +85 °C             |
|--------------------------|--------------------------|
| Operating temperature 1) | 0 – 70 °C                |
| Humidity                 | 0 - 95 %, non-condensing |
| EMC stability            | 2)                       |
| Shock resistance         | 150 m/s²                 |

<sup>&</sup>lt;sup>1)</sup> According to Component specifications. The operating temperature for the entire unit must be specifically defined for each application, as the operating conditions (mounting position, housing, heat sources in the vicinity of the VEB) are unknown.

<sup>2)</sup> For each application, the EMC resistance must be tested separately in the entire system.

## **Mechanical Dimensions**



The dimensioning of the center holes in the 50-pin ERNI board-to-board connector plug align with connector on the base card (does not show the position of the connector on the VEB):

The VEB in the above drawing is visible from the rear of the connector. The component height on the base card under the VEB cannot exceed 3 mm.



# VEB 013-SPI Pin assignment



2

| Pin | Identifier | Function        | i i |
|-----|------------|-----------------|-----|
| 1   | GND        | Ground          | -   |
| 2   | GND        | Ground          | -   |
| 3   | mosi       | SPI Data In     | In  |
| 4   | miso       | SPI Data Out    | Out |
| 5   | sck        | SPI Clock       | In  |
| 6   | -          | -               | -   |
| 7   | ssel       | SPI Chip Select | In  |
| 8   | -          | -               | -   |
| 9   | -          | -               | -   |
| 10  | -          | -               | -   |
| 11  | -          | -               | -   |
| 12  | veb_irq    | IRQ             | Out |
| 13  | -          | -               | -   |
| 14  | -          | -               | -   |
| 15  | -          | -               | -   |
| 16  | -          | -               | -   |
| 17  | -          | -               | -   |
| 18  | -          | -               | -   |
| 19  | VDD        | +3V3 supply     | In  |
| 20  | VDD        | +3V3 supply     | In  |
| 21  | GND        | Ground          |     |
| 22  | -          | -               | -   |
| 23  | VB_RD+     | RX+ transmitter | -   |
| 24  | veb_sync   | Sync            | Out |
| 25  | VB_RD-     | RX- transmitter | -   |
| 26  | dig_in(0)  | Digital Input   | ln1 |
| 27  | VB_TD+     | TX+ transmitter | -   |
| 28  | dig_in(1)  | Digital Input   | In2 |
| 29  | VB_TX-     | TX- transmitter | -   |

| 30 | dig_in(2)       | Digital Input   | ln3  |
|----|-----------------|-----------------|------|
| 31 | -               | VB +3V3         | Out  |
| 32 | dig_in(3)       | Digital Input   | In4  |
| 33 | clk_25mhz_out   | CLK 25 MHz      | Out  |
| 34 | dig_in(4)       | Digital Input   | In5  |
| 35 | periphery_reset | Periphery Reset | Out  |
| 36 | dig_in(5)       | Digital Input   | In6  |
| 37 | -               | -               | -    |
| 38 | dig_in(6)       | Digital Input   | ln7  |
| 39 | dig_out(7)      | Digital Output  | Out8 |
| 40 | dig_in(7)       | Digital Input   | In8  |
| 41 | dig_out(5)      | Digital Output  | Out6 |
| 42 | dig_out(6)      | Digital Output  | Out7 |
| 43 | -               | LED             | Out  |
| 44 | dig_out(4)      | Digital Output  | Out5 |
| 45 | -               | LED             | Out  |
| 46 | dig_out(3)      | Digital Output  | Out4 |
| 47 | dig_out(1)      | Digital Output  | Out2 |
| 48 | dig_out(2)      | Digital Output  | Out3 |
| 49 | GND             | Ground          |      |
| 50 | dig_out(0)      | Digital Output  | Out1 |

Table 1: Pin assignment for 50-pole plug



#### VARAN CLIENT BOARD



VEB 013-SPI

| Pin | Xilinx Pin | Signal name     |
|-----|------------|-----------------|
| 1   |            | -               |
| 2   |            | -               |
| 3   |            | Phy2_RX+        |
| 4   |            | Phy2_RX-        |
| 5   |            | Phy2_TX+        |
| 6   |            | Phy2_TX-        |
| 7   |            | VB2 +3V3        |
| 8   |            | Phy2_led_link   |
| 9   |            | Phy2_led_active |
| 10  | V38        | RESERVE         |
| 11  |            | -               |
| 12  |            | -               |

### Table 2: Pin assignment for 12-pole plug

## **Electrical Integration**



## Layout guidelines

- Place 100 nF blocking capacitors on the power supply pins (+3V3) of the board-toboard connector.
- The minimum clearance between the transformer and the RJ45 connector should be selected (<25 mm).</p>
- Whenever possible, the clearance between the converter and the 50-pin VEB connector should be limited to 50 mm.
- > The VARAN differential lines TD+/TD and RD+/RD must be:
  - As short as possible
  - Parallel (with minimum clearance from one another)
  - Routed with equal length
- > The differential lines should also have the following properties:
  - Clearance between 2 differential line pairs >0.38 mm
  - Clearance between the differential lines to the circuit card edges >25mm
  - Clearance between the differential lines and other signals >0.76 mm
  - Continuous GND surface among the differential lines.
  - Difference lines must not cross with other signals
  - Difference lines must not be routed under components

#### Timing synchronous with extern cyclic access



Set veb\_sync offset within Varan sync0

For overlapped VARAN and Extern accesses an alternating buffer is supported.



- Caution to avoid data inconsistency:
  - The whole data block must be written within one period
  - Ensure that the extern access is ready before the buffer switches

## Event oriented synchronous timing



- Enable desired Irq-type
- Quit every Irq when reading IRQ Quit register

## Address Mapping VARAN Side

| Address<br>(hex) | Size<br>(bytes) | Access<br>Type | Description                                                                                                                                                                                                                                                                                          | Reset value |
|------------------|-----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Memory           |                 |                |                                                                                                                                                                                                                                                                                                      |             |
| 0000             | 2048            | w              | Alternating Buffer (Write Space)<br>Default = switch by sync, switch mode can be changed in<br>the register                                                                                                                                                                                          | 00          |
| 0800             | 2048            | r              | Alternating Buffer (Read Space)<br>Default = switch by sync, switch mode can be changed in<br>the register                                                                                                                                                                                           |             |
| 1000             | 512             | r/w            | reserved                                                                                                                                                                                                                                                                                             | 00          |
| 1200             | 1               | r              | VEB Sync Mode Register<br>Bit 0: 1 = Enable Sync Quitting Mode<br>0 = Enable Pulse width Register<br>Bit 1: 1 = Sync / veb_irq output is active low,<br>0 = active high<br>Bit 2: 1 = Enable tristate buffer for sync / veb_irq<br>output<br>Bit 3: Sync Output Register (read)<br>Bit 74 : Reserved | 00          |
| 1201             | 3               | r/w            | Reserved                                                                                                                                                                                                                                                                                             | 00          |
| 1204             | 4               | r/w            | VARAN Bus Cycle Time [10 ns] 000                                                                                                                                                                                                                                                                     |             |
| 1208             | 1528            | r/w            | Reserved                                                                                                                                                                                                                                                                                             |             |
| 1800             | 2048            | r/w            | DPRAM                                                                                                                                                                                                                                                                                                |             |

Table 3: Address Mapping Varan Manager



## µC Side

| Address<br>(hex) | Size<br>(bytes) | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                    | Reset value |
|------------------|-----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 0000             | 2048            | r              | Alternating Buffer (Read Space)<br>Default = switch by sync, switch mode can be<br>changed in the register                                                                                                                                                                                                                                                     | 00          |
| 0800             | 2048            | w              | Alternating Buffer (Write Space)<br>Default = switch by sync, switch mode can be<br>changed in the register                                                                                                                                                                                                                                                    | 00          |
| 1000             | 256             | r/w            | Transmit/Receive Buffer                                                                                                                                                                                                                                                                                                                                        | -           |
| 1100             | 2               | r/w            | Page Address<br>Two higher bytes of SPI address (A23… A8)                                                                                                                                                                                                                                                                                                      | 0000        |
| 1102             | 1               | r/w            | Predefined Command Register<br>16#01: Page Read<br>16#02: Page program<br>16#03: Sector Erase<br>16#F0: Reboot FPGA                                                                                                                                                                                                                                            | 00          |
| 1103             | 1               | r/w            | Single Command Register                                                                                                                                                                                                                                                                                                                                        | 00          |
| 1104             | 1               | r              | Status Register<br>Bit 0: 1=Ready, 0=Busy                                                                                                                                                                                                                                                                                                                      | 01          |
| 1105             | 1               | w              | Request Register<br>Bit 03 : Software Request (highest priority)<br>Bit 47 : Hardware Requests (Bit 7 lowest priority)                                                                                                                                                                                                                                         | -           |
| 1106             | 1               | r              | Grant Register<br>Bit 03 : Software Grant<br>Bit 47 : Hardware Grants                                                                                                                                                                                                                                                                                          | 00          |
| 1107             | 1               | w              | Clear Request Register<br>Bit 03 : Software Request<br>Bit 47 : Hardware Requests                                                                                                                                                                                                                                                                              | -           |
| 1108             | 248             | r/w            | reserved                                                                                                                                                                                                                                                                                                                                                       |             |
| 1200             | 1               | r/w            | VEB Sync Mode Register<br>Bit 0: 1 = Enable Sync Quitting Mode<br>0 = Enable Pulse width Register<br>Bit 1: 1 = Sync / veb_irq output is active low,<br>0 = active high<br>Bit 2: 1 = Enable tristate buffer for sync / veb_irq<br>output<br>Bit 3: Sync Output Register (read)<br>Bit 64 : Reserved<br>Bit 7: 1 = Enable Sync Clear<br>0 = Disable Sync Clear | 00          |
| 1201             | 1               | r/w            | Reserved                                                                                                                                                                                                                                                                                                                                                       | 00          |
| 1202             | 2               | r/w16          | Sync Pulse width Register<br>Bit 150 : Value in steps of 20 ns (e.g. 5 = 100ns<br>and 0 = disabled)                                                                                                                                                                                                                                                            | 0000        |

#### VARAN CLIENT BOARD

SIGMATEK

| 1204 | 4    | r   | VARAN Bus Cycle Time [10 ns]                                                                                                                                                                                                                                                                                                         | 0000000         |
|------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 1208 | 8    | r/w | Reserved                                                                                                                                                                                                                                                                                                                             | 00              |
| 1210 | 1    | r/w | Digital In/Output Register                                                                                                                                                                                                                                                                                                           | 00              |
| 1211 | 239  | -   | Reserved                                                                                                                                                                                                                                                                                                                             | -               |
| 1300 | 4    | w32 | Transmit FIFO Data Input                                                                                                                                                                                                                                                                                                             | -               |
| 1304 | 4    | w32 | Transmit FIFO Frame Length<br>Write frame length before filling the FIFO<br>Bit 10 0 : Frame Length (in Bytes max. 1518)                                                                                                                                                                                                             | -               |
| 1308 | 4    | r32 | Receive FIFO Data Output                                                                                                                                                                                                                                                                                                             | -               |
| 130C | 4    | r32 | Receive FIFO Frame Length (in Bytes)<br>0 = no valid frame in FIFO                                                                                                                                                                                                                                                                   | 0000000         |
| 1310 | 4    | r   | Available Registers in Transmit FIFO (in Bytes)                                                                                                                                                                                                                                                                                      | 0000000         |
| 1314 | 4    | w   | FIFO Control register<br>Bit 0 : 1 = Reset Transmit FIFO<br>Bit 1 : 1 = Reset Receive FIFO                                                                                                                                                                                                                                           | -               |
| 1314 | 4    | r   | FIFO Status register (IRQ Quit register)<br>Bit 0 : 1 = frame transmitted<br>Bit 1 : 1 = frame received (valid frame is in FIFO)<br>Bit 2 : 1 = transmit FIFO error<br>(Transmit FIFO Frame Length > 1518,<br>or writing false values of bytes in FIFO)<br>Bit 3 : 1 = receive FIFO error<br>(Read Receive FIFO when no valid frame) | 0000000         |
| 1318 | 4    | r/w | Interrupt enable register<br>Bit 0 : 1 = frame transmitted<br>Bit 1 : 1 = frame received<br>Bit 2 : 1 = transmit FIFO error<br>Bit 3 : 1 = receive FIFO error                                                                                                                                                                        | 0000000         |
| 131C | 4    | r/w | Receive MAC Filter register<br>Bit 0 : 1 = Unicast enable<br>(Destination address = MAC address)<br>Bit 1 : 1 = Broadcast enable<br>(Destination address = 16#FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF                                                                                                                                   | 0000000         |
| 1320 | 6    | r/w | MAC Address                                                                                                                                                                                                                                                                                                                          | 0000000<br>0000 |
| 1326 | 1    | r/w | Port Control / Link Status register<br>Bit 0 : 1 = Link established (read only)<br>Transmitting is only allowed, when Link is established<br>Bit 1 : 1 = Port enable<br>(Port must be enabled before transmitting)                                                                                                                   |                 |
| 1327 | 1241 | r/w | reserved                                                                                                                                                                                                                                                                                                                             |                 |
| 1800 | 2048 | r/w | DPRAM                                                                                                                                                                                                                                                                                                                                | 00              |

## Table 4: Address Mapping µC Client

## Sync Modes

The Sync Mode register allows the synchronization response to be modified.



As can be seen in images 2 and 4, a distinction is made between active high and active low (bit 1). The Sync Quitting Mode can be activated (bit 0). In this case, the  $\mu$ C sends a response as defined in 6.

To avoid damage to the output driver, the tristate buffer option (bit 2) can be activated (3 and 5). Bit 0 of the Sync Mode register can also activate the pulse width register. Values can be set in 20 ns increments.

## Interrupt Output

The VEB 013-SPI interrupt output can be configured over the same register as the Sync for low-active, high-active and/or tristate.

If an interrupt is triggered, the output is then active. The VEB IRQ is controlled through the EMAC. The interrupt must be acknowledged in the respective register to deactivate the interrupt output (e.g. EMAC FIFO Status register - IRQ Quit register).

## **External Timing**

#### **SPI Access**



MSB ... Most significant Bit LSB ... Least significant Bit

Q ... Undefined

| Time setting          | Time (ns) |      | Description               |
|-----------------------|-----------|------|---------------------------|
|                       | Min.      | Max. |                           |
| t <sub>su(ssel)</sub> | 20        | -    | SSEL low to SCK high      |
| t <sub>su(MOSI)</sub> | 0         | -    | SCK high to read          |
| t <sub>d(MISO)</sub>  | -         | 80   | SCK low to write          |
| T <sub>sck</sub>      | 200       | -    | SPI clock period          |
| T <sub>h(ssel)</sub>  | 20        |      | SSEL Hold time to SCK low |

Table 4: Time characteristics

The data are recorded with the first rising SCK flank and sent with the falling SCK flank.

In IDLE status, the SSEL is set to HIGH.

SPI frames always have 8 bits. The maximum SPI pulse frequency is 5 MHz.

#### SPI Protocol

The SPI protocol consists of 4 parts:

- 1. Synchronization (optional)
- 2. Header: Definition of the data that is read from the FPGA
- 3. Header: Definition of the data that is written to the FPGA
- 4. Data transfer



#### General description of VEB013-SPI interface

MOSI (VEB013-SPI Input): SPI data input signal

MISO (VEB013-SPI Output): SPI data output signal

SCK (VEB013-SPI Input): SPI clock input signal

/SSEL(VEB013-SPI Input): SPI chip select (active low signal)

- => Data communication between the HOST and the VEB013-SPI uses byte quantities, that is 8 bits.
- => Bit synchronization is done using /SSEL.
- => The most significant bit (MSB) is transferred first.
- => MOSI (VEB013-SPI Input) is sampled at the rising edge of the SCK signal.
- => MISO (VEB013-SPI Output) is changed at the falling edge of the SCK signal.
- => SCK (VEB013-SPI Input) has active high level.

The protocol used in communication between the HOST and the VEB013-SPI consists of a 6 byte header followed by the amount of data specified in the header.

#### Master Out Slave In signal (MOSI)

HDR byte 1: RD addr byte 0 (LSB) HD HDR byte 2: RD addr byte 1 (MSB) HD HDR byte 3: RD length byte (0-255) HD HDR byte 4: WR addr byte 0 (LSB) HD HDR byte 5: WR addr byte 1 (MSB) HD HDR byte 6: WR length byte (0-255) HD WR data byte 0 WR data byte 0 WR data byte 1 WR data byte 2 WR data byte 3 WR data byte 3 WR data byte 4 WR data byte 5 WR data byte 6 ....

#### Master In Slave Out signal (MISO)

HDR byte 1: undefined value HDR byte 2: undefined value HDR byte 3: errors (in previous data transfer) HDR byte 4: defined 0x5A HDR byte 5: defined 0x5A HDR byte 6: defined 0x5A RD data byte 0 RD data byte 1 RD data byte 1 RD data byte 2 RD data byte 3 RD data byte 4 RD data byte 5 RD data byte 6

The header bytes must be followed by the correct amount of data bytes as specified in HDR byte 3 and HDR byte 6. The correct amount of data bytes can be calculated as the maximum of 'RD length byte' and 'WR length byte'.

Note: If 'RD length byte' is smaller than 'WR length byte' then all RD data bytes transferred after 'RD length byte' data bytes are undefined values. If 'RD length byte' is greater than 'WR length byte' then all WR data bytes transferred after 'WR length byte' data bytes are ignored.

Protocol synchronization is done using /SSEL and SCK. If SCK is high while /SSEL is high, the protocol state is set to idle.

Note: Protocol synchronization is optional and can be omitted as long as no errors have occurred.

#### HDR byte 3: errors (in previous data transfer)

Bit 0 is set if SPI Protocol synchronization interrupted the previous data transfer.

- Bit 1 is set if a write buffer overflow occurred in the previous data transfer.
- Bit 2 is set if a read buffer underrun occurred in the previous data transfer.
- Bit 3 is set if there was an access to an invalid address in the previous data transfer.

## **Recommended Shielding for VARAN**

The real-time VARAN Ethernet bus system exhibits very robust characteristics in industrial environments. Through the use of IEEE 802.3 standard Ethernet physics, the potentials between an Ethernet line and sending/receiving components are separated. Messages to a bus participant are immediately repeated by the VARAN Manager in the event of an error. The shielding described below is principally recommended.

For applications in which the bus is run outside the control cabinet, the correct shielding is required. Especially when for structural reasons, the bus line must be placed next to strong electromagnetic interference. It is recommended to avoid placing Varan bus lines parallel to power cables whenever possible.

SIGMATEK recommends the use of CAT5e industrial Ethernet bus cables.

For the shielding, an S-FTP cable should be used.

An S-FTP bus is a symmetric, multi-wire cable with unshielded pairs. For the total shielding, a combination of foil and braiding is used. A non-laminated variant is recommended.

#### The VARAN cable must be secured at a distance of 20 cm from the connector for protection against vibration!

# 1. Wiring from the Control Cabinet to an External VARAN Component

If the Ethernet lines are connected from a VARAN component to a VARAN node located outside the control cabinet, the shielding should be placed at the entry point to the control cabinet housing. All noise can then be dissipated before reaching the electronic components.



## 2. Wiring Outside of the Control Cabinet

If a VARAN bus cable must be placed outside of the control cabinet only, no additional shield connection is required. This requires that only IP67 modules and connectors be used. These components are very robust and noise resistant. The shielding for all sockets in IP67 modules are internally connected to common bus or electrically connected to the housing, whereby the deflection of voltage spikes does not flow through the electronics.



## 3. Shielding for Wiring Within the Control Cabinet

Sources of strong electromagnetic noise located within the control cabinet (drives, Transformers, etc.) can generate interference in a VARAN bus line. Voltage spikes are dissipated over the metallic housing of a RJ45 connector. Noise is conducted over the control cabinet without additional measures needed on the circuit board of electronic components. To avoid error sources with data exchange, it is recommended that shielding be placed before any electronic components in the control cabinet.



## 4. Connecting Noise-Generating Components

When connecting power lines to the bus that generates strong electromagnetic noise, the correct shielding is also important. The shielding should be placed before a power element (or group of power elements).



## 5. Shielding Between Two Control Cabinets

If two control cabinets must be connected over a VARAN bus, it is recommended that the shielding be located at the entry points of each cabinet. Noise is therefore prevented from reaching the electronic components in both cabinets.



19.06.2018

