# ESP IO Expander Chip TCA95x5
Implementation of the TCA9535/TCA9555 io expander chips with `esp_io_expander` component.
| Chip | Communication interface | Component name | Link to datasheet |
| :--------------: | :---------------------: | :------------: | :---------------: |
| TCA9535 | I2C | esp_io_expander_tca95x5 | [datasheet](https://www.ti.com/lit/gpn/tca9535) |
| TCA9555 | I2C | esp_io_expander_tca95x5 | [datasheet](https://www.ti.com/lit/gpn/tca9555) |
## Add to project
Packages from this repository are uploaded to [Espressif's component service](https://components.espressif.com/).
You can add them to your project via `idf.py add-dependency`, e.g.
```
idf.py add-dependency caleb-snow-cbm/esp_io_expander_tca95x5==1.0.0
```
Alternatively, you can clone the repository and copy the contents into your project's `components` directory.
## Example use
Creation of the i2c bus.
```c
i2c_master_bus_handle_t i2c_handle = NULL;
const i2c_master_bus_config_t bus_config = {
.i2c_port = I2C_NUM_0,
.sda_io_num = 47,
.scl_io_num = 48,
.clk_source = I2C_CLK_SRC_DEFAULT,
};
i2c_new_master_bus(&bus_config, &i2c_handle);
```
Creation of the component.
```c
esp_io_expander_handle_t io_expander = NULL;
esp_io_expander_new_i2c_tca9535(i2c_handle, TCA95X5_ADDRESS_001, &io_expander);
```
Print all pins's status to the log:
```c
esp_io_expander_print_state(io_expander);
```
Set pin 0 and pin 1 with output dircetion and low level:
```c
esp_io_expander_set_dir(io_expander, IO_EXPANDER_PIN_NUM_0 | IO_EXPANDER_PIN_NUM_1, IO_EXPANDER_OUTPUT);
esp_io_expander_set_level(io_expander, IO_EXPANDER_PIN_NUM_0 | IO_EXPANDER_PIN_NUM_1, 0);
```
Set pin 2 and pin 3 with input dircetion:
```c
uint32_t pin_levels = 0;
esp_io_expander_set_dir(io_expander, IO_EXPANDER_PIN_NUM_2 | IO_EXPANDER_PIN_NUM_3, IO_EXPANDER_INPUT);
esp_io_expander_get_level(io_expander, IO_EXPANDER_PIN_NUM_2 | IO_EXPANDER_PIN_NUM_3, &pin_levels);
```
idf.py add-dependency "caleb-snow-cbm/esp_io_expander_tca95x5^1.0.1"