nuttx/Documentation/components/drivers/special/i2c.rst

32 lines
1.2 KiB
ReStructuredText
Raw Normal View History

==================
I2C Device Drivers
==================
- ``include/nuttx/i2c/i2c_master.h`` and ``include/nuttx/i2c/i2c_slave.h``.
All structures and APIs needed to work with I2C drivers are provided in
this header file.
- ``struct i2c_ops_s``. Each I2C device driver must implement
an instance of ``struct i2c_ops_s``. That structure defines a
call table with the following methods:
- **Binding I2C Drivers**. I2C drivers are not normally directly
accessed by user code, but are usually bound to another, higher
level device driver. In general, the binding sequence is:
#. Get an instance of ``struct i2c_master_s`` from the
hardware-specific I2C device driver, and
#. Provide that instance to the initialization method of the
higher level device driver.
- **Examples**: ``arch/z80/src/ez80/ez80_i2c.c``,
``arch/z80/src/z8/z8_i2c.c``, etc.
- ``struct i2c_slaveops_s``. Each I2C slave device driver must implement
an instance of ``struct i2c_slaveops_s``. That structure defines a call
table with the following methods:
- **Binding I2C Slave Drivers**. I2C slave drivers are normally directly
accessed by user code, We can read and write to device nodes using posix
interfaces.