# ESP IO Expander Chip PCA9535(C)
Implementation of the PCA9535(C) io expander chip with esp_io_expander component.
| Chip | Communication interface | Component name | Link to datasheet |
| :--------------: | :---------------------: | :------------: | :---------------: |
| PCA9535(C) | I2C | esp_io_expander_pca9535 | [datasheet](https://www.nxp.com/docs/en/data-sheet/PCA9535_PCA9535C.pdf) |
## 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 esp_io_expander_pca9535==1.0.0
```
Alternatively, you can create `idf_component.yml`. More is in [Espressif's documentation](https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-guides/tools/idf-component-manager.html).
## 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 = 6,
.scl_io_num = 5,
.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_pca9535(i2c_handle, ESP_IO_EXPANDER_I2C_PCA9535_ADDRESS_000, &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 "wngfra/esp_io_expander_pca9535^1.0.1"