#include <I2C.h>
Public Member Functions | |
virtual | ~I2C () |
bool | Transaction (uint8_t *dataToSend, uint8_t sendSize, uint8_t *dataReceived, uint8_t receiveSize) |
bool | AddressOnly () |
bool | Write (uint8_t registerAddress, uint8_t data) |
bool | Read (uint8_t registerAddress, uint8_t count, uint8_t *data) |
void | Broadcast (uint8_t registerAddress, uint8_t data) |
void | SetCompatibilityMode (bool enable) |
bool | VerifySensor (uint8_t registerAddress, uint8_t count, const uint8_t *expected) |
Friends | |
class | DigitalModule |
I2C bus interface class.
This class is intended to be used by sensor (and other I2C device) drivers. It probably should not be used directly.
It is constructed by calling DigitalModule::GetI2C() on a DigitalModule object.
|
virtual |
Destructor.
bool I2C::AddressOnly | ( | ) |
void I2C::Broadcast | ( | uint8_t | registerAddress, |
uint8_t | data | ||
) |
Send a broadcast write to all devices on the I2C bus.
This is not currently implemented!
registerAddress | The register to write on all devices on the bus. |
data | The value to write to the devices. |
bool I2C::Read | ( | uint8_t | registerAddress, |
uint8_t | count, | ||
uint8_t * | buffer | ||
) |
Execute a read transaction with the device.
Read 1 to 7 bytes from a device. Most I2C devices will auto-increment the register pointer internally allowing you to read up to 7 consecutive registers on a device in a single transaction.
registerAddress | The register to read first in the transaction. |
count | The number of bytes to read in the transaction. [1..7] |
buffer | A pointer to the array of bytes to store the data read from the device. |
void I2C::SetCompatibilityMode | ( | bool | enable | ) |
SetCompatibilityMode
Enables bitwise clock skewing detection. This will reduce the I2C interface speed, but will allow you to communicate with devices that skew the clock at abnormal times. Compatability mode is enabled by default.
enable | Enable compatibility mode for this sensor or not. |
bool I2C::Transaction | ( | uint8_t * | dataToSend, |
uint8_t | sendSize, | ||
uint8_t * | dataReceived, | ||
uint8_t | receiveSize | ||
) |
Generic transaction.
This is a lower-level interface to the I2C hardware giving you more control over each transaction.
dataToSend | Buffer of data to send as part of the transaction. |
sendSize | Number of bytes to send as part of the transaction. [0..6] |
dataReceived | Buffer to read data into. |
receiveSize | Number of byted to read from the device. [0..7] |
bool I2C::VerifySensor | ( | uint8_t | registerAddress, |
uint8_t | count, | ||
const uint8_t * | expected | ||
) |
Verify that a device's registers contain expected values.
Most devices will have a set of registers that contain a known value that can be used to identify them. This allows an I2C device driver to easily verify that the device contains the expected value.
registerAddress | The base register to start reading from the device. |
count | The size of the field to be verified. |
expected | A buffer containing the values expected from the device. |
bool I2C::Write | ( | uint8_t | registerAddress, |
uint8_t | data | ||
) |
Execute a write transaction with the device.
Write a single byte to a register on a device and wait until the transaction is complete.
registerAddress | The address of the register on the device to be written. |
data | The byte to write to the register on the device. |