# TMS320DM647/DM648 VLYNQ Port # User's Guide Literature Number: SPRUEL9 June 2007 # **Contents** | Pret | ace | | . ( | |------|---------|----------------------------------------------------------|-----| | 1 | Introdu | oction | 10 | | | 1.1 | Purpose of the Peripheral | 10 | | | 1.2 | Features | 10 | | | 1.3 | Functional Block Diagram | 11 | | | 1.4 | Industry Standard(s) Compliance Statement | 11 | | 2 | Periphe | eral Architecture | 12 | | | 2.1 | Clock Control | 12 | | | 2.2 | Signal Descriptions | 13 | | | 2.3 | Pin Multiplexing | 13 | | | 2.4 | Protocol Description | 13 | | | 2.5 | VLYNQ Functional Description | 14 | | | 2.6 | Initialization | 17 | | | 2.7 | Auto Negotiation | 17 | | | 2.8 | Serial Interface Width Configuration | 17 | | | 2.9 | Address Translation | 17 | | | 2.10 | Flow Control | 21 | | | 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 | | | | 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) | | | | 3.5 | Interrupt Status/Clear Register (INTSTATCLR) | | | | 3.6 | Interrupt Pending/Set Register (INTPENDSET) | | | | 3.7 | Interrupt Pointer Register (INTPTR) | | | | 3.8 | Transmit Address Map Register (XAM) | | | | 3.9 | Receive Address Map Size 1 Register (RAMS1) | | | | 3.10 | Receive Address Map Offset 1 Register (RAMO1) | | | | 3.11 | Receive Address Map Size 2 Register (RAMS2) | | | | 3.12 | Receive Address Map Offset 2 Register (RAMO2) | | | | 3.13 | Receive Address Map Size 3 Register (RAMS3) | | | | 3.14 | Receive Address Map Offset 3 Register (RAMO3) | | | | 3.15 | Receive Address Map Size 4 Register (RAMS4) | | | | 3.16 | Receive Address Map Offset 4 Register (RAMO4) | | | | 3.17 | Chip Version Register (CHIPVER) | | | | 3.18 | Auto Negotiation Register (AUTNGO) | | | | 3.19 | Manual Negotiation Register (MANNGO) | | | | 3.20 | Negotiation Status Register (NGOSTAT) | | | | 3.21 | Interrupt Vector 3-0 Register (INTVEC0) | 39 | | 3.22 | Interrupt Vector 7-4 Register (INTVEC1) | 40 | |------------|-----------------------------------------|----| | 4 Remo | te Configuration Registers | 43 | | Appendix A | VLYNQ Protocol Specifications | 44 | | A.1 | Special 8b/10b Code Groups | 44 | | A.2 | Supported Ordered Sets | 44 | | A.3 | VLYNQ 2.0 Packet Format | 46 | | A.4 | VLYNQ 2.X Packets | 47 | | Appendix B | Write/Read Performance | 49 | | B.1 | Write Performance | 49 | | B.2 | Read Performance | 52 | # **List of Figures** | 1 | VLYNQ Port Functional Block Diagram | 11 | |-----|----------------------------------------------------------|----| | 2 | External Clock Block Diagram | 12 | | 3 | Internal Clock Block Diagram | 12 | | 4 | VLYNQ Module Structure | 14 | | 5 | Write Operations | 15 | | 6 | Read Operations | 16 | | 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 | | 27 | Manual Negotiation Register (MANNGO) | 39 | | 28 | Negotiation Status Register (NGOSTAT) | 39 | | 29 | Interrupt Vector 3-0 Register (INTVEC0) | 39 | | 30 | Interrupt Vector 7-4 Register (INTVEC1) | 41 | | A-1 | Packet Format (10-bit Symbol Representation) | 46 | ## **List of Tables** | 1 | VLYNQ Port Pins | 13 | |-----|-----------------------------------------------------------------------------|----| | 2 | Serial Interface Width | 17 | | 3 | Address Translation Example (Single Mapped Region) | 19 | | 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 | Manual Negotiation Register (MANNGO) Field Descriptions | 39 | | 26 | Negotiation Status Register (NGOSTAT) Field Descriptions | 39 | | 27 | Interrupt Vector 3-0 Register (INTVEC0) Field Description | 39 | | 28 | Interrupt Vector 7-4 Register (INTVEC1) Field Description | 41 | | 29 | VLYNQ Port Remote Controller Registers | 43 | | A-1 | Special 8b/10b Code Groups | 44 | | A-2 | Supported Ordered Sets | 44 | | A-3 | Packet Format (10-bit Symbol Representation) Description | 46 | | B-1 | Scaling Factors | 49 | | B-2 | Expected Throughput (VLYNQ Interface Running at 99 MHz) | 50 | | B-3 | Expected Throughput (VLYNQ Interface Running at 76.5 MHz) | 51 | | R-/ | Relative Performance with Various Latencies | 52 | ### Read This First ### **About This Document** This document describes the VLYNQ™ communications interface port in the device. ### **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 TMS320DM647/DM648 Digital Signal Processor (DSP). Copies of these documents are available on the Internet at <a href="www.ti.com">www.ti.com</a>. Tip: Enter the literature number in the search box provided at <a href="www.ti.com">www.ti.com</a>. - SPRS372 TMS320DM647/DM648 Digital Media Processor Data Manual describes the signals, specifications and electrical characteristics of the device. - 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. - SPRUEK5 TMS320DM647/DM648 DSP DDR2 Memory Controller User's Guide describes the DDR2 memory controller in the TMS320DM647/DM648 Digital Signal Processor (DSP). The DDR2/mDDR memory controller is used to interface with JESD79D-2A standard compliant DDR2 SDRAM devices and standard Mobile DDR SDRAM devices. - SPRUEK6 TMS320DM647/DM648 DSP External Memory Interface (EMIF) User's Guide describes the operation of the asynchronous external memory interface (EMIF) in the TMS320DM647/DM648 Digital Signal Processor (DSP). The EMIF supports a glueless interface to a variety of external devices. - SPRUEK7 TMS320DM647/DM648 DSP General-Purpose Input/Output (GPIO) User's Guide describes the general-purpose input/output (GPIO) peripheral in the TMS320DM647/DM648 Digital Signal Processor (DSP). The GPIO peripheral provides dedicated general-purpose pins that can be configured as either inputs or outputs. When configured as an input, you can detect the state of the input by reading the state of an internal register. When configured as an output, you can write to an internal register to control the state driven on the output pin. - SPRUEK8 TMS320DM647/DM648 DSP Inter-Integrated Circuit (I2C) Module User's Guide describes the inter-integrated circuit (I2C) peripheral in the TMS320DM647/DM648 Digital Signal Processor (DSP). The I2C peripheral provides an interface between the DSP and other devices compliant with the I2C-bus specification and connected by way of an I2C-bus. External components attached to this 2-wire serial bus can transmit and receive up to 8-bit wide data to and from the DSP through the I2C peripheral. This document assumes the reader is familiar with the I2C-bus specification. - <u>SPRUELO</u> TMS320DM647/DM648 DSP 64-Bit Timer User's Guide describes the operation of the 64-bit timer in the TMS320DM647/DM648 Digital Signal Processor (DSP). The timer can be configured as a general-purpose 64-bit timer, dual general-purpose 32-bit timers, or a watchdog timer. - SPRUEL1 TMS320DM647/DM648 DSP Multichannel Audio Serial Port (McASP) User's Guide describes the multichannel audio serial port (McASP) in the TMS320DM647/DM648 Digital Signal Processor (DSP). The McASP functions as a general-purpose audio serial port optimized for the needs of multichannel audio applications. The McASP is useful for time-division multiplexed (TDM) stream, Inter-Integrated Sound (I2S) protocols, and intercomponent digital audio interface transmission (DIT). - SPRUEL2 TMS320DM647/DM648 DSP Enhanced DMA (EDMA) Controller User's Guide describes the operation of the enhanced direct memory access (EDMA3) controller in the TMS320DM647/DM648 Digital Signal Processor (DSP). The EDMA3 controller's primary purpose is to service user-programmed data transfers between two memory-mapped slave endpoints on the DSP. - SPRUEL4 TMS320DM647/DM648 Peripheral Component Interconnect (PCI) User's Guide describes the peripheral component interconnect (PCI) port in the TMS320DM647/DM648 Digital Signal Processor (DSP). The PCI port supports connection of the C642x DSP to a PCI host via the integrated PCI master/slave bus interface. The PCI port interfaces to the DSP via the enhanced DMA (EDMA) controller. This architecture allows for both PCI master and slave transactions, while keeping the EDMA channel resources available for other applications. - SPRUEL5 TMS320DM647/DM648 DSP Host Port Interface (UHPI) User's Guide describes the host port interface (HPI) in the TMS320DM647/DM648 Digital Signal Processor (DSP). The HPI is a parallel port through which a host processor can directly access the CPU memory space. The host device functions as a master to the interface, which increases ease of access. The host and CPU can exchange information via internal or external memory. The host also has direct access to memory-mapped peripherals. Connectivity to the CPU memory space is provided through the enhanced direct memory access (EDMA) controller. - SPRUEL8 TMS320DM647/DM648 DSP Universal Asynchronous Receiver/Transmitter (UART) User's Guide describes the universal asynchronous receiver/transmitter (UART) peripheral in the TMS320DM647/DM648 Digital Signal Processor (DSP). The UART peripheral performs serial-to-parallel conversion on data received from a peripheral device, and parallel-to-serial conversion on data received from the CPU. - SPRUEL9 TMS320DM647/DM648 DSP VLYNQ Port User's Guide describes the VLYNQ port in the TMS320DM647/DM648 Digital Signal Processor (DSP). The VLYNQ port is a high-speed point-to-point serial interface for connecting to host processors and other VLYNQ compatible devices. It is a full-duplex serial bus where transmit and receive operations occur separately and simultaneously without interference. - SPRUEM1 TMS320DM647/DM648 DSP Video Port/VCXO Interpolated Control (VIC) Port User's Guide discusses the video port and VCXO interpolated control (VIC) port in the TMS320DM647/DM648 Digital Signal Processor (DSP). The video port can operate as a video capture port, video display port, or transport stream interface (TSI) capture port. The VIC port provides single-bit interpolated VCXO control with resolution from 9 bits to up to 16 bits. When the video port is used in TSI mode, the VIC port is used to control the system clock, VCXO, for MPEG transport stream. SPRUEM2 — TMS320DM647/DM648 DSP Serial Port Interface (SPI) User's Guide discusses the Serial Port Interface (SPI) in the TMS320DM647/DM648 Digital Signal Processor (DSP). This reference guide provides the specifications for a 16-bit configurable, synchronous serial peripheral interface. The SPI is a programmable-length shift register, used for high speed communication between external peripherals or other DSPs. ### **Trademarks** VLYNQ is a trademark of Texas Instruments. ### VLYNQ Port ### Introduction ### 1.1 Purpose of the Peripheral The VLYNQ™ communications interface port is a serial interface with a low pin count, high-speed point-to-point serial interface in the device 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 device. 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 device 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. ### 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. - 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. 10 - · Symmetric Operation: - Tx pins on first device connect to Rx pins on second device and vice versa. - Data pin widths are automatically detected after reset (including connections to legacy VLYNQ devices). - 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. VLYNQ module Slave VLYNQ SCRUN config CPU/EDMA bus Interface VLYNQ register VLYNQ CLOCK access CPU/EDMA initiated VLYNQ\_TXD[3:0] transfers to remote device Master VLYNQ\_RXD[3:0] System config memory bus Off chip Interface (remote) device access **VLQINT GEMINTC** 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. ### 2 Peripheral Architecture This section discusses the architecture and basic functions of the VLYNQ peripheral. ### 2.1 Clock Control 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 12 ### 2.2 Signal Descriptions The VLYNQ module on the 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 clock. | | VLYNQ_SCRUN | VLYNQ serial clock<br>run request<br>(Active low) | I/O | The VLYNQ serial clock run request allows remote requests for the VLYNQ serial clock to be turned off for system power management. Low: The request VLYNQ serial clock is active. High: The VLYNQ serial clock is requested to be high when all transactions are complete. | | VLYNQ_RXD[0:3] | VLYNQ receive data | 1 | VLYNQ receive data is synchronous with the VLYNQ serial clock. | | VLYNQ_TXD[0:3] | VLYNQ transmit data | 0 | VLYNQ transmit data is synchronous with the VLYNQ serial clock. | ### 2.3 Pin Multiplexing 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. ### 2.4 Protocol Description 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 device. ### 2.5 VLYNQ Functional Description 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. 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. ### 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 device. ### 2.5.2 Read Operations 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 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 Note: Not servicing read operations results in deadlock. The only way to recover from a deadlock situation is to perform a hard reset. Read operations are typically not serviced due to read requests that are issued to a non-existent remote VLYNQ device or they are not serviced due to trying to perform reads on the VLYNQ memory map prior to establishing the link. Generally, you should not use read operations to transfer data packets since the serial nature of the interface could potentially result in longer latencies. ### 2.6 Initialization Since VLYNQ devices can be controlled solely over the serial interface (that is, no local CPU exists), an automatic reliable initialization sequence (without user configuration) establishes a connection between two VLYNQ devices, just after a VLYNQ module is enabled and auto-negotiation occurs. Auto-negotiation is defined in Section 2.7. The same sequence is used to recover from error conditions. Bit 0 in the VLYNQ status register (LINK bit) is set to 1 when a link is established. A link pulse timer generates a periodic link code every 2048 serial clock cycles. The link is lost when time expires and no link code has been detected during a period of 4096 serial clock cycles. ### 2.7 Auto Negotiation Auto-negotiation occurs after reset. It involves placing a negotiation protocol in the outbound data and processing the inbound data to establish connection information. The width of the data pins on the serial interface is automatically determined at reset as a part of the initialization sequence. For a connection between two VLYNQ devices of version 2.0 and later (VLYNQ on DM647/DM648 device is version 2.6), the negotiation protocol using the available serial pins is used to convey the maximum width capability of each device. The TXD data pins are not required to have the same width as the RXD data pins. The auto width negotiation does not occur until after completion of the VLYNQ 1.x legacy width configuration, which involves a period of 2000 VLYNQ 1.x system clock cycles for connection to VLYNQ 1.x devices. After the VLYNQ 1.x has determined its width, it receives the VLYNQ2.x auto width negotiation protocol. The VLYNQ 1.x device does not recognize this protocol and transmits error codes over the serial interface. The received error codes allow the VLYNQ 2.x devices to determine how many serial pins are valid on the connected VLYNQ 1.x device. Once the width is established, VLYNQ further identifies the version (version 1.x or version 2.x) of the remote VLYNQ. This better determines the capabilities of the connected VLYNQ device. This is software readable via the VLYNQ auto-negotiation register (AUTNGO), bit 16 (0 = Ver 1.x, 1 = Ver 2.x), after the link has been established. ### 2.8 Serial Interface Width Configuration The VLYNQWD bit in the pin multiplexing register 0 (PINMUX0) controls the data width on the device, thus allowing you to program the serial interface width (as shown in Table 2). VLYNQWD VLYNQ Data Width 00 VLYNQ TXD[0] , VLYNQ RXD[0] 01 VLYNQ TXD[0:1] , VLYNQ RXD[0:1] 11 VLYNQ TXD[0:2] , VLYNQ RXD[0:2] 10 VLYNQ TXD[0:3] , VLYNQ RXD[0:3] Table 2. Serial Interface Width For detailed information on the processor pin multiplexing and configuration register, see the pin multiplexing information in the device-specific data manual. ### 2.9 Address Translation Remote VLYNQ device(s) are memory mapped to the local (host) device's address space when a link is established (this is similar to any other on-chip peripherals). Enumerating the VLYNQ devices (single or multiple) into a coherent memory map for accessing each device is part of the initialization sequence. After the enumeration, the host (local) device can access the remote device address map using local device addresses. The VLYNQ module in the host device manages the address translation of the local address to the remote address. A remote VLYNQ device is mapped to the local device's address via the address map registers (TX address map, RX address map size n, RX address map offset n, where n = 1 to 4). The transmit side has a contiguous map; the size of the map is the same as the remote device map. Figure 7 illustrates this mapping. In the local device, the address of the VLYNQ remote memory map in the local configuration space is the transmit address accessing remote devices over the serial interface. The address of the VLYNQ remote memory map is programmed in the TX address map register (XAM). When the local device transmits, first it strips off the transmit address offset in the local device memory map. Then, the local device sends the data with an address offset from the transmit address. VLYNQ allows each receive packet address to be translated into one of four mapped regions. No restriction is placed on the size or on the offset of each mapped region, except that each must be aligned to 32-bit words. The transmitted address is used to determine which remote mapped region is being accessed at the remote device. This is achieved by summing each memory size sequentially until the memory size is larger than the transmitted address. The last memory size that is added is the targeted region. A memory size and an offset specify the remote map. The remote map is programmed in the RX address map size register (RAMSn) and in the RX address map offset (RAMOn) in the remote device. Figure 7. Example Address Memory Map The following section shows an example illustrating the address translation used in each VLYNQ module. Address bits [31:26] are not used for address translation to remote devices on the DM647/DM648 device. Table 3 illustrates address map register configuration when the DM647/DM648 device is transmitting data to the remote device. Table 3. Address Translation Example (Single Mapped Region) | Register | DM647/DM648 VLYNQ Module | Remote VLYNQ Module | |-------------------------|--------------------------|---------------------| | TX Address Map | 0000 : 0000h | Do not care | | RX Address Map Size 1 | Do not care | 0000 : 0100h | | RX Address Map Offset 1 | Do not care | 0800 : 0000h | ### DM647/DM648 VLYNQ Module: 3800 : 0054h Initial address at the slave configuration bus 0000: 0054h Initial address [25:0] at the slave configuration bus interface subtract 0000: 0000h TX address map register (there is no need to change the reset value of the DM647/DM648 device for this register) 0000:0054h ### Remote VLYNQ Module: 0000: 0054h Initial address from the RX serial interface compare 0000: 0100h RX address map size 1 register 0000:0054h add 0800: 0000h RX address map offset 1 register 0800: 0054h Translated address to remote device The local address 3800: 0054h (or 0000 0054h) was translated to 0800: 0054h on the remote VLYNQ device in Table 4. Table 4 illustrates the address map register configuration when the DM647/DM648 device is receiving data from the remote device. Table 4. Address Translation Example (Single Mapped Region) | Register | DM647/DM648 VLYNQ Module | Remote VLYNQ Module | |-------------------------|--------------------------|---------------------| | TX Address Map | Do not care | 0400 : 0000h | | RX Address Map Size 1 | 0000 : 0100h | Do not care | | RX Address Map Offset 1 | 0200 : 0000h | Do not care | | RX Address Map Size 2 | 0000 : 0100h | Do not care | | RX Address Map Offset 2 | 8200 : 0000h | Do not care | ### **Remote VLYNQ Module:** 0400 : 0154h Initial address at the slave configuration bus for the remote device subtract 0400:0000h TX address map register 0000: 0154h Translated address to remote device via serial interface ### DM647/DM648 VLYNQ Module: 0000:0154h Initial address from the RX serial interface compare 0000:0100h RX address map size 1 register 0000:0154h The RX packet address is greater than the value in the RX address map size 1 register compare 0000:0200h RX address map size 1 register + RX address map size 2 Since the RX packet address < the RX address map size 1 register + RX address map size 2 register add 8200:0000h RX address map offset 2 register subtract 0000:0100h RX address map size 1 register # Example 1. Address Translation Example 8200:0054h The remote address 0x 0400 : 0154 (or 0x0000 0054) was translated to 0x 8200 : 0054 on the DM647/DM648 (local) device in this example. Translated address to DM647/DM648 device The translated address for packets received on the serial interface is determined as follows: ``` If (RX Packet Address < RX Address Map Size 1 Register) { Translated Address = RX Packet Address + RX Address Map Offset 1 Register } else if (RX Packet Address < (RX Address Map Size 1 Register + RX Address Map Size 2 Register)) { Translated Address = RX Packet Address + RX Address Map Offset 2 Register - RX Address Map Size 1 Register } else if (RX Packet Address < (RX Address Map Size 1 Register + RX Address Map Size 2 Register + RX Address Map Size 3 Register)) { Translated Address = RX Packet Address + RX Address Map Offset 3 Register - RX Address Map Size 1 Register - RX Address Map Size 2 Register } else if (RX Packet Address < (RX Address Map Size 1 Register + RX Address Map Size 2 Register + RX Address Map Size 3 Register + RX Address Map Size 4 Register)) { Translated Address = RX Packet Address + RX Address Map Offset 4 Register - RX Address Map Size 1 Register - RX Address Map Size 2 Register - RX Address Map Size 3 Register } else { Translated Address = 0x0 ``` 20 ### 2.10 Flow Control The VLYNQ module includes flow control features. The VLYNQ module automatically generates flow control enable requests, /P/, when the RX/inbound FIFOs (FIFO1 and FIFO2) resources are consumed. The FIFOs can take up to 16 32-bit words. The remote device will begin transmitting idles, /l/, starting on the first byte boundary following reception of the request. When sufficient RX FIFO resources have been made available, a flow control disable request, /C/, is transmitted to the remote device. In response, the remote device will resume transmission of data. See Appendix A. ### 2.11 Reset Considerations ### 2.11.1 **Software Reset Considerations** Peripheral clock and reset control is done through the power and sleep controller (PSC) module that is included with the device. For more information, refer to the power management section (Section 2.14). Additionally, there is a software reset (the reset bit in the VLYNQ control register, CTRL) within the peripheral itself. Writing a 1 to the reset bit resets all of the internal state machines of the VLYNQ module, the serial interface is disabled, and the link is lost. The VLYNQ module remains in reset until the software clears the bit. Note: When setting the reset bit, the VLYNQ status register (STAT) value is the only value that is set to the default value. All of the other VLYNQ memory-mapped registers retain their values prior to the software reset. ### 2.11.2 **Hardware Reset Considerations** When a hardware reset occurs, the VLYNQ peripheral resets its register values to the default values and the serial interface is disabled. After a hardware reset, the VLYNQ memory mapped registers and any chip-level registers that are associated with VLYNQ (for example, pin multiplexing registers) must be configured appropriately before data transmission can resume. ### **CAUTION** Be cautious when only resetting one of the VLYNQ devices after two or more VLYNQ devices have established a link. If only one of the VLYNQ devices is in reset, then no data activity can occur across the serial interface during the time of reset. ### 2.12 Interrupt Support ### 2.12.1 **Interrupt Events and Requests** The VLYNQ module interrupt VLQINT is mapped to the GEMINTC. Interrupts generate when bits are set in the VLYNQ interrupt pending/set register (INTPENDSET). Bits are set in the INTPENDSET register when any of the following occur: - Writing directly to the INTPENDSET - Remote interrupt (via the serial interrupt packet) - Serial bus error When the VLYNQ interrupt pending/set register (INTPENDSET) is a non-zero value, the method of forwarding the interrupt status depends on the state of the INTLOCAL bit in the VLYNQ control register (CTRL). - When INTLOCAL = 0, the contents of INTPENDSET are inserted into an interrupt packet and sent over the serial interface. When packet transmission completes, the associated bits clear in INTPENDSET. - When INTLOCAL = 1, bits in INTPENDSET transfer to the VLYNQ interrupt status/clear register (INTSTATCLR). The logical-OR of all of the bits in INTSTATCLR is driven onto the interrupt line, causing the VLYNQINT to pulse. If the system writes to INTSTATCLR while interrupts are still pending, a new VLQINT interrupt is generated. The VLYNQ interrupt generation mechanism is shown in Figure 8. Figure 8. Interrupt Generation Mechanism Block Diagram For additional flexibility of interrupt handling, there is an interrupt priority vector status/clear register (INTPRI) that reports the highest priority interrupt asserted in the VLYNQ interrupt pending/set register (INTPENDSET) when INTLOCAL = 1. VLYNQ interprets bit 0 as the highest priority and it interprets bit 31 as the lowest priority. The value that is returned when read is the vector of the highest priority interrupt. Software can clear that interrupt by writing back the vector value. Additionally, INTRPRI provides a read-only status bit (NOINTPEND) to indicate whether or not there are any pending interrupts in the interrupt status/clear register (INTSTATCLR). ### 2.12.2 Writes to Interrupt Pending/Set Register As previously discussed, if the GEM CPU writes to the VLYNQ interrupt pending/set register (INTPENDSET), then depending on the value of the INTLOCAL bit in the VLYNQ control (CTRL) register, this will result in a local interrupt (to the device interrupt controller) or an interrupt packet transmitted over the serial interface to the remote device. ### 2.12.3 Remote Interrupts Remote interrupts occur when an interrupt packet is received over the serial interface from a remote device. The interrupt status is extracted from the packet and written to a location pointed to by the interrupt pointer register (INTPTR). The INTPTR should contain the address of the interrupt pending/set register (INTPENDSET). To get INTPTR to contain the address of INTPENDSET, program INTPTR with a value of 14h (the offset for INTPENDSET). Additionally, the INT2CFG bit in the VLYNQ control register (CTRL) must be set to 1, dictating that the VLYNQ writes to a local register space (in this case, INTPENDSET). Once an interrupt packet is received over the serial interface, the interrupt status is extracted and written to INTPENDSET. After the interrupt status is extracted and written to INTPENDSET, the interrupt generation occurs as previously described in Section 2.12.2. The following summarizes the steps that are required to ensure that the device receives the remote interrupts: - Program the VLYNQ interrupt pointer register (INTRPTR) with a value of 14h, which is the offset address of the VLYNQ interrupt/pending set register (INTPENDSET). - Set the INT2CFG bit to 1 in the VLYNQ control register (CTRL). ### 2.12.4 Serial Bus Error Interrupts Due to erroneous transmit packets that are detected by remote devices (remote error) or errors in the inbound packets (local error), the serial bus errors result in the setting of the RERROR or LERROR bits in the VLYNQ status register (STAT). Additionally, if the INTENABLE bit is set in the VLYNQ control register (CTRL), setting the RERROR or LERROR bits cause these status interrupts to post to the interrupt pending/set register (INTPENDSET), causing the VLYNQINT to be asserted to the GEM CPU. To ensure that serial bus errors result in interrupts to notify the application software, you must perform the following steps: - 1. Set the INTENABLE bit to 1 in the VLYNQ control register (CTRL). - 2. Set the INTVEC bits in CTRL to point to a free bit in the VLYNQ interrupt pending/set register (INTPENDSET). The serial bus error should result in setting the bits in INTPENDSET that are not used by the application software for other interrupts (bit locations written directly in INTPENDSET or via remote interrupts). - 3. During VLYNQ initialization, the RERROR bit is set after the VLYNQ module achieves a link. When the link bit is set in the VLYNQ status register (STAT), write a 1 to the RERROR bit. Writing a 1 to the RERROR bit clears the RERROR bit and prevents the software interrupt handler from seeing the first RERROR as a legitimate serial bus error interrupt. ### 2.13 DMA Event Support The VLYNQ module on the device is classified as a master peripheral. Classification as a master peripheral normally implies that the peripheral is able to sustain its own transfers without relying on any external peripherals (for example, the system DMA, etc). However, the VLYNQ module does not have an internal DMA (as some other master peripherals). Therefore, it is likely that the VLYNQ module can rely on the on-chip enhanced DMA (EDMA3) controller for performing burst transfer. The EDMA3 can still be used to perform burst transfers out to remote VLYNQ memory map (writes). This use model provides better throughput with less overhead. **Note:** There is no VLYNQ event that allows hardware synchronization to occur with the EDMA3 controller on the device. The VLYNQ module uses a 16-word deep FIFO to buffer the burst writes. Since the EDMA3 controller is much faster compared to the serial VLYNQ interface, a data back-up can occur. Therefore, configuring EDMA3 for optimal transfer size, etc. is essential. ### 2.14 Power Management The VLYNQ module can be placed in reduced-power modes to conserve power during periods of low activity. The power management of the peripheral is controlled by the processor Power and Sleep Controller (PSC). The PSC acts as a master controller for power management of all of the peripherals on the processor. The power conservation modes that are available via the PSC are: - Idle/Disabled state: Idle/disabled state stops the clocks from going to the peripheral and prevents all of the register accesses. After re-enabling the peripheral from its idle state, all registers prior to setting in the disabled state are restored and data transmission proceeds. Re-initialization is not required. - Synchronized reset: The synchronized reset state is similar to the power-on reset (POR) state. When the processor is turned on, reset to the peripheral is asserted, then clocks to the peripheral are gated. Registers reset to their default values. When powering-up after a synchronized reset, all of the VLYNQ module registers must be reconfigured and the link must be re-established before data transmission. For more detailed information on power management procedures using the PSC, see the TMS320DM647/DM648 DSP Subsystem Reference Guide (SPRUE06). If the serial clock is internally sourced, you can use the CLKDIV bit in the VLYNQ control register (CTRL) to divide the serial clock down. This saves normal mode operation power consumption (at the expense of reduced performance). Additionally, the module provides the capability of auto-idling the serial clock domain (disable the VLYNQ CLK) when the serial clock is sourced from the DM647/DM648 device and the VLYNQ SCRUN pin is connected to the remote device. This allows power savings when there is no activity on the serial interface. Note: There is no support for external wake-up for the VLYNQ module on the DM647/DM648 device. If the VLYNQ module on the DM647/DM648 device has been disabled via the PSC, then even though serial activity requests can be indicated from the remote VLYNQ device via the VLYNQ SCRUN pin, it does not allow the serial clock (VLYNQ CLK) to be sourced until the VLYNQ module is re-enabled via the PSC. This can be configured by enabling the power management enable (PMEN) bit in the VLYNQ control registers (CTRL, 0 = disable, 1 = enable). This bit should only be set if the SCRUN pin is connected to the remote VLYNQ device. The SCRUN pin is a bi-directional pin which is driven low whenever there is serial activity on the local or remote VLYNQ interface. ### 2.15 Emulation Considerations During debug, the GEM CPU may be halted for single stepping, bench marking, profiling, or other debug uses using the emulator. VLYNQ does not support emulation halts/suspend operation. VLYNQ operations continue during emulation halt/suspend. 24 ### 3 VLYNQ Port Registers Table 5 describes the address space for the VLYNQ registers and memory. ### Table 5. VLYNQ Register Address Space | Block Name | Start Address | End Address | Size | |-------------------------|---------------|-------------|-----------------| | VLYNQ Control Registers | 3800 0000h | 3800 01FFh | 512 bytes | | VLYNQ Remote Memory Map | 3800 0200h | 38FF FFFFh | 64M - 512 bytes | Table 6 lists the memory-mapped registers for the VLYNQ port controller. See the device-specific data manual for the memory address of these registers. The first 128 bytes map to the VLYNQ configuration registers that are maintained by the local (device) VLYNQ register control module while the second 128 bytes map to the remote configuration registers that are physically located in the remote device linked by the VLYNQ serial interface. Any access to the second set of registers causes VLYNQ to issue a read or write VLYNQ packet to be transmitted and only completes if a link is established between the two devices. **Table 6. VLYNQ Port Controller Registers** | Offset | Acronym | Register Description | Section | |--------|------------|-------------------------------------------------|--------------| | 0h | REVID | Revision Register | Section 3.1 | | 4h | CTRL | Control Register | Section 3.2 | | 8h | STAT | Status Register | Section 3.3 | | Ch | INTPRI | Interrupt Priority Vector Status/Clear Register | Section 3.4 | | 10h | INTSTATCLR | Interrupt Status/Clear Register | Section 3.5 | | 14h | INTPENDSET | Interrupt Pending/Set Register | Section 3.6 | | 18h | INTPTR | Interrupt Pointer Register | Section 3.7 | | 1Ch | XAM | Transmit Address Map Register | Section 3.8 | | 20h | RAMS1 | Receive Address Map Size 1 Register | Section 3.9 | | 24h | RAMO1 | Receive Address Map Offset 1 Register | Section 3.10 | | 28h | RAMS2 | Receive Address Map Size 2 Register | Section 3.11 | | 2Ch | RAMO2 | Receive Address Map Offset 2 Register | Section 3.12 | | 30h | RAMS3 | Receive Address Map Size 3 Register | Section 3.13 | | 34h | RAMO3 | Receive Address Map Offset 3 Register | Section 3.14 | | 38h | RAMS4 | Receive Address Map Size 4 Register | Section 3.15 | | 3Ch | RAMO4 | Receive Address Map Offset 4 Register | Section 3.16 | | 40h | CHIPVER | Chip Version Register | Section 3.17 | | 44h | AUTNGO | Auto Negotiation Register | Section 3.18 | | 48h | MANNGO | Manual Negotiation Register | Section 3.19 | | 4Ch | NGOSTAT | Negotiation Status Register | Section 3.20 | | 60h | INTVEC0 | Interrupt Vector 3-0 | Section 3.21 | | 64h | INTVEC1 | Interrupt Vector 7-4 | Section 3.22 | ### 3.1 Revision Register (REVID) The revision register (REVID) contains the major and minor revisions for the VLYNQ module. The REVID is shown in Figure 9 and described in Table 7. Figure 9. Revision Register (REVID) LEGEND: R = Read only; -n = value after reset ### Table 7. Revision Register (REVID) Field Descriptions | Bit | Field | Value | Description | | | | |-------|--------|-------|-------------------------|--|--|--| | 31-16 | ID | 01h | Unique module ID. | | | | | 15-8 | REVMAJ | 0-FFh | jor revision. | | | | | | | 2h | Current major revision. | | | | | 7-0 | REVMIN | 0-FFh | nor revision. | | | | | | | 6h | Current minor revision. | | | | 26 ## 3.2 Control Register (CTRL) The control register (CTRL) determines operation of the VLYNQ module. The CTRL is shown in Figure 10 and described in Table 8. ### Figure 10. Control Register (CTRL) | 31 | 30 | 29 27 | 26 | 24 | 23 | 3 | | 22 | | 21 | 20 | 19 | 18 | 16 | |--------|-----------|----------|-----|----------|--------|-------|-----|----------|------|---------|-------|-----|-------|--------| | PMEN | SCLKPUDIS | Reserved | RXS | AMPELVAL | RTMVAI | IDWR | RTN | //ENABLE | TXFA | STPATH | Reser | ved | CL | .KDIV | | R/W- 0 | R/W- 0 | R-0 | F | R/W- 3h | R/W | - 0 | F | R/W- 0 | R | /W- 0 | R- | ) | R | /W- 0 | | 15 | 14 | 13 | 12 | | 8 | 7 | | 6 | 3 | 2 | | | 1 | 0 | | CLKDIR | INTLOCAL | INTENABL | .E | INTVEC | | INT2C | FG | Reserv | ed | AOPTDIS | SABLE | IL | .00P | RESET | | R/W- 0 | R/W- 0 | R/W- 0 | | R/W-0 | | R/W | -0 | R-0 | | R/W | - 0 | R | /W- 0 | R/W- 0 | LEGEND: R/W = Read/Write; R = Read only; -n = value after reset # Table 8. Control Register (CTRL) Field Descriptions | Bit | Field | Value | Description | |-------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | PMEN | | Power management enable. | | | | 0 | VLYNQ CLK is always active if it is set as an output (assuming that VLYNQ module is enabled). | | | | | If set as an output, VLYNQ CLK becomes inactive when there is no traffic over the serial bus. | | | | 1 | The PMEN bit should only be set to 1 when the SCRUN is connected to the remote/external VLYNQ device. | | 30 | SCLKPUDIS | 0 | Serial clock pull-up disable. Always write 0. | | 29-27 | Reserved | 0 | Reserved. | | 26-24 | RXSAMPELVAL | 0-7h | RTM sample value. If the RTMENABLE bit is 0, the receive timing manager forces the value in the RXSAMPELVAL bit as the clock sample value. If the RTMENABLE bit is 1, then the value set by the RXSAMPELVAL bit is ignored. In order to modify the value, you must simultaneously write a 1 to the RTMVALIDWR bit. | | 23 | RTMVALIDWR | | RTM valid write bit. | | | | 0 | Will not allow writes to RXSAMPLEVAL bits. | | | | 1 | Will allow writes to RXSAMPLEVAL bits. | | 22 | RTMENABLE | | RTM enable bit. | | | | 0 | The receive timing manager uses the value set in the RXSAMPLEVAL bit as the clock sample value. | | | | 1 | The receive timing manager is enabled. It automatically selects the receive clock. | | 21 | TXFASTPATH | 0-1 | Transmit fast path. When set, the fastest path is chosen for the serial data. | | 20-19 | Reserved | 0 | Reserved. | | 18-16 | CLKDIV | 0-7h | Serial clock output divider. | | 15 | CLKDIR | | Serial CLK direction. Determines whether the VLYNQ CLK is an input or an output. | | | | 0 | The VLYNQ CLK is externally sourced. | | | | 1 | The VLYNQ CLK is internally sourced and equal to the VLYNQ module system clock divided by the divider value set in the CLKDIV bit. | | 14 | INTLOCAL | | Interrupt local. | | | | 0 | Interrupt is posted in the interrupt status/clear register and results in the assertion of the VLQINT to the device interrupt controllers. | | | | 1 | The interrupt is forwarded to the remote VLYNQ device over the serial interface as an interrupt packet. | | 13 | INTENABLE | | Interrupt enable. | | | | 0 | VLYNQ module status interrupts are ignored. | | | | 1 | VLYNQ module status interrupts (if RERROR or LERROR bits are set) are posted to the interrupt pending/set register. | | 12-8 | INTVEC | 0-1Fh | Interrupt vector. This bit indicates which bit in the interrupt pending/set register is set for VLYNQ module status (RERROR/LERROR) interrupts. | ## Table 8. Control Register (CTRL) Field Descriptions (continued) | Bit | Field | Value | Description | |-----|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | INT2CFG | | Interrupt to configuration register. Determines which register is written with the status contained in interrupt packets that are received over the serial interface. Always write 1 to this bit and configure the interrupt pointer register to point to the interrupt pending/set register. | | | | 0 | Bits[31:2] of the interrupt pointer register are used to point to a system interrupt register. | | | | 1 | The least significant 8 bits of the interrupt pointer register are used to point to a VLYNQ module local register (typically the interrupt pending/set register). | | 6-3 | Reserved | 0 | Reserved. | | 2 | AOPTDISABLE | | Address optimization disable. | | | | 0 | Address optimization is enabled, eliminating unnecessary address bytes. | | | | 1 | Address optimization is disabled. | | 1 | ILOOP | | Internal loop back. | | | | 0 | Normal operation. | | | | 1 | Serial transmit data is wrapped back to the serial receive data. | | 0 | RESET | | Software reset. It does not reset the VLYNQ MMR registers (except for the VLYNQ status register). You have to reprogram the VLYNQ MMRs if they must have a different value after a software reset. | | | | 0 | Normal operation. | | | | 1 | All internal state machines are reset, the serial interface is disabled, and the link is lost. | ### 3.3 Status Register (STAT) The status register (STAT) is used to detect conditions that may be of interest to the system designer. The STAT is shown in Figure 11 and described in Table 9. Figure 11. Status Register (STAT) | 31 | 28 | 27 | 24 | 23 | 20 | 19 | 16 | |----------|----------|-------------|----------|----------|-------|-------|--------| | Res | erved | SWIE | THIN | SWIDT | HOUT | Rese | erved | | F | R-0 | R | -0 | R | -0 | R | -0 | | 15 | 14 | | 12 | 11 | 10 | 9 | 8 | | Reserved | R) | CURRENTSAMF | LE | RTM | IFLOW | OFLOW | RERROR | | R-0 | R-0 | | | R-1 | R-0 | R-0 | W1C-0 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LERROR | NFEMPTY3 | NFEMPTY2 | NFEMPTY1 | NFEMPTY0 | SPEND | MPEND | LINK | | W1C-0 | R-0 LEGEND: R/W = Read/Write; R = Read only; W1C = Write 1 to clear bit; -n = value after reset; x= reset value is indeterminate Table 9. Status Register (STAT) Field Descriptions | Bit | Field | Value | Description | |-------|-----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-28 | Reserved | 0 | Reserved. | | 27-24 | SWIDTHIN | 0-Fh | Size of the inbound serial data. Indicates the number of receive pins that are being used to establish the serial interface. | | | | 0 | No pins used. | | | | 1h | 1 RX pin used. | | | | 2h | 2 RX pins used. | | | | 3h | 3 RX pins used. | | | | 4h | 4 RX pins used. | | | | 5h-Fh | Reserved. | | 23-20 | SWIDTHOUT | 0-Fh | Size of the outbound serial data. Indicates the number of transmit pins that are being used to establish the serial interface. | | | | 0 | No pins used. | | | | 1h | 1 TX pin used. | | | | 2h | 2 TX pins used. | | | | 3h | 3 TX pins used. | | | | 4h | 4 TX pins used. | | | | 5h-Fh | Reserved. | | 19-15 | Reserved | 0 | Reserved. | | 14-12 | RXCURRENTSAMPLE | 0-Fh | Current RTM sample. Indicates the current clock sample value used by RTM. | | 11 | RTM | 1 | RTM enable. Always read as 1. Indicates that the VLYNQ module on the DM647/DM648 DMSoC has the receive timing manager (RTM). | | 10 | IFLOW | | Inbound flow control. | | | | 0 | Free to transmit. | | | | 1 | Indicates that a flow control enable request has been received and has stalled transmit until a flow control disable request is received. | | 9 | OFLOW | | Outbound flow control. Indicates the status of the two inbound FIFOs (FIFO1 or FIFO2). | | | | 0 | Indicates that the internal flow control threshold is not yet reached. | | | | 1 | Indicates that the internal flow control threshold has been reached (FIFO1 or FIFO2 is full) and a flow control enable request has been sent to the remote device. | ## Table 9. Status Register (STAT) Field Descriptions (continued) | Bit | Field | Value | Description | |-----|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 | RERROR | | Remote Error. Write a 1 to this bit to clear it. | | | | 0 | No error. | | | | 1 | This bit indicates that a downstream VLYNQ module has detected a packet error. This bit is set when an error indication, /E/, is received from the serial interface. See Appendix A. | | | | | If this bit is set, and the INTENABLE (bit 13 in VLYNQ control register) is also set, it asserts the VLYNQ interrupt (VLQINT). | | 7 | LERROR | | Local error. Write a 1 to this bit to clear it. | | | | 0 | No error. | | | | 1 | This bit indicates that an inbound packet contains an error that is detected by the local VLYNQ module. | | | | | If this bit is set, and the INTENABLE (bit 13 in VLYNQ control register) is also set, it asserts the VLYNQ interrupt (VLQINT). | | 6 | NFEMPTY3 | | FIFO 3 is not empty. | | | | 0 | Indicates that the slave command FIFO is empty. | | | | 1 | Indicates that the slave command FIFO is not empty. | | 5 | NFEMPTY2 | | FIFO 2 is not empty. | | | | 0 | Indicates that the slave data FIFO is empty. | | | | 1 | Indicates that the slave data FIFO is not empty. | | 4 | NFEMPTY1 | | FIFO 1 is not empty. | | | | 0 | Indicates that the master command FIFO is empty. | | | | 1 | Indicates that the master command FIFO is not empty. | | 3 | NFEMPTY0 | | FIFO 0 is not empty. | | | | 0 | Indicates that the master data FIFO is empty. | | | | 1 | Indicates that the master data FIFO is not empty. | | 2 | SPEND | | Pending slave request. | | | | 0 | No pending slave requests. | | | | 1 | Indicates detection of a transfer request initiated by the VLYNQ module to the off-chip peripheral (TX slave configuration bus interface). | | 1 | MPEND | | Pending master requests. | | | | 0 | No pending master requests. | | | | 1 | Indicates detection of a transfer request initiated by an off-chip peripheral to the VLYNQ module (RX master configuration bus interface). | | 0 | LINK | | Link. | | | | 0 | Indicates that the serial interface initialization sequence has not yet completed or the link has timed out. | | | | 1 | Indicates that the serial interface initialization sequence has completed successfully. | ### 3.4 Interrupt Priority Vector Status/Clear Register (INTPRI) The interrupt priority vector status/clear register (INTPRI) displays the highest priority vector with a pending interrupt when read. When writing, only bits [4:0] are valid, and the value represents the vector of the interrupt to be cleared. The INTPRI is shown in Figure 12 and described in Table 10. Figure 12. Interrupt Priority Vector Status/Clear Register (INTPRI) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 10. Interrupt Priority Vector Status/Clear Register (INTPRI) Field Descriptions | Bit | Field | Value | Description | | |------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31 | NOINTPEND | | Interrupt pending status. | | | | | 0 | dicates there is a pending interrupt. | | | | | 1 | Indicates that there are no pending interrupts from the interrupt status/clear register. | | | 30-5 | Reserved | 0 | Reserved. Always read as 0. Writes have no effect. | | | 4-0 | INSTAT | 0-1Fh | When read, this field displays the vector that is mapped to the highest priority interrupt bit that is pending from the interrupt status/clear register, with bit 0 as the highest priority, and bit 31 as the lowest. Writing the vector value back to this field clears the interrupt. | | ### 3.5 Interrupt Status/Clear Register (INTSTATCLR) The interrupt status/clear register (INTSTATCLR) indicates the unmasked interrupt status. The INTSTATCLR is shown in Figure 13 and described in Table 11. Figure 13. Interrupt Status/Clear Register (INTSTATCLR) LEGEND: R/W = Read/Write; -n = value after reset ### Table 11. Interrupt Status/Clear Register (INTSTATCLR) Field Descriptions | Bit | Field | Value | Description | |------|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | INTCLR | 0-FFFF FFFFh | This field indicates the unmasked status of each interrupt. Writing a 1 to any set bit in this field clears the corresponding interrupt. If there is a bit set in this register and if the INTLOCAL bit in the control register (CTRL) is also set, the VLYNQ interrupt (VLQINT) is asserted. | ### 3.6 Interrupt Pending/Set Register (INTPENDSET) The interrupt pending/set register (INTPENDSET) indicates the pending interrupt status when the INTLOCAL bit in the control register (CTRL) is not set. When the interrupt packet is forwarded on the serial interface, these bits are cleared. The INTPENDSET is shown in Figure 14 and described in Table 12. Figure 14. Interrupt Pending/Set Register (INTPENDSET) LEGEND: R/W = Read/Write: -n = value after reset ### Table 12. Interrupt Pending/Set Register (INTPENDSET) Field Descriptions | Bit | Field | Value | Description | |------|--------|--------------|----------------------------------------------------------------------------| | 31-0 | INTSET | 0-FFFF FFFFh | This field indicates the unmasked status of each pending interrupt. | | | | 0 | Writing a 0 has no effect. | | | | 1 | Writing a 1 to any bit: | | | | | if INTLOCAL = 0 in CTRL, interrupt packet is sent on the serial interface. | | | | | If INTLOCAL = 1 in CTRL, VLYNQ module interrupt (VLQINT) is asserted. | ### 3.7 Interrupt Pointer Register (INTPTR) The interrupt pointer register (INTPTR) typically contains the address of the interrupt pending/set register (INTPENDSET) within the VLYNQ module. To program INTPTR to point to INTPENDSET, program a value of 14h (the offset of INTPENDSET). Additionally, the INT2CFG bit in the control register (CTRL) should be set to 1. The INTPTR is shown in Figure 15 and described in Table 13. Figure 15. Interrupt Pointer Register (INTPTR) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 13. Interrupt Pointer Register (INTPTR) Field Descriptions | Bit | Field | Value | Description | |------|----------|--------------|--------------------------------------------------------------------------------------------------------| | 31-2 | INTPTR | 0-3FFF FFFFh | Interrupt pointer. Program this register with the address of the interrupt pending/set register (14h). | | 1-0 | Reserved | 0 | Reserved. | ### 3.8 Transmit Address Map Register (XAM) The transmit address map register (XAM) is used to translate transmit packet addresses to remote device configuration bus addresses. The XAM is shown in Figure 16 and described in Table 14. Figure 16. Transmit Address Map Register (XAM) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 14. Address Map Register (XAM) Field Descriptions | Bit | Field | Value | Description | |------|----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | TXADRMAP | 0-3FFF FFFFh | This field is subtracted from the slave configuration bus address [25:0] to obtain the zero relative transmit packet address. This field should be programmed with a value of 0 (reset value). | | 1-0 | Reserved | 0 | Reserved. | ### 3.9 Receive Address Map Size 1 Register (RAMS1) The receive address map size 1 register (RAMS1) is used to identify the intended destination of inbound serial packets. The RAMS1 is shown in Figure 17 and described in Table 15. Figure 17. Receive Address Map Size 1 Register (RAMS1) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 15. Receive Address Map Size 1 Register (RAMS1) Field Descriptions | Bit | Field | Value | Description | |------|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADRSIZE1 | 0-3FFF FFFFh | The RXADRSIZE1 field is used to determine if receive packets are destined for the first of four mapped address regions. RXADRSIZE1 is compared with the address contained in the receive packet. If the received packet address is less than the value in RXADRSIZE1, the packet address is added to the receive address map offset 1 register (RAMO1) to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ### 3.10 Receive Address Map Offset 1 Register (RAMO1) The receive address map offset 1 register (RAMO1) is used with the receive address map size 1 register (RAMS1) to translate receive packet addresses to local device configuration bus addresses. The RAMO1 is shown in Figure 18 and described in Table 16. ### Figure 18. Receive Address Map Offset 1 Register (RAMO1) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 16. Receive Address Map Offset 1 Register (RAMO1) Field Descriptions | Bit | Field | Value | Description | |------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADROFFSET1 | 0-3FFF FFFFh | The RXADROFFSET1 field is used with the receive address map size 1 register (RAMS1) to determine the translated address for serial data. If the received packet address is less than the value in RAMS1, the packet address is added to the contents of this register to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ### 3.11 Receive Address Map Size 2 Register (RAMS2) The receive address map size 2 register (RAMS2) is used to identify the intended destination of inbound serial packets. The RAMS2 is shown in Figure 19 and described in Table 17. Figure 19. Receive Address Map Size 2 Register (RAMS2) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 17. Receive Address Map Size 2 Register (RAMS2) Field Descriptions | Bit | Field | Value | Description | |------|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADRSIZE2 | 0-3FFF FFFFh | The RXADRSIZE2 field is used to determine if receive packets are destined for the second of four mapped address regions. RXADRSIZE2 is compared with the address contained in the receive packet. If the received packet address is less than the value in RXADRSIZE2, the packet address is added to the receive address map offset 2 register (RAMO2) to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ### 3.12 Receive Address Map Offset 2 Register (RAMO2) The receive address map offset 2 register (RAMO2) is used with the receive address map size 2 register (RAMS2) to translate receive packet addresses to local device configuration bus addresses. The RAMO2 is shown in Figure 20 and described in Table 18. ### Figure 20. Receive Address Map Offset 2 Register (RAMO2) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 18. Receive Address Map Offset 2 Register (RAMO2) Field Descriptions | Bit | Field | Value | Description | |------|--------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADROFFSET2 | 0-3FFF FFFFh | The RXADROFFSET2 field is used with the receive address map size 2 register (RAMS2) to determine the translated address for serial data. If the received packet address is less than the value in RAMS2, the packet address is added to the contents of this register to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ### 3.13 Receive Address Map Size 3 Register (RAMS3) The receive address map size 3 register (RAMS3) is used to identify the intended destination of inbound serial packets. The RAMS3 is shown in Figure 21 and described in Table 19. Figure 21. Receive Address Map Size 3 Register (RAMS3) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 19. Receive Address Map Size 3 Register (RAMS3) Field Descriptions | Bit | Field | Value | Description | |------|------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADRSIZE3 | 0-3FFF FFFFh | The RXADRSIZE3 field is used to determine if receive packets are destined for the third of four mapped address regions. RXADRSIZE3 is compared with the address contained in the receive packet. If the receive packet address is less than the value in RXADRSIZE3, the packet address is added to the receive address map offset 3 register (RAMO3) to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ### 3.14 Receive Address Map Offset 3 Register (RAMO3) The receive address map offset 3 register (RAMO3) is used with the receive address map size 3 register (RAMS3) to translate receive packet addresses to local device configuration bus addresses. The RAMO3 is shown in Figure 22 and described in Table 20. ### Figure 22. Receive Address Map Offset 3 Register (RAMO3) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 20. Receive Address Map Offset 3 Register (RAMO3) Field Descriptions | Bit | Field | Value | Description | |------|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADROFFSET3 | 0-3FFF FFFFh | The RXADROFFSET3 field is used with the receive address map size 3 register (RAMS3) to determine the translated address for serial data. If the receive packet address is less than the value in RAMS3, the packet address is added to the contents of this register to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ## 3.15 Receive Address Map Size 4 Register (RAMS4) The receive address map size 4 register (RAMS4) is used to identify the intended destination of inbound serial packets. The RAMS4 is shown in Figure 23 and described in Table 21. Figure 23. Receive Address Map Size 4 Register (RAMS4) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ## Table 21. Receive Address Map Size 4 Register (RAMS4) Field Descriptions | Bit | Field | Value | Description | |------|------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADRSIZE4 | 0-3FFF FFFFh | The RXADRSIZE4 field is used to determine if receive packets are destined for the fourth of four mapped address regions. RXADRSIZE4 is compared with the address contained in the receive packet. If the receive packet address is less than the value in RXADRSIZE4, the packet address is added to the receive address map offset 4 register (RAMO4) to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ## 3.16 Receive Address Map Offset 4 Register (RAMO4) The receive address map offset 4 register (RAMO4) is used with the receive address map size 4 register (RAMS4) to translate receive packet addresses to local device configuration bus addresses. The RAMS4 is shown in Figure 24 and described in Table 22. Figure 24. Receive Address Map Offset 4 Register (RAMO4) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ### Table 22. Receive Address Map Offset 4 Register (RAMO4) Field Descriptions | Bit | Field | Value | Description | |------|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-2 | RXADROFFSET4 | 0-3FFF FFFFh | The RXADROFFSET4 field is used with the receive address map size 4 register (RAMS4) to determine the translated address for serial data. If the receive packet address is less than the value in RAMS4, the packet address is added to the contents of this register to obtain the translated address. | | 1-0 | Reserved | 0 | Reserved. | ## 3.17 Chip Version Register (CHIPVER) Each chip that has a VLYNQ module on it has a unique device ID associated with it, which is software readable via the chip version register (CHIPVER). The CHIPVER is shown in Figure 25 and described in Table 23. Figure 25. Chip Version Register (CHIPVER) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ## Table 23. Chip Version Register (CHIPVER) Field Descriptions | Bit | Field | Value | Description | |-------|--------|---------|-----------------------------------------------------------------------------| | 31-16 | DEVREV | 0-FFFFh | Device revision. This field reflects the value of the device revision pins. | | 15-0 | DEVID | 0-FFFFh | Device ID. See the device-specific data manual for this value. | ## 3.18 Auto Negotiation Register (AUTNGO) The auto negotiation register (AUTNGO) reflects the ability of the VLYNQ module residing in the device to communicate with the remote VLYNQ device on their respective abilities after reset. The AUTNGO is shown in Figure 26 and described in Table 24. Figure 26. Auto Negotiation Register (AUTNGO) LEGEND: R/W = Read/Write; R = Read only; -n = value after reset #### Table 24. Auto Negotiation Register (AUTNGO) Field Descriptions | Bit | Field | Value | Description | |-------|----------|-------|-------------------------------------------------------------------------------------------------------| | 31-17 | Reserved | 0 | Reserved. Always read as 0. Writes have no effect. | | 16 | 2X | | Version 2.x mode. | | | | 0 | Indicates that a link was established with a remote device that has a version 1.x VLYNQ module in it. | | | | 1 | Indicates that a link was established with a remote device that has a version 2.x VLYNQ module in it. | | 15-0 | Reserved | 0 | Reserved. Always read as 0. Writes have no effect. | ## 3.19 Manual Negotiation Register (MANNGO) The Manual Negotiation register (MANNGO) is used by the software when Bit 31 of the Auto Negotiation Register indicates that VLYNQ is not able to communicte with the remote VLYNQ on their respective abilities after reset. The MANNGO is shown in Figure 27 and described in Table 25 ## Figure 27. Manual Negotiation Register (MANNGO) LEGEND: R/W = Read/Write; -n = value after reset ## Table 25. Manual Negotiation Register (MANNGO) Field Descriptions | Bit | Field | Value | Description | |------|----------|-------|---------------------------------------------------| | 31-0 | Reserved | 0 | Reserved. Always read as 0. Writes have no effect | ## 3.20 Negotiation Status Register (NGOSTAT) The Negotiation Status Register reflects the current abilities communicated between the local and remote VLYNQ. The NGOSTAT is shown in Figure 28 and described in Table 26 ## Figure 28. Negotiation Status Register (NGOSTAT) LEGEND: R/W = Read/Write: -n = value after reset ## Table 26. Negotiation Status Register (NGOSTAT) Field Descriptions | Bit | Field | Value | Description | |------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-1 | Reserved | 0 | Reserved. Always read as 0. Writes have no effect | | 0 | Mode | 1 | Mode mask. A '1' in a particular bit position indicates that the device supports the mode corresponding with the bit number. A mode-0-only device would show 00000001b, a mode-1-only device would show 00000010b, etc. The default mode=0 is covered in the Packet Format section. | ## 3.21 Interrupt Vector 3-0 Register (INTVEC0) The INTVEC0 is shown in Figure 29 and described in Table 27. ## Figure 29. Interrupt Vector 3-0 Register (INTVEC0) | 31 | 30 | 29 | 28 | | 24 | 23 | 22 | 21 | 20 | | 16 | |--------|---------|---------|----|----------|----|-------------|---------------|---------|----|---------|----| | INTEN3 | NTTYPE3 | INTPOL3 | | INTTVEC3 | | INTEN2 | INTEN2 | INTPOL2 | | INTVEC2 | | | R/W-0 | R/W-0 | R/W-0 | | R/W-0 | | R/W-0 | R/W-0 | R/W-0 | | R/W-0 | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | | 8 | 7 | 6 | 5 | 4 | | 0 | | | | | 12 | INTTVEC1 | 8 | 7<br>INTEN0 | 6<br>INTTYPE0 | | 4 | INTVEC0 | 0 | LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ## Table 27. Interrupt Vector 3-0 Register (INTVEC0) Field Description | Bit | Field | Value | Description | |-----|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | INTEN3 | 0-1 | Interrupt Enable 3. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | Table 27. Interrupt Vector 3-0 Register (INTVEC0) Field Description (continued) | Bit | Field | Value | Description | |-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 30 | INTTYPE3 | | Interrupt Type 3 | | | | 0 | Interrupt Vector 3 is level sensitive | | | | 1 | Interrupt Vector 3 is Pulse | | 29 | INTPOL3 | | Interrupt Polarity 3 | | | | 0 | Interrupt Vector 3 is active high | | | | 1 | Interrupt Vector 3 is active low | | 28-24 | INTVEC3 | 0-1Fh | Interrupt Vector 3. This field maps the vlynq_int_i[3] pin to a bit in the Interrupt Pending/Set Register. | | 23 | INTEN2 | 0-1 | Interrupt Enable 2. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | | 22 | INTTYPE2 | | Interrupt Type 2 | | | | 0 | Interrupt Vector 2 is level sensitive | | | | 1 | Interrupt Vector 2 is Pulse | | 21 | INTPOL2 | | Interrupt Polarity 2 | | | | 0 | Interrupt Vector 2 is active high | | | | 1 | Interrupt Vector 2 is active low | | 20-16 | INTVEC2 | 0-1Fh | Interrupt Vector 2. This field maps the vlynq_int_i[2] pin to a bit in the Interrupt Pending/Set Register. | | 15 | INTEN1 | 0-1 | Interrupt Enable 1. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | | 14 | INTTYPE1 | | Interrupt Type 1 | | | | 0 | Interrupt Vector 1 is level sensitive | | | | 1 | Interrupt Vector 1 is Pulse | | 13 | INTPOL1 | | Interrupt Polarity 1 | | | | 0 | Interrupt Vector 1 is active high | | | | 1 | Interrupt Vector 1 is active low | | 12-8 | INTVEC1 | 0-1Fh | Interrupt Vector 1. This field maps the vlynq_int_i[1] pin to a bit in the Interrupt Pending/Set Register. | | 7 | INTEN0 | 0-1 | Interrupt Enable 0. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | | 6 | INTTYPE0 | | Interrupt Type 0 | | | | 0 | Interrupt Vector 0 is level sensitive | | | | 1 | Interrupt Vector 0 is Pulse | | 5 | INTPOL0 | | Interrupt Polarity 0 | | | | 0 | Interrupt Vector 0 is active high | | | | 1 | Interrupt Vector 0 is active low | | 4-0 | INTVEC0 | 0-1Fh | Interrupt Vector 0. This field maps the vlynq_int_i[0] pin to a bit in the Interrupt Pending/Set Register. | ## 3.22 Interrupt Vector 7-4 Register (INTVEC1) The INTVEC1 is shown in Figure 30 and described in Table 28. | | | Figure 30 | . Interrupt Vector | 7-4 Register (INTVEC1) | | |--------|----------|-----------|--------------------|------------------------|----| | 31 | 30 | 29 | 28 | | 24 | | INTEN7 | INTTYPE7 | INTPOL7 | | INTTVEC7 | | | R/W-0 | R/W-0 | R/W-0 | | R/W-0 | | | 23 | 22 | 21 | 20 | | 16 | | INTEN6 | INTEN6 | INTPOL6 | | INTVEC6 | | | R/W-0 | R/W-0 | R/W-0 | | R/W-0 | | | 15 | 14 | 13 | 12 | | 8 | | INTEN5 | INTTYPE5 | INTPOL5 | | INTTVEC5 | | | R/W-0 | R/W-0 | R/W-0 | | R/W-0 | | | 7 | 6 | 5 | 4 | | 0 | | INTEN4 | INTEN4 | INTPOL4 | | INTVEC4 | | | R/W-0 | R/W-0 | R/W-0 | | R/W-0 | | LEGEND: R/W = Read/Write; R = Read only; -n = value after reset ## Table 28. Interrupt Vector 7-4 Register (INTVEC1) Field Description | Bit | Field | Value | Description | |-------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | INTEN7 | 0-1 | Interrupt Enable 7. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | | 30 | INTTYPE7 | | Interrupt Type 7 | | | | 0 | Interrupt Vector 7 is level sensitive | | | | 1 | Interrupt Vector 7 is Pulse | | 29 | INTPOL7 | | Interrupt Polarity 7 | | | | 0 | Interrupt Vector 7 is active high | | | | 1 | Interrupt Vector 7 is active low | | 28-24 | INTVEC7 | 0-1Fh | Interrupt Vector 7. This field maps the vlynq_int_i[7] pin to a bit in the Interrupt Pending/Set Register. | | 23 | INTEN6 | 0-1 | Interrupt Enable 6. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | | 22 | INTTYPE6 | | Interrupt Type 6 | | | | 0 | Interrupt Vector 6 is level sensitive | | | | 1 | Interrupt Vector 6 is Pulse | | 21 | INTPOL6 | | Interrupt Polarity 6 | | | | 0 | Interrupt Vector 6 is active high | | | | 1 | Interrupt Vector 6 is active low | | 20-16 | INTVEC6 | 0-1Fh | Interrupt Vector 6. This field maps the vlynq_int_i[6] pin to a bit in the Interrupt Pending/Set Register. | | 15 | INTEN5 | 0-1 | Interrupt Enable 5. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | | 14 | INTTYPE5 | | Interrupt Type 5 | | | | 0 | Interrupt Vector 5 is level sensitive | | | | 1 | Interrupt Vector 5 is Pulse | | 13 | INTPOL5 | | Interrupt Polarity 5 | | | | 0 | Interrupt Vector 5 is active high | | | | 1 | Interrupt Vector 5 is active low | | 12-8 | INTVEC5 | 0-1Fh | Interrupt Vector 5. This field maps the vlynq_int_i[5] pin to a bit in the Interrupt Pending/Set Register. | ## Table 28. Interrupt Vector 7-4 Register (INTVEC1) Field Description (continued) | Bit | Field | Value | Description | |-----|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | INTEN4 | 0-1 | Interrupt Enable 4. When set, this bit indicates that interrupts detected should be written to the Interrupt Pending/Set Register which will subsequently generate an interrupt depending on the status of the intlocal bit in the Control Register. | | 6 | INTTYPE4 | | Interrupt Type 4 | | | | 0 | Interrupt Vector 4 is level sensitive | | | | 1 | Interrupt Vector 4 is Pulse | | 5 | INTPOL4 | | Interrupt Polarity 4 | | | | 0 | Interrupt Vector 4 is active high | | | | 1 | Interrupt Vector 4 is active low | | 4-0 | INTVEC4 | 0-1Fh | Interrupt Vector 4. This field maps the vlynq_int_i[4] pin to a bit in the Interrupt Pending/Set Register. | 42 ## 4 Remote Configuration Registers The remote configuration registers listed in Table 29 are the same registers as previously described, but they are for the remote VLYNQ device. Note Before attempting to access the remote registers (offsets 80h through C0h) , you must ensure that a link is established with the remote device. Poll the LINK bit in the VLYNQ status register (STAT) to do this. It is not necessary to configure the address translation registers to access the remote device's memory-mapped registers after the link has been established. Depending on the version and chip specific implementation, the VLYNQ module on the remote device might have additional registers or different reset values. Refer to the remote device data sheet for a precise description of the VLYNQ registers that exist in the remote device. Table 29. VLYNQ Port Remote Controller Registers | Offset | Acronym | Register Description | |--------|-------------|--------------------------------------------------------| | 80h | RREVID | Remote Revision Register | | 84h | RCTRL | Remote Control Register | | 88h | RSTAT | Remote Status Register | | 8Ch | RINTPRI | Remote Interrupt Priority Vector Status/Clear Register | | 90h | RINTSTATCLR | Remote Interrupt Status/Clear Register | | 94h | RINTPENDSET | Remote Interrupt Pending/Set Register | | 98h | RINTPTR | Remote Interrupt Pointer Register | | 9Ch | RXAM | Remote Transmit Address Map Register | | A0h | RRAMS1 | Remote Receive Address Map Size 1 Register | | A4h | RRAMO1 | Remote Receive Address Map Offset 1 Register | | A8h | RRAMS2 | Remote Receive Address Map Size 2 Register | | ACh | RRAMO2 | Remote Receive Address Map Offset 2 Register | | B0h | RRAMS3 | Remote Receive Address Map Size 3 Register | | B4h | RRAMO3 | Remote Receive Address Map Offset 3 Register | | B8h | RRAMS4 | Remote Receive Address Map Size 4 Register | | BCh | RRAMO4 | Remote Receive Address Map Offset 4 Register | | C0h | RCHIPVER | Remote Chip Version Register | | C4h | RAUTNGO | Remote Auto Negotiation Register | | C8h | RMANNGO | Remote Manual Negotiation Register | | CCh | RNGOSTAT | Remote Negotiation Status Register | | E0h | RINTVEC0 | Remote Interrupt Vector 3-0 Register | | E4h | RINTVEC1 | Remote Interrupt Vector 7-4 Register | ## Appendix A VLYNQ Protocol Specifications VLYNQ relies on 8b/10b block coding to minimize the number of serial pins and allow for in-band packet delineation and control. The following sections include general 8b/10b coding definitions and their implementation. ## A.1 Special 8b/10b Code Groups Table A-1. Special 8b/10b Code Groups | | | • | • | | |--------------------|-------------|------------|--------------|--------------| | Code Group<br>Name | Octet Value | Octet Bits | Current RD - | Current RD + | | K28.0 | 1C | 0001 1100 | 001111 0100 | 110000 1011 | | K28.1 | 3C | 0011 1100 | 001111 1001 | 110000 0110 | | K28.2 | 5C | 0101 1100 | 001111 0101 | 110000 1010 | | K28.3 | 7C | 0111 1100 | 001111 0011 | 110000 1100 | | K28.4 | 9C | 1001 1100 | 001111 0010 | 110000 1101 | | K28.5 | BC | 1011 1100 | 001111 1010 | 110000 0101 | | K28.6 | DC | 1101 1100 | 001111 0110 | 110000 1001 | | K28.7 | FC | 1111 1100 | 001111 1000 | 110000 0111 | | K23.7 | F7 | 1111 0111 | 111010 1000 | 000101 0111 | | K27.7 | FB | 1111 1011 | 110110 1000 | 001001 0111 | | K29.7 | FD | 1111 1101 | 101110 1000 | 010001 0111 | | K30.7 | FE | 1111 1110 | 011110 1000 | 100001 0111 | ## A.2 Supported Ordered Sets Each VLYNQ module must support a limited number of ordered sets. Ordered sets provide for the delineation of packets and synchronization between VLYNQ modules at opposite ends of the serial connection. VLYNQ 2.0 and later versions do not require some of the following ordered sets. **Table A-2. Supported Ordered Sets** | Code | Ordered Set | Encoding | Octet Value | |------|----------------------|----------|-------------| | /١/ | Idle | /K28.5/ | BC | | /T/ | End of Packet | /K29.7/ | FD | | /M/ | Byte Disable | /K23.7/ | F7 | | /P/ | Flow Control Enable | /K28.0/ | IC | | /C/ | Flow Control Disable | /K28.2/ | 5C | | /E/ | Error Indication | /K28.1/ | 3C | | /0/ | Init0 | /K28.4/ | 9C | | /1/ | Init1 | /K28.6/ | DC | | /L/ | Link | /K30.7/ | FE | ## A.2.1 Idle (/I/) The idle ordered sets are transmitted continuously and repetitively whenever the serial interface is idle. Idle is also used in the place of the flowed code in VLYNQ versions 2.0 and later. ## A.2.2 End of Packet (/T/) An end of packet delimiter delineates the ending boundary of a packet. ## A.2.3 Byte Disable (/M/) The byte disable symbol masks bytes for write operations. ## A.2.4 Flow Control Enable (/P/) A flow control enable request is transmitted when a VLYNQ module's receive FIFO is full or nearly full. This code causes the remote VLYNQ device to cease transmission of data. ### A.2.5 Flow Control Disable (/C/) The flow control disable request is transmitted by a VLYNQ module when RX FIFO resources are available to accommodate additional data. ## A.2.6 Error Indication (/E/) The error indication is transmitted when errors are detected within a packet. Examples of such errors include illegal packet types and code groups. ## A.2.7 Init0 (/0/) The Init0 code group is used during the link initialization sequence. VLYNQ 2.0 and later versions use this code with an extra byte for identifying version 1.X devices. #### A.2.8 Init1 (/1/) The Init1code group is used during the Link initialization sequence. VLYNQ 2.0 and later uses this code with an extra byte for identifying version 1.X devices. ## A.2.9 Link (/L/) The link code group is used during the link initialization sequence. A link code group is also transmitted each time the internal link timer expires. ## A.3 VLYNQ 2.0 Packet Format The VLYNQ 2.0 packet format is shown in Figure A-1 and described in Table A-3, where 0<N<65. Multi-byte fields are transferred least-significant byte first. Figure A-1. Packet Format (10-bit Symbol Representation) | 10 bits | 10 bits | 10 bits | <4*10 bits | N*10 bits | 10 bits | |---------|---------|---------|------------|-----------|---------| | cmd 1 | cmd 2 | bytecnt | address | data | еор | | | | | | | | | | | | | | | | pkttype | adrmask | | | | | Table A-3. Packet Format (10-bit Symbol Representation) Description | Field | Value | Description | |----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PKTTYPE[3:0] | | This field indicates the packet type. | | | 0000 | Reserved | | | 0001 | Write with address increment. | | | 0010 | Reserved | | | 0011 | Write 32-bit word with address increment. | | | 0100 | Reserved | | | 0101 | Configuration write with address increment. | | | 0110 | Reserved | | | 0111 | Interrupt | | | 1000 | Reserved | | | 1001 | Read with address increment. | | | 1010 | Reserved | | | 1011 | Read 32-bit word with address increment. | | | 1100 | Reserved | | | 1101 | Configuration read with address increment. | | | 1110 | Reserved for VLYNQ version 2.0 and later. | | | 1111 | Read response for all VLYNQ versions. | | ADRMASK[3:0] | | Indicates which byte of the address is included in the packet. Only address bytes that have changed since the previous address will be included. Each bit corresponds to one byte of address. | | BYTECNT[7:0] | | Byte count. This field indicates the total number of bytes in the packet. This field is only included for write, read, and configuration packet types. All other packet types have fixed lengths and do not require this field. | | ADDRESS[7:0] | | Address byte 0. This byte is included only if ADRMASK[0] is set to 1. If ADRMASK[0] is cleared to 0, assume this byte is equal to bits 7:0 of the previous address. Read response packets do not include this field. | | ADDRESS[15:8] | | Address byte 1. This byte is included only if ADRMASK[1] is set to 1. If ADRMASK[1] is cleared to 0, assume this byte is equal to bits 15:8 of the previous address. Read response packets do not include this field. | | ADDRESS[23:16] | | Address byte 2. This byte is only included if ADRMASK[2] is set to 1. If ADRMASK[2] is cleared to 0, this assume this byte is equal to bits 23:16 of the previous address. Read response packets do not include this field. | | ADDRESS[31:24] | | Address byte 3. This byte is only included if ADRMASK[3] is set to 1. If ADRMASK[3] is cleared to 0, assume this byte is equal to bits 31:24 of the previous address. Read response packets do not include this field. | | DATA | | Data payload. The maximum data payload size is limited to sixteen 32-bit words to allow it to fit in the RX FIFO. | | EOP | | End of packet indicator, /T/. | The CMD2 bit is only included in the packet if the packet type indicates extended command (PKTTYPE = 0110). Use configuration packet types to remotely access VLYNQ module registers. The configuration packet types do not depend on control register bit settings. #### A.4 VLYNQ 2.X Packets An example of what can happen to a write burst due to remote and local FIFO state changes and the link pulse timer expiring is shown in Example A-1. This protocol can be extended to apply to multiple channels; therefore, the data return channel is logically isolated from the command channel. # Example A-1. A Write Burst Due to Remote and Local FIFO State Changes and the Link Pulse Timer expiring ``` Basic packets: Read32 - caaaaT Write32 - caaaaddddT ReadCfg - claaaaT WriteCfg - claaaaddddddddT ReadBurst - claaaaT WriteBurst - claaaaddddddddddddT Int - cddddT ReadReturn - clddddddddT Where I - Idle T - EndOfPacket d - data a - address c - command 1 - length M - Byte mask I[#] - Flowed, # is used when exiting flowed for a channel, the # is actually the current channel command. P# - Flow Enable for a channel C# - Flow Disable for a channel L - Link pulse and what is in italics is optional data up to 16 words total. Packet with byte enables: WriteBurst - claaaaMMddMMddMMddT The above packet wrote to the LS half words from the specified address. Packet that has been flowed due to remote FIFO status: WriteBurst - claaaaMMddMIIIIIIIIIIIII#MddMMddT The packet was extended using the I code. The # is used to indicate that the same channel was continued. To the same packet, the potential flowing of the local FIFO's is added: WriteBurst - claaaaMMddMIIP#IIIIIIIIIIII#MddMMdC#dT Link pulse to the stream is added: WriteBurst - claaLaaMMddMIIP#IIIIIIIIIII#MddMMdC#dT ``` An example of a write burst flowed and interrupted by a read return data burst is shown below. In the example, a 1 indicates a data return channel (it is actually the return data command) and a 0 indicates a command channel, which is the command for the transaction. IIIIclaaaaddddIcldddIII1ddddII0ddddddddddIIIIII0dddTIIIII1dTIIII A command, length, address, and start receive data from the idle stream. A flow enable was received for the command channel, but there is data to return, so the flow is followed by a channel 1 descriptor (the command for return data actually indicates a channel 1), and the channel 1 packet is now under way. A flow is now received for channel 1, but it is soon disabled so the channel 1 packet continues. The flow is enabled for channel one again, quickly after flow is released for channel 0, so the data continues for channel 0 when a flow is received again for channel 0. Channel 0 then receives a flow disable, completes its packet, followed by channel 1 flow disable, where the channel 1 packet is also completed. ## Appendix B Write/Read Performance The following sections discuss the write versus read performance and how the throughput (read or write) should be calculated for a given data width and serial clock frequency. Note: The data and throughput calculations shown here are sample calculations for most ideal situations. In general, the data rates depend on a variety of other factors, such as efficiency of read/write burst transactions, ability of buffering up read/write data, and how best it can be serially shifted out without stalling additional read/write data burst, remote and local components, both external and internal (device operations, board considerations, etc.). #### B.1 Write Performance The max write rate describes the maximum available data rate of the serial interface for transmission, taking into consideration the 8b/10b encoding overheads. This is calculated as follows: ``` Max write rate = VLYNQ Serial Clock (MHz) × No. of Pins × 8b/10b encoding overhead ``` The 8b/10b encoding overhead essentially accounts for 20% overhead, thus the actual data throughput after subtraction of the encoding overhead gives a factor of 0.8. For example, if the VLYNQ clock is running at 99 MHz on a 4 pin per direction interface, the raw data is 99 × 4 or 396 Mbps. After the 8B10B encoding is removed, the maximum write rate is $396 \times 0.8 = 316.8$ Mbps. The total throughput on the VLYNQ interface includes both transmit and receive directions. Therefore, for the above configuration, a remote device can also be writing to the local device at the same data rates, then the total throughput is the sum of transmit and receive rates, or 633.6 Mbps. In addition to the 8b/10b encoding, the packet structure for read/write operations also results in additional overheads. The VLYNQ module can transfer single 32-bit words or a burst of up to sixteen 32-bit words. The packet structure of the writes is shown below, here each character represents a byte. ``` Write32 - caaaaddddT WriteBurst - claaaaddddddddddddddT Where T - EndOfPacket d - data, dddd represents additional 32-bit words in burst, up to 16 words. a - address c - command ``` The example above illustrates that single writes require 6 bytes of overhead, while burst writes require 8 bytes of overhead (due to the additional length of the field). From this, a scaling factor can be calculated (data bytes/total bytes), as show in Table B-1. The actual throughput is then calculated as the [scaling factor] $\times$ [max write rate]. **Table B-1. Scaling Factors** | Burst Size in 32-bit words | Data Bytes | Overhead Bytes | Scaling Factor | |----------------------------|------------|----------------|----------------| | 1 | 4 | 6 | 40% | 1 - length **Table B-1. Scaling Factors (continued)** | Burst Size in 32-bit words | Data Bytes | Overhead Bytes | Scaling Factor | |----------------------------|------------|----------------|----------------| | 4 | 16 | 7 | 69.56% | | 8 | 32 | 7 | 82.05% | | 16 | 64 | 7 | 90.14% | Using a VLYNQ interface running at 99 MHz, the performance shown in Table B-2 is ideally expected. Table B-2. Expected Throughput (VLYNQ Interface Running at 99 MHz) | Number of VLYNQ Pins | Burst Size in 32-bit Words | Throughput (Mbits/sec) | Throughput (Mbytes/sec) | |----------------------|----------------------------|------------------------|-------------------------| | 1 | 1 | 31.68 | 3.96 | | | 4 | 55.09 | 6.89 | | | 8 | 64.98 | 8.12 | | | 16 | 71.39 | 8.92 | | 2 | 1 | 63.36 | 7.92 | | | 4 | 110.18 | 13.77 | | | 8 | 129.97 | 16.25 | | | 16 | 142.78 | 17.85 | | 3 | 1 | 95.04 | 11.88 | | | 4 | 165.27 | 20.66 | | | 8 | 194.95 | 24.37 | | | 16 | 214.17 | 26.77 | | 4 | 1 | 126.72 | 15.84 | | | 4 | 220.37 | 27.55 | | | 8 | 259.93 | 32.49 | | | 16 | 285.56 | 35.70 | Using a VLYNQ interface running at 76.5 MHz, the performance shown in Table B-3 is ideally expected. Table B-3. Expected Throughput (VLYNQ Interface Running at 76.5 MHz) | Number of VLYNQ Pins | Burst Size in 32-bit Words | Throughput (Mbits/sec) | Throughput (Mbytes/sec) | |----------------------|----------------------------|------------------------|-------------------------| | 1 | 1 | 24.19 | 3.02 | | | 4 | 42.07 | 5.26 | | | 8 | 49.62 | 6.20 | | | 16 | 54.52 | 6.81 | | 2 | 1 | 48.38 | 6.05 | | | 4 | 84.14 | 10.52 | | | 8 | 99.25 | 12.41 | | | 16 | 109.03 | 13.63 | | 3 | 1 | 72.58 | 9.07 | | | 4 | 126.21 | 15.78 | | | 8 | 148.87 | 18.61 | | | 16 | 163.55 | 20.44 | | 4 | 1 | 96.77 | 12.10 | | | 4 | 168.28 | 21.03 | | | 8 | 198.50 | 24.81 | | | 16 | 218.07 | 27.26 | #### B.2 Read Performance Since reads must complete a transmit-remote read-receive cycle before starting another read transaction, the data throughput is lower as compared to writes. There is latency involved in reading the data from the remote device; and in some cases, a local latency in writing the returned data before the next read can start. The max read rate is calculated the same way as the max write rate. The packet overhead is as shown below: ``` Read32 - caaaaT ReadBurst - claaaaT ReadReturn - cldddddddT Where T - EndOfPacket d - data, dddd represents additional 32-bit words in burst, up to 16 words. a - address c - command 1 - length ``` There are 6 bytes of overhead for a single read, 7 bytes for burst reads, and 3 bytes for read returns. The time required for a read is the total of the time for the read request, remote latency, read return, and local latency. Thus, the throughput can be calculated as data bytes/total transaction time, where the latency of both local and remote devices is combined. For example, with a 4 pin, 99 MHz VLYNQ connection, for a single 32-bit word read: ``` Read Throughput = 32 bits \times 316.8 Mbps/ (6 \times 8 + 3 \times 8 + 4 \times 8 + Latency \times 316.8 Mbps) = 10137.6/(104 + Latency \times 316.8 Mbps) ``` Similarly, for a burst read of sixteen 32-bit words, with a 4 pin, 99 MHz VLYNQ connection ``` Read Throughput = 16 \times 32 bits \times 316.8 Mbps/(6 \times 8 + 3 \times 8 + 16 \times 4 \times 8 + Latency <math>\times 316.8 Mbps) = 162201.6/(584 + Latency \times 316.8 Mbps) ``` Using the formula above, the relative performance with various latencies is illustrated for a 4 pin, 99 MHz VLYNQ clock, burst read (sixteen 32-bit words) throughput rate, as shown in Table B-4: Table B-4. Relative Performance with Various Latencies | Number of VLYNQ Pins<br>(99 MHz) | Burst Size in 32-bit Words | Latency (µsec) | Throughput<br>(Mbits/sec) | Throughput (Mbytes/sec) | |----------------------------------|----------------------------|----------------|---------------------------|-------------------------| | 4 | 16 | 0 | 277.74 | 34.72 | | | | 1 | 179.70 | 22.46 | | | | 10 | 43.02 | 5.38 | | | | 100 | 5.00 | 0.62 | To efficiently use VLYNQ bandwidth, it is desirable for each VLYNQ device to write from the local device to the remote device. Burst transactions are more efficient than single read/write transactions. #### **IMPORTANT NOTICE** Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment. TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed. TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards. TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI. Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions. Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements. TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications. TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use. TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements. Following are URLs where you can obtain information on other Texas Instruments products and application solutions: | Products | | Applications | | |-----------------------|------------------------|--------------------|---------------------------| | Amplifiers | amplifier.ti.com | Audio | www.ti.com/audio | | Data Converters | dataconverter.ti.com | Automotive | www.ti.com/automotive | | DSP | dsp.ti.com | Broadband | www.ti.com/broadband | | Interface | interface.ti.com | Digital Control | www.ti.com/digitalcontrol | | Logic | logic.ti.com | Military | www.ti.com/military | | Power Mgmt | power.ti.com | Optical Networking | www.ti.com/opticalnetwork | | Microcontrollers | microcontroller.ti.com | Security | www.ti.com/security | | RFID | www.ti-rfid.com | Telephony | www.ti.com/telephony | | Low Power<br>Wireless | www.ti.com/lpw | Video & Imaging | www.ti.com/video | | | | Wireless | www.ti.com/wireless | Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2007, Texas Instruments Incorporated