This commit is contained in:
2024-06-19 17:51:32 +03:00
parent 3a794774da
commit 2c856c08f2
3 changed files with 141 additions and 66 deletions

View File

@ -5,7 +5,8 @@
#define DATA_BIT_START_TRANSFER_MAX_DURATION 55 // Signal "0", "1" low time.
#define RESPONSE_MAX_DURATION 85 // Response to low time. Response to high time.
#define MASTER_RELEASE_MAX_DURATION 200 // Bus master has released time.
#define DATA_SIZE 40
#define DATA_SIZE 40 // Sensor data size for 1-wire connection.
#define I2C_ADDRESS 100 // Sensor address size for I2C connection.
#ifdef CONFIG_IDF_TARGET_ESP8266
#define esp_delay_us(x) os_delay_us(x)
@ -13,52 +14,73 @@
#define esp_delay_us(x) esp_rom_delay_us(x)
#endif
static zh_dht_init_config_t _init_config = {0};
static bool _is_initialized = false;
#ifndef CONFIG_IDF_TARGET_ESP8266
static i2c_master_dev_handle_t _dht_handle = {0};
#endif
static const char *TAG = "zh_dht";
static esp_err_t _read_bit(const zh_dht_handle_t *dht_handle, bool *bit);
static esp_err_t _read_bit(bool *bit);
zh_dht_handle_t zh_dht_init(const zh_dht_sensor_type_t sensor_type, const uint8_t sensor_pin)
esp_err_t zh_dht_init(const zh_dht_init_config_t *config)
{
ESP_LOGI(TAG, "DHT initialization begin.");
zh_dht_handle_t zh_dht_handle = {
.sensor_type = sensor_type,
.sensor_pin = sensor_pin};
gpio_config_t config = {0};
config.intr_type = GPIO_INTR_DISABLE;
config.mode = GPIO_MODE_INPUT;
config.pin_bit_mask = (1ULL << sensor_pin);
config.pull_down_en = GPIO_PULLDOWN_DISABLE;
config.pull_up_en = GPIO_PULLUP_ENABLE;
if (gpio_config(&config) != ESP_OK)
if (config == NULL)
{
zh_dht_handle.sensor_pin = 0xFF;
ESP_LOGE(TAG, "DHT initialization fail. Incorrect GPIO number.");
return zh_dht_handle;
ESP_LOGE(TAG, "DHT initialization fail. Invalid argument.");
return ESP_ERR_INVALID_ARG;
}
_init_config = *config;
if (_init_config.sensor_pin != 0xFF)
{
gpio_config_t cfg = {0};
cfg.intr_type = GPIO_INTR_DISABLE;
cfg.mode = GPIO_MODE_INPUT;
cfg.pin_bit_mask = (1ULL << _init_config.sensor_pin);
cfg.pull_down_en = GPIO_PULLDOWN_DISABLE;
cfg.pull_up_en = GPIO_PULLUP_ENABLE;
if (gpio_config(&cfg) != ESP_OK)
{
ESP_LOGE(TAG, "DHT initialization fail. Incorrect GPIO number.");
return ESP_FAIL;
}
}
else
{
// I2C.
}
ESP_LOGI(TAG, "DHT initialization success.");
return zh_dht_handle;
_is_initialized = true;
return ESP_OK;
}
esp_err_t zh_dht_read(const zh_dht_handle_t *dht_handle, float *humidity, float *temperature)
esp_err_t zh_dht_read(float *humidity, float *temperature)
{
ESP_LOGI(TAG, "DHT read begin.");
if (dht_handle == NULL || humidity == NULL || temperature == NULL || dht_handle->sensor_pin == 0xFF)
if (humidity == NULL || temperature == NULL)
{
ESP_LOGE(TAG, "DHT read fail. Invalid argument.");
return ESP_ERR_INVALID_ARG;
}
if (gpio_get_level(dht_handle->sensor_pin) != 1)
if (_is_initialized == false)
{
ESP_LOGE(TAG, "DHT read fail. BH1750 not initialized.");
return ESP_ERR_NOT_FOUND;
}
if (gpio_get_level(_init_config.sensor_pin) != 1)
{
ESP_LOGE(TAG, "DHT read fail. Bus is busy.");
return ESP_ERR_INVALID_RESPONSE;
}
gpio_set_direction(dht_handle->sensor_pin, GPIO_MODE_OUTPUT);
gpio_set_level(dht_handle->sensor_pin, 0);
gpio_set_direction(_init_config.sensor_pin, GPIO_MODE_OUTPUT);
gpio_set_level(_init_config.sensor_pin, 0);
vTaskDelay(10 / portTICK_PERIOD_MS);
gpio_set_level(dht_handle->sensor_pin, 1);
gpio_set_direction(dht_handle->sensor_pin, GPIO_MODE_INPUT);
gpio_set_level(_init_config.sensor_pin, 1);
gpio_set_direction(_init_config.sensor_pin, GPIO_MODE_INPUT);
uint8_t time = 0;
while (gpio_get_level(dht_handle->sensor_pin) == 1)
while (gpio_get_level(_init_config.sensor_pin) == 1)
{
if (time > MASTER_RELEASE_MAX_DURATION)
{
@ -69,7 +91,7 @@ esp_err_t zh_dht_read(const zh_dht_handle_t *dht_handle, float *humidity, float
esp_delay_us(1);
}
time = 0;
while (gpio_get_level(dht_handle->sensor_pin) == 0)
while (gpio_get_level(_init_config.sensor_pin) == 0)
{
if (time > RESPONSE_MAX_DURATION)
{
@ -80,7 +102,7 @@ esp_err_t zh_dht_read(const zh_dht_handle_t *dht_handle, float *humidity, float
esp_delay_us(1);
}
time = 0;
while (gpio_get_level(dht_handle->sensor_pin) == 1)
while (gpio_get_level(_init_config.sensor_pin) == 1)
{
if (time > RESPONSE_MAX_DURATION)
{
@ -96,7 +118,7 @@ esp_err_t zh_dht_read(const zh_dht_handle_t *dht_handle, float *humidity, float
for (uint8_t i = 0; i < 40; ++i)
{
bool bit = 0;
if (_read_bit(dht_handle, &bit) != ESP_OK)
if (_read_bit(&bit) != ESP_OK)
{
ESP_LOGE(TAG, "DHT read fail. Timeout exceeded.");
return ESP_ERR_TIMEOUT;
@ -118,26 +140,19 @@ esp_err_t zh_dht_read(const zh_dht_handle_t *dht_handle, float *humidity, float
return ESP_ERR_INVALID_CRC;
}
*humidity = (dht_data[0] << 8 | dht_data[1]) / 10.0;
if (dht_handle->sensor_type == ZH_DHT22)
*temperature = ((dht_data[2] & 0x7F) << 8 | dht_data[3]) / 10.0;
if ((dht_data[2] & 0x80) != 0)
{
*temperature = ((dht_data[2] & 0b01111111) << 8 | dht_data[3]) / 10.0;
if ((dht_data[2] & 0b10000000) != 0)
{
*temperature *= -1;
}
}
else
{
*temperature = (dht_data[2] << 8 | dht_data[3]) / 10.0;
*temperature *= -1;
}
ESP_LOGI(TAG, "DHT read success.");
return ESP_OK;
}
static esp_err_t _read_bit(const zh_dht_handle_t *dht_handle, bool *bit)
static esp_err_t _read_bit(bool *bit)
{
uint8_t time = 0;
while (gpio_get_level(dht_handle->sensor_pin) == 0)
while (gpio_get_level(_init_config.sensor_pin) == 0)
{
if (time > DATA_BIT_START_TRANSFER_MAX_DURATION)
{
@ -147,7 +162,7 @@ static esp_err_t _read_bit(const zh_dht_handle_t *dht_handle, bool *bit)
esp_delay_us(1);
}
time = 0;
while (gpio_get_level(dht_handle->sensor_pin) == 1)
while (gpio_get_level(_init_config.sensor_pin) == 1)
{
if (time > BIT_1_TRANSFER_MAX_DURATION)
{