## Gowin I3C SDR IP ## Reference Design RD509-1.1E,09/26/2018 ## **Revision History** | Date | Version | Description | |------------|---------|----------------------------| | 01/30/2018 | 1.0E | Initial version published. | | 09/26/2018 | 1.1E | IP name modified. | ## **Contents** | Contents | i | |-----------------------------------------------------------|----| | 1 Overview | 1 | | 2 Communication Between I3C SDR Master and I3C SDR Slave | 2 | | 2.1 Purpose | 2 | | 2.2 Function | 2 | | 2.3 MCU and Submodules | 3 | | 2.4 Board Level Connection | 9 | | 2.5 Result Observation | 10 | | 3 Communication Between I3C SDR Master and GW-I2C Slave | 11 | | 3.1 Purpose | 11 | | 3.2 Function | 11 | | 3.3 MCU and Submodules | 11 | | 3.4 Board Level Connection | 18 | | 3.5 Result Observation | 18 | | 4 Communication Between I3C SDR Master and ASIC-I2C Slave | 19 | | 4.1 Purpose | 19 | | 4.2 Function | 19 | | 4.3 MCU and Submodules | 19 | | 4.4 Board Level Connection | 23 | | 4.5 Result Observation | 23 | ## 1 Overview This manual mainly describes the following three types of reference designs. - 1. Communication between I3C SDR Master and I3C SDR Slave; - 2. Communication between I3C SDR Master and GW-I2C Slave; - 3. Communication between I3C SDR Master and ASIC-I2C Slave. RD509-1.1E 1(23) ## 2Communication Between I3C SDR Mast er and I3C SDR Slave ### 2.1 Purpose This reference design is employed to verify whether the communication runs well between the I3C SDR Master and I3C SDR Slave. #### 2.2 Function The name for this reference design is "w\_r\_ibi\_w". The functions are as follows: - 1. I3C SDR Master writes (sends slave address and write operation bit 8'h30, write data to Slave); - 2. Enters IBI state (Slave sends address and read operation bit; Master shall read the mandatory data byte, and slave sends read data). RD509-1.1E 2(23) #### 2.3 MCU and Submodules MCU is the top.v module in the Master project. #### Introduction - 1. The top.v module defines a number of ports, some of which are defined but not used for timing purposes. The purpose of the module is to observe certain signals that can be pulled to these reserved ports; - 2. top. V is mainly used for the clock division, jitter elimination, and data read/write. - counter: submodule, used for clock division. First, the 50 MHz clock frequency is divided into 10 MHz via PLL, and then the clock frequency is divided into 10 KHz via the "counter" submodule; - deUstb: submodule, used for button jitter elimination; - Write/Read data module: I3C SDR Master output port "STATE" will output the corresponding I3C SDR state. According to its state, complete the corresponding functions. If the STATE is S\_CM\_WAIT\_AD, I3C SDR Master is in the state of awaiting address, and MCU can send the address; if the STATE is S\_CM\_WAIT\_W\_DA, I3C SDR Master is in a state of awaiting writing data, and MCU can write data. #### Code Clock Division After being processed by PLL and counter, the clock frequency is divided from 50 MHz into 10 KHz: 2. Instantiate I3C SDR Master: ``` I3C_REG_top master( LGYS, CMS, ACS, AAS, STOS, STAS, LGYO, CMO, ACO, AAO, SIO, STOO, STAO, ``` RD509-1.1E 3(23) ``` LGYC, CMC, ACC, AAC, SIC, STOC, STAC, STA_HD_S, SEND_AD_HIGH_S, SEND_AD_LOW_S, ACK_HIGH_S, ACK_LOW_S, STO_HIGH_S, STO_LOW_S, SEND_DA_HIGH_S, SEND_DA_LOW_S, RCVE_DA_HIGH_S, RCVE_DA_LOW_S, ADDRESS_S, PARITYERROR, DI, DOBUF, DO, STATE, SCLH, SCLL, j10_1, j10_5, j10_2, j10_6, CE, RST, CLK ``` #### 3. Key jitter elimination: ``` deUstb deKey1(key1,~key_1,CLK); ``` #### 4. Write/Read data, etc.: ``` always @ (posedge CLK)begin if (RST)begin dataTobeSend <=8'h10; DI <=0; SIC <= 0; ....... end ``` RD509-1.1E 4(23) ``` else begin if(SIO)begin case(STATE) S_CM_ADRS_ABTR_OK:begin SIC <=1; ACS <=1; DI<=8'h00; STOS<=0; STAS<=0; end S_CM_WAIT_AD:begin DI<=8'h30; SIC<=1; STOS<=0; STAS<=0; ACS<=0; end S_CM_WAIT_NACK:begin STOS <=1; SIC<=1; DI<=8'h00; STAS<=0; ACS<=0; end S_CM_WAIT_W_DA:begin if(dataCnt_w==3)begin STOS<=1; ACS<=0; ``` RD509-1.1E 5(23) ``` SIC<=1; dataCnt_w \le 0; end else begin if(w_cnt_flag)begin DI <= dataTobeSend;</pre> dataTobeSend <= dataTobeSend+1;</pre> dataCnt_w <= dataCnt_w+1;</pre> w_cnt_flag<=0; STOS<=0; ACS<=0; end end SIC<=1; STAS<=0; end S_CM_READ_OK_SI:begin if(!readOver) begin if(read_cnt_flag)begin dataCnt_r <= dataCnt_r+1; read_cnt_flag<=0; end end SIC<=1; DI<=8'h00; ``` RD509-1.1E 6(23) ``` STOS<=0; STAS<=0; ACS<=0; end S_IDLE:begin pass <=1; SIC<=1; DI<=8'h00; STOS<=0; STAS<=0; ACS<=0; end default: begin DI<=8'h00; SIC<=0; STAS<=0; STOS<=0; ACS<=0; end endcase end else begin case(STATE) S_CM_W_STO:begin AAS <= 1; ACS<=1; ``` RD509-1.1E 7(23) ``` DI<=8'h00; SIC<=0; STAS<=0; STOS<=0; end S_CM_READ_SL_OK:begin if(dataCnt_r == 3)begin if(!readOver)begin STOS<=1; end readOver <=1; ACS <= 0; end else begin read_cnt_flag<=1; ACS<=1; end DI<=8'h00; SIC<=0; STAS<=0; end S_CM_ADRS_ABTR_OK:begin SIC <=1; ACS <=1; DI<=8'h00; ``` RD509-1.1E 8(23) ``` STAS<=0; STOS<=0; end default:begin DI<=8'h00; SIC<=0; STOS<=0; STAS<=0; ACS<=0; w_cnt_flag<=1; end endcase end end if(key3)begin STAS<=1; end end ``` #### 5. Pull out the observed signals: ``` assign j9_4 = sda_line;//a1:0 assign j9_5 = scl_line; assign j9_6 = STAS; ...... ``` #### 2.4 Board Level Connection This reference design implements communication between the I3C SDR Master and its Slave using double boards; i.e., set I3C SDR Master on a GW1N-9K board and set I3C SDR Slave on the other GW1N-9K board. As such, three lines are required to connect the boards: one for SCL, one for SDA, and one for GND. For the physical constraints of the other observed signals, please refer to dk\_start\_ge1n4.cst. RD509-1.1E 9(23) ## 2.5 Result Observation This reference design uses an oscilloscope to observe whether SCL and SDA are correct. In addition, if you want to observe the Bus signals, such as STATE, DI, and DOBUF, the logic analyzer is recommended. RD509-1.1E 10(23) # 3 Communication Between I3C SDR Mast er and GW-I2C Slave ## 3.1 Purpose This reference design predominantly verifies whether the communication runs well between the I3C SDR Master and GW-I2C Slave. #### 3.2 Function The name for this reference design is "write\_read". The functions are as follows: - 1. I3C SDR Master writes (sends slave address and write operation bit 8'hA0, sends register address and data to Slave); - 2. I3C SDR Master reads (sends slave address and read operation bit 8'hA0, sends slave address and read operation bit 8'hA1, and then reads data from Slave). #### 3.3 MCU and Submodules #### Introduction MCU is the top.v in the Master project. This top.v and the top.v in the Master project of communication between I3C SDR Master and I2C Slave are all modified based on the top.v in the Master project of Communication Between I3C SDR Master and I3C SDR Slave, so the top.v modules for the reference designs are similar. top. V is mainly used for clock division, jitter elimination, and data read/write. 1. counter: submodule, used for clock division. First, the 50 MHz clock frequency is divided into 10 MHz via PLL. Then the clock frequency is RD509-1.1E 11(23) - divided into 10 KHz via the "counter" submodule; - 2. deUstb: submodule, used for button jitter elimination; - 3. Write/Read data module: I3C SDR Master output port STATE will output the corresponding I3C SDR state. According to its state, complete the corresponding functions. If the STATE is S\_CM\_WAIT\_AD, I3C SDR master is in a state of awaiting address, and MCU can send the address. If the STATE is S\_CM\_WAIT\_W\_DA, I3C SDR Master is in a state of awaiting writing data, and MCU can write the data. #### Code 1. Clock division. After being processed by PLL and counter, the clock frequency is divided from 50 MHz into 10 KHz: 2. Instantiate 3C Master: ``` I3C_REG_top master( LGYS, CMS, ACS, AAS, STOS, STAS, LGYO, CMO, ACO, AAO, SIO, STOO, STAO, LGYC, CMC, ACC, AAC, SIC, STOC, STAC, STA_HD_S, SEND_AD_HIGH_S, SEND_AD_LOW_S, ACK_HIGH_S, ACK_LOW_S, STO_HIGH_S, STO_LOW_S, SEND_DA_HIGH_S, SEND_DA_LOW_S, ``` RD509-1.1E 12(23) ``` RCVE_DA_HIGH_S, RCVE_DA_LOW_S, ADDRESS_S, PARITYERROR, DI, DOBUF, DO, STATE, SCLH, SCLL, SDA,SCL,SDA_PULL,SCL_PULL, CE, RST, CLK 'ifdef DEBUG_REG ,dbg_ABTR 'endif ); ``` #### 3. Key jitter elimination: ``` deUstb deKey1(key1,~key_1,CLK); ``` #### 4. Write/Read data, etc.: ``` always @(posedge CLK)begin if(RST)begin dataTobeSend <=8'h20; DI <=0; SIC <= 0; STOS<=0; STAS<=0; pass<=0; w_cnt_flag<=0; r_cnt_flag<=0; read_flag <=0; send_ad_flag<=0; led_4_flag<=0; ``` RD509-1.1E 13(23) ``` led_5_flag<=0;</pre> led_6_flag<=0;</pre> end else begin if(SIO)begin case(STATE) S_CM_WAIT_AD:begin if(send_ad_flag && !reg_addr)begin DI<=8'hA1; end else begin DI<=8'hA0; reg_addr<=1; if(read_flag)begin send_ad_flag<=1; end end SIC<=1; end S_CM_WAIT_W_DA:begin//9 if(reg_addr)begin DI<=8'h10; //reg_addr<=0; led_5_flag<=1;</pre> if(read_flag)begin STAS <=1; end end ``` RD509-1.1E 14(23) ``` else begin if(!read_flag)begin if(&dataCnt_w)begin STAS <= 1; dataCnt_w <= 0; read_flag <= 1; led_4_flag <= 1; end else begin if(w_cnt_flag && !reg_addr)begin DI <= dataTobeSend;</pre> dataTobeSend <= dataTobeSend+1;</pre> dataCnt_w <= dataCnt_w+1;</pre> w_cnt_flag<=0; end end end end SIC<=1; end S_CI2CM_SEND_ACK_OK:begin if(dataCnt_r == 6)begin STOS <=1; dataCnt_r <= 0; led_6_flag <= 1; end else begin if(r_cnt_flag)begin dataCnt_r <= dataCnt_r +1;</pre> ``` RD509-1.1E 15(23) ``` r_cnt_flag <=0; end end AAS \le 0; SIC <= 1; end S_CM_SL_END:begin SIC <=1; end S_IDLE:begin pass <=1; SIC<=1; end default: begin DI<=8'h00; SIC<=0; end endcase end else begin case(STATE) S_CI2CM_SEND_ACK:begin//17----state current I2C master read slave if(dataCnt_r == 5)begin AAS <= 0; readOver <= 1; end else begin ``` RD509-1.1E 16(23) ``` if(readOver)begin AAS \le 0; end else begin AAS <= 1; end end end S_CI2CM_WAIT_ACK_HF:begin reg_addr <= 0; end default:begin DI<=8'h00; SIC<=0; STOS<=0; STAS<=0; AAS \le 0; w_cnt_flag <=1; r_cnt_flag <=1; end endcase if(key4) begin STAS<=1; pass <=0; send_ad_flag <=0; led_4_flag <=0; led_5_flag <=0; led_6_flag <=0; ``` RD509-1.1E 17(23) ``` end end end end end ``` #### 5. Pull out the observed signal: ``` assign j9_4 = sda_line;//a1:0 assign j9_5 = scl_line; assign j9_6 = STAS; ...... ``` #### 3.4 Board Level Connection This reference design implements communication between the I3C SDR Master and GW-I2C Slave using double boards; i.e., set the I3C SDR Master on a GW1N-9K board and set the GW-I2C Slave on the other GW1N-9K board. As such, three lines are required to connect the boards: one for SCL, one for SDA, and one for GND. ### 3.5 Result Observation This reference design uses an oscilloscope to observe whether SCL and SDA are correct. In addition, if you want to observe the Bus signals, such as STATE, DI, and DOBUF, the logic analyzer is recommended. RD509-1.1E 18(23) # 4Communication Between I3C SDR Mast er and ASIC-I2C Slave ## 4.1 Purpose This reference design is mainly employed to verify whether the communication runs well between the I3C SDR Master and ASIC-I2C Slave. #### 4.2 Function The name for this reference design is "write". Its main function is that the I3C SDR Master writes (sends slave address and write operation bit 8'hA0, sends register address and data to Slave). #### 4.3 MCU and Submodules #### Introduction MCU is top.v in the Master project. top. V is mainly used for the clock division, jitter elimination, and data read/write operations. - counter: submodule, used for clock division. First, the 50 MHz clock frequency is divided into 10 MHz via PLL. Then, the clock frequency is divided into 10 KHz via the "counter" submodule; - 2. deUstb: submodule, used for button jitter elimination; - 3. Write/Read data module: I3C SDR Master output port STATE, will output the corresponding I3C SDR state. According to its state, complete the corresponding functions. If the STATE is S\_CM\_WAIT\_AD, the I3C SDR Master is in a state of awaiting address, and MCU can send the address. If the STATE is S\_CM\_WAIT\_W\_DA, I3C SDR Master is in a state of awaiting writing data, and MCU can RD509-1.1E 19(23) write data. #### Code 1. Clock Division. After being processed by the PLL and counter, the clock frequency is divided from 50 MHz into 10 KHz: 2. Instantiate I3C SDR Master: ``` I3C_REG_top master( LGYS, CMS, ACS, AAS, STOS, STAS, LGYO, CMO, ACO, AAO, SIO, STOO, STAO, LGYC, CMC, ACC, AAC, SIC, STOC, STAC, STA_HD_S, SEND_AD_HIGH_S, SEND_AD_LOW_S, ACK_HIGH_S, ACK_LOW_S, STO_HIGH_S, STO_LOW_S, SEND_DA_HIGH_S, SEND_DA_LOW_S, RCVE_DA_HIGH_S, RCVE_DA_LOW_S, ADDRESS_S, PARITYERROR, DI, DOBUF, DO, STATE, SCLH, SCLL, ``` RD509-1.1E 20(23) ``` SDA,SCL,SDA_PULL,SCL_PULL, CE, RST, CLK ); ``` 3. Key jitter elimination: ``` deUstb deKey1(key1,~key_1,CLK); ``` #### 4. Write/Read data, etc.: ``` always @(posedge CLK)begin if(RST)begin dataTobeSend <=8'h10; DI \le 0; SIC \le 0; STOS<=0; STAS<=0; pass<=0; w_cnt_flag<=0; dataCnt_w <=0; led_flag4<=0;</pre> led_flag5<=0;</pre> led_flag6<=0;</pre> end else begin if(SIO)begin case(STATE) S_CM_WAIT_AD:begin DI<=8'hA0; SIC<=1; End S_CM_WAIT_W_DA:begin//9 ``` RD509-1.1E 21(23) ``` if(&dataCnt_w)begin led_flag4 <=1;</pre> STOS<=1; DI <= dataTobeSend;</pre> STOS <=1; dataCnt_w <= 0; end else begin if(w_cnt_flag)begin DI <= dataTobeSend; dataTobeSend <= dataTobeSend+1;</pre> dataCnt_w <= dataCnt_w+1; w_cnt_flag<=0; end end SIC<=1; end S_IDLE:begin pass <=1; SIC<=1; end default: begin DI<=8'h00; SIC<=0; STAS<=0; end endcase end else begin case(STATE) S_CI2CM_WAIT_ACK_HF:begin ``` RD509-1.1E 22(23) ``` w_cnt_flag<=1; end default:begin DI<=8'h00; SIC<=0; STOS<=0; STAS<=0; end endcase if(key4)begin STAS<=1; end end end end end end</pre> ``` #### 5. Pull out the observed signal. ``` assign j9_4 = sda_line;//a1:0 assign j9_5 = scl_line; assign j9_6 = STAS; ...... ``` #### 4.4 Board Level Connection This reference design implements communication between the I3C SDR Master and ASIC-I2C Slave using double boards; i.e., set I3C SDR Master on a GW1N-9K board and set ASIC-I2C Slave on the other GW1N-9K board. As such, three lines are required to connect the boards: one for SCL, one for SDA, and one for GND. ## 4.5 Result Observation This reference design uses an oscilloscope to observe whether the SCL and the SDA are correct. In addition, if you want to observe the Bus signals, such as STATE, DI, and DOBUF, the logic analyzer is recommended. RD509-1.1E 23(23)