High-Speed I²C for the MAX1239 ADC Using the MAXQ2000 Microcontroller
Abstract
This application note provides a much-needed working high-speed I2C example. The application note shows an application circuit and provides all the firmware required to interface the MAXQ2000 microcontroller (MAXQ20 core) to the MAX1239 for a conversion rate of 91ksps. The example firmware was developed using the MAX-IDE Version 1.0.
MAX1239 Overview
The MAX1239 is a 12-channel, 12-bit, low-power ADC featuring a 1.7MHz high-speed I2C-compatible serial interface. The MAX1239 supports both Fast/Standard mode (FS mode at 400kHz) and High-Speed mode (HS mode at 1.7MHz) with conversion rates up to 94.4ksps. HS mode is required to achieve conversion rates from 26ksps to 94.4ksps. External clock mode is required for conversion rates from 40ksps to 94.4ksps.
Hardware Overview
A simplified system block diagram is shown in Figure 1. The application circuit utilizes two evaluation (EV) kits: the MAX1238EVKIT with an installed MAX1239 (instead of a MAX1238), and a MAXQ2000-KIT. The MAX1239 was selected because of the digital-logic voltage range. The MAXQ2000 microcontroller's general-purpose input/output (GPIO) ports only accept up to +3.3V; using level translators with high-speed I2C would have made the circuit overly complicated. The MAXQ2000 is not present on the MAX1238 EV kit board, so it was added to the system by connecting SCL, SDA, and GND on both boards. In addition, it is very important to apply +3.3V (instead of +5V) to VDD on the MAX1238 EV kit board. Order a free sample of the MAX1239EEE or MAX1239EEE+ and solder it onto the MAX1238 EV kit. The modified MAX1238 EV kit schematic is shown in Figure 2.
The pinout of the MAX1239 allows easy isolation of the analog circuitry from the digital circuitry; the analog circuitry is grouped together on the left side of the board, and the digital circuitry is grouped together on the right side of the board. Keep this in mind when connecting the two boards together. Connect J2-52 (SDA) on the MAXQ2000 EV kit board to the SDA pad on the MAX1238 EV kit. Similarly, connect J2-54 (SCL) to the SCL pad. The grounds of both boards must be connected together. In addition, R5 and R7 both have to be populated with 2.2kΩ 5% resistors. The MAX1238 EV kit already has 47kΩ I2C pullup resistors and the MAXQ2000 EV kit has 10kΩ I2C pullup resistors. Adding R5 and R7 will provide approximately 1.6kΩ of pullup resistance on the I2C bus.
The MAXQ2000 EV kit contains a complete set of hardware, software, sample code, and documentation needed to start designing with the MAXQ2000. Schematics for the MAXQ2000 EV kit are available in the data sheet.
Firmware Overview
The example firmware was developed using the free MAX-IDE Version 1.0. Download the latest version of the MAX-IDE.
The main source file is hsi2c.asm
, and it was written in assembly to optimize the timing of the HS-mode I2C interface. The source code does the following things:
- Initializes the MAXQ2000's UART for 8-N-1 at 115.2kbps
- Initializes the MAX1239 CONF BYTE for single-ended channel AIN0
- Initializes the MAX1239 SETUP BYTE for the internal reference, external clock, and unipolar operation
- Initializes the MAX1239 for I2C HS mode
- Reads back 12-bit samples from the MAX1239 in I2C HS mode
- Transmits the 12-bit samples over the serial port
The example assembly program collects samples from the MAX1239 by bit-banging a HS-mode I2C interface on the MAXQ2000's GPIO ports. The MAXQ2000's 16MHz system clock allows the bit-banged HS-mode I2C interface to run up to 1.7MHz.
The hsi2c.asm
file defaults to the slave address of the MAX1239EEE or MAX1239EEE+. The firmware must be customized for each different part in the family. For example, follow the two steps below when using the MAX1239KEEE, MAX1239KEEE+, MAX1239LEEE, MAX1239LEEE+, MAX1239MEEE, or MAX1239MEEE+:
- Edit the I2C_ADDR define statements to reflect the I2C address of the part used. These variables are required to be the compliment of the actual address. For example, an address of 0111 111 (r/w) needs to be encoded as:
- The source code expects a 16MHz system clock to be used (MAXQ2000 crystal).
I2C_ADDR7 equ 1
I2C_ADDR6 equ 0
I2C_ADDR5 equ 0
I2C_ADDR4 equ 0
I2C_ADDR3 equ 0
I2C_ADDR2 equ 0
I2C_ADDR1 equ 0
The following figures illustrate the FS-mode (Figure 3) and HS-mode (Figure 4) I2C frames implemented in this application note.
Figures 5 through Figure 16 are scope shots of the FS-mode (Figure 3) and HS-mode (Figure 4) I2C frames implemented in this application note. Channel 1 is SCL and Channel 2 is SDA on all scope shots.
The specification for high-speed I2C has existed since January 2000. Nonetheless, few, if any microcontrollers are available today with an internal high-speed I2C peripheral. This is an unfortunate situation since several devices, such as ADCs, DACs, CODECs, and even power supplies, are being designed to support the high-speed I2C interface. This application note provides a much-needed working, high-speed I2C example.
Download: Source Code