mirror of
https://github.com/arendst/Tasmota.git
synced 2025-07-27 20:56:35 +00:00
Merge pull request #9172 from device111/development
AHT1x driver refactor, AHT20 support added
This commit is contained in:
commit
228890e435
@ -64,7 +64,8 @@ Index | Define | Driver | Device | Address(es) | Description
|
|||||||
41 | USE_DHT12 | xsns_58 | DHT12 | 0x5C | Temperature and humidity sensor
|
41 | USE_DHT12 | xsns_58 | DHT12 | 0x5C | Temperature and humidity sensor
|
||||||
42 | USE_DS1624 | xsns_59 | DS1621 | 0x48 - 0x4F | Temperature sensor
|
42 | USE_DS1624 | xsns_59 | DS1621 | 0x48 - 0x4F | Temperature sensor
|
||||||
42 | USE_DS1624 | xsns_59 | DS1624 | 0x48 - 0x4F | Temperature sensor
|
42 | USE_DS1624 | xsns_59 | DS1624 | 0x48 - 0x4F | Temperature sensor
|
||||||
43 | USE_AHT1x | xsns_63 | AHT10/15 | 0x38 | Temperature and humidity sensor
|
43 | USE_AHT1x | xsns_63 | AHT10/15 | 0x38 - 0x39 | Temperature and humidity sensor
|
||||||
|
43 | USE_AHT2x | xsns_63 | AHT20 | 0x38 | Temperature and humidity sensor
|
||||||
44 | USE_WEMOS_MOTOR_V1 | xdrv_34 | | 0x2D - 0x30 | WEMOS motor shield v1.0.0 (6612FNG)
|
44 | USE_WEMOS_MOTOR_V1 | xdrv_34 | | 0x2D - 0x30 | WEMOS motor shield v1.0.0 (6612FNG)
|
||||||
45 | USE_HDC1080 | xsns_65 | HDC1080 | 0x40 | Temperature and Humidity sensor
|
45 | USE_HDC1080 | xsns_65 | HDC1080 | 0x40 | Temperature and Humidity sensor
|
||||||
46 | USE_IAQ | xsns_66 | IAQ | 0x5a | Air quality sensor
|
46 | USE_IAQ | xsns_66 | IAQ | 0x5a | Air quality sensor
|
||||||
|
@ -538,7 +538,8 @@
|
|||||||
// #define USE_HIH6 // [I2cDriver36] Enable Honeywell HIH Humidity and Temperature sensor (I2C address 0x27) (+0k6)
|
// #define USE_HIH6 // [I2cDriver36] Enable Honeywell HIH Humidity and Temperature sensor (I2C address 0x27) (+0k6)
|
||||||
// #define USE_DHT12 // [I2cDriver41] Enable DHT12 humidity and temperature sensor (I2C address 0x5C) (+0k7 code)
|
// #define USE_DHT12 // [I2cDriver41] Enable DHT12 humidity and temperature sensor (I2C address 0x5C) (+0k7 code)
|
||||||
// #define USE_DS1624 // [I2cDriver42] Enable DS1624, DS1621 temperature sensor (I2C addresses 0x48 - 0x4F) (+1k2 code)
|
// #define USE_DS1624 // [I2cDriver42] Enable DS1624, DS1621 temperature sensor (I2C addresses 0x48 - 0x4F) (+1k2 code)
|
||||||
// #define USE_AHT1x // [I2cDriver43] Enable AHT10/15 humidity and temperature sensor (I2C address 0x38) (+0k8 code)
|
// #define USE_AHT1x // [I2cDriver43] Enable AHT10/15 humidity and temperature sensor (I2C address 0x38, 0x39) (+0k8 code)
|
||||||
|
// #define USE_AHT2x // [I2cDriver43] Enable AHT20 instead of AHT1x humidity and temperature sensor (I2C address 0x38) (+0k8 code)
|
||||||
// #define USE_WEMOS_MOTOR_V1 // [I2cDriver44] Enable Wemos motor driver V1 (I2C addresses 0x2D - 0x30) (+0k7 code)
|
// #define USE_WEMOS_MOTOR_V1 // [I2cDriver44] Enable Wemos motor driver V1 (I2C addresses 0x2D - 0x30) (+0k7 code)
|
||||||
// #define WEMOS_MOTOR_V1_ADDR 0x30 // Default I2C address 0x30
|
// #define WEMOS_MOTOR_V1_ADDR 0x30 // Default I2C address 0x30
|
||||||
// #define WEMOS_MOTOR_V1_FREQ 1000 // Default frequency
|
// #define WEMOS_MOTOR_V1_FREQ 1000 // Default frequency
|
||||||
|
@ -120,7 +120,8 @@
|
|||||||
#define USE_HIH6 // Enable Honywell HIH Humidity and Temperature sensor (I2C address 0x27) (+0k6)
|
#define USE_HIH6 // Enable Honywell HIH Humidity and Temperature sensor (I2C address 0x27) (+0k6)
|
||||||
#define USE_DHT12 // Add I2C code for DHT12 temperature and humidity sensor (+0k7 code)
|
#define USE_DHT12 // Add I2C code for DHT12 temperature and humidity sensor (+0k7 code)
|
||||||
#define USE_DS1624 // Add I2C code for DS1624, DS1621 sensor
|
#define USE_DS1624 // Add I2C code for DS1624, DS1621 sensor
|
||||||
//#define USE_AHT1x // Enable AHT10/15 humidity and temperature sensor (I2C address 0x38) (+0k8 code)
|
//#define USE_AHT1x // Enable AHT10/15 humidity and temperature sensor (I2C address 0x38, 0x39) (+0k8 code)
|
||||||
|
// #define USE_AHT2x // Enable AHT20 instead of AHT1x humidity and temperature sensor (I2C address 0x38) (+0k8 code) (I2C address 0x38) (+0k8 code)
|
||||||
#define USE_WEMOS_MOTOR_V1 // Enable Wemos motor driver V1 (I2C addresses 0x2D - 0x30) (+0k7 code)
|
#define USE_WEMOS_MOTOR_V1 // Enable Wemos motor driver V1 (I2C addresses 0x2D - 0x30) (+0k7 code)
|
||||||
#define WEMOS_MOTOR_V1_ADDR 0x30 // Default I2C address 0x30
|
#define WEMOS_MOTOR_V1_ADDR 0x30 // Default I2C address 0x30
|
||||||
#define WEMOS_MOTOR_V1_FREQ 1000 // Default frequency
|
#define WEMOS_MOTOR_V1_FREQ 1000 // Default frequency
|
||||||
|
@ -20,12 +20,14 @@
|
|||||||
|
|
||||||
#ifdef USE_I2C
|
#ifdef USE_I2C
|
||||||
#ifdef USE_AHT1x
|
#ifdef USE_AHT1x
|
||||||
|
|
||||||
/*********************************************************************************************\
|
/*********************************************************************************************\
|
||||||
* AHT10/15 - Temperature and Humidity
|
* AHT10/15/20 - Temperature and Humidity
|
||||||
*
|
*
|
||||||
* I2C Address: 0x38
|
* AHT1x I2C Address: 0x38, 0x39
|
||||||
|
* the driver supports two I2c adresses but only one Sensor allowed.
|
||||||
*
|
*
|
||||||
* Attention: this Sensor is incompatible with other I2C devices on I2C bus.
|
* Attention: the AHT10/15 Sensor is incompatible with other I2C devices on I2C bus.
|
||||||
*
|
*
|
||||||
* The Datasheet write:
|
* The Datasheet write:
|
||||||
* "Only a single AHT10 can be connected to the I2C bus and no other I2C
|
* "Only a single AHT10 can be connected to the I2C bus and no other I2C
|
||||||
@ -33,6 +35,11 @@
|
|||||||
*
|
*
|
||||||
* after lot of search and tests, now is confirmed that works only reliable with one sensor
|
* after lot of search and tests, now is confirmed that works only reliable with one sensor
|
||||||
* on I2C Bus
|
* on I2C Bus
|
||||||
|
*
|
||||||
|
* 27.08.2020 support for AHT20 added. Now, the AHT20 should support standard I2C Protokoll
|
||||||
|
* and allows other I2C Devices on the bus but have only one I2C Address (0x38)
|
||||||
|
*
|
||||||
|
* AHT20 I2C Address: 0x38
|
||||||
\*********************************************************************************************/
|
\*********************************************************************************************/
|
||||||
|
|
||||||
#define XSNS_63 63
|
#define XSNS_63 63
|
||||||
@ -52,40 +59,50 @@
|
|||||||
#define AHT1X_RST_DELAY 30
|
#define AHT1X_RST_DELAY 30
|
||||||
#define AHT1X_MEAS_DELAY 80 // over 75ms in datasheet
|
#define AHT1X_MEAS_DELAY 80 // over 75ms in datasheet
|
||||||
|
|
||||||
uint8_t AHTSetCalCmd[3] = {0xE1, 0x08, 00}; //load factory calibration coeff
|
#ifdef USE_AHT2x
|
||||||
uint8_t AHTSetCycleCmd[3] = {0xE1, 0x28, 00}; //enable cycle mode
|
#define AHTX_CMD 0xB1 // Cmd for AHT2x
|
||||||
uint8_t AHTMeasureCmd[3] = {0xAC, 0x33, 00}; //start measurment command
|
const char ahtTypes[] PROGMEM = "AHT2X|AHT2X";
|
||||||
uint8_t AHTResetCmd = 0xBA; //soft reset command
|
#else
|
||||||
|
#define AHTX_CMD 0xE1 // Cmd for AHT1x
|
||||||
|
const char ahtTypes[] PROGMEM = "AHT1X|AHT1X";
|
||||||
|
#endif
|
||||||
|
|
||||||
const char ahtTypes[] PROGMEM = "AHT1X|AHT1X";
|
uint8_t AHTSetCalCmd[3] = { AHTX_CMD, 0x08, 0x00 }; // load factory calibration coeff
|
||||||
uint8_t aht1x_addresses[] = { AHT1X_ADDR1, AHT1X_ADDR2 };
|
uint8_t AHTSetCycleCmd[3] = { AHTX_CMD, 0x28, 0x00 }; // enable cycle mode
|
||||||
uint8_t aht1x_count = 0;
|
uint8_t AHTMeasureCmd[3] = { 0xAC, 0x33, 0x00 }; // start measurment command
|
||||||
uint8_t aht1x_Pcount = 0;
|
uint8_t AHTResetCmd = 0xBA; // soft reset command
|
||||||
|
|
||||||
struct AHT1XSTRUCT
|
struct {
|
||||||
{
|
bool write_ok = false;
|
||||||
|
uint8_t addresses[2] = { AHT1X_ADDR1, AHT1X_ADDR2 };
|
||||||
|
uint8_t count = 0;
|
||||||
|
uint8_t Pcount = 0;
|
||||||
|
} aht1x;
|
||||||
|
|
||||||
|
struct {
|
||||||
float humidity = NAN;
|
float humidity = NAN;
|
||||||
float temperature = NAN;
|
float temperature = NAN;
|
||||||
uint8_t address; // bus address
|
uint8_t address; // bus address
|
||||||
char types[6]; // Sensor type name and address -
|
char types[6]; // Sensor type name and address -
|
||||||
} aht1x_sensors[AHT1X_MAX_SENSORS];
|
} aht1x_sensors[AHT1X_MAX_SENSORS];
|
||||||
|
|
||||||
bool AHT1XWrite(uint8_t aht1x_idx)
|
bool AHT1XWrite(uint8_t aht1x_idx) {
|
||||||
{
|
|
||||||
Wire.beginTransmission(aht1x_sensors[aht1x_idx].address);
|
Wire.beginTransmission(aht1x_sensors[aht1x_idx].address);
|
||||||
Wire.write(AHTMeasureCmd, 3);
|
Wire.write(AHTMeasureCmd, 3);
|
||||||
if (Wire.endTransmission() != 0)
|
if (Wire.endTransmission() != 0)
|
||||||
return false;
|
return false;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AHT1XRead(uint8_t aht1x_idx)
|
bool AHT1XRead(uint8_t aht1x_idx) {
|
||||||
{
|
|
||||||
uint8_t data[6];
|
uint8_t data[6];
|
||||||
Wire.requestFrom(aht1x_sensors[aht1x_idx].address, (uint8_t) 6);
|
Wire.requestFrom(aht1x_sensors[aht1x_idx].address, (uint8_t) 6);
|
||||||
for(uint8_t i = 0; Wire.available() > 0; i++){
|
|
||||||
|
for(uint8_t i = 0; Wire.available() > 0; i++) {
|
||||||
data[i] = Wire.read();
|
data[i] = Wire.read();
|
||||||
}
|
}
|
||||||
if ((data[0] & 0x80) == 0x80) return false; //device is busy
|
if (data[0] & 0x80)
|
||||||
|
return false; //device is busy
|
||||||
|
|
||||||
aht1x_sensors[aht1x_idx].humidity = (((data[1] << 12)| (data[2] << 4) | data[3] >> 4) * AHT_HUMIDITY_CONST / KILOBYTE_CONST);
|
aht1x_sensors[aht1x_idx].humidity = (((data[1] << 12)| (data[2] << 4) | data[3] >> 4) * AHT_HUMIDITY_CONST / KILOBYTE_CONST);
|
||||||
aht1x_sensors[aht1x_idx].temperature = ((AHT_TEMPERATURE_CONST * (((data[3] & 0x0F) << 16) | (data[4] << 8) | data[5]) / KILOBYTE_CONST) - AHT_TEMPERATURE_OFFSET);
|
aht1x_sensors[aht1x_idx].temperature = ((AHT_TEMPERATURE_CONST * (((data[3] & 0x0F) << 16) | (data[4] << 8) | data[5]) / KILOBYTE_CONST) - AHT_TEMPERATURE_OFFSET);
|
||||||
@ -95,32 +112,33 @@ bool AHT1XRead(uint8_t aht1x_idx)
|
|||||||
|
|
||||||
/********************************************************************************************/
|
/********************************************************************************************/
|
||||||
|
|
||||||
// Test for Polling the device without delays
|
// Polling the device without delays
|
||||||
// Incompatible with other devices on I2C bus
|
// Incompatible with other devices on I2C bus
|
||||||
void AHT1XPoll(void) // We have 100ms for read. Sensor needs 80-95 ms
|
void AHT1XPoll(void) { // We have 100ms for read. Sensor needs 80-95 ms
|
||||||
{
|
aht1x.Pcount++;
|
||||||
aht1x_Pcount++;
|
switch (aht1x.Pcount) {
|
||||||
switch (aht1x_Pcount) {
|
|
||||||
case 10:
|
case 10:
|
||||||
AHT1XWrite(0);
|
aht1x.write_ok = AHT1XWrite(0);
|
||||||
break;
|
break;
|
||||||
case 11:
|
case 11:
|
||||||
AHT1XRead(0);
|
if (aht1x.write_ok) AHT1XRead(0);
|
||||||
aht1x_Pcount = 0;
|
aht1x.Pcount = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char AHT1XReadStatus(uint8_t aht1x_address)
|
unsigned char AHT1XReadStatus(uint8_t aht1x_address) {
|
||||||
{
|
|
||||||
uint8_t result = 0;
|
uint8_t result = 0;
|
||||||
|
// Need for AHT20?
|
||||||
|
//Wire.beginTransmission(aht1x_address);
|
||||||
|
//Wire.write(0x71);
|
||||||
|
//if (Wire.endTransmission() != 0) return false;
|
||||||
Wire.requestFrom(aht1x_address, (uint8_t) 1);
|
Wire.requestFrom(aht1x_address, (uint8_t) 1);
|
||||||
result = Wire.read();
|
result = Wire.read();
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AHT1XReset(uint8_t aht1x_address)
|
void AHT1XReset(uint8_t aht1x_address) {
|
||||||
{
|
|
||||||
Wire.beginTransmission(aht1x_address);
|
Wire.beginTransmission(aht1x_address);
|
||||||
Wire.write(AHTResetCmd);
|
Wire.write(AHTResetCmd);
|
||||||
Wire.endTransmission();
|
Wire.endTransmission();
|
||||||
@ -128,35 +146,32 @@ void AHT1XReset(uint8_t aht1x_address)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/********************************************************************************************/
|
/********************************************************************************************/
|
||||||
bool AHT1XInit(uint8_t aht1x_address)
|
bool AHT1XInit(uint8_t aht1x_address) {
|
||||||
{
|
|
||||||
Wire.beginTransmission(aht1x_address);
|
Wire.beginTransmission(aht1x_address);
|
||||||
Wire.write(AHTSetCalCmd, 3);
|
Wire.write(AHTSetCalCmd, 3);
|
||||||
if (Wire.endTransmission() != 0) return false;
|
if (Wire.endTransmission() != 0)
|
||||||
|
return false;
|
||||||
delay(AHT1X_CMD_DELAY);
|
delay(AHT1X_CMD_DELAY);
|
||||||
if((AHT1XReadStatus(aht1x_address) & 0x68) == 0x08) // Sensor calcoef aktiv
|
if(AHT1XReadStatus(aht1x_address) & 0x08) // Sensor calibrated?
|
||||||
return true;
|
return true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AHT1XDetect(void)
|
void AHT1XDetect(void) {
|
||||||
{
|
|
||||||
for (uint8_t i = 0; i < AHT1X_MAX_SENSORS; i++) {
|
for (uint8_t i = 0; i < AHT1X_MAX_SENSORS; i++) {
|
||||||
if (I2cActive(aht1x_addresses[i])) { continue; }
|
if (!I2cSetDevice(aht1x.addresses[i])) {continue;}
|
||||||
if (AHT1XInit(aht1x_addresses[i]))
|
if (AHT1XInit(aht1x.addresses[i])) {
|
||||||
{
|
aht1x_sensors[aht1x.count].address = aht1x.addresses[i];
|
||||||
aht1x_sensors[aht1x_count].address = aht1x_addresses[i];
|
GetTextIndexed(aht1x_sensors[aht1x.count].types, sizeof(aht1x_sensors[aht1x.count].types), i, ahtTypes);
|
||||||
GetTextIndexed(aht1x_sensors[aht1x_count].types, sizeof(aht1x_sensors[aht1x_count].types), i, ahtTypes);
|
I2cSetActiveFound(aht1x_sensors[aht1x.count].address, aht1x_sensors[aht1x.count].types);
|
||||||
I2cSetActiveFound(aht1x_sensors[aht1x_count].address, aht1x_sensors[aht1x_count].types);
|
aht1x.count++;
|
||||||
aht1x_count = 1;
|
|
||||||
break; // Only one Sensor allowed at the moment (I2C Sensor-Bug)
|
break; // Only one Sensor allowed at the moment (I2C Sensor-Bug)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AHT1XShow(bool json)
|
void AHT1XShow(bool json) {
|
||||||
{
|
for (uint32_t i = 0; i < aht1x.count; i++) {
|
||||||
for (uint32_t i = 0; i < aht1x_count; i++) {
|
|
||||||
float tem = ConvertTemp(aht1x_sensors[i].temperature);
|
float tem = ConvertTemp(aht1x_sensors[i].temperature);
|
||||||
float hum = ConvertHumidity(aht1x_sensors[i].humidity);
|
float hum = ConvertHumidity(aht1x_sensors[i].humidity);
|
||||||
char types[11]; // AHT1X-0x38
|
char types[11]; // AHT1X-0x38
|
||||||
@ -177,7 +192,7 @@ bool Xsns63(uint8_t function)
|
|||||||
if (FUNC_INIT == function) {
|
if (FUNC_INIT == function) {
|
||||||
AHT1XDetect();
|
AHT1XDetect();
|
||||||
}
|
}
|
||||||
else if (aht1x_count){
|
else if (aht1x.count) {
|
||||||
switch (function) {
|
switch (function) {
|
||||||
case FUNC_EVERY_100_MSECOND:
|
case FUNC_EVERY_100_MSECOND:
|
||||||
AHT1XPoll();
|
AHT1XPoll();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user