remove i2c mutex (now done in arduino-esp v2)
This commit is contained in:
parent
cbca3ebb90
commit
c9c4f2e714
@ -30,11 +30,6 @@
|
||||
// length of display buffer for lmic event messages
|
||||
#define LMIC_EVENTMSG_LEN 17
|
||||
|
||||
// I2C bus access control
|
||||
#define I2C_MUTEX_LOCK() \
|
||||
(xSemaphoreTake(I2Caccess, pdMS_TO_TICKS(DISPLAYREFRESH_MS)) == pdTRUE)
|
||||
#define I2C_MUTEX_UNLOCK() (xSemaphoreGive(I2Caccess))
|
||||
|
||||
// pseudo system halt function, useful to prevent writeloops to NVRAM
|
||||
#ifndef _ASSERT
|
||||
#define _ASSERT(cond) \
|
||||
|
@ -52,9 +52,6 @@ int bme_init(void) {
|
||||
int rc = 0;
|
||||
|
||||
#ifdef HAS_BME680
|
||||
// block i2c bus access
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
|
||||
Wire.begin(HAS_BME680);
|
||||
iaqSensor.begin(BME680_ADDR, Wire);
|
||||
|
||||
@ -69,25 +66,14 @@ int bme_init(void) {
|
||||
|
||||
rc = checkIaqSensorStatus();
|
||||
|
||||
} else
|
||||
ESP_LOGE(TAG, "I2c bus busy - BME680 initialization error");
|
||||
|
||||
#elif defined HAS_BME280
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
rc = bme.begin(BME280_ADDR);
|
||||
} else
|
||||
ESP_LOGE(TAG, "I2c bus busy - BME280 initialization error");
|
||||
|
||||
#elif defined HAS_BMP180
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
// Wire.begin(21, 22);
|
||||
rc = bmp.begin();
|
||||
} else
|
||||
ESP_LOGE(TAG, "I2c bus busy - BMP180 initialization error");
|
||||
|
||||
#endif
|
||||
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
if (rc)
|
||||
bmecycler.attach(BMECYCLE, setBMEIRQ); // start cyclic data transmit
|
||||
return rc;
|
||||
@ -123,8 +109,7 @@ int checkIaqSensorStatus(void) {
|
||||
// store current BME sensor data in struct
|
||||
void bme_storedata(bmeStatus_t *bme_store) {
|
||||
|
||||
if ((cfg.payloadmask & MEMS_DATA) &&
|
||||
(I2C_MUTEX_LOCK())) { // block i2c bus access
|
||||
if (cfg.payloadmask & MEMS_DATA)
|
||||
|
||||
#ifdef HAS_BME680
|
||||
if (iaqSensor.run()) { // if new data is available
|
||||
@ -154,9 +139,6 @@ void bme_storedata(bmeStatus_t *bme_store) {
|
||||
bme_store->iaq = 0; // IAQ feature not present with BME280
|
||||
#endif
|
||||
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
}
|
||||
|
||||
} // bme_storedata()
|
||||
|
||||
#ifdef HAS_BME680
|
||||
|
@ -90,13 +90,6 @@ void dp_setup(int contrast) {
|
||||
|
||||
void dp_init(bool verbose) {
|
||||
|
||||
#if (HAS_DISPLAY) == 1 // i2c
|
||||
// block i2c bus access
|
||||
if (!I2C_MUTEX_LOCK())
|
||||
ESP_LOGV(TAG, "[%0.3f] i2c mutex lock failed", _seconds());
|
||||
else {
|
||||
#endif
|
||||
|
||||
dp_setup(DISPLAYCONTRAST);
|
||||
|
||||
if (verbose) {
|
||||
@ -122,8 +115,7 @@ void dp_init(bool verbose) {
|
||||
(chip_info.features & CHIP_FEATURE_BLE) ? "/BLE" : "");
|
||||
dp_println();
|
||||
dp_printf("%dMB %s Flash", spi_flash_get_chip_size() / (1024 * 1024),
|
||||
(chip_info.features & CHIP_FEATURE_EMB_FLASH) ? "int."
|
||||
: "ext.");
|
||||
(chip_info.features & CHIP_FEATURE_EMB_FLASH) ? "int." : "ext.");
|
||||
|
||||
// give user some time to read or take picture
|
||||
dp_dump(displaybuf);
|
||||
@ -165,11 +157,6 @@ void dp_init(bool verbose) {
|
||||
|
||||
dp_power(cfg.screenon); // set display off if disabled
|
||||
|
||||
#if (HAS_DISPLAY) == 1 // i2c
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
} // mutex
|
||||
#endif
|
||||
|
||||
} // dp_init
|
||||
|
||||
void dp_refresh(bool nextPage) {
|
||||
@ -182,10 +169,6 @@ void dp_refresh(bool nextPage) {
|
||||
if (!DisplayIsOn && (DisplayIsOn == cfg.screenon))
|
||||
return;
|
||||
|
||||
// block i2c bus access
|
||||
if (!I2C_MUTEX_LOCK())
|
||||
ESP_LOGV(TAG, "[%0.3f] i2c mutex lock failed", _seconds());
|
||||
else {
|
||||
// set display on/off according to current device configuration
|
||||
if (DisplayIsOn != cfg.screenon) {
|
||||
DisplayIsOn = cfg.screenon;
|
||||
@ -202,9 +185,6 @@ void dp_refresh(bool nextPage) {
|
||||
|
||||
dp_drawPage(nextPage);
|
||||
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
|
||||
} // mutex
|
||||
} // refreshDisplay()
|
||||
|
||||
void dp_drawPage(bool nextpage) {
|
||||
@ -600,14 +580,8 @@ void dp_power(uint8_t screenon) {
|
||||
|
||||
void dp_shutdown(void) {
|
||||
#if (HAS_DISPLAY) == 1
|
||||
// block i2c bus access
|
||||
if (!I2C_MUTEX_LOCK())
|
||||
ESP_LOGV(TAG, "[%0.3f] i2c mutex lock failed", _seconds());
|
||||
else {
|
||||
obdPower(&ssoled, false);
|
||||
delay(DISPLAYREFRESH_MS / 1000 * 1.1);
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
}
|
||||
#elif (HAS_DISPLAY) == 2
|
||||
// to come
|
||||
#endif
|
||||
|
23
src/i2c.cpp
23
src/i2c.cpp
@ -49,9 +49,6 @@ void i2c_scan(void) {
|
||||
|
||||
ESP_LOGI(TAG, "Starting I2C bus scan...");
|
||||
|
||||
// block i2c bus access
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
|
||||
memset(&bbi2c, 0, sizeof(bbi2c));
|
||||
bbi2c.bWire = 0;
|
||||
bbi2c.iSDA = MY_DISPLAY_SDA;
|
||||
@ -83,15 +80,10 @@ void i2c_scan(void) {
|
||||
} // for i
|
||||
ESP_LOGI(TAG, "%u I2C device(s) found", iCount);
|
||||
}
|
||||
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
} else
|
||||
ESP_LOGE(TAG, "I2C bus busy - scan error");
|
||||
}
|
||||
|
||||
// mutexed functions for i2c r/w access
|
||||
// functions for i2c r/w access, mutexing is done by Wire.cpp
|
||||
int i2c_readBytes(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len) {
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
|
||||
uint8_t ret = 0;
|
||||
Wire.beginTransmission(addr);
|
||||
@ -110,16 +102,10 @@ int i2c_readBytes(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len) {
|
||||
}
|
||||
|
||||
finish:
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
return ret;
|
||||
} else {
|
||||
ESP_LOGW(TAG, "[%0.3f] i2c mutex lock failed", _seconds());
|
||||
return 0xFF;
|
||||
}
|
||||
return ret ? ret : 0xFF;
|
||||
}
|
||||
|
||||
int i2c_writeBytes(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len) {
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
|
||||
uint8_t ret = 0;
|
||||
Wire.beginTransmission(addr);
|
||||
@ -129,10 +115,5 @@ int i2c_writeBytes(uint8_t addr, uint8_t reg, uint8_t *data, uint8_t len) {
|
||||
}
|
||||
ret = Wire.endTransmission();
|
||||
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
return ret ? ret : 0xFF;
|
||||
} else {
|
||||
ESP_LOGW(TAG, "[%0.3f] i2c mutex lock failed", _seconds());
|
||||
return 0xFF;
|
||||
}
|
||||
}
|
||||
|
@ -87,11 +87,6 @@ void setup() {
|
||||
|
||||
char features[100] = "";
|
||||
|
||||
// create some semaphores for syncing / mutexing tasks
|
||||
I2Caccess = xSemaphoreCreateMutex(); // for access management of i2c bus
|
||||
_ASSERT(I2Caccess != NULL);
|
||||
I2C_MUTEX_UNLOCK();
|
||||
|
||||
// disable brownout detection
|
||||
#ifdef DISABLE_BROWNOUT
|
||||
// register with brownout is at address DR_REG_RTCCNTL_BASE + 0xd4
|
||||
|
@ -10,8 +10,6 @@ RtcDS3231<TwoWire> Rtc(Wire); // RTC hardware i2c interface
|
||||
// initialize RTC
|
||||
uint8_t rtc_init(void) {
|
||||
|
||||
if (I2C_MUTEX_LOCK()) { // block i2c bus access
|
||||
|
||||
Wire.begin(HAS_RTC);
|
||||
Rtc.Begin(MY_DISPLAY_SDA, MY_DISPLAY_SCL);
|
||||
|
||||
@ -36,41 +34,37 @@ uint8_t rtc_init(void) {
|
||||
}
|
||||
#endif
|
||||
|
||||
I2C_MUTEX_UNLOCK(); // release i2c bus access
|
||||
ESP_LOGI(TAG, "RTC initialized");
|
||||
return 1; // success
|
||||
} else {
|
||||
ESP_LOGE(TAG, "RTC initialization error, I2C bus busy");
|
||||
return 0; // failure
|
||||
}
|
||||
|
||||
// failure
|
||||
// return 0
|
||||
|
||||
} // rtc_init()
|
||||
|
||||
uint8_t set_rtctime(time_t t) { // t is sec epoch time
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
|
||||
#ifdef RTC_INT // sync rtc 1Hz pulse on top of second
|
||||
Rtc.SetSquareWavePin(DS3231SquareWavePin_ModeNone); // off
|
||||
Rtc.SetSquareWavePin(DS3231SquareWavePin_ModeClock); // start
|
||||
#endif
|
||||
Rtc.SetDateTime(RtcDateTime(t - SECS_YR_2000)); // epoch -> sec2000
|
||||
I2C_MUTEX_UNLOCK();
|
||||
ESP_LOGI(TAG, "RTC time synced");
|
||||
return 1; // success
|
||||
} else {
|
||||
ESP_LOGE(TAG, "RTC set time failure");
|
||||
return 0; // failure
|
||||
}
|
||||
|
||||
// failure
|
||||
// return 0
|
||||
|
||||
} // set_rtctime()
|
||||
|
||||
time_t get_rtctime(uint16_t *msec) {
|
||||
|
||||
time_t t = 0;
|
||||
*msec = 0;
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
if (Rtc.IsDateTimeValid() && Rtc.GetIsRunning()) {
|
||||
RtcDateTime tt = Rtc.GetDateTime();
|
||||
t = tt.Epoch32Time(); // sec2000 -> epoch
|
||||
}
|
||||
I2C_MUTEX_UNLOCK();
|
||||
#ifdef RTC_INT
|
||||
// adjust time to top of next second by waiting TimePulseTick to flip
|
||||
bool lastTick = TimePulseTick;
|
||||
@ -79,19 +73,12 @@ time_t get_rtctime(uint16_t *msec) {
|
||||
t++;
|
||||
#endif
|
||||
return t;
|
||||
} else {
|
||||
ESP_LOGE(TAG, "RTC get time failure");
|
||||
return 0; // failure
|
||||
}
|
||||
|
||||
} // get_rtctime()
|
||||
|
||||
float get_rtctemp(void) {
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
RtcTemperature temp = Rtc.GetTemperature();
|
||||
I2C_MUTEX_UNLOCK();
|
||||
return temp.AsFloatDegC();
|
||||
}
|
||||
return 0;
|
||||
} // get_rtctemp()
|
||||
|
||||
#endif // HAS_RTC
|
@ -63,8 +63,7 @@ void calibrateTime(void) {
|
||||
} // calibrateTime()
|
||||
|
||||
// set system time (UTC), calibrate RTC and RTC_INT pps
|
||||
bool setMyTime(uint32_t t_sec, uint16_t t_msec,
|
||||
timesource_t mytimesource) {
|
||||
bool setMyTime(uint32_t t_sec, uint16_t t_msec, timesource_t mytimesource) {
|
||||
|
||||
struct timeval tv = {0};
|
||||
|
||||
@ -141,22 +140,12 @@ uint8_t timepulse_init() {
|
||||
|
||||
// if we have, use pulse from on board RTC chip as time base for calendar time
|
||||
#if defined RTC_INT
|
||||
|
||||
// setup external rtc 1Hz clock pulse
|
||||
if (I2C_MUTEX_LOCK()) {
|
||||
Rtc.SetSquareWavePinClockFrequency(DS3231SquareWaveClock_1Hz);
|
||||
Rtc.SetSquareWavePin(DS3231SquareWavePin_ModeClock);
|
||||
I2C_MUTEX_UNLOCK();
|
||||
pinMode(RTC_INT, INPUT_PULLUP);
|
||||
attachInterrupt(digitalPinToInterrupt(RTC_INT), CLOCKIRQ, FALLING);
|
||||
ESP_LOGI(TAG, "Timepulse: external (RTC)");
|
||||
return 1; // success
|
||||
} else {
|
||||
ESP_LOGE(TAG, "RTC initialization error, I2C bus busy");
|
||||
return 0; // failure
|
||||
}
|
||||
return 1; // success
|
||||
|
||||
#else
|
||||
// use ESP32 hardware timer as time base for calendar time
|
||||
ppsIRQ = timerBegin(1, 8000, true); // set 80 MHz prescaler to 1/10000 sec
|
||||
@ -164,8 +153,6 @@ uint8_t timepulse_init() {
|
||||
timerAttachInterrupt(ppsIRQ, &CLOCKIRQ, false);
|
||||
timerAlarmEnable(ppsIRQ);
|
||||
ESP_LOGI(TAG, "Timepulse: internal (ESP32 hardware timer)");
|
||||
return 1; // success
|
||||
|
||||
#endif
|
||||
|
||||
// start cyclic time sync
|
||||
|
Loading…
Reference in New Issue
Block a user