1 /* 2 * Copyright (c) 2021 Leonard Pollak 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #ifndef ZEPHYR_DRIVERS_SENSOR_SHT4X_SHT4X_H_ 8 #define ZEPHYR_DRIVERS_SENSOR_SHT4X_SHT4X_H_ 9 10 #include <zephyr/device.h> 11 12 #define SHT4X_CMD_READ_SERIAL 0x89 13 #define SHT4X_CMD_RESET 0x94 14 15 #define SHT4X_RESET_WAIT_MS 1 16 17 #define SHT4X_HEATER_POWER_IDX_MAX 3 18 #define SHT4X_HEATER_DURATION_IDX_MAX 2 19 20 /* 21 * CRC parameters were taken from the 22 * "Checksum Calculation" section of the datasheet. 23 */ 24 #define SHT4X_CRC_POLY 0x31 25 #define SHT4X_CRC_INIT 0xFF 26 27 struct sht4x_config { 28 struct i2c_dt_spec bus; 29 uint8_t repeatability; 30 }; 31 32 struct sht4x_data { 33 uint16_t t_sample; 34 uint16_t rh_sample; 35 uint8_t heater_power; 36 uint8_t heater_duration; 37 }; 38 39 static const uint8_t measure_cmd[3] = { 40 0xE0, 0xF6, 0xFD 41 }; 42 43 static const uint16_t measure_wait_us[3] = { 44 1600, 4500, 8300 45 }; 46 47 /* 48 * heater specifics 49 * 50 * power: 51 * High power heater pulse -> ~200 mW @3.3V 52 * Medium power heater pulse -> ~110 mW @3.3V 53 * Low power heater pulse -> ~20 mW @3.3V 54 * 55 * duration: 56 * Long heater pulse -> 1.1s 57 * Short heater pulse -> 0.11s 58 */ 59 60 static const int8_t heater_cmd[SHT4X_HEATER_POWER_IDX_MAX][SHT4X_HEATER_DURATION_IDX_MAX] = { 61 { 0x39, 0x32 }, 62 { 0x2F, 0x24 }, 63 { 0x1E, 0x15 } 64 }; 65 66 static const uint32_t heater_wait_ms[SHT4X_HEATER_DURATION_IDX_MAX] = { 67 1000, 100 68 }; 69 70 #endif /* ZEPHYR_DRIVERS_SENSOR_SHT4X_SHT4X_H_ */ 71