The MCP23017 provides 16-bit, general-purpose parallel I/O expansion for I2C bus applications.
Thechip consists of multiple 8-bit configuration registers for input, output and polarity selection. The system master can enable the I/Os as either inputs or outputs by writing the I/O configuration bits (IODIRA/B). The data for each input or output is kept in the corresponding input or output register. The polarity of the Input Port register can be inverted with the Polarity Inversion register. All registers can be read by the system master.
The 16-bit I/O port functionally consists of two 8-bit ports (PORTA and PORTB). The MCP23017 can be configured to operate in the 8-bit or 16-bit modes via IOCON.BANK. There are two interrupt pins, INTA and INTB, that can be associated with their respective ports, or can be logically OR’ed together so that both pins will activate if either port causes an interrupt. The interrupt output can be configured to activate under two conditions (mutually exclusive):
- When any input state differs from its corresponding Input Port register state. This is used to indicate to the system master that an input state has changed.
- When an input state differs from a preconfigured register value (DEFVAL register).
The Interrupt Capture register captures port values at the time of the interrupt, thereby saving the condition that caused the interrupt. The Power-on Reset (POR) sets the registers to their default values and initializes the device state machine. The hardware address pins are used to determine the device address.
- 16-bit input/output port expander with interrupt output
- Cascadable for up to 8 devices on one bus
- 25mA sink/source capability per I/O
- Supports 100kHz, 400kHz and 1.7MHz I2C™Compatible compatible modes