| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- #ifndef UNITEMP_I2C
- #define UNITEMP_I2C
- #include "../unitemp.h"
- #include <furi_hal_i2c.h>
- typedef struct I2CSensor {
- //Указатель на интерфейс I2C
- FuriHalI2cBusHandle* i2c;
- //Минимальный адрес устройства на шине I2C
- uint8_t minI2CAdr;
- //Максимальный адрес устройства на шине I2C
- uint8_t maxI2CAdr;
- //Текущий адрес устройства на шине I2C
- uint8_t currentI2CAdr;
- //Указатель на собственный экземпляр датчика
- void* sensorInstance;
- } I2CSensor;
- /**
- * @brief Выделение памяти для датчика на шине I2C
- *
- * @param sensor Указатель на датчик
- * @param st Тип датчика
- * @return Истина если всё ок
- */
- bool unitemp_I2C_sensor_alloc(void* s, uint8_t* anotherValues);
- /**
- * @brief Высвобождение памяти инстанса датчика
- *
- * @param sensor Указатель на датчик
- */
- bool unitemp_I2C_sensor_free(void* sensor);
- /**
- * @brief Обновить значение с датчка
- *
- * @param sensor Указатель на датчик (тип Sensor)
- * @return Статус обновления
- */
- UnitempStatus unitemp_I2C_sensor_update(void* sensor);
- /**
- * @brief Прочитать значение регистра reg
- *
- * @param i2c_sensor Указатель на датчик
- * @param reg Номер регистра
- * @return Значение регистра
- */
- uint8_t readReg(I2CSensor* i2c_sensor, uint8_t reg);
- /**
- * @brief Прочитать масссив значений из памяти
- *
- * @param i2c_sensor
- * @param startReg
- * @param len
- * @param data
- * @return Истина если устройство вернуло данные
- */
- bool readRegArray(I2CSensor* i2c_sensor, uint8_t startReg, uint8_t len, uint8_t* data);
- /**
- * @brief Записать значение в регистр
- *
- * @param i2c_sensor Указатель на датчик
- * @param reg Номер регистра
- * @param value Значение для записи
- * @return Истина если значение записано
- */
- bool writeReg(I2CSensor* i2c_sensor, uint8_t reg, uint8_t value);
- #endif
|