

# DI2CM

# I<sup>2</sup>C Bus Interface - Master ver 3.11

#### OVERVIEW

I<sup>2</sup>C is a two-wire, bi-directional serial bus that provides a simple and efficient method of data transmission over a short distance between many devices. The DI2CM core provides an interface between a microprocessor / microcontroller and an I<sup>2</sup>C bus. It can work as a master transmitter or master receiver depending on working mode determined by microprocessor/microcontroller. The DI2CM core incorporates all features required by the latest I<sup>2</sup>C specification including clock synchronization, arbitration, multi-master systems and High-speed transmission mode. Built-in timer allows operation from a wide range of the clk frequencies.

# **KEY FEATURES**

- Conforms to v.2.1 of the I<sup>2</sup>C specification
- Master operation
  - Master transmitter
  - Master receiver
- Support for all transmission speeds
  - Standard (up to 100 kb/s)
  - Fast (up to 400 kb/s)
  - High Speed (up to 3,4 Mb/s)
- Arbitration and clock synchronization
- Support for multi-master systems
- Support for both 7-bit and 10-bit addressing formats on the I<sup>2</sup>C bus
- Interrupt generation

All trademarks mentioned in this document are trademarks of their respective owners.

- Build-in 8-bit timer for data transfers speed adjusting
- Host side interface dedicated for microprocessors/microcontrollers
- User-defined timing (data setup, start setup, start hold, etc.)
- Fully synthesizable
- Static synchronous design with positive edge clocking and synchronous reset
- No internal tri-states
- Scan test ready

## **APPLICATIONS**

- Embedded microprocessor boards
- Consumer and professional audio/video
- Home and automotive radio
- Low-power applications
- Communication systems
- Cost-effective reliable automotive systems

#### **DELIVERABLES**

- Source code:
  - ◊ VHDL Source Code or/and
  - ◊ VERILOG Source Code or/and
  - ♦ Encrypted, or plain text EDIF netlist
- VHDL & VERILOG test bench environment
  - Active-HDL automatic simulation macros
  - ModelSim automatic simulation macros
  - ◊ Tests with reference responses
- Technical documentation
  - Installation notes

http://www.DigitalCoreDesign.com http://www.dcd.pl

- ♦ HDL core specification
- ◊ Datasheet
- Synthesis scripts
- Example application
- Technical support
  - ◊ IP Core implementation support
  - ♦ 3 months maintenance
    - Delivery the IP Core updates, minor and major versions changes
    - Delivery the documentation updates
    - Phone & email support

## LICENSING

Comprehensible and clearly defined licensing methods without royalty fees make using of IP Core easy and simply.

<u>Single Design</u> license allows use IP Core in single FPGA bitstream and ASIC implementation.

<u>Unlimited Designs</u>, <u>One Year</u> licenses allow use IP Core in unlimited number of FPGA bitstreams and ASIC implementations.

In all cases number of IP Core instantiations within a design, and number of manufactured chips are unlimited. There is no time restriction except <u>One Year</u> license where time of use is limited to 12 months.

- Single Design license for
  - VHDL, Verilog source code called <u>HDL</u> Source
  - o Encrypted, or plain text EDIF called Netlist
- One Year license for
  - Encrypted Netlist only
- Unlimited Designs license for
  - HDL Source
  - Netlist
- Upgrade from
  - HDL Source to Netlist
  - Single Design to Unlimited Designs



# PINS DESCRIPTION

| PIN          | TYPE   | DESCRIPTION                              |  |  |  |  |
|--------------|--------|------------------------------------------|--|--|--|--|
| clk          | input  | Global clock                             |  |  |  |  |
| rst          | input  | Global reset                             |  |  |  |  |
| address(1:0) | input  | Processor address lines                  |  |  |  |  |
| cs           | input  | Chip select                              |  |  |  |  |
| we           | input  | Processor write strobe                   |  |  |  |  |
| rd           | input  | Processor read strobe                    |  |  |  |  |
| scli         | input  | I <sup>2</sup> C bus clock line (input)  |  |  |  |  |
| sdai         | input  | I <sup>2</sup> C bus data line (input)   |  |  |  |  |
| datai(7:0)   | input  | Processor data bus (input)               |  |  |  |  |
| datao(7:0)   | output | Processor data bus (output)              |  |  |  |  |
| sclo         | output | I <sup>2</sup> C bus clock line (output) |  |  |  |  |
| sclhs        | output | High-speed clock line (output)           |  |  |  |  |
| sdao         | output | I <sup>2</sup> C bus data line (output)  |  |  |  |  |
| irq          | output | Processor interrupt line                 |  |  |  |  |

# **BLOCK DIAGRAM**

Figure below shows the DI2CM IP Core block diagram.



**CPU Interface** – Performs the interface functions between DI2CM internal blocks and microprocessor. Allows easy connection of the core to a microprocessor/microcontroller system

**Control Logic** – Manages execution of all commands sent via interface. Synchronizes internal data flow.

**Shift Register** – Controls SDA line, performs data and address shifts during the data transmission and reception.

**Control Register** – Contains five control bits used for performing all types of I<sup>2</sup>C Bus transmissions.

**Status Register** – Contains seven status bits that indicates state of the I<sup>2</sup>C Bus and the DI2CM core.

**Clock Generator** – Performs generation of the serial clock.

Input Filter – Performs spike filtering.

**Clock Synchronization** – Performs clock synchronization.

**Arbitration Logic** – Performs arbitration during operations in multi-master systems.

**Timer** – Allows operation from a wide range of the input frequencies. It is programmed by an user before transmission and can be reprogrammed to change the SCL frequency.

All trademarks mentioned in this document are trademarks of their respective owners.

#### IMPLEMENTATION

Figures below show the typical DI2CM implementations in system with Standard/Fast and High-speed devices.



DI2CM implementation in I<sup>2</sup>C-bus system with Standard/Fast devices only



DI2CM implementation in l<sup>2</sup>C-bus system with High-speed devices

http://www.DigitalCoreDesign.com http://www.dcd.pl

# PERFORMANCE

The following table gives a survey about the Core area and performance in the LATTICE® devices after Place & Route (all key features have been included):

| Device  | Speed<br>grade | LUTs/PFUs | F <sub>max</sub> |  |  |  |
|---------|----------------|-----------|------------------|--|--|--|
| SC      | -7             | 295 / 124 | 301 MHz          |  |  |  |
| ECP2    | -7             | 285 / 120 | 253 MHz          |  |  |  |
| ECP2M   | -7             | 239 / 120 | 253 MHz          |  |  |  |
| XP2     | -7             | 239 / 120 | 210 MHz          |  |  |  |
| EC      | -5             | 340 / 120 | 185 MHz          |  |  |  |
| ECP     | -5             | 340 / 120 | 183 MHz          |  |  |  |
| XP      | -5             | 340 / 120 | 155 MHz          |  |  |  |
| ispXPGA | -5             | 363 / 103 | 107 MHz          |  |  |  |
| ORCA 4  | -3             | 387 / 57  | 69 MHz           |  |  |  |
| ORCA 3  | -7             | 316 / 57  | 43 MHz           |  |  |  |

Core performance in LATTICE® devices

The main features of each Digital Core Design  $I^2C$  compliant cores have been summarized in table below. It gives a briefly member characterization helping user to select the most suitable IP Core for its application.

| Design | I <sup>2</sup> C specification<br>version | Master operation | Slave operation | CPU interface | Passive device interface | Interrupt genera-<br>tion | Clock synchroni-<br>zation | Arbitration | 7-bit addressing | 10-bit addressing | Standard mode | Fast mode    | High-speed mode | User defined tim-<br>ing | Spike filtering |
|--------|-------------------------------------------|------------------|-----------------|---------------|--------------------------|---------------------------|----------------------------|-------------|------------------|-------------------|---------------|--------------|-----------------|--------------------------|-----------------|
| DI2CM  | 2.1                                       | <b>✓</b>         | -               | <b>\</b>      | -                        | <b>✓</b>                  | <b>✓</b>                   | <b>✓</b>    | $\checkmark$     | <b>✓</b>          | <b>\</b>      | $\checkmark$ | <b>✓</b>        | $\checkmark$             | $\checkmark$    |
| DI2CS  | 2.1                                       | -                | <b>✓</b>        | <             | -                        | <b>✓</b>                  | <b>✓</b>                   | -           | <b>✓</b>         | -                 | <b>✓</b>      | <b>✓</b>     | <b>√</b>        | <b>✓</b>                 | <b>✓</b>        |
| DI2CSB | 2.1                                       | -                | <b>✓</b>        | -             | <b>✓</b>                 | -                         | -                          | -           | $\checkmark$     | -                 | <b>\</b>      | $\checkmark$ | <b>✓</b>        | -                        | $\checkmark$    |

PC cores summary table

# CONTACTS

For any modification or special request please contact to Digital Core Design or local distributors.

# **Headquarters:**

Wroclawska 94

41-902 Bytom, POLAND

e-mail: info@dcd.pl

tel. : +48 32 282 82 66 fax : +48 32 282 74 37

#### **Distributors:**

Please check http://www.dcd.pl/apartn.php