ESP32-PaxCounter/src/i2c.cpp

91 lines
2.0 KiB
C++
Raw Normal View History

2019-09-02 16:53:39 +02:00
// Basic config
#include "globals.h"
2019-10-16 21:14:34 +02:00
#include "i2c.h"
2019-09-02 16:53:39 +02:00
// Local logging tag
static const char TAG[] = __FILE__;
2019-10-16 21:14:34 +02:00
void i2c_init(void) {
#ifdef HAS_DISPLAY
Wire.begin(MY_OLED_SDA, MY_OLED_SCL, 400000);
#else
Wire.begin(SDA, SCL, 400000);
#endif
}
void i2c_deinit(void) {
Wire.~TwoWire(); // shutdown/power off I2C hardware
#ifdef HAS_DISPLAY
// to save power, because Wire.end() enables pullups
pinMode(MY_OLED_SDA, INPUT);
pinMode(MY_OLED_SCL, INPUT);
#else
pinMode(SDA, INPUT);
pinMode(SCL, INPUT);
#endif
}
2019-09-02 16:53:39 +02:00
int i2c_scan(void) {
int i2c_ret, addr;
int devices = 0;
ESP_LOGI(TAG, "Starting I2C bus scan...");
2019-09-09 12:06:23 +02:00
// block i2c bus access
if (I2C_MUTEX_LOCK()) {
2019-09-02 16:53:39 +02:00
2019-10-13 16:59:03 +02:00
// Scan at 100KHz low speed
Wire.setClock(100000);
2019-09-09 12:06:23 +02:00
for (addr = 8; addr <= 119; addr++) {
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
Wire.beginTransmission(addr);
Wire.write(addr);
i2c_ret = Wire.endTransmission();
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
if (i2c_ret == 0) {
devices++;
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
switch (addr) {
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
case SSD1306_PRIMARY_ADDRESS:
case SSD1306_SECONDARY_ADDRESS:
ESP_LOGI(TAG, "0x%X: SSD1306 Display controller", addr);
break;
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
case BME_PRIMARY_ADDRESS:
case BME_SECONDARY_ADDRESS:
ESP_LOGI(TAG, "0x%X: Bosch BME MEMS", addr);
break;
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
case AXP192_PRIMARY_ADDRESS:
ESP_LOGI(TAG, "0x%X: AXP192 power management", addr);
break;
2019-09-02 20:45:40 +02:00
2019-09-09 12:06:23 +02:00
case QUECTEL_GPS_PRIMARY_ADDRESS:
ESP_LOGI(TAG, "0x%X: Quectel GPS", addr);
break;
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
case MCP_24AA02E64_PRIMARY_ADDRESS:
ESP_LOGI(TAG, "0x%X: 24AA02E64 serial EEPROM", addr);
break;
2019-09-02 16:53:39 +02:00
2019-09-09 12:06:23 +02:00
default:
ESP_LOGI(TAG, "0x%X: Unknown device", addr);
break;
}
} // switch
} // for loop
ESP_LOGI(TAG, "I2C scan done, %u devices found.", devices);
2019-10-13 16:59:03 +02:00
// Set back to 400KHz
Wire.setClock(400000);
2019-09-09 12:06:23 +02:00
I2C_MUTEX_UNLOCK(); // release i2c bus access
} else
ESP_LOGE(TAG, "I2c bus busy - scan error");
2019-09-02 16:53:39 +02:00
return devices;
2019-09-07 19:52:25 +02:00
}