TMS320DM644x DMSoC
VLYNQ Port
User's Guide
Literature Number: SPRUE36A
September 2007
2 SPRUE36A – September 2007
Submit Documentation Feedback
Contents
Preface ............................................................................................................................... 7
1 Introduction ................................................................................................................ 9
1.1 Purpose of the Peripheral ....................................................................................... 9
1.2 Features ........................................................................................................... 9
1.3 Functional Block Diagram ..................................................................................... 10
1.4 Industry Standard(s) Compliance Statement ............................................................... 10
2 Peripheral Architecture .............................................................................................. 11
2.1 Clock Control .................................................................................................... 11
2.2 Signal Descriptions ............................................................................................. 12
2.3 Pin Multiplexing ................................................................................................. 12
2.4 Protocol Description ............................................................................................ 12
2.5 VLYNQ Functional Description ............................................................................... 13
2.6 Initialization ...................................................................................................... 16
2.7 Auto-Negotiation ................................................................................................ 16
2.8 Serial Interface Width Configuration ......................................................................... 16
2.9 Address Translation ............................................................................................ 17
2.10 Flow Control ..................................................................................................... 20
2.11 Reset Considerations .......................................................................................... 21
2.12 Interrupt Support ................................................................................................ 21
2.13 DMA Event Support ............................................................................................ 23
2.14 Power Management ............................................................................................ 24
2.15 Emulation Considerations ..................................................................................... 24
3 VLYNQ Port Registers ................................................................................................ 25
3.1 Revision Register (REVID) .................................................................................... 26
3.2 Control Register (CTRL) ....................................................................................... 27
3.3 Status Register (STAT) ........................................................................................ 29
3.4 Interrupt Priority Vector Status/Clear Register (INTPRI) .................................................. 31
3.5 Interrupt Status/Clear Register (INTSTATCLR) ............................................................ 31
3.6 Interrupt Pending/Set Register (INTPENDSET) ............................................................ 32
3.7 Interrupt Pointer Register (INTPTR) ......................................................................... 32
3.8 Transmit Address Map Register (XAM)...................................................................... 33
3.9 Receive Address Map Size 1 Register (RAMS1) .......................................................... 34
3.10 Receive Address Map Offset 1 Register (RAMO1) ........................................................ 34
3.11 Receive Address Map Size 2 Register (RAMS2) .......................................................... 35
3.12 Receive Address Map Offset 2 Register (RAMO2) ........................................................ 35
3.13 Receive Address Map Size 3 Register (RAMS3) .......................................................... 36
3.14 Receive Address Map Offset 3 Register (RAMO3) ........................................................ 36
3.15 Receive Address Map Size 4 Register (RAMS4) .......................................................... 37
3.16 Receive Address Map Offset 4 Register (RAMO4) ........................................................ 37
3.17 Chip Version Register (CHIPVER) ........................................................................... 38
3.18 Auto Negotiation Register (AUTNGO) ....................................................................... 38
4 Remote Configuration Registers ................................................................................. 39
Appendix A VLYNQ Protocol Specifications ........................................................................ 40
A.1 Special 8b/10b Code Groups ................................................................................. 40
SPRUE36A – September 2007 Table of Contents 3
Submit Documentation Feedback
A.2 Supported Ordered Sets ....................................................................................... 40
A.3 VLYNQ 2.0 Packet Format .................................................................................... 41
A.4 VLYNQ 2.X Packets ............................................................................................ 43
Appendix B Write/Read Performance .................................................................................. 45
B.1 Write Performance.............................................................................................. 45
B.2 Read Performance ............................................................................................. 47
Appendix C Revision History ............................................................................................. 48
4 Contents SPRUE36A – September 2007
Submit Documentation Feedback
List of Figures
1 VLYNQ Port Functional Block Diagram ................................................................................. 10
2 External Clock Block Diagram ............................................................................................ 11
3 Internal Clock Block Diagram ............................................................................................. 11
4 VLYNQ Module Structure ................................................................................................. 13
5 Write Operations ........................................................................................................... 14
6 Read Operations ........................................................................................................... 15
7 Example Address Memory Map .......................................................................................... 18
8 Interrupt Generation Mechanism Block Diagram ....................................................................... 22
9 Revision Register (REVID) ................................................................................................ 26
10 Control Register (CTRL) ................................................................................................... 27
11 Status Register (STAT) .................................................................................................... 29
12 Interrupt Priority Vector Status/Clear Register (INTPRI) .............................................................. 31
13 Interrupt Status/Clear Register (INTSTATCLR) ........................................................................ 31
14 Interrupt Pending/Set Register (INTPENDSET) ........................................................................ 32
15 Interrupt Pointer Register (INTPTR) ..................................................................................... 32
16 Transmit Address Map Register (XAM) ................................................................................. 33
17 Receive Address Map Size 1 Register (RAMS1) ...................................................................... 34
18 Receive Address Map Offset 1 Register (RAMO1) .................................................................... 34
19 Receive Address Map Size 2 Register (RAMS2) ...................................................................... 35
20 Receive Address Map Offset 2 Register (RAMO2) .................................................................... 35
21 Receive Address Map Size 3 Register (RAMS3) ...................................................................... 36
22 Receive Address Map Offset 3 Register (RAMO3) .................................................................... 36
23 Receive Address Map Size 4 Register (RAMS4) ...................................................................... 37
24 Receive Address Map Offset 4 Register (RAMO4) .................................................................... 37
25 Chip Version Register (CHIPVER) ....................................................................................... 38
26 Auto Negotiation Register (AUTNGO) ................................................................................... 38
A-1 Packet Format (10-bit Symbol Representation) ........................................................................ 41
SPRUE36A – September 2007 List of Figures 5
Submit Documentation Feedback
List of Tables
1 VLYNQ Port Pins ........................................................................................................... 12
2 Serial Interface Width ...................................................................................................... 16
3 Address Translation Example (Single Mapped Region) .............................................................. 18
4 Address Translation Example (Single Mapped Region) .............................................................. 19
5 VLYNQ Register Address Space ......................................................................................... 25
6 VLYNQ Port Controller Registers ........................................................................................ 25
7 Revision Register (REVID) Field Descriptions ......................................................................... 26
8 Control Register (CTRL) Field Descriptions ............................................................................ 27
9 Status Register (STAT) Field Descriptions ............................................................................. 29
10 Interrupt Priority Vector Status/Clear Register (INTPRI) Field Descriptions ........................................ 31
11 Interrupt Status/Clear Register (INTSTATCLR) Field Descriptions .................................................. 31
12 Interrupt Pending/Set Register (INTPENDSET) Field Descriptions ................................................. 32
13 Interrupt Pointer Register (INTPTR) Field Descriptions ............................................................... 32
14 Address Map Register (XAM) Field Descriptions ...................................................................... 33
15 Receive Address Map Size 1 Register (RAMS1) Field Descriptions ................................................ 34
16 Receive Address Map Offset 1 Register (RAMO1) Field Descriptions .............................................. 34
17 Receive Address Map Size 2 Register (RAMS2) Field Descriptions ................................................ 35
18 Receive Address Map Offset 2 Register (RAMO2) Field Descriptions .............................................. 35
19 Receive Address Map Size 3 Register (RAMS3) Field Descriptions ................................................ 36
20 Receive Address Map Offset 3 Register (RAMO3) Field Descriptions .............................................. 36
21 Receive Address Map Size 4 Register (RAMS4) Field Descriptions ................................................ 37
22 Receive Address Map Offset 4 Register (RAMO4) Field Descriptions .............................................. 37
23 Chip Version Register (CHIPVER) Field Descriptions................................................................. 38
24 Auto Negotiation Register (AUTNGO) Field Descriptions ............................................................ 38
25 VLYNQ Port Remote Controller Registers .............................................................................. 39
A-1 Special 8b/10b Code Groups ............................................................................................. 40
A-2 Supported Ordered Sets .................................................................................................. 40
A-3 Packet Format (10-bit Symbol Representation) Description .......................................................... 42
B-1 Scaling Factors ............................................................................................................. 46
B-2 Expected Throughput (VLYNQ Interface Running at 76.5 MHZ and 99 MHZ) .................................... 46
B-3 Relative Performance with Various Latencies .......................................................................... 47
C-1 Document Revision History ............................................................................................... 48
6 List of Tables SPRUE36A – September 2007
Submit Documentation Feedback
About This Document
This document describes the VLYNQ™ communications interface port in the TMS320DM644x Digital
Media System-on-Chip (DMSoC).
Notational Conventions
This document uses the following conventions.
• Hexadecimal numbers are shown with the suffix h. For example, the following number is 40
hexadecimal (decimal 64): 40h.
• Registers in this document are shown in figures and described in tables.
– Each register figure shows a rectangle divided into fields that represent the fields of the register.
Each field is labeled with its bit name, its beginning and ending bit numbers above, and its
read/write properties below. A legend explains the notation used for the properties.
– Reserved bits in a register figure designate a bit that is used for future device expansion.
Related Documentation From Texas Instruments
The following documents describe the TMS320DM644x Digital Media System-on-Chip (DMSoC). Copies
of these documents are available on the Internet at www.ti.com . Tip: Enter the literature number in the
search box provided at www.ti.com.
The current documentation that describes the DM644x DMSoC, related peripherals, and other technical
collateral, is available in the C6000 DSP product folder at: www.ti.com/c6000 .
SPRUE14 — TMS320DM644x DMSoC ARM Subsystem Reference Guide. Describes the ARM
subsystem in the TMS320DM644x Digital Media System-on-Chip (DMSoC). The ARM subsystem is
designed to give the ARM926EJ-S (ARM9) master control of the device. In general, the ARM is
responsible for configuration and control of the device; including the DSP subsystem, the video
processing subsystem, and a majority of the peripherals and external memories.
Preface
SPRUE36A – September 2007
Read This First
SPRUE15 — TMS320DM644x DMSoC DSP Subsystem Reference Guide. Describes the digital signal
processor (DSP) subsystem in the TMS320DM644x Digital Media System-on-Chip (DMSoC).
SPRUE19 — TMS320DM644x DMSoC Peripherals Overview Reference Guide. Provides an overview
and briefly describes the peripherals available on the TMS320DM644x Digital Media
System-on-Chip (DMSoC).
SPRAA84 — TMS320C64x to TMS320C64x+ CPU Migration Guide. Describes migrating from the
Texas Instruments TMS320C64x digital signal processor (DSP) to the TMS320C64x+ DSP. The
objective of this document is to indicate differences between the two cores. Functionality in the
devices that is identical is not included.
SPRU732 — TMS320C64x/C64x+ DSP CPU and Instruction Set Reference Guide. Describes the CPU
architecture, pipeline, instruction set, and interrupts for the TMS320C64x and TMS320C64x+ digital
signal processors (DSPs) of the TMS320C6000 DSP family. The C64x/C64x+ DSP generation
comprises fixed-point devices in the C6000 DSP platform. The C64x+ DSP is an enhancement of
the C64x DSP with added functionality and an expanded instruction set.
SPRU871 — TMS320C64x+ DSP Megamodule Reference Guide. Describes the TMS320C64x+ digital
signal processor (DSP) megamodule. Included is a discussion on the internal direct memory access
(IDMA) controller, the interrupt controller, the power-down controller, memory protection, bandwidth
management, and the memory and cache.
SPRUE36A – September 2007 Preface 7
Submit Documentation Feedback
Related Documentation From Texas Instruments
SPRAAA6 — EDMA v3.0 (EDMA3) Migration Guide for TMS320DM644x DMSoC. Describes migrating
from the Texas Instruments TMS320C64x digital signal processor (DSP) enhanced direct memory
access (EDMA2) to the TMS320DM644x Digital Media System-on-Chip (DMSoC) EDMA3. This
document summarizes the key differences between the EDMA3 and the EDMA2 and provides
guidance for migrating from EDMA2 to EDMA3.
Trademarks
VLYNQ is a trademark of Texas Instruments.
8 Read This First SPRUE36A – September 2007
Submit Documentation Feedback
1 Introduction
1.1 Purpose of the Peripheral
The VLYNQ™ communications interface port is a low pin count, high-speed, point-to-point serial interface
in the TMS320DM644x Digital Media System-on-Chip (DMSoC) used for connecting to host processors
and other VLYNQ-compatible devices. The VLYNQ port is a full-duplex serial bus where transmit and
receive operations occur separately and simultaneously without interference.
VLYNQ enables the extension of an internal bus segment to one or more external physical devices. The
external devices are mapped to local physical address space and appear as if they are on the internal bus
of the DM644x DMSoC. The external devices must also have a VLYNQ interface.
VLYNQ uses a simple block code (8b/10b) packet format and supports in-band flow control so that no
extra terminals are needed to indicate that overflow conditions might occur.
The VLYNQ module on the DM644x DMSoC serializes a write transaction to the remote/external device
and transfers the write via the VLYNQ port (TX pins). The remote VLYNQ module deserializes the
transaction on the other side.
The read transactions to the remote/external device follow the same process, but the remote device's
VLYNQ module serializes the read return data and transfers it to the VLYNQ port (RX pins). The read
return data is finally deserialized and released to the device internal bus.
The external device can also initiate read and write transactions.
User's Guide
SPRUE36A – September 2007
VLYNQ Port
1.2 Features
The general features of the VLYNQ port are:
• Low pin count (10 pin interface, scalable to as low as 3 pins)
• No tri-state signals
– All signals are dedicated and driven by only one device
– Necessary to allow support for high-speed PHYs
• Scalable Performance
– Programmable frequency and 1 to 4 bits for TX and RX data
– Performance increases linearly as the data port width increases
• Simple packet-based transfer protocol for memory-mapped access
– Write request/data packet
– Read request packet
– Read response data packet
– Interrupt request packet
• Auto width negotiation
SPRUE36A – September 2007 VLYNQ Port 9
Submit Documentation Feedback
Slave
config
bus
Interface
Master
config
Interface
bus
VLYNQmodule
VLYNQregister
access
CPU/EDMA initiated
transfersto
remotedevice
Offchip
(remote)
deviceaccess
ARM/EDMA
memory
System
VLYNQ_SCRUN
VLYNQ_CLOCK
VLYNQ_RXD[3:0]
VLYNQ_TXD[3:0]
INT31
ARMinterrupt
controller
VLQINT
Introduction
• Symmetric Operations
– Transmit (TX) pins on the first device connect to the receive (RX) pins on the second device and
vice-versa.
– Data pin widths are automatically detected after reset
– Re-request packets, response packets, and flow control information are all multiplexed and sent
across the same physical pins.
– Supports both host/peripheral and peer-to-peer communication models
• Simple block code packet formatting (8b/10b)
• Supports in-band and flow control
– No extra pins are needed
– Allows the receiver to momentarily throttle the transmitter back when overflow is about to occur
– Uses the special built-in block code capability to interleave flow control information seamlessly with
user data
• Automatic packet formatting optimizations
• Internal loopback modes are provided
• Connects to legacy VLYNQ devices
1.3 Functional Block Diagram
Figure 1 shows a functional block diagram of the VLYNQ port.
Figure 1. VLYNQ Port Functional Block Diagram
1.4 Industry Standard(s) Compliance Statement
VLYNQ is an interface defined by Texas Instruments and does not conform to any other industry standard.
VLYNQ Port10 SPRUE36A – September 2007
Submit Documentation Feedback
2 Peripheral Architecture
CLKDIR=0
VLYNQ
DMxxxdevice
VLYNQ.CLK
CLKDIR=0
VLYNQ
VLYNQdevice
CLKDIR=1
VLYNQ
DMxxxdevice
VLYNQ.CLK
CLKDIR=0
VLYNQ
VLYNQdevice
Don't
care
VLYNQ
internal
sysclk
2.1 Clock Control
Peripheral Architecture
This section discusses the architecture and basic functions of the VLYNQ peripheral.
The module's serial clock direction and frequency are software configurable through the CLKDIR and
CLKDIV bits in the VLYNQ control register (CTRL). The VLYNQ serial clock can be sourced from the
internal system clock (CLKDIR = 1) or by an external clock source (CLKDIR = 0) for its serial operations.
The CLKDIV bit can divide the serial clock (1/1 - 1/8) down when the internal clock is selected as the
source. The serial clock is not affected by the CLKDIV bit values, if the serial clock is externally sourced.
The reset value of the CLKDIR bit is 0 (external clock source).
The external clock source is shown in Figure 2 . The internal clock source is shown in Figure 3 .
Figure 2. External Clock Block Diagram
SPRUE36A – September 2007 VLYNQ Port 11
Submit Documentation Feedback
Figure 3. Internal Clock Block Diagram
Peripheral Architecture
2.2 Signal Descriptions
The VLYNQ module on the DM644x device is configurable for a 1 to 4 bit-wide RX/TX. Chip-level pin
multiplexing registers control the configuration. See the pin multiplexing information in the device-specific
data manual.
If the configured width does not match the number of transmit/receive lines that are available on the
remote device, negotiation between the two VLYNQ devices automatically configures the width (see
Section 2.7 ).
The VLYNQ interface signals are shown in Table 1 .
Table 1. VLYNQ Port Pins
Pin Name Signal Name I/O Description
VLYNQ_CLOCK VLYNQ serial clock I/O The VLYNQ reference clock supports the internally or externally generated
VLYNQ_SCRUN VLYNQ serial clock I/O The VLYNQ serial clock run request allows remote requests for the VLYNQ
run request serial clock to be turned off for system power management.
(Active low) Low: The request VLYNQ serial clock is active.
VLYNQ_RXD[0:3] VLYNQ receive data I VLYNQ receive data is synchronous with the VLYNQ serial clock.
VLYNQ_TXD[0:3] VLYNQ transmit data O VLYNQ transmit data is synchronous with the VLYNQ serial clock.
clock.
High: The VLYNQ serial clock is requested to be high when all transactions are
complete.
2.3 Pin Multiplexing
2.4 Protocol Description
The VLYNQ signals share pins on the processor package with other processor functions. The VLYNQ
module pins are not enabled at reset. In order to change the default function of device pins at reset, the
pin multiplexing registers (PINMUX n) must be configured appropriately. See the pin multiplexing
information in the device-specific data manual for more detailed information on the processor pin
multiplexing and configuration registers.
VLYNQ relies on 8b/10b block coding to minimize the number of serial pins and allows for in-band packet
delineation and control.
Appendix A provides general information on 8b/10b coding definitions and their implementation within the
VLYNQ module in the DM644x device.
VLYNQ Port12 SPRUE36A – September 2007
Submit Documentation Feedback
2.5 VLYNQ Functional Description
Address
translation
commands
Outbound
Outbound
command
FIFO
data
Return
FIFO
data
FIFO
Return
command
Inbound
FIFO
Registers
translation
Address
TxSM
8B/10B
encoding
Serializer
commands
Inbound
RxSM Deserializer
decoding
8B/10B
Serial
TxData
Serial
TxClk
Serial
RxClk
Serial
RxData
Master
configbus
interface
Systemclock VLYNQclock
Slave
configbus
interface
(FIFO3)
(FIFO2)
(FIFO0)
(FIFO1)
The VLYNQ core supports both host-to-peripheral and peer-to-peer communication models and is
symmetrical. The VLYNQ module structure is shown in Figure 4 .
Peripheral Architecture
Figure 4. VLYNQ Module Structure
The VLYNQ core module implements two 32-bit configuration bus interfaces. Transmit operations and
control register access require the slave configuration bus interface. The master configuration bus
interface is required for receive operations. Converting to and from the 32-bit bus to the external serial
interface requires serializer and deserializer blocks.
8b/10b block coding encodes data on the serial interface. Frame delineation, initialization, and flow control
use special overhead code groups.
FIFOs buffer the entire burst on the bus for maximum performance, thus minimizing bus latency. Using
write operations of each VLYNQ module interfaced is typically recommended to ensure the best
performance on both directions of the link.
SPRUE36A – September 2007 VLYNQ Port 13
Submit Documentation Feedback
Address
translation
commands
Outbound
Outbound
command
FIFO
data
Return
FIFO
data
FIFO
Return
command
Inbound
FIFO
Registers
translation
Address
TxSM
8B/10B
encoding
Serializer
commands
Inbound
RxSM Deserializer
decoding
8B/10B
Serial
TxData
Serial
RxData
Systemclock
Address
translation
Registers
commands
Inbound
translation
Address
commands
Outbound
8B/10B
decoding
FIFO
FIFO
command
Inbound
data
Return
FIFO
RxSM Deserializer
RxData
Serial
encoding
8B/10B
VLYNQClock
command
Return
data
FIFO
Outbound
TxSM Serializer
TxData
Serial
Slave
configbus
interface
Systemclock VLYNQclock
LocalVLYNQ
RemoteVLYNQ
Master
configbus
interface
Master
configbus
interface
Slave
configbus
interface
Peripheral Architecture
2.5.1 Write Operations
Write requests that initiate from the slave configuration bus interface of the local device write to the
outbound command (CMD) FIFO. Data is subsequently read from the FIFO and encapsulated in a write
request packet. The address is translated, and the packet is encoded and serialized before being
transmitted to remote device. The remote device subsequently deserializes and decodes the receive data
and writes it into the inbound CMD FIFO. A write operation initiates on the remote device’s master
configuration bus interface after reading the address and data from the FIFO.
The data flow between two VLYNQs that are connected is shown in Figure 5 . In the example shown in
Figure 5 , the write originates from the DM644x device.
Figure 5. Write Operations
VLYNQ Port14 SPRUE36A – September 2007
Submit Documentation Feedback
2.5.2 Read Operations
Address
translation
commands
Outbound
Outbound
command
FIFO
data
Return
FIFO
data
FIFO
Return
command
Inbound
FIFO
Registers
translation
Address
TxSM
8B/10B
encoding
Serializer
commands
Inbound
RxSM Deserializer
decoding
8B/10B
Serial
TxData
Serial
RxData
Systemclock
Address
translation
Registers
commands
Inbound
translation
Address
commands
Outbound
8B/10B
decoding
FIFO
FIFO
command
Inbound
data
Return
FIFO
RxSM Deserializer
RxData
Serial
encoding
8B/10B
VLYNQClock
command
Return
data
FIFO
Outbound
TxSM Serializer
TxData
Serial
Slave
configbus
interface
VLYNQClock
Systemclock
LocalVLYNC
RemoteVLYNQ
Master
configbus
interface
Slave
configbus
interface
Master
configbus
interface
Peripheral Architecture
Read requests from the slave configuration bus interface are written to the outbound CMD FIFO (similar to
the write requests). Data is subsequently read from the FIFO and encapsulated into a read request
packet. The packet is encoded and serialized before it is transmitted to the remote device. Next, the
remote device deserializes, decodes the receive data, and writes the receive data to the inbound CMD
FIFO. After reading the address from the FIFO, a master configuration bus interface read operation
initiates in the remote device. When the remote master configuration bus interface receives the read data,
the data is written to the return data FIFO before it is encoded and serialized. When the receive data
reaches the local VLYNQ module, it is deserialized, decoded, and written to the return data FIFO (local
device). Finally, the read data is transferred on the local device’s slave configuration interface.
The data flow between two connected VLYNQ devices with read requests that originate from the DM644x
device is shown in Figure 6 . The remote VLYNQ device returns the read data. Read data is shown with
dotted arrows.
Figure 6. Read Operations
SPRUE36A – September 2007 VLYNQ Port 15
Submit Documentation Feedback