MCP23Sxx I/O Expander ===================== .. seo:: :description: Instructions for setting up MCP23S08, MCP23S16 or MCP23S17 digital port expander in ESPHome. This is exactly the same API as the MCP23SXX I/O Expander except talks on the SPI bus :image: mcp23Sxx.png The Microchip MCP23Sxx series of general purpose, parallel I/O expansion for SPI bus applications. This is exactly the same API as the MCP23SXX I/O Expander except talks on the SPI bus **Supported Variants :** - :ref:`mcp23S08-label` - :ref:`mcp23S17-label` .. _mcp23S08-label: MCP23S08 Component ------------------ The MCP23S08 component (`datasheet <http://ww1.microchip.com/downloads/en/DeviceDoc/MCP23008-MCP23S08-Data-Sheet-20001919F.pdf>`__, `Digi-Key <https://www.digikey.com/product-detail/en/microchip-technology/MCP23S08-E-P/MCP23S08-E-P-ND/735954>`__) has 8 GPIOs that can be configured independently. .. code-block:: yaml # Example configuration entry mcp23s08: - id: 'mcp23s08_hub' cs_pin: D8 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 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 inverted: false Configuration variables: ************************ - **id** (**Required**, :ref:`config-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*, bool): 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**, :ref:`config-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 :ref:`Pin Schema <config-pin_schema>` .. _mcp23S17-label: MCP23S17 Component ------------------ The MCP23S17 component allows you to use MCP23S17 I/O expanders (`datasheet <http://ww1.microchip.com/downloads/en/DeviceDoc/20001952C.pdf>`__, `Digi-Key <https://www.digikey.com/product-detail/en/microchip-technology/MCP23S17-E-SP/MCP23S17-E-SP-ND/894276>`__) in ESPHome. It uses the :ref:`SPI Bus <spi>` 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. .. code-block:: yaml # Example configuration entry mcp23s17: - id: 'mcp23s17_hub' cs_pin: D8 deviceaddress: 0 # Individual outputs switch: - platform: gpio name: "MCP23S17 Pin #0" pin: mcp23xxx: mcp23s17_hub # Use pin number 0 number: 0 mode: OUTPUT 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_PULLUP inverted: false Configuration variables: ************************ - **id** (**Required**, :ref:`config-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*, bool): 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**, :ref:`config-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 :ref:`Pin Schema <config-pin_schema>` See Also -------- - :ref:`spi` - :doc:`switch/gpio` - :doc:`binary_sensor/gpio` - :apiref:`API Reference (MCP23S08) <mcp23S08/mcp23S08.h>` - :apiref:`API Reference (MCP23S17) <mcp23S17/mcp23S17.h>` - :ghedit:`Edit`