76 uint8_t data[5] = {0, 0, 0, 0, 0};
111 for (i = -1; i < 40; i++) {
112 uint32_t start_time =
micros();
116 if (
micros() - start_time > 90) {
129 uint32_t end_time = start_time;
134 if (end_time - start_time > 90) {
149 if (end_time - start_time >= 40) {
150 data[byte] |= 1 << bit;
160 if (!report_errors && error_code != 0)
164 ESP_LOGW(TAG, ESP_LOG_MSG_COMM_FAIL);
169 "Data: Hum=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
170 ", Temp=0b" BYTE_TO_BINARY_PATTERN BYTE_TO_BINARY_PATTERN
", Checksum=0b" BYTE_TO_BINARY_PATTERN,
171 BYTE_TO_BINARY(data[0]), BYTE_TO_BINARY(data[1]), BYTE_TO_BINARY(data[2]), BYTE_TO_BINARY(data[3]),
172 BYTE_TO_BINARY(data[4]));
174 uint8_t checksum_a = data[0] + data[1] + data[2] + data[3];
179 if (checksum_a != data[4] && checksum_b != data[4]) {
181 ESP_LOGW(TAG,
"Checksum invalid: %u!=%u", checksum_a, data[4]);
187 if (checksum_a == data[4]) {
190 const uint16_t raw_temperature =
static_cast<uint16_t
>(data[2]) * 10 + (data[3] & 0x7F);
191 *
temperature =
static_cast<float>(raw_temperature) / 10.0f;
192 if ((data[3] & 0x80) != 0) {
197 const uint16_t raw_humidity =
static_cast<uint16_t
>(data[0]) * 10 + data[1];
198 *humidity =
static_cast<float>(raw_humidity) / 10.0f;
209 if (raw_temperature & 0x8000) {
210 if (!(raw_temperature & 0x4000))
211 raw_temperature = ~(raw_temperature & 0x7FFF);
212 }
else if (raw_temperature & 0x800) {
213 raw_temperature |= 0xf000;
216 if (raw_temperature == 1 && raw_humidity == 10) {
218 ESP_LOGW(TAG,
"Invalid data");
223 *humidity =
static_cast<float>(raw_humidity) * 0.1f;
224 if (*humidity > 100.0f)
226 *
temperature =
static_cast<int16_t
>(raw_temperature) * 0.1f;
229 if (*
temperature == 0.0f && (*humidity == 1.0f || *humidity == 2.0f)) {
231 ESP_LOGW(TAG,
"Invalid data");