73 uint8_t data[5] = {0, 0, 0, 0, 0};
109 for (i = -1; i < 40; i++) {
110 uint32_t start_time =
micros();
114 if (
micros() - start_time > 90) {
127 uint32_t end_time = start_time;
132 if (end_time - start_time > 90) {
147 if (end_time - start_time >= 40) {
148 data[byte] |= 1 << bit;
158 if (!report_errors && error_code != 0)
162 ESP_LOGW(TAG, ESP_LOG_MSG_COMM_FAIL);
167 "Data: Hum=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
168 ", Temp=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
", Checksum=0b" BYTE_TO_BINARY_PATTERN,
169 BYTE_TO_BINARY(data[0]), BYTE_TO_BINARY(data[1]), BYTE_TO_BINARY(data[2]), BYTE_TO_BINARY(data[3]),
170 BYTE_TO_BINARY(data[4]));
172 uint8_t checksum_a = data[0] + data[1] + data[2] + data[3];
177 if (checksum_a != data[4] && checksum_b != data[4]) {
179 ESP_LOGW(TAG,
"Checksum invalid: %u!=%u", checksum_a, data[4]);
185 if (checksum_a == data[4]) {
188 const uint16_t raw_temperature =
static_cast<uint16_t
>(data[2]) * 10 + (data[3] & 0x7F);
189 *
temperature =
static_cast<float>(raw_temperature) / 10.0f;
190 if ((data[3] & 0x80) != 0) {
195 const uint16_t raw_humidity =
static_cast<uint16_t
>(data[0]) * 10 + data[1];
196 *humidity =
static_cast<float>(raw_humidity) / 10.0f;
207 if (raw_temperature & 0x8000) {
208 if (!(raw_temperature & 0x4000))
209 raw_temperature = ~(raw_temperature & 0x7FFF);
210 }
else if (raw_temperature & 0x800) {
211 raw_temperature |= 0xf000;
214 if (raw_temperature == 1 && raw_humidity == 10) {
216 ESP_LOGW(TAG,
"Invalid data");
221 *humidity =
static_cast<float>(raw_humidity) * 0.1f;
222 if (*humidity > 100.0f)
224 *
temperature =
static_cast<int16_t
>(raw_temperature) * 0.1f;
227 if (*
temperature == 0.0f && (*humidity == 1.0f || *humidity == 2.0f)) {
229 ESP_LOGW(TAG,
"Invalid data");