This module supports different interfaces for communicating via I²C protocol. All interfaces can be assigned to arbitrary GPIOs for SCL and SDA and can be operated concurrently.
-`i2c.SW` software based bitbanging, master mode only, synchronous operation
-`i2c.HW0` ESP32 hardware port 0, master or slave mode, synchronous or asynchronous operation
-`i2c.HW1` ESP32 hardware port 1, master or slave mode, synchronous or asynchronous operation
The hardware master interfaces differ from the SW interface as the commands (start, stop, read, write) are queued up to an internal command list. Actual I²C communication is initiated afterwards using the `i2c.transfer()` function. Commands for the `i2c.SW` interface are immediately effective on the I²C bus and read data is also instantly available.
Starts a transfer for the specified hardware module. Providing a callback function allows the transfer to be started asynchronously in the background and `i2c.transfer()` finishes immediately. Without a callback function, the transfer is executed synchronously and `i2c.transfer()` comes back when the transfer completed. Data from a read operation is returned from `i2c.transfer()` in this case.
First argument to the callback is the error code (0 = no error), followed by a string with data obtained from a read operation during the transfer or `nil`.
#### Syntax
`i2c.transfer(id[, cb_fn][, to_ms])`
#### Parameters
-`id` interface id, `i2c.SW` not allowed
-`cb_fn(err, data)` function to be called when transfer finished
-`to_ms` timeout for the transfer in ms, defaults to 0=infinite
#### Returns
-`string` of received data (or `nil` if no read) for synchronous operation
The I²C slave mode is only available for the hardware interfaces `i2c.HW0` and `i2c.HW1`.
## i2c.slave.on()
Registers or unregisters an event callback handler.
#### Syntax
`i2c.slave.on(id, event[, cb_fn])
#### Parameters
-`id` interface id, `i2c.HW0` or `i2c.HW1`
-`event` one of
- "receive" data received from master
-`cb_fn(err, data)` function to be called when data was received from the master. Unregisters previous callback for `event` when omitted.
#### Returns
`nil`
## i2c.slave.setup()
Initialize the I²C interface for slave mode.
#### Syntax
`i2c.slave.setup(id, slave_config)
#### Parameters
-`id` interface id, `i2c.HW0` or `i2c.HW1`
-`slave_config` table containing slave configuration information
-`sda` 0~33, IO index
-`scl` 0-33, IO index
-`addr` slave address (7bit or 10bit)
-`10bit` enable 10bit addressing with `true`, use 7bit with `false` (optional, defaults to `false` is omitted)
-`rxbuf_len` length of receive buffer (optional, defaults to 128 if omitted)
-`txbuf_len` length of transmit buffer (optional, defaults to 128 if omitted)
#### Returns
`nil`
## i2c.slave.send()
Writes send data for the master into the transmit buffer. This function returns immediately if there's enough room left in the buffer. It blocks if the buffer is doesn't provide enough space.
Data items can be multiple numbers, strings or lua tables.