79 uint8_t data[5] = {0, 0, 0, 0, 0};
112 for (i = -1; i < 40; i++) {
113 uint32_t start_time =
micros();
117 if (
micros() - start_time > 90) {
130 uint32_t end_time = start_time;
135 if (end_time - start_time > 90) {
150 if (end_time - start_time >= 40) {
151 data[byte] |= 1 << bit;
161 if (!report_errors && error_code != 0)
165 ESP_LOGW(TAG, ESP_LOG_MSG_COMM_FAIL);
170 "Data: Hum=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
171 ", Temp=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
", Checksum=0b" BYTE_TO_BINARY_PATTERN,
172 BYTE_TO_BINARY(data[0]), BYTE_TO_BINARY(data[1]), BYTE_TO_BINARY(data[2]), BYTE_TO_BINARY(data[3]),
173 BYTE_TO_BINARY(data[4]));
175 uint8_t checksum_a = data[0] + data[1] + data[2] + data[3];
180 if (checksum_a != data[4] && checksum_b != data[4]) {
182 ESP_LOGW(TAG,
"Checksum invalid: %u!=%u", checksum_a, data[4]);
188 if (checksum_a == data[4]) {
191 const uint16_t raw_temperature =
static_cast<uint16_t
>(data[2]) * 10 + (data[3] & 0x7F);
192 *
temperature =
static_cast<float>(raw_temperature) / 10.0f;
193 if ((data[3] & 0x80) != 0) {
198 const uint16_t raw_humidity =
static_cast<uint16_t
>(data[0]) * 10 + data[1];
199 *humidity =
static_cast<float>(raw_humidity) / 10.0f;
210 if (raw_temperature & 0x8000) {
211 if (!(raw_temperature & 0x4000))
212 raw_temperature = ~(raw_temperature & 0x7FFF);
213 }
else if (raw_temperature & 0x800) {
214 raw_temperature |= 0xf000;
217 if (raw_temperature == 1 && raw_humidity == 10) {
219 ESP_LOGW(TAG,
"Invalid data");
224 *humidity =
static_cast<float>(raw_humidity) * 0.1f;
225 if (*humidity > 100.0f)
227 *
temperature =
static_cast<int16_t
>(raw_temperature) * 0.1f;
230 if (*
temperature == 0.0f && (*humidity == 1.0f || *humidity == 2.0f)) {
232 ESP_LOGW(TAG,
"Invalid data");