# GPIO Pin Expansion Using I<sup>2</sup>C Bus Interface in Altera MAX Series

2014.09.22

AN-494 Subscribe Send Feedback

This design example shows the capability of Altera<sup>®</sup> MAX<sup>®</sup> II, MAX V and MAX 10 to provide general purpose I/O (GPIO) pin expansion via an industry standard I<sup>2</sup>C bus.

To reduce package size and pin count, the number of general purpose I/Os are limited in many microprocessor-based systems. However, if the system has an I<sup>2</sup>C interface, this design example shows how to add additional GPIO pins via the I<sup>2</sup>C bus.

The supported Altera devices are an excellent choice to implement industry standard interfaces, such as the I<sup>2</sup>C. Their low power, easy power-on feature, and internal oscillator make them ideal programmable logic devices to implement applications such as I<sup>2</sup>C interfaces to provide GPIO pin expansion.

### **Related Information**

- **Design Example for MAX II** Provides the MAX II design files for this application note (AN 494).
- **Design Example for MAX 10** Provides the MAX 10 design file for this application note (AN 494).
- Power Management in Portable Systems Using MAX II CPLDs
- MAX II CPLD Design Guidelines

# GPIO Pin Expansion and I<sup>2</sup>C

In some cases, it may be required to have access to the GPIO pins from a relatively long PCB trace path within the system (such as in the two different parts of a clamshell cell phone). Because the I<sup>2</sup>C interface is a two-wire system, the design provides multiple input and output pins at the remote end with just a common two-wire trace. This provides increased design flexibility and also adds to the physical compactness of the entire system. It also enables smaller packaging and a reduced pin count. Devices such as fan controllers, LED status displays, and status indicators can be easily connected and controlled via the general purpose output pins. Similarly, devices such as reset pins and push button switches can be easily coupled to the general purpose inputs provided on the device to serve various applications.

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at www.altera.com/common/legal.html. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2008 Registered



2

### Figure 1: GPIO Pin Expansion via an I<sup>2</sup>C Bus



## I<sup>2</sup>C Interface for GPIO Pin Expansion

The supported Altera device acts as a slave on the I<sup>2</sup>C bus and has two pins on its I<sup>2</sup>C interface: the I<sup>2</sup>C clock SCL and the I<sup>2</sup>C data line SDA. The host system, which acts as an I<sup>2</sup>C master, communicates with the device (which acts as an I<sup>2</sup>C slave). The device presents eight general purpose input ports and eight general purpose output ports to the host. Data, which is transmitted serially over the I<sup>2</sup>C bus, is received in parallel at the GPIO pins. This way, all eight general purpose I/Os can be read or written at the same time.

## I<sup>2</sup>C Interface

For the I<sup>2</sup>C interface, the device (I<sup>2</sup>C slave) has a built-in 7-bit address and follows the general I<sup>2</sup>C protocol. The start signal is sent by the master, followed by the 7-bit address and an R/W bit. When the address broadcast on the I<sup>2</sup>C bus matches a slave device's address, an ACK (acknowledge) signal is sent by the device followed by data according to the read or write signal sent by the master. This is then followed by another ACK signal. The exchange of data continues in this manner until the Stop (P) signal is sent by the master.

### Table 1: I2C Interface Pin Description

| Signal | Purpose                      | Direction     |
|--------|------------------------------|---------------|
| SCL    | I <sup>2</sup> C Clock       | Output        |
| SDA    | I <sup>2</sup> C Serial Data | Bidirectional |



Send Feedback

### Figure 2: I<sup>2</sup>C Signal Format



## **GPIO** Interface

Whenever the master issues a write condition (R/W=0), the data received on the I<sup>2</sup>C bus is used to update the general purpose output pins until a stop or a repeat start condition is encountered. Similarly, when the I<sup>2</sup>C master issues a read condition (R/W = 1), the values at the general purpose input pins are sampled at the ACK bit and transmitted serially over the I<sup>2</sup>C bus. This process continues until the master issues a stop or repeat start.

### Table 2: GPIO Pin Description

| Signal       | Purpose | Direction |
|--------------|---------|-----------|
| 8-bit Input  | General | In        |
| 8-bit Output | General | Out       |

# GPIO Pin Expansion Using I<sup>2</sup>C Bus Interface Using MAX II Devices

The detailed description of the implementation is based on the MAX II devices. This application can also be implemented in MAX V and MAX 10 devices.



#### **Figure 3: GPIO Pin Expansion Demonstration Circuit**



Implementation involves using this design example source code and allocating I<sup>2</sup>C bus lines and GPIO pin expansion inputs and outputs to MAX II GPIOs. GPIO pin expansion is demonstrated on the MDN-B2 demo board with the help of an I<sup>2</sup>C simulator that is created using a PC parallel port and interfacing hardware to create an I2C compliant two-wire bus.

Details about setting up an I<sup>2</sup>C environment is described in the Dallas Semiconductor's Maxim application note AN3230. This utility program uses the parallel port and its interfacing hardware to interact with the MAX II device and provides the SDA and SCL connections, as required on an I<sup>2</sup>C two-wire system. When implemented, this design allows inputs from the MDN-B2 demo board (set via DIP switches) to reach the I<sup>2</sup>C master. Similarly, data sent by the I<sup>2</sup>C master is available on the GPIO output ports (connected to LEDs on the demo board) of the MAX II device. The I<sup>2</sup>C master in this demonstration is the user interface on the PC running the parallel port I<sup>2</sup>C software.

The following details the implementation of this design example on the MDN-B2 demo board.

| Signal         | Pin    | Signal         | Pin    |
|----------------|--------|----------------|--------|
| SCLK           | pin 39 | SDA            | pin 40 |
| GPIO_output[0] | pin 69 | GPIO_output[1] | pin 70 |
| GPIO_output[2] | pin 71 | GPIO_output[3] | pin 72 |
| GPIO_output[4] | pin 73 | GPIO_output[5] | pin 74 |
| GPIO_output[6] | pin 75 | GPIO_output[7] | pin 76 |
| GPIO_input[0]  | pin 55 | GPIO_input[1]  | pin 56 |
| GPIO_input[2]  | pin 57 | GPIO_input[3]  | pin 58 |
| GPIO_input[4]  | pin 61 | GPIO_input[5]  | pin 66 |
| GPIO_input[6]  | pin 67 | GPIO_input[7]  | pin 68 |

#### Table 3: EPM240G Pin Assignments

4



Note: Assign unused pins As input-tristated in the Quartus<sup>®</sup> II software. You must also enable the Auto Open-Drain setting on the SCLK and SDA pins. To do this, on the Assignments menu, click Settings and then select Analysis and Synthesis Settings to enable the Auto Open-Drain setting. These settings are followed by a compilation cycle.

#### **Related Information**

**Dallas Semiconductor's Maxim application note AN3230** Provides details about setting up an I2C environment

### Design Demonstration on the MDN-B2 Demo Board

To demonstrate this design on the MDN-B2 demo board, perform the following steps:

- 1. Turn on the power to the demo board using the slide switch SW1.
- 2. Download the design to the device through the JTAG header JP5 on the demo board and a conventional programming cable (ByteBlaster<sup>™</sup> II or USB-Blaster<sup>™</sup>).
- **3.** Keep SW4 on the demo board pressed before and during the start of the programming process. After programming, turn off the power and remove the JTAG connector.
- 4. To set up a parallel port driven I<sup>2</sup>C environment on your PC, perform the following:
  - **a.** Download a software utility, such as the Maxim parallel port utility, to communicate with the slave in the I<sup>2</sup>C defined protocol. Install the parallel port software. (The ParDS2W.exe program downloaded from parallel port software from Direct-IO is used in this example.)
  - **b.** You must install a parallel port driver to enable access to the parallel port in Windows XP or Windows 2000 for this parallel port utility.
  - c. After installation, you must configure the Direct-IO program. Open the Windows control panel and click the Direct IO icon. Enter the **Begin** and **End** addresses of your parallel port (normally, this is 378 through 37F; however, confirm your PC's parallel port address by looking at the settings in **Control Panel/System/Hardware/Device Manager/Ports/ECP Printer port (LPT)/Resources**
  - d. Configure the parallel port to ECP by changing the BIOS settings when you start up your PC.
  - e. Next, select the Security tab of the Direct IO control panel and browse to the directory path of the ParDS2W.exe program. Click Open and then click Add to add the program. The path of this utility is shown in the Allowed Processes field. Click OK.
  - **f.** Attach the parallel port I<sup>2</sup>C dongle that is supplied along with the MDN-B2 demo board. Use an extension chord, if necessary, to extend the parallel port connection closer to your demo board.
  - **g.** Attach the 4-pin socket on the pig tail of the I<sup>2</sup>C parallel port dongle to the I<sup>2</sup>C header (JP3) of the demo board so that the red mark on the socket meets pin 1 on the JP3 header.
  - **h.** Open the ParDS2W program, select the appropriate parallel port address of your PC (as seen when configuring Direct IO) and set the **2-Wire Device Address** to 00h.
  - i. Finally, you can test the I<sup>2</sup>C setup on the **Test Circuit** tab to see if you have a Test PASS message in the Status window. If you do, the I<sup>2</sup>C environment is set.
- 5. With the parallel port utility you can now perform write and read operations in I<sup>2</sup>C using the 2-Wire Functions.
- **6.** To perform a write I<sup>2</sup>C operation, click **Start** and then click **Write Byte**. Enter a hex byte in the field adjacent to Write Data and click **Write Data**. Observe the corresponding value on the eight red LEDs. Click **Stop** after each write operation.
- 7. Similarly, a read operation is performed by clicking **Start** and then **Read Byte**. The Read window displays the settings on the SW5 dip switch on the demo board. Click **Stop** after each read operation.

GPIO Pin Expansion Using I2C Bus Interface in Altera MAX Series



#### Acknowledgments

6

Related Information Parallel port driver from Direct-IO

# Acknowledgments

Design example adapted for Altera MAX 10 FPGAs by: Orchid Technologies Engineering and Consulting, Inc. Maynard, Massachusetts 01754 TEL: 978-461-2000 WEB: www.orchid-tech.com

EMAIL: info@orchid-tech.com

# **Document Revision History**

| Date           | Version    | Changes                                                                                                        |
|----------------|------------|----------------------------------------------------------------------------------------------------------------|
| September 2014 | 2014.09.22 | <ul> <li>Added MAX V and MAX 10 devices.</li> <li>Updated template.</li> <li>Restructured document.</li> </ul> |
| December 2007  | 1.0        | Initial release.                                                                                               |



Send Feedback