### **TEB2000 CPLD** #### Table of contents ○ ★ ● Pvi ← W • 1.1 Feature Summary CPLD Device witr design ator Revision 2 Product Specification 2 Product Specification 2.1 Port Description 22 Functional Description 24 Functional Description 22 Functional Description 22 Functional Description 23 Functional Description 24 Functional Description • JTAG ■ 2.2.3 EN1 UART 2.2.4 NOSEQ I2C ■ 2.2.5 PGOOD Power ■ 2.2.6 MODE Boot Mode Reset 2.2.7 Reset 2.2.8 Boot Mode ■ 2.2.9 UART SD • LED ■ 2.2.10 SD ■ 2.2.11 On-board LEDs ■ 2.2.12 I2C to GPIO ### Firmware Revision Supported PCB Revision • 2.3.1.1 GPIO input registers • 2.3.1.2 GPIO output registers 2.3.1.2 GPIO output registers • 3 Appx. A: Change History and Legal Notices 3.1 Revision Changes # Product 3 Document Change History o 4.1 Data Privacy 4.2 Document Warranty ### Port Description Liability 4.4 Copyright Notice | 4.5 Technology Licenses | | | | | | |-------------------------|---------------------------------------------|------------|-------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Name / opt.º 4. | 6 <b>Direction</b> ental I<br>7 REACH, RoHS | Protection | Pullup/Down | Bank Power | Description | | UART_TXD | in | 77 | UP | 3.3V | UARTO TX /<br>Sends data to<br>MIO13. MIO13<br>is connected to<br>B2B JB1 Pin 98.<br>( HSS console ).<br>In hardware is<br>connected to<br>FT230XQ (U12)<br>chip pin TXD<br>indirectly. | | UART_RXD | out | 84 | UP | 3.3V | UARTO RX /<br>Recieves data<br>from MIO12.<br>MIO12 is<br>connected to<br>B2B JB1 Pin<br>100. ( HSS<br>console ). In<br>hardware is<br>connected to<br>FT230XQ (U12)<br>chip pin RXD<br>indirectly. | | MIO12 | in | 100 | NONE | 3.3V | Sends data to<br>UART_RX / In<br>hardware is<br>connected to<br>B2B JB1-pin<br>100. | |---------------------|-------|-----|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | MIO13 | out | 99 | NONE | 3.3V | Read data from<br>UART_TX / In<br>hardware is<br>connected to<br>B2B JB1-pin 98. | | FT_B_RX | out | 138 | NONE | 3.3V | FTDI UART RX<br>(UART1 RX) / In<br>hardware is<br>connected to<br>FTDI chip U4<br>pin 33. (Linux<br>console) | | FT_B_TX /<br>BDBUS0 | in | 139 | UP | 3.3V | FTDI UART TX<br>(UART1 TX) / In<br>hardware is<br>connected to<br>FTDI chip U4<br>pin 32. (Linux<br>console) | | MIO14 | out | 105 | NONE | 3.3V | Receives data<br>from FT_B_TX<br>of FTDI chip / In<br>hardware is<br>connected to<br>B2B JB1-pin 91. | | MIO15 | in | 95 | NONE | 3.3V | Sends data to<br>FT_B_RX of<br>FTDI chip / In<br>hardware is<br>connected to<br>B2B JB1-pin 86. | | СМО | in | 76 | UP | 3.3V | DIP switch S2-2<br>/ used as JTAG<br>Selection/ If<br>CM0 set to high<br>(S2-2 OFF)<br>Access to CPLD<br>of module<br>otherwise<br>access to FPGA<br>of module. | | CM1 | in | 75 | UP | 3.3V | DIP switch S2-1<br>/ Used to<br>change PGOOD<br>pin state /If CM1<br>set to high (S2-1<br>OFF) PGOOD<br>= '1' otherwise '0' | | EN1 | out | 81 | UP | 3.3V | B2B Power<br>Enable / In<br>firmware EN1 is<br>connected to 3.3<br>V permanently. | | FLED_1 | inout | 28 | NONE | 3.3V | LED (D3-red) /<br>Shows the<br>status of<br>PGOOD or<br>shows the<br>FT_B_TX<br>(UART1 RXD). | | FLED_2 | inout | 27 | NONE | 3.3V | LED (D4-green) / Shows the status of PGOOD or shows the FT_B_RX (UART1 TXD). | |---------------|-------|-----|------|------|----------------------------------------------------------------------------------------------------------------------------------------| | ULED1 | out | 117 | NONE | 3.3V | LED (D1-red) /<br>Shows the<br>status of CM0 or<br>shows the<br>UART_RXD<br>(UART0 RX). | | ULED2 | out | 115 | NONE | 3.3V | LED (D2-green) / Shows the status of CM0 or shows the UART_TXD (UART0 TX). | | PHY_LED1 | out | 86 | DOWN | 3.3V | Shows the status of NOSEQ and MIO0 signals. | | PHY_LED1R | out | 92 | NONE | 3.3V | Shows the status of NOSEQ and MIO0 signals. | | PHY_LED2 | out | 85 | NONE | 3.3V | Shows the status of NOSEQ and MIO0 signals. | | PHY_LED2R | out | 91 | NONE | 3.3V | Shows the status of NOSEQ and MIO0 signals. | | JTAGEN | | 120 | | 3.3V | Enable JTAG<br>access to CPLD<br>for Firmware<br>update (zero:<br>normal IOs,<br>one: CPLD<br>JTAG access).<br>Selectable over<br>S2-3 | | M_TCK | in | 131 | NONE | 3.3V | JTAG from/to<br>FTDI | | M_TDI | in | 136 | NONE | 3.3V | JTAG from/to<br>FTDI | | M_TDO | out | 137 | NONE | 3.3V | JTAG from/to<br>FTDI | | M_TMS | in | 130 | NONE | 3.3V | JTAG from/to<br>FTDI | | TCK_B | out | 1 | NONE | 3.3V | JTAG from/to<br>Module | | TDI_B | out | 3 | NONE | 3.3V | JTAG from/to<br>Module | | TDO_B / C_TDO | in | 2 | UP | 3.3V | JTAG from/to<br>Module | | TMS_B | out | 4 | NONE | 3.3V | JTAG from/to<br>Module | | MIO0 | in | 94 | UP | 3.3V | This pin is connected to DIP swith S2-4 and B2B JB1 Pin 88. This signal is forwarded to MODE signal in firmware. | |-------------|-------|-----|------|------|----------------------------------------------------------------------------------------------------------------------------------| | MIO9 | out | 96 | NONE | 3.3V | SD_CD signal is directed to this signal in firmware, if PGOOD = '1'. / In hardware is connected to B2B JB1 pin 92. | | MODE | out | 83 | NONE | 3.3V | Dip switch S2-4<br>(MIO0) is<br>connected to<br>MODE pin. This<br>pin in hardware<br>is connected<br>to B2B JB1 pin<br>31. | | NOSEQ | inout | 78 | UP | 3.3V | NOSEQ can be<br>set or reset by<br>i2c interface in<br>linux console, if<br>an i2c interface<br>is prepared<br>already in linux. | | PGOOD | inout | 82 | UP | 3.3V | PGOOD can be<br>set or reset via<br>CM1 ( dip<br>switch S2-1). In<br>hardware is<br>connected to<br>B2B JB1 pin 29. | | PROGMODE | out | 104 | UP | 3.3V | Enable B2B<br>Module JTAG<br>access to CPLD<br>for Firmware<br>update | | RESIN | out | 119 | NONE | 3.3V | Module Reset<br>pin on B2B JB2<br>pin 17. | | S1 | in | 114 | UP | 3.3V | Push Button /<br>Used as module<br>Reset. In<br>hardware is<br>connected to S1<br>reset<br>pushbutton. | | SDA / MIO11 | inout | 97 | UP | 3.3V | I2C Data | | SCL /MIO10 | in | 98 | UP | 3.3V | I2C Clock | | XO | inout | 39 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X1 | inout | 38 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | |----|-------|----|------|------|-------------------------------------------------------------------------------------------------| | X2 | inout | 40 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X3 | inout | 41 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X4 | inout | 42 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X5 | inout | 43 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X6 | inout | 44 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X7 | inout | 45 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X8 | inout | 47 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | Х9 | inout | 48 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X10 | inout | 49 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | |--------|-------|-----|------|------|-------------------------------------------------------------------------------------------------| | X11 | inout | 50 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X12 | inout | 52 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X13 | inout | 54 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X14 | inout | 55 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X15 | inout | 56 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X16 | inout | 59 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | X17 | inout | 60 | NONE | 3.3V | This port can be read or written via GPIO_input register and GPIO_output register respectively. | | BCBUS0 | in | 122 | NONE | 3.3V | currently_not_us ed | | BCBUS1 | in | 121 | NONE | 3.3V | currently_not_us ed | | BDBUS2 | in | 133 | NONE | 3.3V | currently_not_us<br>ed | | BDBUS3 | in | 132 | NONE | 3.3V | currently_not_us ed | | DUMMY | out | 74 | NONE | 3.3V | No Connect | |-----------|-----|-----|------|------|------------------------------------------------------------------------------------------------------------------------------| | SD_CD | in | 93 | UP | 3.3V | This port is forwarded to PHY_LED2. If SD card is plugged , PHY_LED2 is on. This port forwarded to MIO9 too, if PGOOD = '1'. | | SD_SEL | out | 113 | NONE | 3.3V | Set to GND / cur<br>rently_not_used | | E_SD_DAT3 | in | 111 | NONE | 3.3V | currently_not_us<br>ed | | E_SD_DAT2 | in | 112 | NONE | 3.3V | currently_not_us<br>ed | | E_SD_DAT1 | in | 107 | NONE | 3.3V | currently_not_us ed | | E_SD_DAT0 | in | 106 | NONE | 3.3V | currently_not_us ed | | E_SD_SCLK | in | 109 | NONE | 3.3V | currently_not_us ed | | E_SD_CMD | in | 110 | NONE | 3.3V | currently_not_us ed | | USB_OC | in | 73 | NONE | 3.3V | This port can be read via GPIO_input register. | | ACBUS5 | in | 140 | NONE | 3.3V | currently_not_us ed | | ACBUS4 | in | 141 | NONE | 3.3V | currently_not_us ed | | ADBUS7 | in | 142 | NONE | 3.3V | currently_not_us ed | | ADBUS4 | in | 143 | NONE | 3.3V | currently_not_us ed | | BDBUS7 | in | 125 | NONE | 3.3V | currently_not_us ed | | BDBUS6 | in | 126 | NONE | 3.3V | currently_not_us ed | | BDBUS5 | in | 127 | NONE | 3.3V | currently_not_us ed | | BDBUS4 | in | 128 | NONE | 3.3V | currently_not_us ed | ## **Functional Description** ### Dip Switch | DIP Switch S2 | | | | | |---------------|------|------|------|-------------| | S2-1 | S2-2 | S2-3 | S2-4 | Description | | CM1 | СМО | JTAGEN | MIO0 | JTAGEN set carrier board CPLD into the chain for firmware update. | |-----|-----|--------|------|-------------------------------------------------------------------| |-----|-----|--------|------|-------------------------------------------------------------------| #### **JTAG** JTAG signals routed directly through the CPLD to module in B2B connector. TEB2000 CPLD can be selected with JTAGEN (DIP switch S2-3). Access between CPLD of the TEB2000 board and the plugged module same as TEM0007 can be multiplexed via JTAGEN (S2-3). Logical one is for accessing to CPLD of TEB2000 (OFF) and logical zero is for the module (ON). Access to FPGA of the plugged module or its CPLD can be switched with PROGMODE which is driven by CM0 (DIP switch S2-2). CM1 and CM0 are pulled up in CPLD internally. | S2-2 | S2-3 | CM0<br>(PROGMODE)<br>(S2-2) | JTAGEN (S2-3) | Description | |------|------|-----------------------------|---------------|------------------------------| | OFF | OFF | 1 | 1 | Access to TEB2000<br>CPLD | | OFF | ON | 1 | 0 | Access to CPLD of B2B Module | | ON | OFF | 0 | 1 | Access to TEB2000<br>CPLD | | ON | ON | 0 | 0 | Access to FPGA of B2B Module | #### EN<sub>1</sub> EN1 is set to one in firmware permanently. #### **NOSEQ** NOSEQ pulled up to 3.3V. NOSEQ can be set or reset by i2c interface in linux console, if an i2c interface is already prepared for the i2c interface in linux. | NOSEQ | Connected to | Related command in linux console | Description | |-------|-----------------|-----------------------------------------------------------|------------------------------------------------------------------------------------| | '0' | GPIO_output[16] | i2cset -y <related<br>bus&gt; 0x20 0x02 0x00</related<br> | It is depends on<br>the linux design.<br>For example i2cset<br>-y 0 0x20 0x02 0x00 | | '1' | GPIO_output[16] | i2cset -y <related<br>bus&gt; 0x20 0x02 0x01</related<br> | It is depends on<br>the linux design.<br>For example i2cset<br>-y 0 0x20 0x02 0x01 | To read the NOSEQ status, GPIO\_input[16] must be read like the following instruction: i2cget -y <related bus> 0x20 0x02 For example --> i2cget -y 0 0x20 0x02 Note that the bus number depends on the linux design and can be varied for different designs. #### **PGOOD** PGOOD pulled up to 3.3V in CPLD internally. PGOOD pin can be set or reset by user. If CM1 set to high (S2-1 OFF), PGOOD will be set to high otherwise PGOOD is set to low. | PGOOD | Condition | Description | |-------|-----------|---------------------| | '0' | CM1 = '0' | Dip switch S2-1 ON | | '1' | CM1 = '1' | Dip switch S2-1 OFF | #### **MODE** This pin can be controlled with dip switch S2-4 (MIO0). | MODE | Condition | Description | |------|------------|---------------------| | '0' | MIO0 = '0' | Dip switch S2-4 ON | | '1' | MIO0 = '1' | Dip switch S2-4 OFF | #### Reset There is two reset switchs on the board (S1 and S6). The S6 is a soft reset button (SRST) that is not directed to CPLD chip. The S1 signal is connected to CPLD chip and is used in firmware code to create a reset signal. RESIN signal is the output reset signal of the CPLD and is driven by S1 push button. The S1 push button is debounced. | Signal | Designator | Connected to | Active Level | Description | |--------|------------|-------------------|--------------|-------------------------------------------| | SRST | S6 | B2B JB2 pin 56 | Active low | This signal is not used in CPLD firmware. | | S1 | S1 | CPLD chip pin 114 | Active low | This signal is used in CPLD firmware. | | Pin | CPLD Pin | Connected to | Description | |-------|----------|----------------|-------------| | RESIN | 119 | B2B JB2 Pin 17 | Active-low | #### **Boot Mode** For plugged Polarfire SoC module same as TEM0007 the boot mode can not be selected via MODE and PGOOD pins, because polarfire SoC boot mode can be selected only via HSS design for TEM0007. #### **UART** MIO14 is driven by BDBUS0 (FTDI RX). BDBUS1 (FTDI TX) is driven by MIO15 . MIO13 is driven by UART\_TXD. UART\_RXD is driven by MIO12. | UART 0 (HSS Console) | | | | | | | |---------------------------|----------|------------------------|-------------------------------|----------|------------------------|-------------| | CPLD<br>UART<br>Input Pin | CPLD Pin | Connected to | CPLD<br>UART<br>Output<br>Pin | CPLD Pin | Connected to | Description | | MIO12 | 100 | B2B-JB1-100 | UART_RXD | 84 | U8-Pin 11 | | | UART_TXD | 77 | U8-Pin 13 | MIO13 | 99 | B2B-JB1-98 | | | | | UAR' | T 1 (Linux Con | sole) | | | | CPLD<br>UART<br>Input Pin | CPLD Pin | Connected to | CPLD<br>UART<br>Output<br>Pin | CPLD Pin | Connected to | Description | | FT_B_TX | 139 | FTDI Chip U4<br>Pin 32 | MIO14 | 105 | B2B-JB1-91 | | | MIO15 | 95 | B2B-JB1-86 | FT_B_RX | 138 | FTDI Chip U4<br>Pin 33 | | SD selection (SD\_SEL) is set to GND (SD Card slot). MIO9 is switched to SD\_CD (Card Detect) and its status depends on SD\_CD . #### **On-board LEDs** | LED | Designator | LED Status | Condition | Description | |----------------|------------|-----------------------|--------------------------------------------------------|-------------| | ULED1 (Red) | D1 | Fast blink red | Access to CPLD of module ( CM0 = '1') S2-2 = OFF | | | | | Connected to UART1_RX | Otherwise | | | ULED2 (Green) | D2 | Fast blink green | Access to CPLD of<br>module ( CM0 = '1')<br>S2-2 = OFF | | | | | Connected to UART1_TX | Otherwise | | | FLED_1 (Red) | D3 | Fast blink red | PGOOD = '1' ( CM1<br>= '0' ) S2-1 = ON | | | | | Connected to UART0_RX | Otherwise | | | FLED_2 (Green) | D4 | Fast blink green | PGOOD = '1' ( CM1<br>= '0' ) S2-1 = ON | | | | | Connected to UART0_TX | Otherwise | | | LED | Designator | LED Status | Condition | Description | |-----------------------------------------------------------|------------|----------------------------|-------------------------------|--------------------------------------------------------------------------------| | PHY_LED1<br>(Green LED<br>Anode, Yellow<br>LED Cathode) / | J14B | Fast blink yellow | NOSEQ = '0' and<br>MIO0 = '0' | In Linux<br>console enter:<br>i2cset -y 0<br>0x20 0x02 0x00<br>and S2-4 = ON* | | PHY_LED1R<br>(Green LED<br>Cathode, Yellow<br>LED Anode) | | Slow blink yellow | NOSEQ = '0' and<br>MIO0 = '1' | In Linux<br>console enter:<br>i2cset -y 0<br>0x20 0x02 0x00<br>and S2-4 = OFF* | | | | Fast blink yellow green | NOSEQ = '1' and<br>MIO0 = '0' | In Linux<br>console enter:<br>i2cset -y 0<br>0x20 0x02 0x01<br>and S2-4 = ON* | | | | Slow blink yellow<br>green | NOSEQ = '1' and<br>MIO0 = '1' | In Linux<br>console enter:<br>i2cset -y 0<br>0x20 0x02 0x01<br>and S2-4 = OFF* | | PHY_LED2<br>(Green LED<br>Cathode, Yellow | J14C | ON | SD card plugged (SD_CD = '0') | | | LED Anode) / | | | | | | PHY_LED2R<br>(Green LED<br>Anode, Yellow<br>LED Cathode) | | | | | | | OFF | Otherwise | | |--|-----|-----------|--| | | | | | | | | | | | | | | | \*Note: The related bus number of I2C can be varied and it depends on the Linux design. For example the bus number is 0 #### I2C to GPIO I2C to GPIO is a subsystem in firmware of CPLD that provides an i2c interface that writes received data to GPIO\_output 8 bit registers or reads 8 bit GPIO\_input registers and send read data to i2c bus. I2C bus is connected to MIO10 ( SCL signal) and MIO11 (SDA signal). MIO10 to MIO15 are direct connection between CPLD of TEB2000 and FPGA on the module (for example TEM0007) through B2B connector. If in FPGA design exists no i2c interface for MIO10 and MIO11, this block will be unused. More information about MIO10 to MIO15 are shown in the following table for TEM0007 modules and TEB2000 carrier board: | B2B Pin | B2B JB1-<br>96 | B2B JB1-<br>94 | B2B JB1-<br>100 | B2B JB1-<br>98 | B2B JB1-<br>91 | B2B JB1-<br>86 | | |---------|----------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|-------------| | Carrier | Label / | Label / | Label / | Label / | Label / | Label / | Description | | board | Firmware fu | nct <b>il5in</b> mware fur | nct <b>ilčin</b> mware fui | ncti <b>l5in</b> mware fur | ncti <b>löin</b> mware fur | nct <b>ilbin</b> mware fur | action | | TEB2000 | MIO10 / I2C-<br>SCL | MIO11 / I2C-<br>SDA | MIO12 /<br>UARTO_RX | MIO13 /<br>UARTO_TX | MIO14 /<br>UART1-TX | MIO15 /<br>UART1-RX | MIO10 and<br>MIO11 are<br>used in<br>CPLD<br>firmware as<br>I2C SCL and<br>SDA respecti<br>vely. | |---------|----------------------|----------------------|----------------------|----------------------|---------------------|---------------------|--------------------------------------------------------------------------------------------------| | B2B Pin | B2B JM1-<br>95 | B2B JM1-<br>93 | B2B JM1-<br>99 | B2B JM1-<br>97 | B2B JM1-<br>92 | B2B JM1-<br>85 | | | Module | Label /<br>Chip pin | Label /<br>Chip pin | Label /<br>Chip pin | Label /<br>Chip pin | Label /<br>Chip pin | Label /<br>Chip pin | Description | | TEM0007 | I2C_CON_SC<br>L / A3 | I2C_CON_SD<br>A / E3 | UART_CON_<br>TX / C2 | UART_CON_<br>RX / D3 | UART_RX /<br>H2 | UART_TX /<br>H5 | MIO10 and<br>MIO11 are<br>already set in<br>test_design<br>of TEM0007<br>as SCL and | ### I2C to GPIO registers access methods I2C to GPIO subsystem has 4 output and 4 input 8 bit registers. These registers can be written or read in linux as shown in the following tables: | GPIO input register | Address | Read command in Linux <sup>*</sup> | Description | |---------------------|---------|------------------------------------|----------------------------------------------------| | GPIO_input[7:0] | 0x00 | i2cget -y 0 0x20<br>0x00 | 0x20 is device address. (<br>I2C to GPIO address). | | GPIO_input[15:8] | 0x01 | i2cget -y 0 0x20<br>0x01 | 0x20 is device address. (<br>I2C to GPIO address). | | GPIO_input[23:16] | 0x02 | i2cget -y 0 0x20<br>0x02 | 0x20 is device address. (<br>I2C to GPIO address). | | GPIO_input[31:24] | 0x03 | i2cget -y 0 0x20<br>0x03 | 0x20 is device address. (<br>I2C to GPIO address). | | GPIO output register | Address | Write command in Linux <sup>*</sup> | Description | |----------------------|---------|--------------------------------------|---------------------------------------------------------------------------------| | GPIO_output[7:0] | 0x00 | i2cset -y 0 0x20<br>0x00 <8bit data> | 0x20 is device address. (<br>I2C to GPIO address).<br>0x00 is register address. | | GPIO_output[15:8] | 0x01 | i2cset -y 0 0x20<br>0x01 <8bit data> | 0x20 is device address. (<br>I2C to GPIO address).<br>0x01 is register address. | | GPIO_output[23:16] | 0x02 | i2cset -y 0 0x20<br>0x02 <8bit data> | 0x20 is device address. (<br>I2C to GPIO address).<br>0x02 is register address. | | GPIO_output[31:24] | 0x03 | i2cset -y 0 0x20<br>0x03 <8bit data> | 0x20 is device address. (<br>I2C to GPIO address).<br>0x03 is register address. | <sup>\*</sup>The related bus number can be varied with Linux design. For example the bus number is 0 here. Note that resetting due to SRST push button or rebooting via reboot command in linux console will not delete the saved changed status of GPIO\_output registers via i2c interface. However, resetting with the S1 reset button deletes all saved data in GPIO\_output registers and sets these registers to the default values. ### **I2C** to GPIO registers #### **GPIO** input registers The following port or signals can be read via GPIO\_input[] registers. | GPIO_input[7:0] (address 0x00) | | | | | |--------------------------------|--------------------|-------------|--|--| | GPIO input bit | Port/Signal | Description | | | | 0 | CPLD_REVISION [0]* | | | | | 1 | CPLD_REVISION [1]* | | | | | 2 | CPLD_REVISION [2]* | | | | | 3 | CPLD_REVISION [3]* | | | | | 4 | CPLD_REVISION [4]* | | | | | 5 | CPLD_REVISION [5]* | | | | | 6 | CPLD_REVISION [6]* | | | | | 7 | CPLD_REVISION [7]* | | | | \*Note: CPLD\_REVISION[7:0] = Firmware version | GPIO_input[15:8] (address 0x01) | | | | |---------------------------------|-------------|-------------|--| | GPIO input bit | Port/Signal | Description | | | 8 | X0 | | | | 9 | X1 | | | | 10 | X2 | | | | 11 | Х3 | | | | 12 | X4 | | | | 13 | X5 | | | | 14 | X6 | | | | 15 | X7 | | | | GPIO_input[23:16] (address 0x02) | | | | |----------------------------------|-------------|-------------|--| | GPIO input bit | Port/Signal | Description | | | 16 | NOSEQ | | |----|-------|--| | 17 | X8 | | | 18 | Х9 | | | 19 | X10 | | | 20 | X11 | | | 21 | X12 | | | 22 | X13 | | | 23 | X14 | | | GPIO_input[31:24] (address 0x03) | | | |----------------------------------|-------------|-------------| | GPIO input bit | Port/Signal | Description | | 24 | X15 | | | 25 | X16 | | | 26 | X17 | | | 27 | СМО | | | 28 | CM1 | | | 29 | PGOOD | | | 30 | MIO0 (MODE) | | | 31 | USB_OC | | #### GPIO output registers The following port or signals can be written via ${\sf GPIO\_output[\ ]}$ registers. | GPIO_output[7:0] (address 0x00) | | | | |---------------------------------|-------------|-------------|--| | GPIO output bit | Port/Signal | Description | | | 0 | X0 | | | | 1 | X1 | | | | 2 | X2 | | | | 3 | Х3 | | | | 4 | X4 | | | | 5 | X5 | | | | 6 | X6 | | |---|----|--| | 7 | X7 | | | GPIO_output[15:8] (address 0x01) | | | | | | |-----------------------------------------|-----|--|--|--|--| | GPIO output bit Port/Signal Description | | | | | | | 8 | X8 | | | | | | 9 | Х9 | | | | | | 10 | X10 | | | | | | 11 | X11 | | | | | | 12 | X12 | | | | | | 13 | X13 | | | | | | 14 | X14 | | | | | | 15 | X15 | | | | | | GPIO_output[23:16] (address 0x02) | | | |-----------------------------------|-------------|-------------| | GPIO output bit | Port/Signal | Description | | 16 | NOSEQ | | | 17 | X16 | | | 18 | X17 | | | 19 | Reserved | | | 20 | Reserved | | | 21 | Reserved | | | 22 | Reserved | | | 23 | Reserved | | | GPIO_output[31:24] (address 0x03) | | | |-----------------------------------|-------------|-------------| | GPIO output bit | Port/Signal | Description | | 24 | Reserved | | | 25 | Reserved | | | 26 | Reserved | | | 27 | Reserved | | | 28 | Reserved | | |----|----------|--| | 29 | Reserved | | | 30 | Reserved | | | 31 | Reserved | | ### Appx. A: Change History and Legal Notices ### **Revision Changes** - Changes REV01 to REV02 - Bug fix: The process of GPIO\_output read/write needed a reset signal to avoid i2c error by i2c reading or i2c writing first time after switching on. - The changed data in GPIO\_output register will be reset to default value by resetting via S1 bush button. But rebooting via reboot command in linux or resetting via SRST button switch will not reset the GPIO\_output register. - Unnecessary signal same as CR5 and CR4 has been deleted. - o Internal oscillator frequency of CPLD is increased from 12.09MHz to 24.18MHz. - O GPIO\_input[30] is allocated to MIO0 (MODE) instead of S1. - GPIO\_output register mapping changed. - FLED\_1 and FLED\_2 function changed. - REV01 - o I2C port added. - o I2C to GPIO component added. - NOSEQ can be changed via I2C port. - UART1 port added. This board has two UART ports. (UART0 and UART1) - New construction for UART0 and UART1 serial interfaces - o Generic parameter CPLD\_REVISION added. - JTAG timing correction - LED states and related ports/signals are changed. --> SD\_CD, NOSEQ, MIO0, PGOOD, CM0 and CM1 - New mapping for related ports/signals to GPIO\_input and GPIO\_output registers - New Ports are defined according to the schematic or revision 1 ### **Document Change History** To get content of older revision got to "Change History" of this page and select older document revision number. | Date Document CPLD Revision Firmware Revision | Supported<br>PCB Revision | Authors | Description | | |-----------------------------------------------|---------------------------|---------|-------------|--| |-----------------------------------------------|---------------------------|---------|-------------|--| ### Appx. B: 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' com.atlassian.confluence.core.ContentEntityObject] 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