LINKUSB
Hardware description
A device driver writer’s guide

_____________________________________________________________________

MIKE’s Technical Note 3

Dipl. Ing. Michael Brüstle

April 2014
V:20250107113800

Contents

1 Introduction
 1.1 Overview
 1.2 Design mind maps
2 Hardware
 2.1 Specification
 2.2 Front view
 2.3 Back view
  2.3.1 Connector pinout
 2.4 Circuit board
3 USB characteristic
 3.1 Vendor/Device IDs
 3.2 USB descriptors
4 Firmware
 4.1 Endpoint configuration
  4.1.1 Endpoint Zero
  4.1.2 Endpoint 1
  4.1.3 Endpoint 2, 4, 6 and 8
 4.2 Custom commands
  4.2.1 VR_IDENTIFY_DEVICE (0xB0)
  4.2.2 VR_GET_BOOT_ERROR (0xB1)
  4.2.3 VR_GET_SUBSYS_STATUS (0xB2)
  4.2.4 VR_SET_CONTROL_REGISTER (0xB3)
  4.2.5 VR_GET_FIFO_STATUS (0xB4)
  4.2.6 VR_EEPROM_RD (0xB5)
  4.2.7 VR_EEPROM_WR (0xB6)
  4.2.8 VR_GET_SERIAL_NUMBER (0xB7)
 4.3 File Format
5 Troubleshooting
 5.1 Power
 5.2 USB
 5.3 FPGA I
 5.4 FPGA II
6 Remarks
References

1 Introduction

The classic INMOS transputer interfaces for connecting a transputer [1] and a PC are the two ISA-Bus interfaces B004 and B008, named after the corresponding popular PC boards. The B004 is a simple polling byte wide port interface, while the B008 expands this with interrupt and DMA capabilities.

Irrespective of the low speed (<400KB/s) and the high system impact (polling and only byte wide) is the ISA-Bus a thing of the past for PC’s build in this century.

To allow standard desktops and notebooks to interface with a transputer or a whole network of transputer the USB interface was selected. USB has many advantages which will not be listed here except one: You don’t need another wall power supply!

1.1 Overview

The LINKUSB interface device is an USB 2.0 to transputer link protocol converter. It incorporates two almost independent transputer link connectors with differential link signals and open collector control pins.

As link connector the standard RJ45 connector is used. It has the same signals and voltage levels as an Aalener link adaptor except the omitted power pin.

The link speed can be selected as 5MHz, 10MHz, 20MHz and 40MHz. Unfortunately 40MHz can only be used for testing, as there is no transputer which supports this speed. But it can be useful to check the link cable quality with a small loopback jumper.

The design is a bus powered device and the housing is a small aluminium case.

1.2 Design mind maps

The project has its roots in 2007 after identifying the need to support the standard USB interface. By process of elimination the Cypress USB Controller CY7C68013A-56PVXC [2] was selected.

The VHDL code for the transputer link module exists from an earlier FPGA project. A Xilinx Spartan II XC2S15-5VQG100C [4] was selected due to the low complexity of the design and the 5V tolerant inputs.

The bit-stream for programming this FPGA-Type is so small that it can be downloaded from the USB Controller as a boot PROM is required for the firmware. This has also the advantage that only one PROM has to be updated and the firmware code is combined with the FPGA code.

Based on the fact that the USB controller provides four identical bulk endpoints, it was obvious to implement two distinct link interfaces.

The maximum length of an USB 2.0 cable is 5 meter. To enable longer distances between the PC and the remote transputer farm, the link interface was tied down to differential signalling. This doesn’t include the control signals: Error, Reset and Analyse. These signals are very slow and in general equipped with noise reduction circuits.

The pin assignment of the RJ45 connector allows the usage of simple standard CAT5 100baseTX crossover cables.

To utilise the RJ45 jack on both sides (UP and DOWN in INMOS naming convention) all control signals has open collector outputs and are readable. This has the advantage that the direction is only software dependent.

In 2013 there was a minor design revision.

The main changes for version 1.1 where:

To compensate the longer programming time for the FPGA a proprietary compression/decompression algorithm has been implemented. The FPGA bit-stream can be reduced from 42080 bytes to approximately 24K which is roughly the same size as the uncompressed XC2S15 bit-stream.

A special pin configuration named ”Parsytec” has been implemented which changes the analyse pin to the inverted value of the reset pin, new status LED modes has been incorporated and a few new custom commands where added.

2 Hardware

2.1 Specification

The following thresholds should be taken as guidance levels.

Operating temperature:
0C to 40C
Operating humidity:
10 to 90% non-condensing
Dimensions (WxDxH):
104mm x 55mm x 24mm
Weight:
120g
Power consumption:
Max 0.75W

2.2 Front view

The front panel consist of:

There is no difference between pressing the reset button and unplug/plug the USB cable, except that it is easier to handle.

The identification LED has two purposes: The LED is active during programming of the FPGA (about one second after power-on-reset has been released) and the identification of the device via software. If there are more than one LINKUSB devices connected to a machine, it’s much easier to identify the right module by switching on this LED, than looking for the different serial numbers on each device.

2.3 Back view

The back panel consist of a dual RJ45 jack, each with two status LEDs:

Depending on the configured mode the green LED (left) and the yellow LED (right) can be configured to show different information:





Mode Green Yellow



Off - -
Standard Send/Receive DataError or Fault
Data OnlySend Data Receive Data
Debug Send FIFO Empty Receive FIFO Full




Table 1: Status LED modes

The LED brightness for data transfers is not content dependent. Sending a long run of bytes with only 0 bits is as bright as sending bytes with all bits 1.

The Fault-State is an internal state which signals one of the following illegal receiving sequences:

To clear this condition, an explicit custom command (initialize) has to be send to the affected link.

2.3.1 Connector pinout

All pins are 5V TTL compatible. Pin 1 is under the yellow LED.

1.
TX+
2.
TX-
3.
RX+
4.
notR
5.
notA (or R in Parsytec pin configuration)
6.
RX-
7.
notE
8.
GND

Every subsystem pin has a 2.2KOhm pull-up resistor. Additionally every subsystem input pin has a simple RC low pass filter (100Ohm, 100nF) to increase the noise immunity.

RX+ has a 2.2KOhm pull-down, RX- a 2.2KOhm pull-up resistor. From RX+ and RX- there is a separate 100Ohm resistor to a common 100nF capacitor to ground for impedance matching.

The device and the transputer are not electrical isolated. This can lead to problems if only one is powered particularly over a longer time. As a consequence of this, current can flow into the unpowered device. If totem-pole drivers are involved (e.g. transputer configured as UP system and driving Reset and Analyse) this problem should kept in mind and considered. The best way to avoid this issue is to use open collector outputs for all subsystem signals.

2.4 Circuit board

The circuit board is a four layer 100mm x 50.8mm standard FR4 PCB. Layer 2 is the dedicated ground plane and layer 3 contains the three power areas (5V, 3.3V and 2.5V).


Top view Top view

Figure 1: Top view

Besides the main actors XC2S30-5VQ100C [U1] and CY7C68014A-56PVXC [U2] there are a few other integrated circuits mounted:

The dual linear power regulator is a TPS70258 [U3] from Texas Instruments.

The serial I2C EEPROM is a 24FC512-I/SN [U4] from Microchip Technology. If the [JP1] is not present the PROM is write protected.

For the differential link signal the well-known DS89C21TM [U6,U7] from Texas Instruments is used. There is one for each link.

Finally to protect the FPGA the subsystem signals are driven by a hex buffer SN74LV07AD [U8] also from Texas Instruments.

3 USB characteristic

This device has no USB logo as this module has not performed any compliance program from the USB consortium.

3.1 Vendor/Device IDs

The VendorID is 0x16C0. The ProductID is 0x09CE.

This VendorID is shared by several people. A small range of ProductID’s has been acquired and should be unique.

3.2 USB descriptors

A more detailed description of the endpoints can be found in the Firmware section.

    Device Descriptor:  
    bcdUSB:             0x0200  
    bDeviceClass:         0x00  
    bDeviceSubClass:      0x00  
    bDeviceProtocol:      0x00  
    bMaxPacketSize0:      0x40 (64)  
    idVendor:           0x16C0  
    idProduct:          0x09CE  
    bcdDevice:          0x0000  
    iManufacturer:        0x01  0x0409: "Bruestle"  
    iProduct:             0x02  0x0409: "LINKUSB"  
    iSerialNumber:        0x03  0x0409: "123456"  
    bNumConfigurations:   0x01  
 
    ConnectionStatus: DeviceConnected  
    Current Config Value: 0x01  
    Device Bus Speed:     High  
    Device Address:       0x03  
    Open Pipes:              5  
 
    Endpoint Descriptor:  
    bEndpointAddress:     0x81  IN  
    Transfer Type:   Interrupt  
    wMaxPacketSize:     0x0200 (512)  
    bInterval:            0x01  
 
    Endpoint Descriptor:  
    bEndpointAddress:     0x02  OUT  
    Transfer Type:        Bulk  
    wMaxPacketSize:     0x0200 (512)  
    bInterval:            0x00  
 
    Endpoint Descriptor:  
    bEndpointAddress:     0x04  OUT  
    Transfer Type:        Bulk  
    wMaxPacketSize:     0x0200 (512)  
    bInterval:            0x00  
 
    Endpoint Descriptor:  
    bEndpointAddress:     0x86  IN  
    Transfer Type:        Bulk  
    wMaxPacketSize:     0x0200 (512)  
    bInterval:            0x00  
 
    Endpoint Descriptor:  
    bEndpointAddress:     0x88  IN  
    Transfer Type:        Bulk  
    wMaxPacketSize:     0x0200 (512)  
    bInterval:            0x00  
 
    Configuration Descriptor:  
    wTotalLength:       0x0035  
    bNumInterfaces:       0x01  
    bConfigurationValue:  0x01  
    iConfiguration:       0x00  
    bmAttributes:         0x80 (Bus Powered)  
    MaxPower:             0x64 (200 mA)  
 
    Interface Descriptor:  
    bInterfaceNumber:     0x00  
    bAlternateSetting:    0x00  
    bNumEndpoints:        0x05  
    bInterfaceClass:      0xFF  
    bInterfaceSubClass:   0xFF  
    bInterfaceProtocol:   0xFF  
    iInterface:           0x00

4 Firmware

The firmware is stored in the I2C EEPROM and loaded automatically into the internal RAM by the FX2LP Microcontroller.

After a basic internal setup, the first task is to program the FPGA. This code section reads the compressed bit-stream from the PROM which is then decompressed and the FPGA configured (slave parallel mode). When this has been accomplished the whole USB configuration of the FX2LP is performed which setup up the slave FIFO interface.

Finally the controller execute an endless loop and polls the subsystem status respectively handles the possible setup requests from the host controller.

Default settings:

LinkSpeed 20MHz
LedMode Standard
SubSysDirection.0Down
SubSysDirection.1Down
PinConfiguration Standard

For speed and functional tests it’s possible to set a link into loopback mode. It is also possible to connect both links in a so called crossback mode. These connections are made internally in the FPGA.

4.1 Endpoint configuration








Nr Type Direction Size AddressControl






ZeroControl Bidirectional64 - -
1 InterruptIn 64 - -
2 Bulk Out 512 (2x)0 (Link0)FlagA (Empty)
4 Bulk Out 512 (2x)1 (Link1)FlagB (Empty)
6 Bulk In 512 (2x)2 (Link0)FlagC (Full)
8 Bulk In 512 (2x)3 (Link1)FlagD (Full)







Table 2: Endpoints information

4.1.1 Endpoint Zero

Endpoint zero has special significance in a USB system. It is a CONTROL endpoint, and it is required by every USB device. The USB host uses special SETUP tokens to signal transfers that deal with device control; only CONTROL endpoints accept these special tokens.

This endpoint is also used to send custom commands to the device.

4.1.2 Endpoint 1

Endpoint 1 is an interrupt endpoint and sends unsolicited data to the host. If one or more subsystem signals changes a package with the new values is send to the host. This allows the provisioning of the subsystem signals in a way that not every request from the application (e.g. error signal polling) has to go the long way over the bus to the device.

4.1.3 Endpoint 2, 4, 6 and 8

The 4 bulk endpoints are responsible for the actual link data transfers and running in the so called Auto-In/Out mode.

Auto-In Mode allows the FPGA to stream data into a FIFO continuously, with no need for it or the firmware to packetize the data. For OUT endpoints, Auto-Out Mode allows the host to continuously fill a FIFO, with no need for the FPGA or firmware to handshake each incoming packet, arm the endpoint buffers, etc.

4.2 Custom commands

All custom commands are addressed to endpoint zero.

For a description of the USB SETUP Packet in FX2LP see [3] 2.3 USB Requests.

There is no data phase for the two commands VR_IDENTIFY_DEVICE and VR_SET_CONTROL_REGISTER. The information is transferred in the request value.

4.2.1 VR_IDENTIFY_DEVICE (0xB0)

SETUPDAT[ 2 ]:










76543210









0 000000?1 = Identification LED on









4.2.2 VR_GET_BOOT_ERROR (0xB1)

Returns 2 bytes:

Byte0LSB( BootError )
Byte1 MSB( BootError )

Possible results:

= 0no error
0 problems in configuring the FPGA

4.2.3 VR_GET_SUBSYS_STATUS (0xB2)

Returns 2 bytes:

Byte 0: Subsystem Status Link0
Byte 1: Subsystem Status Link1

Bit coding:

RESET 0x01
ANALYSE0x02
ERROR 0x04
FAULT 0x08

Bit 3-7 are reserved.

4.2.4 VR_SET_CONTROL_REGISTER (0xB3)

SETUPDAT[ 2 ]:










76543210









0 00L000?1 = Activate reset
0 00L001?1 = Activate analyse
0 00L010?1 = Activate error
0 00L110?1 = Set loopback
0 00L111?1 = Initialize









1 000000?1 = Set crossback
1 010000?1 = Set pinmode to Parsytec
1 100010?1 = Status LED Test









1 10000
M
Status LED Mode
1 10010
S
Linkspeed









L:0 = Link0, 1 = Link1
M:00 = Off, 01 = Standard, 10 = Data Only, 11 = Debug
S: 00 = 40Mhz, 01 = 20Mhz, 10 = 10Mhz, 11 = 5Mhz

4.2.5 VR_GET_FIFO_STATUS (0xB4)

Returns 2 bytes:

Byte 0: EP2468STAT; (see [3])
Byte 1: Reserved;

4.2.6 VR_EEPROM_RD (0xB5)

SETUPDAT[ 2 ]: LSB( Address )
SETUPDAT[ 3 ]: MSB( Address )
SETUPDAT[ 4 ]: Reserved
SETUPDAT[ 5 ]: Reserved
SETUPDAT[ 6 ]: LSB( Length )
SETUPDAT[ 7 ]: MSB( Length )

The Length must be greater 0 and lower equal to 64.

4.2.7 VR_EEPROM_WR (0xB6)

IMPORTANT: It is illegal to change the serial number in any way and the programmer is liable for the adoption of the serial number in the firmware update routine.

SETUPDAT[ 2 ]: LSB( Address )
SETUPDAT[ 3 ]: MSB( Address )
SETUPDAT[ 4 ]: Reserved
SETUPDAT[ 5 ]: Reserved
SETUPDAT[ 6 ]: LSB( Length )
SETUPDAT[ 7 ]: MSB( Length )

The Length must be greater 0 and lower equal to 64.

It’s recommended to align and maximize the Length as every VR_EEPROM_WR command will generate a page write.

4.2.8 VR_GET_SERIAL_NUMBER (0xB7)

Returns 12 bytes which contains a 6 character Unicode text string.

4.3 File Format

The firmware update file is a binary file with a size of exact 32768 Bytes. It starts with the firmware in the EZ-USB EEPROM Boot-load Data Format [3] followed by the FPGA configuration bit-stream. Its exact start address depends on the compression rate.

Between these two sections is a special structure stored called ”MyVitalProductData”.

It contains the following information:

The structure starts with a header and one or more info blocks. The MVPD_KEY starts always at a 16 Byte boundary. Currently this is 0x1000 but may be changed in the future. To validate the structure the sum of all bytes modulo 256 must produce 0. Integer values are stored in little-endian format.

From the supplied binary files a short name, the version, the last written timestamp (in the Microsoft FILETIME format) and the CRC32 value are stored.

    #define MVPD_KEY "_MVPD_"  
    #define MVPD_DWORD 0x50564D5F  
    #define MVPD_KEY_LENGTH 6  
 
    #pragma pack( 1 )  
    typedef struct _HEADER {  
        char              key[ MVPD_KEY_LENGTH ];  
        unsigned char     length;  
        unsigned char     checksum;  
    } HEADER;  
 
    typedef struct _VERINFO {  
        unsigned char     length;  
        char              id;         // ’V’  
        unsigned char     major;  
        unsigned char     minor;  
        unsigned long int crc;  
        __int64           lastwr;  
        char              name[ 8 ];  
    } VERINFO;  
 
    typedef struct _SERINFO {  
        unsigned char     length;  
        char              id;         // ’S’  
        unsigned char     reserved;  
        unsigned char     seriallength;  
        unsigned long int serialoffset;  
    } SERINFO;  
    #pragma pack()

All version information is for reference purpose only, while the serial information is required for firmware updates.

5 Troubleshooting

The labels in square brackets refer to figure 1.

It is also assumed that the USB port is connected to a Windows PC where the LINKUSB driver is correct installed.

5.1 Power

Let’s start with a fully disconnected device.

First check if there is short circuit between VBUS (5V) and GND. This can be measured at [JP3].

After the device is connected to a USB bus [J1] the green LED [LED1] should light up. This LED is powered from the 3.3V supply.

The 3.3V supply voltage can be measured at the capacitor [C8], the 2.5V at [C9].

To measure the current consumption it’s required to opening the solder bridge below the USB [J1] on the bottom side and connect an ampere meter. The nominal value is 120mA.

5.2 USB

In the Windows Device Manager the LINKUSB Device with its Serial Number should appear.

If instead a Device with the ID USB\VID_04B4&PID_8613 shows up, maybe [JP2] is missing or the PROM [U4] is defective. It’s also possible that the PROM content has become corrupted. The last case requires a new initial programming cycle which is not feasible in the field.

After opening the Device Properties Dialog (Settings) activate the Identify Device. This operation doesn’t involve any FPGA resources.

If the blue LED [LED2] lights up the Host to USB connection is functional.

5.3 FPGA I

In the Device Properties Dialog (Settings) the Subsystem Status of both Link 0 and Link 1 should be inactive (off).

If all Status values are active the FPGA may be not configured successfully. Checking the BootError value may confirm this.

With an external test switch connect each subsystem signal from the RJ45 jack [J2] with GND separately and verify the level in the Device Properties Dialog (Settings).

If all tests where passed successfully the FPGA is correct initialized and the static part inside the FPGA is operational.

5.4 FPGA II

The next test is similar to the previous test with the external test switch except that the corresponding action to pull the signal to ground is now made with the relevant VR_SET_CONTROL_REGISTER command.

If this is too extensive opening the Device Properties Dialog (Settings) and turning on Test LED uses almost the same FPGA resources but doesn’t test the subsystem open collector drivers.

To test each link data path it is necessary to put the particular link into the loopback mode.

Every byte which has been send should be available for read back without delay. It is possible to send up to 1024 Bytes in one write operation if there is also a subsequent read operation with a sufficient buffer.

In case of problems visually check the 80MHz oscillator [U5].

To extend this test and involve the line driver/receiver it is necessary to switch off the loopback mode and use an external loopback plug like the COMPAQ 317463-001.

When using a crossover cable it is also recommended to re-check the subsystem signals. If activating the Reset on one side both Subsystem Status signals should be on. Continuity check of the cable is also recommended.

6 Remarks

As the transputer link protocol is stream oriented and the USB bulk transfer is block oriented it is necessary to commit partial filled blocks. This will be made after the last received data byte and an additional wait time of approximately sixteen bit time segments.

It is not guaranteed that the receive block length matches the send block length.

This device buffers and acknowledges incoming link data as long as buffer space is available. This behaviour may be interpreted by the other communication partner as a ready to go sign which is maybe not desired.

References

[1]   Transputer reference manual, INMOS Ltd Bristol

[2]   EZ-USB FX2LP USB Microcontroller (38-08032), Cypress Corp.

[3]   EZ-USB Technical Reference Manual v1.2, Cypress Corp.

[4]   Spartan-II FPGA Family Data Sheet (DS001), Xilinx Inc.