# **TE0782 CPLD** ## Table of contents OVERVIEW o 1.1 Firmware Revision and supported PCB Revision • 2 Product Specification • 2 Product Specification 2.1 Port Description Firmware for PCB-CFU-Withards-signator U14. CPLD Device in Chain: LCMX02-1200HC • 2.2.1 JTAG • 2.2.2 Power • 2.2.3 Root Mode 2.2.3 Boot Mode Power Management Reset Management University UART Root Mode Boot Mode ■ 2.2.6 LED • LED 2.2.7 I2C Interface • 3 ACOX. A: Change History and Legal Notices • UAR 3.1 Revision Changes • 3.1 Revision Charges • 3.2 Document Change History • 3.3 Legal Notices Firmware4 Revision and supported PCB Revision • 3.5 Document Windows See Document Warranty See Document & Rahimitation of Liability 3.7 Copyright Notice 3.8 Technology Licenses 3.9 Environmental Protection Product 3 Decification WEEE ## **Port Description** | Name / opt.<br>VHD Name | Direction | Pin | Pullup/Down | Bank Voltage | Description | |-------------------------|-----------|-----|-------------|--------------|------------------------------------------------------------------| | BM0/MIO5 | out | 47 | None | LVCMOS33 | Boot Mode Pin | | BM2/MIO4 | out | 48 | None | LVCMOS33 | Boot Mode Pin | | BM3/MIO2 | out | 49 | None | LVCMOS33 | Boot Mode Pin | | BOOTMODE | in | 99 | UP | LVCMOS33 | Boot Mode Pin<br>from B2B / Used<br>for UART as input<br>to MIO9 | | CONFIGX | out | 98 | UP | LVCMOS33 | MIO8 to B2B /<br>Used for UART as<br>output from MIO8 | | CPLD_GPIO0 | | 12 | - | - | / currently_not_used | | CPLD_GPIO1 | | 11 | - | - | / currently_not_used | | CPLD_GPIO2 | | 10 | - | - | / currently_not_used | | CPLD_GPIO3 | | 9 | - | - | / currently_not_used | | CPLD_GPIO4 | | 8 | - | - | / currently_not_used | | CPLD_GPIO5 | | 7 | - | - | / currently_not_used | | CPLD_IO | | 54 | - | - | / currently_not_used | | DONE | in | 34 | UP | LVCMOS33 | FPGA Done Pin | | EN_1.0V_MGT /<br>EN_1V0_MGT | out | 20 | None | LVCMOS33 | Power control | |-----------------------------|-------|----|------|----------|--------------------------------------------------------------| | EN_1.2V_MGT /<br>EN_1V2_MGT | out | 18 | None | LVCMOS33 | Power control | | EN_1.8V | out | 16 | None | LVCMOS33 | Power control | | EN_1V | out | 21 | None | LVCMOS33 | Power control | | EN_3.3V | out | 15 | None | LVCMOS33 | Power control | | ETH1_RESET | out | 53 | None | LVCMOS18 | ETH Reset | | ETH1_RESET33 | in | 43 | UP | LVCMOS33 | ETH Reset from MIO7 | | I2C_SCL | in | 58 | None | LVCMOS18 | I2C CLK / I2C CLK<br>connected to<br>module I2C<br>interface | | I2C_SDA | inout | 57 | None | LVCMOS18 | I2C DATA/ I2C<br>SDA connected to<br>module I2C<br>interface | | INIT | | 36 | - | - | / currently_not_used | | JTAGENB | in | 82 | None | LVCMOS33 | Is used here to set<br>bootmode JTAG<br>(low) or QSPI(high) | | LED1 / GLED | out | 4 | None | LVCMOS33 | green LED D2 | | LED2 / RLED | out | 3 | None | LVCMOS33 | red LED D1 | | M_TCK | in | 91 | None | LVCMOS33 | CPLD JTAG B2B | | M_TDI | in | 94 | None | LVCMOS33 | CPLD JTAG B2B | | M_TDO | out | 95 | None | LVCMOS33 | CPLD JTAG B2B | | M_TMS | in | 90 | None | LVCMOS33 | CPLD JTAG B2B | | MIO8 | in | 38 | UP | LVCMOS33 | used UART RS activity | | MIO9 | out | 39 | None | LVCMOS33 | User IO,<br>connected to<br>BOOTMODE Pin<br>on B2B | | MMC_RST | out | 40 | None | LVCMOS33 | eMMC Reset | | N.C. / dummy | | 1 | - | - | / currently_not_used | | N.C. | | 2 | - | - | / currently_not_used | | N.C. | | 27 | - | - | / currently_not_used | | N.C. | | 28 | - | - | / currently_not_used | | N.C. | | 29 | - | - | / currently_not_used | | N.C. | | 30 | - | - | / currently_not_used | | N.C. | | 32 | - | - | / currently_not_used | | N.C. | | 41 | - | - | / currently_not_used | | N.C. | | 42 | - | - | / currently_not_used | | N.C. | | 59 | - | - | / currently_not_used | | N.C. | | 60 | - | - | / currently_not_used | | N.C. | | 61 | - | - | / currently_not_used | | N.C. | | 62 | - | - | / currently_not_used | |-------------|-----|----|------|----------|------------------------------| | N.C. | | 63 | - | - | / currently_not_used | | N.C. | | 64 | - | - | / currently_not_used | | N.C. | | 65 | - | - | / currently_not_used | | N.C. | | 66 | - | - | / currently_not_used | | N.C. | | 67 | - | - | / currently_not_used | | N.C. | | 68 | - | - | / currently_not_used | | N.C. | | 69 | - | - | / currently_not_used | | N.C. | | 70 | - | - | / currently_not_used | | N.C. | | 71 | - | - | / currently_not_used | | N.C. | | 74 | - | - | / currently_not_used | | N.C. | | 75 | - | - | / currently_not_used | | N.C. | | 76 | - | - | / currently_not_used | | N.C. | | 77 | - | - | / currently_not_used | | N.C. | | 78 | - | - | / currently_not_used | | N.C. | | 81 | - | - | / currently_not_used | | N.C. | | 83 | - | - | / currently_not_used | | N.C. | | 84 | - | - | / currently_not_used | | N.C. | | 85 | - | - | / currently_not_used | | N.C. | | 86 | - | - | / currently_not_used | | N.C. | | 87 | - | - | / currently_not_used | | N.C. | | 88 | - | - | / currently_not_used | | N.C. | | 89 | - | - | / currently_not_used | | N.C. | | 96 | - | - | / currently_not_used | | OTG-RST | out | 52 | UP | LVCMOS18 | OTG Rest | | OTG-RST33 | in | 45 | UP | LVCMOS33 | OTG Reset from MIO0 | | PG_1.0V_MGT | in | 19 | UP | LVCMOS33 | Power control | | PG_1.2V_MGT | in | 17 | UP | LVCMOS33 | Power control | | PG_1.8V | in | 14 | UP | LVCMOS33 | Power control | | PG_1V | in | 25 | UP | LVCMOS33 | Power control | | PG_1V5 | in | 24 | UP | LVCMOS33 | Power control | | PG_3.3V | in | 13 | UP | LVCMOS33 | Power control | | PROG_B | | 35 | None | - | / currently_not_used | | PS_POR | out | 37 | None | LVCMOS33 | PS_POR_B<br>(Power On Reset) | | PS_SRST | out | 51 | None | LVCMOS18 | PS_SRST_B (PS<br>Reset) | | RESIN | in | 97 | UP | LVCMOS33 | Reset from B2B | | RTC_INT | | 31 | - | - | / currently_not_used | | | | | | | | ## **Functional Description** #### **JTAG** Used only for Firmware Update. Zynq has dedicated JTAG connection. #### **Power** Power enables (EN\_1V, EN\_1V8, EN\_3V3, EN\_1V2\_MGT, EN\_1V0\_MGT) are all enabled sequentially. EN\_1V EN\_1V8 EN\_3V3 EN\_1V0\_MGT EN\_1V2\_MGT Power goods (PG\_1V, PG\_1V5, PG\_1V8, PG\_3V3, PG\_1V2\_MGT, PG\_1V0\_MGT) are used for System Reset and LED Monitoring. #### **Boot Mode** JTAG or QSPI. Bootmode is read through JTAGEN signal (can be set by DIP switch on carrier). Can also be changed through software I2C after linux has bootet. (command: i2cset -y 0 0x20 0x03 <0x02 or 0x00>) ### **Reset** PS\_POR is triggered by soft\_resetn when bootmode is changed by software (I2C interface) or main power failed PS\_SRST is triggered when user reset pressed (RESIN) or main power failed. ETH1\_RESET is triggered when ETH1\_RESET33(e.g. by fsbl) or main power failed. OTG\_RST is triggered when ETH1\_OTG\_RST33(e.g. by fsbl) or main power failed. MMC\_RST is triggered when main power failed. (i) main power failed main power failed - is triggered when at least one of the Power Good signals of the DCDCs goes down. #### **UART** MIO8 is connected to CONFIGX. UART TX from FPGA to RX XMOD. BOOTMODE is connected to MIO9. UART RX. #### **LED** #### Red LED D1 | Blink sequence | Priority | Condition | Description | |----------------|----------|-----------|-------------| |----------------|----------|-----------|-------------| | THE RESERVE OF THE PARTY | highest | RESIN = LOW (low active) | external reset "RESIN" is pressed | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------| | *******O | | | blink sequence not used | | ******00 | | | blink sequence not used | | *****000 | | PG_1V or PG_1V5 or<br>PG_1V8 or PG_3V3 is zero | One of the Power Good<br>Signals of internal Voltages<br>DCDCs LOW | | ****0000 | | | blink sequence not used | | ***00000 | | | blink sequence not used | | **000000 | | PG_1V2_MGT or<br>PG_1V0_MGT is zero | One of the Power Good<br>Signals of MGT Voltages<br>DCDCs LOW | | *000000 | GND UIN | DONE = '0' | FPGA not programmed,<br>wrong Bootmode? Check<br>JTAGEN signal.<br>No design on QSPI Flash? | | continuously ON | lowest | software controlled command: i2cset -y 0 0x20 0x05 <0x00 or 0x01> | If none of the above condition is met | | Blink sequence | Priority | Condition | Description | |----------------|----------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | ******* | highest | PG_1V or PG_1V5 or<br>PG_1V8 or PG_3V3 or<br>PG_1V2_MGT or<br>PG_1V0_MGT is zero | Power Good Signal of DCDCs deassertion occurred after power up. Look at content of power good register i2cget -y 0 0x20 0x02 | | ******O | | | blink sequence not used | | ******00 | | | blink sequence not used | | *****000 | | | blink sequence not used | | ****0000 | | | blink sequence not used | | ***00000 | | bootmode was changed via I2C. | command: i2cset -y 0 0x20<br>0x03 <0x02 or 0x00> | | **000000 | | | blink sequence not used | | *0000000 | | | blink sequence not used | | UART activity | lowest | LED = MIO8 | If none of the above condition is met | #### **I2C Interface** This subsystem provides 2 x 32-bit (8 x 8-bit) of general purpose parallel input and output (I/O) expansion for the I2C bus protocol. Address of this module is 0x20. This module contains eight 8-bit registers for reading and writing (GPIO\_register\_1[7:0] to GPIO\_register\_1[31:24] and GPIO\_register\_2[7:0] to GPIO\_register\_2[31:24]) separately with address 0x00 to 0x07. These registers can be accessed with I2C commands in linux console or with i2c functions in FSBL code. To access these registers the following commands in linux console can be used: ``` To see the i2c bus addresses: i2cdetect -y - r 0 To read register of i2c to GPIO module: 0x20 <register address> i2cget -y 0 i2cget -y 0 i2cset -y 0 ox20 <register address> <data> ``` All eight registers can be read, but only two of them can be written from the linux console. | I2C Register | permissions | address | function | I2C command | |-----------------------------|-------------|---------|------------------------------------------------------------------|--------------------------------| | GPIO_register_1(7 downto 0) | readable | 0x00 | contains the CPLD<br>Firmware Revision (not<br>the PCB revision) | read: i2cget -y 0 0x20<br>0x00 | | GPIO_register_1(15 downto 8) | readable | 0x01 | contains the bootmode in bit 8 and bit 9. This register is read by the fsbl and printed in the console as the bootmode during power up | | |-------------------------------|--------------------|------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | GPIO_register_1(23 downto 16) | readable | 0x02 | Bit 17 to 23 contain the<br>DCDC power good<br>signals and the DONE<br>pin | | | GPIO_register_1(31 downto 24) | readable/writeable | 0x03 | Bit 24 and 25 contain<br>the bootmode, JTAG(b<br>00) or QSPI(b 10) | write: i2cset -y 0 0x20<br>0x03 <0x02 or 0x00> | | GPIO_register_2(7 downto 0) | readable | 0x04 | Bit 0 to 3 show the state of the reset signals PS_POR, PS_SRST, ETH1_RESET, OTG_RST | | | GPIO_register_2(15 downto 8) | readable/writeable | 0x05 | Bit 8 can be controlled<br>to change the state of<br>the red LED D1 if no<br>other red LED<br>condition is met | write: i2cset -y 0 0x20<br>0x05 <0x00 or 0x01> | | GPIO_register_2(23 downto 16) | readable | 0x06 | not used | | | GPIO_register_2(31 downto 24) | readable | 0x07 | not used | | # Appx. A: Change History and Legal Notices # **Revision Changes** # **Document Change History** To get content of older revision got to "Change History" of this page and select older document revision number. | | Document CPLD Revision Firmware Revision | | Supported<br>PCB Revision | Authors | Description | Firmware<br>release | |--|------------------------------------------|--|---------------------------|---------|-------------|---------------------| |--|------------------------------------------|--|---------------------------|---------|-------------|---------------------| # **Legal Notices** # **Data Privacy** Please also note our data protection declaration at https://www.trenz-electronic.de/en/Data-protection-Privacy # **Document Warranty** The material contained in this document is provided "as is" and is subject to being changed at any time without notice. Trenz Electronic does not warrant the accuracy and completeness of the materials in this document. Further, to the maximum extent permitted by applicable law, Trenz Electronic disclaims all warranties, either express or implied, with regard to this document and any information contained herein, including but not limited to the implied warranties of merchantability, fitness for a particular purpose or non infringement of intellectual property. Trenz Electronic shall not be liable for errors or for incidental or consequential damages in connection with the furnishing, use, or performance of this document or of any information contained herein. ### **Limitation of Liability** In no event will Trenz Electronic, its suppliers, or other third parties mentioned in this document be liable for any damages whatsoever (including, without limitation, those resulting from lost profits, lost data or business interruption) arising out of the use, inability to use, or the results of use of this document, any documents linked to this document, or the materials or information contained at any or all such documents. If your use of the materials or information from this document results in the need for servicing, repair or correction of equipment or data, you assume all costs thereof. ### **Copyright Notice** No part of this manual may be reproduced in any form or by any means (including electronic storage and retrieval or translation into a foreign language) without prior agreement and written consent from Trenz Electronic. ### **Technology Licenses** The hardware / firmware / software described in this document are furnished under a license and may be used /modified / copied only in accordance with the terms of such license. #### **Environmental Protection** To confront directly with the responsibility toward the environment, the global community and eventually also oneself. Such a resolution should be integral part not only of everybody's life. Also enterprises shall be conscious of their social responsibility and contribute to the preservation of our common living space. That is why Trenz Electronic invests in the protection of our Environment. ## **REACH, RoHS and WEEE** #### **REACH** Trenz Electronic is a manufacturer and a distributor of electronic products. It is therefore a so called downstream user in the sense of REACH. The products we supply to you are solely non-chemical products (goods). Moreover and under normal and reasonably foreseeable circumstances of application, the goods supplied to you shall not release any substance. For that, Trenz Electronic is obliged to neither register nor to provide safety data sheet. According to present knowledge and to best of our knowledge, no SVHC (Substances of Very High Concern) on the Candidate List are contained in our products. Furthermore, we will immediately and unsolicited inform our customers in compliance with REACH - Article 33 if any substance present in our goods (above a concentration of 0,1 % weight by weight) will be classified as SVHC by the European Chemicals Agency (ECHA). #### **RoHS** Trenz Electronic GmbH herewith declares that all its products are developed, manufactured and distributed RoHS compliant. #### WEEE Information for users within the European Union in accordance with Directive 2002/96/EC of the European Parliament and of the Council of 27 January 2003 on waste electrical and electronic equipment (WEEE). Users of electrical and electronic equipment in private households are required not to dispose of waste electrical and electronic equipment as unsorted municipal waste and to collect such waste electrical and electronic equipment separately. By the 13 August 2005, Member States shall have ensured that systems are set up allowing final holders and distributors to return waste electrical and electronic equipment at least free of charge. Member States shall ensure the availability and accessibility of the necessary collection facilities. Separate collection is the precondition to ensure specific treatment and recycling of waste electrical and electronic equipment and is necessary to achieve the chosen level of protection of human health and the environment in the European Union. Consumers have to actively contribute to the success of such collection and the return of waste electrical and electronic equipment. Presence of hazardous substances in electrical and electronic equipment results in potential effects on the environment and human health. The symbol consisting of the crossed-out wheeled bin indicates separate collection for waste electrical and electronic equipment. Trenz Electronic is registered under WEEE-Reg.-Nr. DE97922676. #### Error rendering macro 'page-info' Ambiguous method overloading for method jdk.proxy279.\$Proxy4022#hasContentLevelPermission. Cannot resolve which method to invoke for [null, class java.lang.String, class com.atlassian.confluence. pages.Page] due to overlapping prototypes between: [interface com.atlassian.confluence.user. ConfluenceUser, class java.lang.String, class com.atlassian.confluence.core.ContentEntityObject] [interface com.atlassian.user.User, class java.lang.String, class com.atlassian.confluence.core. ContentEntityObject]