

### GLADCI - Latin America Group Development Integrated Circuit

Authors: Felipe Fernandes da Costa Ronal Dario Celaya Francismar Mariano de oliveira

# Contents

| Ve | Version Control i                                                                                                 |                             |  |  |  |  |  |  |
|----|-------------------------------------------------------------------------------------------------------------------|-----------------------------|--|--|--|--|--|--|
| Li | st of tables                                                                                                      | ii                          |  |  |  |  |  |  |
| 1  | Introduction         1.1 Description                                                                              | <b>iii</b><br>iii           |  |  |  |  |  |  |
| 2  | Sub-blocks           2.0.1         APB Core           2.0.2         FIFO RX/TX           2.0.3         I2C MODULE | <b>iv</b><br>iv<br>vi<br>vi |  |  |  |  |  |  |
| 3  | I2C Top Block operation                                                                                           | viii                        |  |  |  |  |  |  |
| 4  | Final considerations                                                                                              | viii                        |  |  |  |  |  |  |
| 5  | 5 References ix                                                                                                   |                             |  |  |  |  |  |  |



| Revision | Date       | Author               | Revised | Comments        |  |
|----------|------------|----------------------|---------|-----------------|--|
| 0.1      | 20/01/2014 | Felipe F. da Costa - |         | Creating a file |  |
|          |            |                      |         | description IP  |  |
| 0.2      | 21/01/2014 | Felipe F. da Costa   | -       | Added           |  |
|          |            |                      |         | complete        |  |
|          |            |                      |         | description     |  |
|          |            |                      |         | block           |  |
| 0.3      | 23/01/2014 | Felipe F. da Costa   | -       | Revising and    |  |
|          |            |                      |         | added a         |  |
|          |            |                      |         | description to  |  |
|          |            |                      |         | figures on I2C  |  |
|          |            |                      |         | Block           |  |

## List of Tables

| 1 | Pinout description                 | iv   |
|---|------------------------------------|------|
|   | Protocol Description               |      |
| 3 | Register Configuration Description | viii |

## 1 Introduction

### 1.1 Description

I2C is a multimaster protocol used to simplify use from uart and defined by philips like a standart module to interface with analogic devices. Here is presented a solution using a interface with APB protocol definided by the ARM. I2C in general transport 8 bit data through bidiretional ports SDA and use clock SCL to give a pulse and control transport data. But This I2C has propurse is to transport 16 bit data. Figure 1 show a Top block using APB and I2C and Table 1 show the pinout description used for each block.



Figure 1: APBI2C top block

| PCLKInput1Clock systemPRESETnInput1Reset is active at LOWPWRITEInput1When HIGH is write on i2c, LOW is read<br>operationPENABLEInput1APB set it notice I2C data is ready to read<br>or writePREADYOutput1I2C response to APB block data is ready<br>to be read or writePSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Used to notice a write or read whitout<br>INT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Output used to write on FIFO TXPRDATAOutput32Output used to read data from FIFO RXSDAInout1Bi-diretional data transport |             |           |      |                                             |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------|------|---------------------------------------------|--|--|--|
| PRESETNInput1Reset is active at LOWPWRITEInput1When HIGH is write on i2c, LOW is read<br>operationPENABLEInput1APB set it notice I2C data is ready to read<br>or writePREADYOutput1I2C response to APB block data is ready<br>to be read or writePSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Used to notice a write or read whitout<br>INT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Output used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                      | Signal name | Direction | Size | Description pin                             |  |  |  |
| PWRITEInput1When HIGH is write on i2c, LOW is read<br>operationPENABLEInput1APB set it notice I2C data is ready to read<br>or writePREADYOutput1I2C response to APB block data is ready<br>to be read or writePSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Used to notice a write or read whitout<br>INT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Output used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                                                         | PCLK        | Input     | 1    | Clock system                                |  |  |  |
| PENABLEInput1APB set it notice I2C data is ready to read<br>or writePREADYOutput1I2C response to APB block data is ready<br>to be read or writePSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Interruption used to notice TX FIFO is<br>EMPTYPADDRInput32Address used to reference read data or<br>writePWDATAInput32Input used to write on FIFO TXPRDATAOutput32Output used to read data from FIFO RXSDAInout1Bi-diretional data transport                                                                                                                                      | PRESETn     | Input     | 1    | Reset is active at LOW                      |  |  |  |
| PENABLEInput1APB set it notice I2C data is ready to read<br>or writePREADYOutput1I2C response to APB block data is ready<br>to be read or writePSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Interruption used to notice TX FIFO is<br>EMPTYPADDRInput32Address used to reference read data or<br>writePWDATAInput32Input used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                                                                                                                                     | PWRITE      | Input     | 1    | When HIGH is write on i2c, LOW is read      |  |  |  |
| Output1or writePREADYOutput1I2C response to APB block data is ready<br>to be read or writePSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Used to notice a write or read whitout<br>INT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Input used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                                                                                                                 |             |           |      | operation                                   |  |  |  |
| PREADYOutput1I2C response to APB block data is ready<br>to be read or writePSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Used to notice a write or read whitout<br>INT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Output used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                                                                                                                               | PENABLE     | Input     | 1    | APB set it notice I2C data is ready to read |  |  |  |
| to be read or writePSELxInput1PSELxInput1INT_RXOutput1INT_TXOutput1INT_TXOutput1INT_TXOutput1INT_TXOutput1INT_TXOutput1INT_TXOutput1PSLVERROutput1Used to notice a write or read whitoutINT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Output used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                               |             |           |      | or write                                    |  |  |  |
| PSELxInput1Pin used to select I2CINT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Used to notice a write or read whitout<br>INT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Input used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                                                                                                                                                                                                                                                                        | PREADY      | Output    | 1    | I2C response to APB block data is ready     |  |  |  |
| INT_RXOutput1Interruption used to notice RX FIFO is<br>FULLINT_TXOutput1Interruption used to notice TX FIFO is<br>EMPTYPSLVERROutput1Used to notice a write or read whitout<br>INT_RX or TX HIGHPADDRInput32Address used to reference read data or<br>writePWDATAInput32Input used to write on FIFO TXPRDATAOutput1Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                                         |             |           |      | to be read or write                         |  |  |  |
| FULL       INT_TX     Output     1     Interruption used to notice TX FIFO is<br>EMPTY       PSLVERR     Output     1     Used to notice a write or read whitout<br>INT_RX or TX HIGH       PADDR     Input     32     Address used to reference read data or<br>write       PWDATA     Input     32     Input used to write on FIFO TX       PRDATA     Output     32     Output used to read data from FIFO RX       SDA     Inout     1     Bi-diretional data transport                                                                                                                                                                                                                             | PSELx       | Input     | 1    | Pin used to select I2C                      |  |  |  |
| INT_TX       Output       1       Interruption used to notice TX FIFO is EMPTY         PSLVERR       Output       1       Used to notice a write or read whitout INT_RX or TX HIGH         PADDR       Input       32       Address used to reference read data or write         PWDATA       Input       32       Input used to write on FIFO TX         PRDATA       Output       32       Output used to read data from FIFO RX         SDA       Inout       1       Bi-diretional data transport                                                                                                                                                                                                   | INT_RX      | Output    | 1    | Interruption used to notice RX FIFO is      |  |  |  |
| EMPTY       PSLVERR     Output     1     Used to notice a write or read whitout<br>INT_RX or TX HIGH       PADDR     Input     32     Address used to reference read data or<br>write       PWDATA     Input     32     Input used to write on FIFO TX       PRDATA     Output     32     Output used to read data from FIFO RX       SDA     Inout     1     Bi-diretional data transport                                                                                                                                                                                                                                                                                                              |             |           |      | FULL                                        |  |  |  |
| PSLVERR       Output       1       Used to notice a write or read whitout<br>INT_RX or TX HIGH         PADDR       Input       32       Address used to reference read data or<br>write         PWDATA       Input       32       Input used to write on FIFO TX         PRDATA       Output       32       Output used to read data from FIFO RX         SDA       Inout       1       Bi-diretional data transport                                                                                                                                                                                                                                                                                    | INT_TX      | Output    | 1    | Interruption used to notice TX FIFO is      |  |  |  |
| Image: Participation     Image: Participation       PADDR     Input     32     Address used to reference read data or write       PWDATA     Input     32     Input used to write on FIFO TX       PRDATA     Output     32     Output used to read data from FIFO RX       SDA     Inout     1     Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                                                        |             |           |      | EMPTY                                       |  |  |  |
| PADDRInput32Address used to reference read data or<br>writePWDATAInput32Input used to write on FIFO TXPRDATAOutput32Output used to read data from FIFO RXSDAInout1Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | PSLVERR     | Output    | 1    | Used to notice a write or read whitout      |  |  |  |
| WDATAInput32writePWDATAInput32Input used to write on FIFO TXPRDATAOutput32Output used to read data from FIFO RXSDAInout1Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |           |      | INT_RX or TX HIGH                           |  |  |  |
| PWDATAInput32Input used to write on FIFO TXPRDATAOutput32Output used to read data from FIFO RXSDAInout1Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | PADDR       | Input     | 32   | Address used to reference read data or      |  |  |  |
| PRDATAOutput32Output used to read data from FIFO RXSDAInout1Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |           |      | write                                       |  |  |  |
| SDA         Inout         1         Bi-diretional data transport                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PWDATA      | Input     | 32   | Input used to write on FIFO TX              |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PRDATA      | Output    | 32   | Output used to read data from FIFO RX       |  |  |  |
| SCL Inout 1 Bi-diretional Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SDA         | Inout     | 1    | Bi-diretional data transport                |  |  |  |
| Son mout i Di difettoria ersen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SCL         | Inout     | 1    | Bi-diretional Clock                         |  |  |  |

Table 1: Pinout description

## 2 Sub-blocks

#### 2.0.1 APB Core

The APB is part of the AMBA 3 protocol family. It provides a low-cost interface that is optimized for minimal power consumption and reduced interface complexity. The APB interfaces to any peripherals that are low-bandwidth and do not require the high performance of a pipelined bus interface. The APB has unpipelined protocol. All signal transitions are only related to the rising edge of the clock to enable the integration of APB peripherals easily into any design flow. Every transfer takes at least two cycles. Figure 2 show protocol to write on APB, figure 3 show protocol to read from APB and figure 4,5 sample a read PSLVERR fail when APB try read data where in the same way is to write protocol.

To access the TX FIFO write is necessary to set the PADDR in 0h and pwrite should be set at a high level so that it is enabled in the mode of writing and performing well in writing PWDATA. To read the RX FIFO is necessary to set PADDR to 4h and pwrite should be low. And lastly writing logger configuration in which PADDR should be set at 8h and pwrite should high level.



Figure 2: APB Protocol write



Figure 3: APB Protocol read



Figure 4: APB Protocol read ERROR



Figure 5: APB Protocol write ERROR

#### $2.0.2 \quad FIFO \ RX/TX$

First In First Out or FIFO was modified to suit the use of the I2C. Being that their signals are simply and in part are used for I2C module to start operating. The FIFO principle to have 16 registers of 32 bits is stored where the pattern of transmission of data. The proposal is work with the FIFO full and FIFO when not completely full.

#### 2.0.3 I2C MODULE

The I2C module to boot operations need the FIFO has any data to be transported and received as well as your your registry properly configured setup. Like other modules present in opencores well as companies in the I2C specification

supports the basic operations using basic protocols that will be described later. The principle is used a block of default cominicação with a configuration register that two bits are used to determine the mode of operation and 12 bits to determine the maximum frequency used may not exceed the clock used in the system.

On table 2 we show standard protocol used by many chip designs and your respective means across the wave form signal.

|          | Table 2. Trotocol Description              |  |  |  |
|----------|--------------------------------------------|--|--|--|
| Protocol | Description                                |  |  |  |
| А        | Start bit used to notice block control we  |  |  |  |
|          | are starting a transmission                |  |  |  |
| Control  | Used to send what peripheral is to be      |  |  |  |
|          | selected                                   |  |  |  |
| Address  | Where is going to be writed                |  |  |  |
| Data     | Data to be write                           |  |  |  |
| ACK      | If all goes right this signal must be LOW  |  |  |  |
|          | for each byte                              |  |  |  |
| NACK     | If not all goes right this signal must be  |  |  |  |
|          | HIGH for each byte                         |  |  |  |
| R        | This is a restart condition when we re try |  |  |  |
|          | send a byte to I2C                         |  |  |  |
| S        | Stop bit condition used when we finish a   |  |  |  |
|          | transmission packet                        |  |  |  |
|          |                                            |  |  |  |

 Table 2: Protocol Description

Figure 6 shows a pattern transfer data between blocks of I2C. For each byte transferred can be seen that there is a ACK and the end of the transfer start and the transfer there is one start bit and one stop bit.

| Α | CONTROL | ACK | ADDRESS  | ACK | DATA | ACK | DATA | ACK | S |
|---|---------|-----|----------|-----|------|-----|------|-----|---|
| ~ | CONTROL | AON | ADDICEOU | AOR | DAIA | ACK | DAIA | Aon |   |

Figure 6: I2C starndard transmission protocol

Figure 7 shows the attempted transfer / read data. Not necessarily need to be this way implementation. What should be illustrated here is that at any time during data transfer can be a NACK and it will be necessary to retransmit the byte, ie will be remade byte transfer as many times as necessary like showed on figure 8 where we have a restart bit operaion.

| A | CONTROL | NACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ADDRESS  | NACK          | DATA | NACK                           | DATA | NACK   | s |  |
|---|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------|------|--------------------------------|------|--------|---|--|
| 1 | CONTROL | in a contraction of the second | ADDITEOU | in the second | DAIA | in a contraction of the second | BAIA | nation | - |  |

Figure 7: I2C non starndard transmission fail protocol

A CONTROL NACK R CONTROL NACK R CONTROL NACK R CONTROL

Figure 8: I2C starndard transmission fail protocol

## 3 I2C Top Block operation

For a successful operation for the I2C module occurs is necessary to obey the following rules:

- 1. The module in the data write operation after a reset and finally the configuration register with the clock being generated and TX enabled enabler must be written. When the module finishes transmitting all data that is stored in the FIFO then the interrupt is enabled INT\_TX warning that the FIFO is ready to receive more data. Since the attempt of written data into the FIFO before the interrupt is generated at high PSLVERR causes what is recognized as an error.
- 2. The rules for the module is receiving data the same way as described for transmission mode. The only thing that differs is the interrupt used to warn that the data has arrived.
- 3. For reading and writing of data are used two independent FIFOs which in turn can write one another and can only be read. That is, if you can not read it again since it was already written . The same goes for the logger configuration .

Registers to be read or written must obey the access agreement with ARM processors, to access. Table 2 shows how is register configuration.

| rasio of respect comparation perciption |                                                             |  |  |  |  |
|-----------------------------------------|-------------------------------------------------------------|--|--|--|--|
| Register                                | $13 \ 12 \ 11 \ 10 \ 9 \ 8 \ 7 \ 6 \ 5 \ 4 \ 3 \ 2 \ 1 \ 0$ |  |  |  |  |
| TX - 0                                  | If bit 1 is HIGH TX operation is enable                     |  |  |  |  |
| RX - 1                                  | If bit 1 is HIGH RX operation is enable                     |  |  |  |  |
| CLOCK REGISTER - 2 to13                 | Counter used to regulate clock used to propagate            |  |  |  |  |
|                                         | data, this must be handle with care beacuse this            |  |  |  |  |
|                                         | clock can not exceed your global clock                      |  |  |  |  |

Table 3: Register Configuration Description

## 4 Final considerations

The I2C module is still in development and has yet to be verified their functionality. This document need still show the waveforms and a detailed explanation of the waveforms of the transmission and reception of I2C. 5 References

