MCP23Sxx I/O Expander
The Microchip MCP23Sxx series of general purpose, parallel I/O expansion for SPI bus applications. This series features exactly the same API as the MCP230xx I/O Expander (I²C).
Supported Variants :
MCP23S08 Component
The MCP23S08 component (datasheet, Digi-Key) has 8 GPIOs that can be configured independently.
# Example configuration entry
mcp23s08:
  - id: 'mcp23s08_hub'
    cs_pin: GPIOXX
    deviceaddress: 0
# Individual outputs
switch:
  - platform: gpio
    name: "MCP23S08 Pin #0"
    pin:
      mcp23xxx: mcp23s08_hub
      # Use pin number 0
      number: 0
      # One of INPUT, INPUT_PULLUP or OUTPUT
      mode:
        output: true
      inverted: false
# Individual inputs
binary_sensor:
  - platform: gpio
    name: "MCP23S08 Pin #1"
    pin:
      mcp23xxx: mcp23s08_hub
      # Use pin number 1
      number: 1
      # One of INPUT or INPUT_PULLUP
      mode:
        input: true
      inverted: falseConfiguration variables
- id (Required, ID): The id to use for this MCP23S08 component. 
- cs_pin (Required, int): The SPI chip select pin to use 
- deviceaddress (Optional, int): The address of the chip. Defaults to - 0.
- open_drain_interrupt (Optional, boolean): Configure interrupt pins to open-drain mode. Useful when the MCP23S08’s power supply is greater than 3.3 volts. Note that these pins will require pull-up resistors (to 3.3 volts) when this mode is enabled. 
Pin Configuration Variables
- mcp23xxx (Required, ID): The id of the MCP23S08 component.
- interrupt (Optional): Set this pin to trigger the INT pin on the component. Can be one of CHANGE,RISING,FALLING.
- All other options from Pin Schema
MCP23S17 Component
The MCP23S17 component allows you to use MCP23S17 I/O expanders (datasheet, Digi-Key) in ESPHome. It uses the SPI Bus for communication.
Once configured, you can use any of the 16 pins as pins for your projects. Within ESPHome they emulate a real internal GPIO pin and can therefore be used with many of ESPHome’s components such as the GPIO binary sensor or GPIO switch.
# Example configuration entry
mcp23s17:
  - id: 'mcp23s17_hub'
    cs_pin: GPIOXX
    deviceaddress: 0
# Individual outputs
switch:
  - platform: gpio
    name: "MCP23S17 Pin #0"
    pin:
      mcp23xxx: mcp23s17_hub
      # Use pin number 0
      number: 0
      mode:
        output: true
      inverted: false
# Individual inputs
binary_sensor:
  - platform: gpio
    name: "MCP23S17 Pin #1"
    pin:
      mcp23xxx: mcp23s17_hub
      # Use pin number 1
      number: 1
      # One of INPUT or INPUT_PULLUP
      mode:
        input: true
        pullup: true
      inverted: falseConfiguration variables
- id (Required, ID): The id to use for this MCP23S17 component. 
- cs_pin (Required, int): The SPI chip select pin to use. 
- deviceaddress (Optional, int): The address of the chip. Defaults to - 0.
- open_drain_interrupt (Optional, boolean): Configure interrupt pins to open-drain mode. Useful when the MCP23S17’s power supply is greater than 3.3 volts. Note that these pins will require pull-up resistors (to 3.3 volts) when this mode is enabled. 
Pin Configuration Variables
- mcp23xxx (Required, ID): The id of the MCP23S17 component.
- interrupt (Optional): Set this pin to trigger the port INT pin on the component. Can be one of CHANGE,RISING,FALLING.
- All other options from Pin Schema