# DLP2021-Q1 and DLP3021-Q1 FPGA #### **ABSTRACT** This document defines the interfaces and functionality of the DLP® Automotive Dynamic Ground Projection FPGA design implemented for the Spartan 7 (XA7S15-1CPGA196Q). Some specifications are based on the Spartan 7 hardware blocks and non-design-specific constraints. In these cases, Xilinx Spartan 7 documentation is considered the more accurate source of information if there are conflicting values. # **Table of Contents** | | 3 | |-----------------------------------------------------------------|----------------| | 1.1 Purpose and Scope | 3 | | 2 FPGA Pin Configuration and Functions | 4 | | 2.1 DMD Interface | 4 | | 2.2 Light Control | 5 | | 2.3 Communication | 5 | | 2.4 Support | 6 | | 2.5 FPGA Dedicated Pins | 6 | | 2.6 Power and Ground | 7 | | 2.7 Unused Pins | <mark>7</mark> | | 3 Specifications | | | 3.1 Recommended Operating Conditions | 9 | | 3.2 FPGA Power Consumption | | | 3.3 Host SPI Interface Timing | <mark>9</mark> | | 3.4 Power Supply and Reset Timing | 10 | | 3.5 DMD Interface Timing | 12 | | 3.6 Flash Memory Interface Timing | 12 | | 3.7 Reference Clock Timing | 12 | | 3.8 I2C Interface Timing | 13 | | 4 Feature Descriptions | 13 | | 4.1 Video Control | | | 4.2 Temperature Measurements | 17 | | 4.3 PWM Outputs | | | 4.4 Host IRQ Interrupt Signal | | | 4.5 Video and Image Compression | | | 5 Layout | | | 6 Host Command Protocol | 19 | | 6.1 SPI Specifications | | | 6.2 SPI Write Command | | | 6.3 SPI Read Command | | | 7 FPGA Register Definitions | | | 8 Revision History | 28 | | | | | List of Figures | | | Figure 1-1. Dynamic Ground Projection Electronics Block Diagram | 3 | | Figure 3-1. Host SPI Interface Timing Diagram | 9 | | Figure 3-2. Power-up Timing Diagram | 10 | | Figure 3-3. Power-Down Timing Diagram | | | Figure 4-1. Typical PWM Circuit | | | Figure 6-1. SPI Write Command Format | | | Figure 6-2. SPI Read Command Format | 20 | # Trademarks | Table 2-1. DMD Interface Pin Descriptions | | |------------------------------------------------------------------|--------------| | Table 2-2. Light Control Pin Descriptions | | | Table 2-3. Communication Pin Descriptions | | | Table 2-4. Support Pin Descriptions | <del>(</del> | | Table 2-5. FPGA Dedicated Pin Descriptions | | | Table 2-6. Power and Ground Pin Descriptions | | | Table 2-7. Unused Pins | | | Table 3-1. Recommended Operating Conditions | | | Table 3-2. FPGA Power Consumption Specification | 9 | | Table 3-3. Host SPI Interface Timing | | | Table 3-4. Power-up Timing Specifications | | | Table 3-5. Power-Down Timing Specifications | | | Table 3-6. Brownout Detection Specifications | | | Table 3-7. DMD Interface Timing Specifications | 12 | | Table 3-8. Flash Memory Interface Timing | 12 | | Table 3-9. Reference Clock Timing Specifications | 12 | | Table 3-10. I <sup>2</sup> C Interface Timing <sup>(1) (2)</sup> | 13 | | Table 4-1. Video Control Register Configuration | 13 | | Table 4-2. PWM Selection Configuration | 17 | | Table 4-3. Typical Storage Capabilities for DLP3021-Q1 | 19 | | Table 4-4. Typical Storage Capabilities for DLP2021-Q1 | | | Table 6-1. SPI Specifications | | | Table 6-2. SPI MOSI Write Command Information | 20 | | Table 6-3. SPI MISO Write Command Information | | | Table 6-4. SPI MOSI Read Command Information | | | Table 6-5. SPI MISO Read Command Information | | | Table 7-1. FPGA SPI Registers | | | Table 7-2. Device Access Type Codes | 22 | | Table 7-3. FPGA_INTERRUPT_CLEAR Register Field Descriptions | | | Table 7-4. FPGA_INTERRUPT_SET Register Field Descriptions | | | Table 7-5. FPGA_INTERRUPT_ENABLE Register Field Descriptions | 23 | | Table 7-6. FPGA_VERSION Register Field Descriptions | 23 | | Table 7-7. FMT_FLIP Register Field Descriptions | | | Table 7-8. RSC_SEQBUF_SELECT Register Field Descriptions | 24 | | Table 7-9. PWM_CONTROL Register Field Descriptions | 24 | | Table 7-10. VCM_FRAME_RATE Register Field Descriptions | 24 | | Table 7-11. VCM_START_ADDR1 Register Field Descriptions | 24 | | Table 7-12. VCM_CONFIG1 Register Field Descriptions | | | Table 7-13. VCM_START_ADDR2 Register Field Descriptions | | | Table 7-14. VCM_CONFIG2 Register Field Descriptions | 25 | | Table 7-15. VCM_CONTROL Register Field Descriptions | 26 | | Table 7-16. VCM_STATUS Register Field Descriptions | | | Table 7-17. TMP_CTRL Register Field Descriptions | 27 | | Table 7-18. TMP_STATUS Register Field Descriptions | 27 | | Table 7-19. TMP_REMOTE_TEMP Register Field Descriptions | 27 | | Table 7-20 TMP LOCAL TEMP Register Field Descriptions | 28 | **List of Tables** # **Trademarks** $\mathsf{DLP}^{\texttt{®}}$ is a registered trademark of Texas Instruments. All trademarks are the property of their respective owners. www.ti.com Introduction # 1 Introduction # 1.1 Purpose and Scope In this application, the FPGA reads video data directly from a Flash memory to display on the DMD. The FPGA also coordinates the illumination timing to coordinate with the displayed video content. Figure 1-1. Dynamic Ground Projection Electronics Block Diagram # **2 FPGA Pin Configuration and Functions** This section details the pin configuration of the FPGA and describes the function and I/O type of each pin. # 2.1 DMD Interface **Table 2-1. DMD Interface Pin Descriptions** | PIN I/O | | | i Descriptions | | | |------------------------|--------|-------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | | 1/0 | | | | | NAME | NUMBER | POWER | TYPE | DESCRIPTION | | | D0 | L14 | 1.8V | 0 | DMD data pins | | | D1 | L13 | 1.8V | 0 | _ | | | D2 | J14 | 1.8V | 0 | | | | D3 | K12 | 1.8V | 0 | | | | D4 | H12 | 1.8V | 0 | | | | D5 | K13 | 1.8V | 0 | | | | D6 | G14 | 1.8V | 0 | | | | D7 | H14 | 1.8V | 0 | | | | D8 | H13 | 1.8V | 0 | | | | D9 | G12 | 1.8V | 0 | | | | D10 <sup>(1)</sup> | F14 | 1.8V | 0 | | | | D11 <sup>(1)</sup> | E12 | 1.8V | 0 | | | | D12 <sup>(1)</sup> | E13 | 1.8V | 0 | | | | D13 <sup>(1)</sup> | F13 | 1.8V | 0 | | | | D14 <sup>(1)</sup> | D14 | 1.8V | 0 | | | | DCLK | B14 | 1.8V | 0 | DMD data clock (DDR) | | | TRC | C14 | 1.8V | 0 | DMD data toggle rate control | | | LOADB | C13 | 1.8V | 0 | DMD data load signal (active low) | | | SAC BUS | M14 | 1.8V | 0 | DMD SAC bus data | | | SAC CLK | N13 | 1.8V | 0 | DMD SAC bus clock | | | DAD BUS | N14 | 1.8V | 0 | DMD DAD bus data | | | DMD TDO <sup>(1)</sup> | P12 | 1.8V | I | DMD interface test data input. Signal connected to DMD JTAG interface to allow the verification of the interface. This signal connects to the DMD JTAG TDO. Includes an internal pullup resister. DMD JTAG functionality is not implemented in the FPGA design. This pin can be left disconnected. | | | DMD TDI <sup>(1)</sup> | P10 | 1.8V | 0 | DMD interface test data output. Signal connected to DMD JTAG interface to allow the verification of the interface. This signal connects to the DMD JTAG TDI. DMD JTAG functionality is not implemented in the FPGA design. This pin can be left disconnected. | | | DMD TCK <sup>(1)</sup> | P11 | 1.8V | 0 | DMD interface test data input. Signal connected to DMD JTAG interface to allow the verification of the interface. This signal connects to the DMD JTAG TDO. DMD JTAG functionality is not implemented in the FPGA design. This pin can be left disconnected. | | | DMD TMS <sup>(1)</sup> | M10 | 1.8V | 0 | DMD interface test mode. Signal connected to DMD JTAG interface to allow the verification of the interface. DMD JTAG functionality is not implemented in the FPGA design. This pin can be left disconnected. | | | RESET OEZ | P13 | 1.8V | 0 | DMD DAD output enable (active low). A pullup to the 1.8-V rail for the DMD interface is needed to keep this signal inactive when tri-stated. | | | SCTRL | A13 | 1.8V | 0 | DMD data serial control signal | | | RESET STROBE | M12 | 1.8V | 0 | DMD DAD bus strobe | | | | | - | - | • | | <sup>(1)</sup> This pin is not applicable to the DLP2021-Q1. # 2.2 Light Control **Table 2-2. Light Control Pin Descriptions** | PIN | | I/O | | | |----------|--------|-------|------|--------------------------------------| | NAME | NUMBER | POWER | TYPE | DESCRIPTION | | S_EN | A2 | 3.3V | 0 | Shunt enable for illumination driver | | R_EN | A3 | 3.3V | 0 | Red select for illumination driver | | G_EN | A4 | 3.3V | 0 | Green select for illumination driver | | B_EN | A5 | 3.3V | 0 | Blue select for illumination driver | | LED_EN | B6 | 3.3V | 0 | Enable to illumination driver | | PWM0 | N2 | 3.3V | 0 | Red PWM output | | PWM1 | N3 | 3.3V | 0 | Green PWM output | | PWM2 | P3 | 3.3V | 0 | Blue PWM output | | PWM_SEL0 | P4 | 3.3V | 0 | Encoded PWM select | | PWM_SEL1 | N4 | 3.3V | 0 | Encoded PWM select | # 2.3 Communication **Table 2-3. Communication Pin Descriptions** | PI | N | I/O | | · | | |-------------------------|----------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | NAME | NUMBER | POWER | TYPE | DESCRIPTION | | | HOST CLK | H3 | 3.3V | I | SPI port (Slave) clock | | | HOST MOSI | H1 | 3.3V | I | SPI port (Slave) data input | | | HOST MISO | J1 | 3.3V | 0 | SPI port (Slave) data output | | | HOST CS | M1 | 3.3V | I | SPI port (Slave) chip select | | | HOST IRQ | N1 | 3.3V | 0 | Host interrupt | | | Temp SDA <sup>(1)</sup> | L2 | 3.3V | В | I <sup>2</sup> C Port (Controller) data An external pullup is required. Typical use of this I <sup>2</sup> C port is communication with a temperature sensing device. | | | Temp SCL <sup>(1)</sup> | К3 | 3.3V | 0 | I2C Port (Controller) clock An external pullup is required. Typical use of this I <sup>2</sup> C port is communication with a temperature sensing device. | | | Flash DQ0 | C10, F12 | 1.8V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash DQ1 | C11, E11 | 1.8V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash DQ2 | B11 | 1.8V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash DQ3 | A12 | 1.8V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash DQ4 | B12 | 1.8 V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash DQ5 | A10 | 1.8V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash DQ6 | A9 | 1.8V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash DQ7 | D11 | 1.8V | В | SPI port (Controller) Control interface to flash device, transmit and receive data. | | | Flash CS | C12, D13 | 1.8V | 0 | SPI port (Controller) Control interface to flash device, transmit and receive data. An external pullup resistor (≤10 kΩ) is required. | | | Flash DQS | H11 | 1.8V | I | Flash data strobe | | #### **Table 2-3. Communication Pin Descriptions (continued)** | PIN | | I/O | | | | |-----|-----------|--------|-------|------|-------------| | | NAME | NUMBER | POWER | TYPE | DESCRIPTION | | | Flash Clk | B9, A7 | 1.8V | 0 | Flash clock | <sup>(1)</sup> This pin is not supported directly by the FPGA, and must be read with the support of an external MCU. For example on the DLP2021LEQ1EVM, the TMP411 I2C is routed to the MSP430. # 2.4 Support **Table 2-4. Support Pin Descriptions** | PI | PIN | | 0 | | |---------------------|----------|-------|----------|-----------------------------------------------------------------------------------------------------------------------| | NAME | NUMBER | POWER | TYPE | DESCRIPTION | | TSTPT_0 | B1 | 3.3V | 0 | Reserved for test outputs. These I/O should be left open or unconnected for normal operation in final product design. | | TSTPT_1 | B2 | 3.3V | 0 | | | TSTPT_2 | C1 | 3.3V | 0 | | | TSTPT_3 | C2 | 3.3V | 0 | | | TSTPT_4 | D1 | 3.3V | 0 | | | TSTPT_5 | D3 | 3.3V | 0 | | | TSTPT_6 | E1 | 3.3V | 0 | | | TSTPT_7 | E2 | 3.3V | 0 | | | Osc Input | G2 | 3.3V | I | Reference clock input | | Brownout Detect | F2 | 1.8V | I (HSTL) | Brownout Detect | | DMD Discharge<br>En | M5 | 3.3V | 0 | DMD Discharge enable | | Clock Loopback | J11, J13 | | | Reserved | # 2.5 FPGA Dedicated Pins The following pins are hardware-dedicated on Spartan 7 FPGA. For primary guidelines, see Xilinx documentation. Descriptions in Table 2-5 are recommendations for application-specific consideration. **Table 2-5. FPGA Dedicated Pin Descriptions** | P | IN | 1/0 | I/O | | |--------------------|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | NAME | NUMBER | 1/0 | DESCRIPTION | | | PUDC | B10 | I | Pullup during configuration Tie either directly (or through a 1-K $\Omega$ or less resistor) to GND. This will enable pullups on pins during configuration. | | | PROGRAMZ | N8 | I | Asynchronous reset to configuration logic (active low) | | | INITZ | N7 | B (open drain) | Indicates initialization of configuration memory (active low) | | | DONE | M9 | В | Indicates successful completion of configuration (active high) | | | CFGBVS_0 | N9 | 1 | Tie to ground | | | DXN_0 | J7 | N/A | Temperature-sensing diode pin for FPGA. Tie to ground if not used. | | | DXP_0 | J8 | N/A | Temperature-sensing diode pin for FPGA. Tie to ground if not used. | | | M0_0 | L10 | I | Configuration mode select Tie to 1.8V. | | | M1_0 | L8 | I | Configuration mode select Tie to ground. | | | M2_0 | L9 | I | Configuration mode select Tie to ground. | | | HSTL VREF | C4, L3 | REF | Voltage reference for HSTL 1.8-V input | | | TDO <sup>(1)</sup> | M6 | 1 | JTAG data output | | | TDI <sup>(1)</sup> | M7 | I | JTAG data input | | Table 2-5. FPGA Dedicated Pin Descriptions (continued) | PIN | | I/O | | |--------------------|--------|-----|------------------| | NAME | NUMBER | 1/0 | DESCRIPTION | | TCK <sup>(1)</sup> | A8 | 0 | JTAG clock | | TMS <sup>(1)</sup> | L7 | I | JTAG mode select | <sup>(1)</sup> This pin is not applicable to the DLP2021-Q1. # 2.6 Power and Ground Table 2-6. Power and Ground Pin Descriptions | PIN | | I/O | | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------------------------------| | NAME | NUMBER | | DESCRIPTION | | VCCAUX | D6, D8, D10 | PWR | 1.8-V power supply pins for auxiliary circuits | | VCCBRAM | C7, C9 | PWR | 1.0-V power supply pins for the FPGA logic block RAM | | VCCINT | E7, E9, F6, G9, H6,<br>J9, K6, K8 | PWR | 0.9-V/1.0-V power supply pins for the internal core logic | | VCCO_0 | N6, P8 | PWR | Power supply pins for bank 0 | | VCCO_14 | F10, H10, K10 | PWR | Power supply pins for bank 14 | | VCCO_34 | E5, G5, J5 | PWR | Power supply pins for bank 34 | | GND | A1, H5, H9, J2, J6,<br>J10, J12, K4, K5, K7,<br>K9, K14, L1, L5, L6,<br>L11, M3, M8, M13,<br>N5, N10, P1, P5, P6,<br>P7, P9, P14, A6, A11,<br>A14, B3, B8, B13, C6,<br>C8, D2, D5, D7, D9,<br>D12, E4, E6, E8, E10,<br>E14, F1, F5, F9, F11,<br>G3, G6, G10, G11,<br>G13 | RTN | Ground | # 2.7 Unused Pins All NC pins have internal pullups and should be left unconnected in the schematic design. Table 2-7. Unused Pins | F | TYPE | | | |--------------------|--------|------|--| | NAME | NUMBER | IIFE | | | IO_L2P_T0_34 | B4 | NC | | | IO_L3N_T0_DQS_34 | B5 | NC | | | IO_L3P_T0_DQS_34 | C5 | NC | | | IO_L5N_T0_34 | B1 | NC | | | IO_L5P_T0_34 | B2 | NC | | | IO_L6P_T0_34 | D4 | NC | | | IO_L7N_T1_34 | C1 | NC | | | IO_L7P_T1_34 | C2 | NC | | | IO_L8N_T1_34 | D3 | NC | | | IO_L8P_T1_34 | E3 | NC | | | IO_L9N_T1_DQS_34 | D1 | NC | | | IO_L9P_T1_DQS_34 | E1 | NC | | | IO_L10N_T1_34 | E2 | NC | | | IO_L11N_T1_SRCC_34 | F3 | NC | | | IO_L11P_T1_SRCC_34 | F4 | NC | | | IO_L12N_T1_MRCC_34 | G1 | NC | | # Table 2-7. Unused Pins (continued) | PIN | | | | | |--------------------|--------|----|--|--| | | TYPE | | | | | NAME | NUMBER | | | | | IO_L13N_T2_MRCC_34 | G4 | NC | | | | IO_L13P_T2_MRCC_34 | H4 | NC | | | | IO_L14N_T2_SRCC_34 | H2 | NC | | | | IO_L16N_T2_34 | J3 | NC | | | | IO_L16P_T2_34 | J4 | NC | | | | IO_L17N_T2_34 | K1 | NC | | | | IO_L18N_T2_34 | K2 | NC | | | | IO_L19P_T3_34 | L4 | NC | | | | IO_L20P_T3_34 | M2 | NC | | | | IO_L23N_T3_34 | P2 | NC | | | | IO_0_34 | C3 | NC | | | | IO_L16P_T2_CSI_14 | K11 | NC | | | | IO_L18P_T2_D28_14 | L12 | NC | | | | IO_L23P_T3_D19_14 | N11 | NC | | | | IO_L23N_T3_D18_14 | N12 | NC | | | | IO_L24N_T3_D16_14 | M11 | NC | | | | TCK_0 | A8 | NC | | | | TDI_0 | M7 | NC | | | | TDO_0 | M6 | NC | | | | TMS_0 | L7 | NC | | | | NC1 | B7 | NC | | | | NC2 | F7 | NC | | | | NC3 | F8 | NC | | | | NC4 | G7 | NC | | | | NC5 | G8 | NC | | | | NC6 | H7 | NC | | | | NC7 | H8 | NC | | | www.ti.com Specifications # 3 Specifications # 3.1 Recommended Operating Conditions **Table 3-1. Recommended Operating Conditions** | | MIN | NOM | MAX | UNIT | |------------------------|------|------|------|------| | VCCO_0 | 1.71 | 1.8 | 1.89 | V | | VCCO_14 | 1.71 | 1.8 | 1.89 | V | | VCCO_34 | 3.14 | 3.3 | 3.46 | V | | VCCAUX <sup>(1)</sup> | 1.71 | 1.80 | 1.89 | V | | VCCBRAM <sup>(1)</sup> | 0.95 | 1.00 | 1.05 | V | | VCCINT <sup>(1)</sup> | 0.95 | 1.00 | 1.05 | V | <sup>(1)</sup> Values are based on FPGA documentation available at the time of writing. Refer to the FPGA data sheet as the primary source specification. # 3.2 FPGA Power Consumption **Table 3-2. FPGA Power Consumption Specification** | Component | MIN | NOM | MAX | UNIT | |------------------|-----|-----|-----|------| | 1.0 volt rail | | | 127 | mW | | 1.8 volt rail | | | 308 | mW | | 3.3 volt rail | | | 45 | mW | | FPGA total power | | 363 | 480 | mW | # 3.3 Host SPI Interface Timing Table 3-3. Host SPI Interface Timing | | Description | MIN | MAX | UNIT | |--------------------|------------------------------------------------------------------------------------|-----|-----|------| | f <sub>clock</sub> | Clock frequency, HOST CLK (50% reference points) | | 5 | MHz | | t <sub>su</sub> | Setup time – HOST MOSI valid before HOST CLK capture edge (50% reference points) | 0 | | ns | | t <sub>h</sub> | Hold time – HOST MOSI valid before HOST CLK capture edge (50% reference points) | 20 | | ns | | t <sub>out</sub> | Clock to data out – HOST MISO from HOST CLK transition edge (50% reference points) | 40 | 60 | ns | Figure 3-1. Host SPI Interface Timing Diagram Specifications Www.ti.com # 3.4 Power Supply and Reset Timing # 3.4.1 Power-Up Timing Table 3-4 specifies the configuration and initialization timing during FPGA start-up. After Host\_irq gets set high, the FPGA is configured and ready to receive commands on the SPI interface. However, the first commands will not be executed for an additional 10 ms. **Table 3-4. Power-up Timing Specifications** | | | MIN | NOM | MAX | UNIT | |-----------------------|-------------------------------------------------------------------------------------|-----|------|-----|------| | t <sub>init</sub> (2) | FPGA configuration initialization. 1.8V power to DONE rising edge | | 230 | | ms | | t <sub>oez</sub> | DONE rising edge to DMD RESET OEZ low | | 8.5 | | ms | | t <sub>irq</sub> (3) | RESET OEZ low to HOST IRQ high | | 1.15 | | ms | | t <sub>ramp</sub> (1) | Ramp time for each power supply: 1.0V, 1.8V, and 3.3V (GND to 90% reference points) | 0.2 | | 50 | ms | - (1) Value is based on FPGA documentation available at the time of writing. As primary source specification, see the device-specific FPGA data sheet. - (2) INITZ should be pulled up to 1.8V for shortest start-up time. If INITZ rising edge is delayed then the configuration will be delayed. - (3) HOST IRQ ready bit will indicate that the FPGA is ready for SPI communication from a host. This bit must be set in the interrupt enable mask in order for this condition to set HOST IRQ high at startup. The interrupt enable mask can be automatically configured on startup from the default configuration. Figure 3-2. Power-up Timing Diagram www.ti.com Specifications #### 3.4.2 Power-Down Timing **Table 3-5. Power-Down Timing Specifications** | | | 0 1 | | | | |-----------------------|-----------------------------------------------------------------------------------------------------------|-----|-----|-----|------| | | | MIN | NOM | MAX | UNIT | | t <sub>park</sub> | Time required for DMD to properly park <sup>(1)</sup> (2) | | | 500 | μs | | t <sub>debounce</sub> | Time required for input voltage to remain below brownout detection threshold before park sequence begins. | 100 | | | μs | - (1) DMD voltages (2.5V, 1.8V, 8.5V, 16V, -10V) must remain valid until parked on DLP3021-Q1 - (2) DMD voltages (1.8V, 8.5V, 16V, -10V) must remain valid until parked on DLP2021-Q1 Figure 3-3. Power-Down Timing Diagram Specifications TINSTRUMENTS www.ti.com #### 3.4.3 Brownout Detection The DLP3021-Q1 FPGA configuration includes a brownout detection function to alert and properly shut down the system when the input voltage begins to fall. FPGA pin F2 is configured as the brownout detect pin. This pin is configured as a digital input that will trigger a brownout interrupt on a high-to-low transition. The input voltage should be divided down as an input to this pin so that the nominal voltage to the pin will not exceed 1.8V. The brownout condition will occur when the input falls below a nominal voltage of 0.9V. Once the brownout condition is triggered and the input voltage remains below the brownout voltage threshold for a 100µs debounce period, the FPGA will automatically begin to park the DMD for proper power-down sequencing. After the brownout detection has parked the DMD, the system must be fully powered down before restarting, ensuring proper power-up sequencing upon restart. **Table 3-6. Brownout Detection Specifications** | | | MIN | NOM | MAX | UNIT | |-----------------------|----------------------------------------------------|--------|--------|--------------------|------| | V <sub>Brownout</sub> | Input voltage that triggers the brownout condition | 0.8(1) | 0.9(1) | 1.0 <sup>(1)</sup> | V | <sup>(1)</sup> Voltage valid for $V_{REF} = 0.9V$ . #### 3.5 DMD Interface Timing **Table 3-7. DMD Interface Timing Specifications** | | 14.0.0 0 11 2 11 2 11 40 11 40 1 | | | | | |---------------------|-----------------------------------------------------------------------------------------------------------------------|------|-----|-----|------| | | | MIN | NOM | MAX | UNIT | | f <sub>clock</sub> | Clock frequency, DCLK and SAC CLK | | 80 | 82 | MHz | | t <sub>wh</sub> | Pulse width high, DCLK and SAC CLK (50% reference points) | 5 | | | ns | | t <sub>wl</sub> | Pulse width low, DCLK and SAC CLK (50% reference points) | 5 | | | ns | | t <sub>t</sub> | Transition time, all signals (20% to 80% reference points) | 0.5 | | 2.5 | ns | | t <sub>su</sub> | Output setup time – D(14:0), SCTRL, LOADB and TRC relative to rising and falling edges of DCLK (50% reference points) | 1.5 | | | ns | | t <sub>h</sub> | Output hold time – D(14:0), SCTRL, LOADB and TRC relative to rising and falling edges of DCLK (50% reference points) | 1.5 | | | ns | | t <sub>clkdat</sub> | Clock to data output delay | -1.5 | | 1.5 | ns | | | | | | | | # 3.6 Flash Memory Interface Timing Table 3-8. Flash Memory Interface Timing | | | MIN | NOM | MAX | UNIT | |------------|------------------------------------|-----|-----|-----|------| | DLP2021-Q1 | f <sub>clock</sub> Clock frequency | | | 140 | MHz | | | Trace Delay | | | 100 | ps | | DLP3021-Q1 | f <sub>clock</sub> Clock frequency | | | 130 | MHz | | | Trace Delay | | | 100 | ps | #### 3.7 Reference Clock Timing This design utilizes MMCM blocks within the FPGA. **Table 3-9. Reference Clock Timing Specifications** | | | MIN | NOM | MAX | UNIT | |---------------------|-----------------------------------------------|----------------|-----|------|------| | f <sub>clock</sub> | Clock frequency, Osc Input | 39.5 | 40 | 40.5 | MHz | | t <sub>wh</sub> | Pulse duration, Osc Input high <sup>(1)</sup> | 25% of f_clock | | | | | t <sub>wl</sub> | Pulse duration, Osc Input low <sup>(1)</sup> | 25% of f_clock | | | | | t <sub>clkjit</sub> | Clock period jitter, Osc Input <sup>(1)</sup> | | | 50 | ps | <sup>(1)</sup> Values are based on FPGA documentation available at the time of writing. Refer to the FPGA data sheet as primary source for MMCM specifications. www.ti.com Specifications #### 3.8 I2C Interface Timing # Table 3-10. I<sup>2</sup>C Interface Timing<sup>(1)</sup> (2) | | Description | MIN | NOM | MAX | UNIT | |--------------------|-----------------|-----|-----|-----|------| | f <sub>clock</sub> | Clock frequency | | 51 | | kHz | <sup>(1)</sup> Meets all I2C timing as specified by the I2C bus specification. #### 4 Feature Descriptions #### 4.1 Video Control The FPGA is capable of reading video data from external flash memory and displaying it on the DMD. The video data must be converted and compressed by the DLP Composer tool before it is stored in flash memory. When the flash binary is generated, DLP Composer will specify the address locations of the video content within memory. There are two sets of registers for two video configurations. This allows a seamless transition between two videos if desired. More than two videos can also be displayed seamlessly, but intervention is required from a host controller during playback to do so. One configuration can be modified while the other configuration is playing. A configuration is latched in when the video configuration begins playing. Interrupt signals can be used to notify a host controller when one configuration completes so that its values can be modified to another desired video while the next configuration plays. During operation, the following registers can be used to configure the FPGA to display video content from flash memory: - Video Frame Rate - · Video Start Address 1 - Video Configuration 1 - Video Start Address 2 - Video Configuration 2 - Video Control - Video Status The steps to display video are: - Write Video Frame Rate Set frame rate to match the DMD sequence. - Write Start Address X Set start address of the desired video in flash. - Write Configuration X Set number of frames in the video, and number of times to loop the video. - (Optional) Write Start Address Y Set start address of the second desired video in flash. - (Optional) Write Configuration Y Set number of frames in the next video, and number of times to loop the video - Write Video Control Select playback options, and play video. #### 4.1.1 Video Options The Video Control register is used to set up which video configuration is used and how to transition between the two video configurations. **Table 4-1. Video Control Register Configuration** | LOOP<br>CONFIGURATIONS (BIT<br>4) | TOGGLE<br>CONFIGURATIONS (BIT<br>5) | CONFIGURATION<br>POINTER (BIT 3) | | |-----------------------------------|-------------------------------------|----------------------------------|-------------------------------------| | VIDEO CONTROL REGISTER | | | RESULT | | 0 | 0 | 0 | Play config 1 once | | 0 | 0 | 1 | Play config 2 once | | 0 | 1 | 0 | Play (config 1, then config 2) once | | 0 | 1 | 1 | Play (config 2, then config 1) once | | 1 | 0 | 0 | Repeat config 1 continuously | The I2C interface timing is only applicable to the DLP3021-Q1 because DLP2021-Q1 firmware does not support the I2C connection for the TMP411. Feature Descriptions www.ti.com Table 4-1. Video Control Register Configuration (continued) | LOOP<br>CONFIGURATIONS (BIT<br>4) | TOGGLE<br>CONFIGURATIONS (BIT<br>5) | CONFIGURATION<br>POINTER (BIT 3) | | |-----------------------------------|-------------------------------------|----------------------------------|-----------------------------------------------| | VIDEO CONTROL REGISTER | | | RESULT | | 1 | 0 | 1 | Repeat config 2 continuously | | 1 | 1 | 0 | Repeat (config 1, then config 2) continuously | | 1 | 1 | 1 | Repeat (config 2, then config 1) continuously | If "Loop configurations" = 0, the end action is determined by "Auto-stop" (bit 2). The Auto-stop bit allows you to either fully turn off the video (1), or freeze on the last image in the video (0). If "Loop configurations" = 1, there is no end action because the video or videos will loop until stopped by command. #### 4.1.2 Example 1: Display a Static Image The following steps can be used to display a single image on the DMD. - 1. Write Video Frame Rate register. - a. The clock count should match the length of the DMD sequence that is used. - 2. Write Video Start Address 1 register. - a. The start address should match the location of the image in flash memory. This can be found in the build log output from the DLP Composer tool. - 3. Write Video Configuration 1 register. - a. Frame count = 1 - b. Loop count = 1 - 4. Write Video Control register. - a. Loop configurations = 1 - b. Toggle configurations = 0 - c. Configuration pointer = 0 - d. Play = 1 - e. Stop = 0 This configuration will display the image forever, or until the "stop" bit is set. Since the "loop configurations" bit is set, it will continually execute this configuration each time it completes. #### 4.1.3 Example 2: Display 1 Video Repeatedly The following steps can be used to display a single video on the DMD repeatedly. - 1. Write Video Frame Rate register. - a. The clock count should match the length of the DMD sequence that is used. - 2. Write Video Start Address 1 register. - a. The start address should match the location of the video in Flash memory. This can be found in the build log output from the DLP Composer tool. - 3. Write Video Configuration 1 register. - a. Frame count = number of frames in the video - b. Loop count = 1 - 4. Write Video Control register. - a. Loop configurations = 1 - b. Toggle configurations = 0 - c. Configurations pointer = 0 - d. Play = 1 - e. Stop = 0 This configuration will play the video and then continue to repeat it until the "stop" bit is set. Since the "loop configurations" bit is set, it will continue to execute this configuration each time it completes. www.ti.com Feature Descriptions #### 4.1.4 Example 3: Display Two Videos Then Stop The following steps can be used to display two videos in a row and then stop displaying. - 1. Write Video Frame Rate register. - a. The clock count should match the length of the DMD sequence that is used. - 2. Write Video Start Address 1 register. - a. Start address should match the location of the video in flash memory. - 3. Write Video Configuration 1 register. - a. Frame count = number of frames in the video - b. Loop count = 1 - 4. Write Video Start Address 2 register. - a. The start address should match the location of the video in Flash memory. This can be found in the build log output from the DLP Composer tool. - 5. Write Video Configuration 2 register. - a. Frame count = number of frames in the video - b. Loop count = 1 - 6. Write Video Control register. - a. Loop configurations = 0 - b. Toggle configurations = 1 - c. Configurations pointer = 0 - d. Play = 1 - e. Stop = 0 - f. Auto-stop = 1 This configuration will begin with Configuration 1 due to "configuration pointer" = 0. It will play one loop of this video, and then toggle to Configuration 2. After one loop of this second video, the display will auto-stop. This means that light will turn off and no image will be displayed. # 4.1.5 Example 4: Display a Video Once and Then Display an Image Forever The following steps can be used to display a video followed by a static image: - 1. Write Video Frame Rate register. - a. The clock count should match the length of the DMD sequence that is used. - 2. Write Video Start Address 1 register. - a. The start address should match the location of the video in Flash memory. This can be found in the build log output from the DLP Composer tool. - 3. Write Video Configuration 1 register. - a. Frame count = number of frames in the video - b. Loop count = 1 - 4. 4. Write Video Start Address 2 register. - a. The tart address should match the location of the video in Flash memory. This can be found in the build log output from the DLP Composer tool. - 5. Write Video Configuration 2 register. - a. Frame count = 1 - b. Loop count = 1 - 6. Write Video Control register. - a. Loop configurations = 0 - b. Toggle configurations = 1 - c. Configurations pointer = 0 - d. Play = 1 - e. Stop = 0 - f. Auto-stop = 0 This configuration will begin with Configuration 1 due to "configuration pointer" = 0. It will play one loop of the desired video, and then toggle to Configuration 2. In this case, configuration 2 is set to one frame (image). Because auto-stop is set to 0, the display will repeat the last frame of Configuration 2 instead of stopping. Feature Descriptions www.ti.com Configuration 2 is set to one frame for the desired image, and therefore, this image is displayed repeatedly until commanded to stop. #### 4.1.6 Example 5: Display 3+ Videos/Images Seamlessly Displaying more than two videos without pause requires host intervention since there are only two sets of configuration registers. The HOST IRQ signal includes interrupt events that can help seamlessly transition to additional video content. - 1. Write FPGA Interrupt Enable register "Video configuration complete" bit. - Read FPGA Interrupt Set register and Write FPGA Interrupt Clear register. - a. Write 1 to the FPGA Interrupt Clear register to clear any active interrupts that can be holding the HOST IRQ signal high. - 3. Write Video Frame Rate register. - a. The clock count should match the length of the DMD sequence that is used. - 4. Write Video Start Address 1 register. - a. Start address should match the location of the first video in Flash memory. This can be found in the build log output from the DLP Composer tool. - 5. Write Video Configuration 1 register. - a. Frame count = number of frames in the video - b. Loop count = 1 - Write Video Start Address 2 register. - a. Start address should match the location of the second video in Flash memory. This can be found in the build log output from the DLP Composer tool. - 7. Write Video Configuration 2 register. - a. Frame count = number of frames in the video - b. Loop count = 1 - 8. Write Video Control register. - a. Loop configurations = 0 - b. Toggle configurations = 1 - c. Configurations pointer = 0 - d. Play = 1 - e. Stop = 0 - Auto-stop = 0 - 9. Wait for HOST IRQ signal to interrupt host MCU and read FPGA Interrupt Set register to confirm that "video configuration complete" is a source of the interrupt. - 10. Write Video Start Address 1 register. - a. Start address should match the location of the **third** video in flash memory - 11. Write Video Configuration 1 register. - a. Frame count = number of frames in the video - b. Loop count = 1 - 12. 12. Wait for HOST IRQ signal to interrupt host MCU and read FPGA Interrupt Set register to confirm that "video configuration complete" is a source of the interrupt. - 13. Write Video Control register. - a. Loop configurations = 0 - b. Toggle configurations = 1 - c. Configurations pointer = 0 - d. Play = 1 - e. Stop = 0 - f. Auto-stop = 0 ww.ti.com Feature Descriptions The first two videos are set up in Video Configuration 1 and 2. Then, the host MCU should wait until the "video configuration complete" interrupt triggers to indicate that the FPGA has swapped to displaying Configuration 2. After this occurs, the host MCU can modify Configuration 1 without affecting the displayed video content. It should then store the settings of the third video in Configuration 1 before video 2 completes. After video 2 completes, the FPGA will loop back to configuration 1, which should now be set up to display video 3. This process can be repeated for any desired number of videos or images. After HOST IRQ interrupts to switch to the final video configuration, the Video Control register can be set to auto-stop after completion. When this register is written, do not set the play bit. If the play bit is set at this time, the video configuration would restart at the specified configuration pointer on the next video frame instead of waiting for the current configuration to complete. #### **4.2 Temperature Measurements** The FPGA can optionally read temperature measurements from an external TMP411 temperature sensor connected through I2C. This allows reading the TMP411 local temperature and DMD remote temperature using a diode built into the DMD. The FPGA reads the two temperatures from the TMP411 at approximately 8Hz and stores the latest values in registers that can be read back by the host controller. The temperature values in the FPGA are returned in the TMP411 12-bit format. The eight MSbs are an integer portion. The four LSBs are the fractional portion, which should be divided by 16 and added to the integer portion. #### Note DLP2021-Q1 firmware does not support the I2C connection for the TMP411. This requires external MCU handler for TMP411 data. The FPGA firmware for DLP2021-Q1 never sees the temperature data, only the main host. #### 4.3 PWM Outputs The FPGA has three PWM outputs which typically correspond to red, green, and blue illumination colors. The PWM duty cycles can be adjusted to set a reference voltage to an external illumination driver circuit as needed to balance colors and adjust output brightness. A typical PWM circuit is shown in Figure 4-1. In this example, each PWM is low-pass filtered and the outputs connect to a 4:1 analog multiplexer. An optional resistor is shown in parallel with the capacitor for each filter to act as a voltage divider if needed to match the required illumination driver reference voltage range. The PWM output frequency is 40 kHz at maximum duty cycle. The PWM\_SELx signals can be used to select which output PWM is multiplexed to the illumination driver while the DMD sequence is executing. Table 4-2 describes the expected relationship between the PWM\_SELx outputs and the multiplexer output. | PWM_SEL0 | PWM_SEL1 | MULTIPLEXER OUTPUT | TYPICAL SEQUENCE COLOR | |----------|----------|--------------------|------------------------| | 0 | 0 | None | None | | 0 | 1 | PWM1 | Red | | 1 | 0 | PWM2 | Green | 1 PWM3 **Table 4-2. PWM Selection Configuration** 1 Blue Feature Descriptions www.ti.com Figure 4-1. Typical PWM Circuit #### 4.4 Host IRQ Interrupt Signal HOST IRQ is a level interrupt output from the FPGA. Multiple internal interrupt sources can trigger the external interrupt signal. If the signal is low, all of the enabled interrupt sources are cleared. If the signal is high, one of the sources is enabled and has been triggered. Three registers are used for handling the interrupt sources: - FPGA Interrupt Enable - **FPGA Interrupt Set** - **FPGA Interrupt Clear** FPGA Interrupt Enable is used to mask which interrupt sources will trigger the external HOST IRQ signal. For example, if the "video loop complete" enable bit is set to 1, then this source will set HOST IRQ high when triggered. If it is set to 0, then HOST IRQ will not be set high due to this source. FPGA Interrupt Set is used to read back the currently set interrupts. Once an internal interrupt source is set, it will remain set until it is cleared by writing to the FPGA Interrupt Clear register. FPGA Interrupt Clear is used to clear interrupt sources once handled. Typically, the FPGA Interrupt Set register can be directly written to the FPGA Interrupt Clear register in order to clear all currently active interrupts. Then, the host MCU can determine what action to take based on the interrupts that were set. HOST IRQ will remain high if multiple enabled interrupt sources trigger. #### 4.5 Video and Image Compression Videos and images stored in flash will be automatically compressed by the DLP Composer tool when the flash binary is built. These video frames and images will be formatted for display on the DLP3021-Q1 and compressed using a simplified run length encoding (RLE) for lossless compression. The maximum compression ratio is 16:1 for all black or all white images, but typical image compressibility is around 2:1 compression. The compression ratio will depend on the content, so the total number of images or length of video that can be stored will depend on the video content and size of the flash chip chosen. www.ti.com Layout Typical storage capabilities are listed in Table 4-3. Table 4-3. Typical Storage Capabilities for DLP3021-Q1 | FLASH SIZE | APPROX. NUMBER OF IMAGES / FRAMES <sup>(1)</sup> | VIDEO LENGTH (s) 25-Hz Video | |------------|--------------------------------------------------|------------------------------| | 512 Mb | 150 | 6 | | 1 Gb | 300 | 12 | | 2 Gb | 600 | 24 | <sup>(1)</sup> Number of frames stored in flash will depend on compressibility of video and image data. Actual number of frames will depend on individual content. Table 4-4. Typical Storage Capabilities for DLP2021-Q1 | FLASH SIZE | APPROX. NUMBER OF IMAGES / FRAMES <sup>(1)</sup> | VIDEO LENGTH (s) 25-Hz Video | |------------|--------------------------------------------------|------------------------------| | 512 Mb | 300 | 12 | | 1 Gb | 600 | 24 | | 2 Gb | 1200 | 48 | <sup>(1)</sup> Number of frames stored in flash will depend on compressibility of video and image data. Actual number of frames will depend on individual content. #### 5 Layout For new board designs, ensure proper trace length matching of the FPGA to flash memory interface and DMD interface. - · DMD clock and data - This consists of the signals between the FPGA and the DMD synchronous with DCLK, including D0-D14, LOADB, SCTRL, RESET\_STROBE, and TRC. The trace length matching requirement for these signals is ±50mils. - DAD\_BUS and SAC\_BUS are synchronous to SAC\_CLK. These signals should be matched within 20mm of each other but do not have matching requirements to the previous set of signals. - DMD\_TMS, DMD\_TDO, DMD\_TDI are synchronous to DMD\_TCK and should be matched within 20mm of each other but do not have matching requirements to the previous set of signals. - · Flash clock and data - This consists of the eight data signals, clock, chip select, and data strobe between the FPGA and the flash memory. The trace length matching requirement for these signals is ±15mm. For FPGA specific layout guidelines, see the Xilinx 7 Series FPGAs PCB Design Guide. #### **6 Host Command Protocol** # 6.1 SPI Specifications Table 6-1. SPI Specifications | PARAMETER | VALUE | |---------------------------------|--------------------------------------------------------------------------------| | Clock Frequency | 5 MHz | | Mode (Clock Phase and Polarity) | 0 (Data captured on rising edge, transitions on falling edge. Clock idle low.) | | Bit order | Most significant bit first within a byte | | Byte order | Least significant byte first | | Chip select polarity | Active low | Host Command Protocol www.ti.com # 6.2 SPI Write Command MOSI (master output, slave input): #### Table 6-2. SPI MOSI Write Command Information | DATA | DESCRIPTION | | | |----------|-----------------------------------------------------------------------------------------------------|--|--| | CMD | Command byte. 0 for write | | | | Address | 2-byte register address | | | | Data | 4-byte register data | | | | Checksum | Sum of all transmitted bytes including command, address, data. Discard overflow if sum exceeds 255. | | | MISO (Master input, slave output): #### **Table 6-3. SPI MISO Write Command Information** | | DATA | DESCRIPTION | | | | | | |-------------------------------|--------------------------------------------------------|------------------------------|--|--|--|--|--| | | CMD (ACK) Echo of the received command from the master | | | | | | | | | Address (ACK) | Echo of the received address | | | | | | | Data Echo of the received dat | | Echo of the received data | | | | | | | MOSI | CMD = 0 | Address (LSB) | Address (MSB) | Data (LSB) | Data | Data | Data (MSB) | Checksum | |------|---------|---------------|---------------|---------------|------------|------|------------|------------| | | | | | | | | | | | MISO | Dummy | CMD = 0 | Address (LSB) | Address (MSB) | Data (LSB) | Data | Data | Data (MSB) | Figure 6-1. SPI Write Command Format #### 6.3 SPI Read Command MOSI (Master output, slave input): #### **Table 6-4. SPI MOSI Read Command Information** | DATA | DESCRIPTION | | | |---------|--------------------------|--|--| | CMD | Command byte. 1 for read | | | | Address | 2-byte register address | | | MISO (Master input, slave output): #### Table 6-5. SPI MISO Read Command Information | iable of the interest i | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--|--|--| | DATA | DESCRIPTION | | | | | CMD (ACK) | Echo of the received command from the master | | | | | Address (ACK) | Echo of the received address | | | | | Data | Data from requested register | | | | | Checksum | Sum of command, address, and data bytes. Does not include dummy byte. | | | | Figure 6-2. SPI Read Command Format # **7 FPGA Register Definitions** This section defines the FPGA registers that can be accessed over SPI. Table 7-1 lists the memory-mapped registers for the device registers. All register offset addresses not listed in Table 7-1 should be considered as reserved locations and the register contents should not be modified. Table 7-1. FPGA SPI Registers | Address | Acronym | Register Name | Section | |---------|--------------------------------|------------------------------------------------------|---------| | 0x0 | FPGA_INTERRUPT_CLEAR | FPA Interrupt Clear | Go | | 0x4 | FPGA_INTERRUPT_SET | FPGA Interrupt set | Go | | 0x8 | FPGA_INTERRUPT_ENABLE | FPGA Interrupt enable | Go | | 0xC | FPGA_MAIN_STATUS | TI internal use. Read/Write behavior is not defined. | | | 0x10 | FPGA_VERSION | FPGA Version | Go | | 0x14 | FPGA_CONTROL | TI internal use. Read/Write behavior is not defined. | | | 0x20 | FMT_FLIP | Format flip | Go | | 0x24 | FMT_CONTROL | TI internal use. Read/Write behavior is not defined. | | | 0x28 | FMT_CMB_STATUS. | TI internal use. Read/Write behavior is not defined. | | | 0x2C | FMT_FRB_STATUS | TI internal use. Read/Write behavior is not defined. | | | 0x30 | RSC_SW_DMD_UNPARK | TI internal use. Read/Write behavior is not defined. | | | 0x34 | RSC_PARK_WAVEFORM_CTRL | TI internal use. Read/Write behavior is not defined. | | | 0x38 | RSC_UNUSED | TI internal use. Read/Write behavior is not defined. | | | 0x3C | RSC_MISC_CONTROL | TI internal use. Read/Write behavior is not defined. | | | 0x40 | RSC_SEQ_CONTROL | TI internal use. Read/Write behavior is not defined. | | | 0x44 | RSC_SEQBUF_SELECT | Sequence Buffer Select | Go | | 0x50 | PWM_CONTROL | PWM Control | Go | | 0x60 | VCM_FRAME_RATE | Frame Rate | Go | | 0x64 | VCM_START_ADDR1 | Video 1 start address | Go | | 0x68 | VCM_CONFIG1 | Video configuration 1 | Go | | 0x6C | VCM_START_ADDR2 | Video 2 start address | Go | | 0x70 | VCM_CONFIG2 | Video configuration 2 | Go | | 0x74 | VCM_CONTROL | Video control | Go | | 0x78 | VCM_STATUS | Video Status | Go | | 0x7C | VCM_SEQABORT | TI internal use. Read/Write behavior is not defined. | | | 0x80 | VCM_TMSEL | TI internal use. Read/Write behavior is not defined. | | | 0x90 | TMP_CTRL <sup>(1)</sup> | Temperature control | Go | | 0x94 | TMP_STATUS <sup>(1)</sup> | Temperature Status | Go | | 0x98 | TMP_REMOTE_TEMP <sup>(1)</sup> | Remote Temperature Measurement | Go | | 0x9C | TMP_LOCAL_TEMP <sup>(1)</sup> | Local Temperature Measurement | Go | | 0xDC | DESTOP_TIMEOUT_DEBUG_INFO_REG | TI internal use. Read/Write behavior is not defined. | | | 0xE0 | DESTOP_MBOX0_SAPTR_REG | TI internal use. Read/Write behavior is not defined. | | | 0xE4 | DESTOP_MBOX0_CTRL_REG | TI internal use. Read/Write behavior is not defined. | | | 0xF0 | DESTOP_MBOX0_DATA_REG | TI internal use. Read/Write behavior is not defined. | | | 0x100 | DESTOP_MBOX1_SAPTR_REG | TI internal use. Read/Write behavior is not defined. | | | 0x104 | DESTOP_MBOX1_CTRL_REG | TI internal use. Read/Write behavior is not defined. | | | 0x110 | DESTOP_MBOX1_DATA_REG | TI internal use. Read/Write behavior is not defined. | | <sup>(1)</sup> This register is not applicable to the DLP2021-Q1. FPGA Register Definitions www.ti.com Table 7-2. Device Access Type Codes Complex bit access types are encoded to fit into small table cells. Section 7 shows the codes that are used for | ACCESS TYPE | CODE | DESCRIPTION | | | | | |------------------------|-----------|----------------------------------------|--|--|--|--| | Read Type | Read Type | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | W | W | Write | | | | | | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | #### 7.1 FPGA\_INTERRUPT\_CLEAR Register (Address = 0x0) [reset = 0x0] FPGA\_INTERRUPT\_CLEAR is shown in Section 7. Return to Summary Table. access types in this section. Write 1 to any bit to clear the interrupt event. Table 7-3, FPGA INTERRUPT CLEAR Register Field Descriptions | | 14510 1 0111 071_11 | | 1 1_0LLAR Register Field Descriptions | | | |------|---------------------|------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | BIT | FIELD | TYPE | RESET | DESCRIPTION | | | 31-5 | RESERVED | R | 0x0 | Reserved | | | 4 | VID_CONFIG_COMP_IRQ | R/W | 0x0 | Video configuration completed including all requested loops. This triggers once after all loops of a video complete. If both video configurations are requested to be used, it will trigger after each configuration completes. | | | 3 | VID_LOOP_COMP_IRQ | R/W | 0x0 | Video loop completed. If multiple loops of a video are requested, this interrupt triggers after each completed loop. | | | 2 | BROWNOUT_IRQ | R/W | 0x0 | Brownout detected | | | 1 | INIT_DONE_IRQ | R/W | 0x0 | Initialization done | | | 0 | RESERVED | R | 0x0 | Reserved | | # 7.2 FPGA\_INTERRUPT\_SET Register (Address = 0x4) [reset = 0x0] FPGA\_INTERRUPT\_SET is shown in Table 7-4. Return to Summary Table. Read the status of interrupt events. Table 7-4. FPGA\_INTERRUPT\_SET Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|---------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R | 0x0 | Reserved | | 4 | VID_CONFIG_COMP_IRQ | R/W | 0x0 | Video configuration completed including all requested loops. This triggers once after all loops of a video complete. If both video configurations are requested to be used, it will trigger after each configuration completes. | | 3 | VID_LOOP_COMP_IRQ | R/W | 0x0 | Video loop completed. If multiple loops of a video are requested, this interrupt triggers after each completed loop. | | 2 | BROWNOUT_IRQ | R/W | 0x0 | Brownout detected | | 1 | INIT_DONE_IRQ | R/W | 0x0 | Initialization done | | 0 | RESERVED | R | 0x0 | Reserved | # 7.3 FPGA\_INTERRUPT\_ENABLE Register (Address = 0x8) [reset = 0x0] FPGA\_INTERRUPT\_ENABLE is shown in Table 7-5. Return to Summary Table. Interrupt event mask. Write 1 to any bit to enable that interrupt event to set HOST IRQ high. Table 7-5. FPGA\_INTERRUPT\_ENABLE Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|---------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R | 0x0 | Reserved | | 4 | VID_CONFIG_COMP_IRQ | R/W | 0x0 | Video configuration completed including all requested loops. This triggers once after all loops of a video complete. If both video configurations are requested to be used, it will trigger after each configuration completes. | | 3 | VID_LOOP_COMP_IRQ | R/W | 0x0 | Video loop completed. If multiple loops of a video are requested, this interrupt triggers after each completed loop. | | 2 | BROWNOUT_IRQ | R/W | 0x0 | Brownout detected | | 1 | INIT_DONE_IRQ | R/W | 0x0 | Initialization done | | 0 | RESERVED | R | 0x0 | Reserved | #### 7.4 FPGA\_VERSION Register (Address = 0x10) [reset = 0x10000000] FPGA\_VERSION is shown in FPGA\_VERSION Register Field Descriptions. Return to Summary Table. **FPGA Bitstream Version** Table 7-6. FPGA\_VERSION Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |-------|--------------------|------|-------|---------------------------------------------------------------------------------------------------------------| | 31-28 | FPGA_BUILD_LEVEL | R | 0x1 | FPGA bitsream build level 0x0 = Debug release, not reproducible 0x1+ = Versioned release, can be reproduced | | 27-20 | FPGA_VERSION_MINOR | R | 0x0 | FPGA Bitsream Minor Revision | | 19-12 | FPGA_VERSION_MAJOR | R | 0x0 | FPGA Bitsream Major Revision | | 11-0 | FPGA_BUILD_NUMBER | R | 0x0 | FPGA Bitstream build number | #### 7.5 FMT\_FLIP Register (Address = 0x20) [reset = 0x0] FMT\_FLIP is shown in FMT\_FLIP Register Field Descriptions. Return to Summary Table. DMD Flip control register Table 7-7. FMT FLIP Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|------------------|------|-------|-------------------------------------------------------------------------------------------| | 31-5 | RESERVED | R | 0x0 | Reserved | | 4 | FMT_CTL_DMDLFLIP | R/W | 0x0 | DMD Long Side Flip 0x0 = no long side flip 0x1 = Enable Image flip along DMD long side | | 3-1 | RESERVED | R | 0x0 | Reserved | | 0 | FMT_CTL_DMDSFLIP | R/W | 0x0 | DMD Short Side Flip 0x0 = no short side flip 0x1 = Enable Image flip along DMD short side | #### 7.6 RSC\_SEQBUF\_SELECT Register (Address = 0x44) [reset = 0x0] RSC\_SEQBUF\_SELECT is shown in RSC\_SEQBUF\_SELECT Register Field Descriptions. Return to Summary Table. Sequence Buffer Select Table 7-8. RSC\_SEQBUF\_SELECT Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|-------------------|------|-------|----------------------------------------------------------------------------------------------| | 31-1 | RESERVED | R | 0x0 | Reserved | | 0 | RSC_SEQBUF_SELECT | R/W | 0x0 | Sequence Buffer Select<br>0x0 = Select sequencer buffer 0<br>0x1 = Select sequencer buffer 1 | #### 7.7 PWM\_CONTROL Register (Address = 0x50) [reset = 0x46419064] PWM\_CONTROL is shown in PWM\_CONTROL Register Field Descriptions. Return to Summary Table. **PWM Control Register** Table 7-9. PWM\_CONTROL Register Field Descriptions | | | _ | _ | • • • • • • • • • • • • • • • • • • • | |-------|-------------|------|-------|---------------------------------------| | BIT | FIELD | TYPE | RESET | DESCRIPTION | | 31 | RESERVED | R | 0x0 | Reserved | | 30 | PWM_EN | R/W | 0x1 | PWM Enable | | 29-20 | PWM_BPWM_DC | R/W | 0x64 | Blue PWM Duty Cycle | | 19-10 | PWM_GPWM_DC | R/W | 0x64 | Green PWM Duty Cycle | | 9-0 | PWM_RPWM_DC | R/W | 0x64 | Red PWM Duty Cycle | #### 7.8 VCM\_FRAME\_RATE Register (Address = 0x60) [reset = 0x00186A00] VCM\_FRAME\_RATE is shown in VCM\_FRAME\_RATE Register Field Descriptions. Return to Summary Table. Frame Rate Selection Table 7-10. VCM\_FRAME\_RATE Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |-------|----------------|------|-------|----------------------------------------------------------------------------------------------------------| | 31-24 | RESERVED | R | 0x0 | Reserved | | 23-0 | VCM_FRAME_RATE | R/W | 0 | Video frame time in 40-MHz clock counts. Value should match sequence time 25 Hz = 1600000 60 Hz = 666666 | #### 7.9 VCM\_START\_ADDR1 Register (Address = 0x64) [reset = 0x0] VCM START ADDR1 is shown in Table 7-11. Return to Summary Table. Video 1 start address Table 7-11. VCM\_START\_ADDR1 Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|-------------|------|-------|--------------------------------| | 31-0 | START_ADDR1 | R/W | 0x0 | Video 1 start address in flash | # 7.10 VCM\_CONFIG1 Register (Address = 0x68) [reset = 0x1001] VCM\_CONFIG1 is shown in Table 7-12. Return to Summary Table. Video configuration 1 Table 7-12. VCM\_CONFIG1 Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |-------|------------|------|-------|-------------------------------------------------------------------------| | 31-24 | RESERVED | R | 0x0 | Reserved | | 23-12 | LOOP_CNT1 | R/W | 0x1 | Number of times to loop video 1 0x0 = invalid 0x1 = 1 loop 0x2 = 2 loop | | 11-0 | FRAME_CNT1 | R/W | 0x1 | Number of frames in video 1 0x0 = invalid 0x1 = 1 frame 0x2 = 2 frames | # 7.11 VCM\_START\_ADDR2 Register (Address = 0x6C) [reset = 0x0] VCM\_START\_ADDR2 is shown in Table 7-13. Return to Summary Table. Video 2 start address Table 7-13. VCM\_START\_ADDR2 Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|-------------|------|-------|--------------------------------| | 31-0 | START_ADDR2 | R/W | 0x0 | Video 2 start address in flash | # 7.12 VCM\_CONFIG2 Register (Address = 0x70) [reset = 0x1001] VCM\_CONFIG2 is shown in Table 7-14. Return to Summary Table. Video configuration 2 Table 7-14. VCM\_CONFIG2 Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |-------|------------|------|-------|-------------------------------------------------------------------------| | 31-24 | RESERVED | R | 0x0 | Reserved | | 23-12 | LOOP_CNT2 | R/W | 0x1 | Number of times to loop video 2 0x0 = invalid 0x1 = 1 loop 0x2 = 2 loop | | 11-0 | FRAME_CNT2 | R/W | 0x1 | Number of frames in video 2 0x0 = invalid 0x1 = 1 frame 0x2 = 2 frames | # 7.13 VCM\_CONTROL Register (Address = 0x74) [reset = 0x10] VCM\_CONTROL is shown in Table 7-15. Return to Summary Table. Table 7-15. VCM\_CONTROL Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|--------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 31-6 | RESERVED | R | 0x0 | Reserved | | 5 | VCM_TOGGLE_CONFIGS | R/W | 0x0 | Video buffer toggle selection 0x0 = Playback will only use the selected buffer 0x1 = Playback will use both buffers | | 4 | VCM_LOOP_CONFIGS | R/W | 0x1 | Loop configuration 0x1 = Repeat configuration | | 3 | VCM_BUF_PTR | R/W | 0x0 | Video Configuration pointer 0x0 = Play Video 1 0x1 = Play Video 2 | | 2 | VCM_AUTOSTOP | R/W | 0x0 | Auto-stop after playback 0x0 = Repeat last frame of video playback until commanded otherwise 0x1 = Stop and park the DMD after video(s) complete | | 1 | VCM_STOP | R/W | 0x0 | Stop Video / Park DMD 0x0 = Allow Video Play 0x1 = Stop video playback and park DMD. Must be set to 0 to play video | | 0 | VCM_PLAY | R/W | 0x0 | Play video. Self-clearing | # 7.14 VCM\_STATUS Register (Address = 0x78) [reset = 0x0] VCM\_STATUS is shown in Table 7-16. Return to Summary Table. Video Status Register Table 7-16. VCM\_STATUS Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|---------------------|------|-------|-------------------------------------------| | 31-3 | RESERVED | R | 0x0 | Reserved | | 2 | VCM_SEQABORT_ERR | R | 0x0 | Sequence abort error Clears on video play | | 1 | VCM_CURR_CONFIG_PTR | R | 0x0 | Current video configuration pointer | | 0 | VCM_VID_IN_PROGRESS | R | 0x0 | Video in progress when set | # 7.15 TMP\_CTRL Register (Address = 0x90) [reset = 0x00010003] TMP\_CTRL is shown in Table 7-17. Return to Summary Table. Temperature control register Table 7-17. TMP\_CTRL Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |-------|---------------|------|-------|--------------------------------------------------------------------------------| | 31-17 | RESERVED | R | 0x0 | Reserved | | 16 | TMP_CTRLEN | R/W | 0x1 | Temperature function enable 0x0 = Disable 0x1 = Enable | | 15-8 | TMP_I2CSLADDR | R/W | 0x0 | TMP411 I2C slave address (for details, see TMP411 data sheet) | | 7-0 | TMP_NFACTOR | R/W | 0x3 | N factor to compensate TMP411 measurement (for details, see TMP411 data sheet) | #### 7.16 TMP\_STATUS Register (Address = 0x94) [reset = 0x0] TMP\_STATUS is shown in Table 7-18. Return to Summary Table. Temperature Status Register Table 7-18. TMP\_STATUS Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |------|-----------|------|-------|-----------------------------------------------------------------------------------------------------------------| | 31-2 | RESERVED | R | 0x0 | Reserved | | 1 | TMP_VALID | R | 0x0 | Temperature Status Valid 0x0 = I2C temperature read failed or not yet completed 0x1 = I2C temp read succeeded | | 0 | TMP_PASS | R | 0x0 | Temperature Status Pass 0x0 = Select sequencer buffer 0 0x1 = Select sequencer buffer 1 | #### 7.17 TMP\_REMOTE\_TEMP Register (Address = 0x98) [reset = 0x0] TMP\_REMOTE\_TEMP is shown in Table 7-19. Return to Summary Table. **DMD Temperature Measurement** Table 7-19. TMP\_REMOTE\_TEMP Register Field Descriptions | | | _ | _ | | |-------|---------------------|------|-------|------------------------------------------------| | BIT | FIELD | TYPE | RESET | DESCRIPTION | | 31-28 | RESERVED | R | 0x0 | Reserved | | 27-16 | TMP_REMOTE_FILTERED | R | 0x0 | TMP411 Remote temperature filtered measurement | | | | | | DMD temperature measurement after filtering | | 15-12 | RESERVED | R | 0x0 | Reserved | | 11-0 | TMP_REMOTE_RAW | R | 0x0 | TMP411 Remote temperature raw measurement | | | | | | Single DMD temperature measurement | Revision History www.ti.com # 7.18 TMP\_LOCAL\_TEMP Register (Address = 0x9C) [reset = 0x0] TMP\_LOCAL\_TEMP is shown in Table 7-20. Return to Summary Table. TMP411 Temperature Measurement # Table 7-20. TMP\_LOCAL\_TEMP Register Field Descriptions | BIT | FIELD | TYPE | RESET | DESCRIPTION | |-------|--------------------|------|-------|----------------------------------------------------------------------------------------------| | 31-28 | RESERVED | R | 0x0 | Reserved | | 27-16 | TMP_LOCAL_FILTERED | R | 0x0 | TMP411 Local temperature filtered measurement TMP411 temperature measurement after filtering | | 15-12 | RESERVED | R | 0x0 | Reserved | | 11-0 | TMP_LOCAL_RAW | R | 0x0 | TMP411 Local temperature raw measurement Single temperature measurement | # 8 Revision History NOTE: Page numbers for previous revisions may differ from page numbers in the current version. #### Changes from Revision A (April 2024) to Revision B (June 2024) Page # IMPORTANT NOTICE AND DISCLAIMER TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATA SHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS. These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements. These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources. TI's products are provided subject to TI's Terms of Sale or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products. TI objects to and rejects any additional or different terms you may have proposed. Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2024, Texas Instruments Incorporated