Go to the documentation of this file.
35 #include "drv_digital_out.h"
36 #include "drv_digital_in.h"
37 #include "drv_one_wire.h"
59 #define TEMPLOG7_CMD_CONVERT_TEMP 0x44
60 #define TEMPLOG7_CMD_ALERT_SEARCH 0xEC
61 #define TEMPLOG7_CMD_WRITE_SCRATCHPAD_1 0x4E
62 #define TEMPLOG7_CMD_READ_SCRATCHPAD_1 0xBE
63 #define TEMPLOG7_CMD_COPY_SCRATCHPAD_1 0x48
64 #define TEMPLOG7_CMD_WRITE_SCRATCHPAD_2 0x0F
65 #define TEMPLOG7_CMD_READ_SCRATCHPAD_2 0xAA
66 #define TEMPLOG7_CMD_COPY_SCRATCHPAD_2 0x55
67 #define TEMPLOG7_CMD_READ_EEPROM 0xF0
68 #define TEMPLOG7_CMD_GPIO_WRITE 0xA5
69 #define TEMPLOG7_CMD_GPIO_READ 0xF5
87 #define TEMPLOG7_TEMP_RES_16BIT 0.0078125f
88 #define TEMPLOG7_TEMP_RES_12BIT 0.0625f
94 #define TEMPLOG7_STATUS_ALERT_HIGH 0x80
95 #define TEMPLOG7_STATUS_ALERT_LOW 0x40
96 #define TEMPLOG7_STATUS_RESERVED 0x30
97 #define TEMPLOG7_STATUS_DATA_VALID 0x08
98 #define TEMPLOG7_STATUS_POWER_MODE 0x04
99 #define TEMPLOG7_STATUS_ARB_DONE 0x02
100 #define TEMPLOG7_STATUS_LOCK_STATUS 0x01
106 #define TEMPLOG7_CFG1_TEMP_FMT_12_BIT 0x00
107 #define TEMPLOG7_CFG1_TEMP_FMT_16_BIT 0x80
108 #define TEMPLOG7_CFG1_TEMP_FMT_MASK 0x80
109 #define TEMPLOG7_CFG1_RESERVED 0x40
110 #define TEMPLOG7_CFG1_CONV_TIME_SEL_3MS 0x00
111 #define TEMPLOG7_CFG1_CONV_TIME_SEL_5p5MS 0x20
112 #define TEMPLOG7_CFG1_CONV_TIME_SEL_MASK 0x20
113 #define TEMPLOG7_CFG1_ALERT_MODE_ALERT 0x00
114 #define TEMPLOG7_CFG1_ALERT_MODE_COMPARATOR 0x10
115 #define TEMPLOG7_CFG1_ALERT_MODE_MASK 0x10
116 #define TEMPLOG7_CFG1_AVG_SEL_NO_AVG 0x00
117 #define TEMPLOG7_CFG1_AVG_SEL_8_B2B_CONV 0x08
118 #define TEMPLOG7_CFG1_AVG_SEL_MASK 0x08
119 #define TEMPLOG7_CFG1_CONV_MODE_SEL_ONE_SHOT 0x00
120 #define TEMPLOG7_CFG1_CONV_MODE_SEL_STACKED 0x01
121 #define TEMPLOG7_CFG1_CONV_MODE_SEL_AUTO 0x02
122 #define TEMPLOG7_CFG1_CONV_MODE_SEL_MASK 0x07
128 #define TEMPLOG7_CFG2_OD_DIS 0x00
129 #define TEMPLOG7_CFG2_OD_EN 0x80
130 #define TEMPLOG7_CFG2_OD_MASK 0x80
131 #define TEMPLOG7_CFG2_FLEX_ADDR_MODE_HOST 0x00
132 #define TEMPLOG7_CFG2_FLEX_ADDR_MODE_IO 0x20
133 #define TEMPLOG7_CFG2_FLEX_ADDR_MODE_RES 0x40
134 #define TEMPLOG7_CFG2_FLEX_ADDR_MODE_IO_RES 0x60
135 #define TEMPLOG7_CFG2_FLEX_ADDR_MODE_MASK 0x60
136 #define TEMPLOG7_CFG2_ARB_MODE_DIS 0x00
137 #define TEMPLOG7_CFG2_ARB_MODE_SOFT_EN 0x10
138 #define TEMPLOG7_CFG2_ARB_MODE_FAST_EN 0x18
139 #define TEMPLOG7_CFG2_ARB_MODE_MASK 0x18
140 #define TEMPLOG7_CFG2_HYSTERESIS_5_C 0x00
141 #define TEMPLOG7_CFG2_HYSTERESIS_10_C 0x02
142 #define TEMPLOG7_CFG2_HYSTERESIS_15_C 0x04
143 #define TEMPLOG7_CFG2_HYSTERESIS_20_C 0x06
144 #define TEMPLOG7_CFG2_HYSTERESIS_MASK 0x06
145 #define TEMPLOG7_CFG2_LOCK_DIS 0x00
146 #define TEMPLOG7_CFG2_LOCK_EN 0x01
147 #define TEMPLOG7_CFG2_LOCK_MASK 0x01
153 #define TEMPLOG7_TEMP_ALERT_LOW 5.0f
154 #define TEMPLOG7_TEMP_ALERT_HIGH 40.0f
155 #define TEMPLOG7_TEMP_OFFSET 0.0f
161 #define TEMPLOG7_IO_READ_NIO3_STATE 0x80
162 #define TEMPLOG7_IO_READ_NIO2_STATE 0x40
163 #define TEMPLOG7_IO_READ_NIO1_STATE 0x20
164 #define TEMPLOG7_IO_READ_NIO0_STATE 0x10
165 #define TEMPLOG7_IO_READ_IO3_STATE 0x08
166 #define TEMPLOG7_IO_READ_IO2_STATE 0x04
167 #define TEMPLOG7_IO_READ_IO1_STATE 0x02
168 #define TEMPLOG7_IO_READ_IO0_STATE 0x01
174 #define TEMPLOG7_IO_CFG_IO3_SEL_INPUT 0x00
175 #define TEMPLOG7_IO_CFG_IO3_SEL_OUTPUT_LOW 0x80
176 #define TEMPLOG7_IO_CFG_IO3_SEL_OUTPUT_HIGH 0xC0
177 #define TEMPLOG7_IO_CFG_IO3_SEL_MASK 0xC0
178 #define TEMPLOG7_IO_CFG_IO2_SEL_INPUT 0x00
179 #define TEMPLOG7_IO_CFG_IO2_SEL_ALERT 0x10
180 #define TEMPLOG7_IO_CFG_IO2_SEL_OUTPUT_LOW 0x20
181 #define TEMPLOG7_IO_CFG_IO2_SEL_OUTPUT_HIGH 0x30
182 #define TEMPLOG7_IO_CFG_IO2_SEL_MASK 0x30
183 #define TEMPLOG7_IO_CFG_IO1_SEL_INPUT 0x00
184 #define TEMPLOG7_IO_CFG_IO1_SEL_OUTPUT_LOW 0x08
185 #define TEMPLOG7_IO_CFG_IO1_SEL_OUTPUT_HIGH 0x0C
186 #define TEMPLOG7_IO_CFG_IO1_SEL_MASK 0x0C
187 #define TEMPLOG7_IO_CFG_IO0_SEL_INPUT 0x00
188 #define TEMPLOG7_IO_CFG_IO0_SEL_OUTPUT_LOW 0x02
189 #define TEMPLOG7_IO_CFG_IO0_SEL_OUTPUT_HIGH 0x03
190 #define TEMPLOG7_IO_CFG_IO0_SEL_MASK 0x03
191 #define TEMPLOG7_IO_CHECK_CODE_OK 0xAA
197 #define TEMPLOG7_EEPROM_ADDR_MIN 0x00
198 #define TEMPLOG7_EEPROM_ADDR_MAX 0xFF
199 #define TEMPLOG7_EEPROM_ADDR_BLOCK 8
200 #define TEMPLOG7_EEPROM_ADDR_MASK 0xFFF8u
206 #define TEMPLOG7_COPY_SCRATCHPAD_2_QUALIFIER 0xA5
212 #define TEMPLOG7_FAMILY_CODE 0x26
218 #define TEMPLOG7_ADDRESS_0 0x00
219 #define TEMPLOG7_ADDRESS_ALL 0xFF
237 #define TEMPLOG7_MAP_MIKROBUS( cfg, mikrobus ) \
238 cfg.gp0 = MIKROBUS( mikrobus, MIKROBUS_AN ); \
239 cfg.gp1 = MIKROBUS( mikrobus, MIKROBUS_PWM ); \
240 cfg.alert = MIKROBUS( mikrobus, MIKROBUS_INT );
pin_name_t alert
Definition: templog7.h:312
err_t templog7_select_device(templog7_t *ctx)
Temp-Log 7 select device function.
@ TEMPLOG7_OK
Definition: templog7.h:324
err_t templog7_check_communication(templog7_t *ctx)
Temp-Log 7 check communication function.
one_wire_rom_address_t rom_addr
Definition: templog7.h:296
err_t templog7_read_gpio(templog7_t *ctx, uint8_t *data_out)
Temp-Log 7 read gpio function.
err_t templog7_read_eeprom(templog7_t *ctx, uint16_t address, uint8_t *data_out, uint16_t len)
Temp-Log 7 read EEPROM function.
pin_name_t gp0
Definition: templog7.h:308
err_t templog7_default_cfg(templog7_t *ctx)
Temp-Log 7 default configuration function.
@ TEMPLOG7_ERROR
Definition: templog7.h:325
err_t templog7_read_temperature(templog7_t *ctx, float *temperature)
Temp-Log 7 read temperature function.
uint16_t address
Definition: templog7.h:279
@ TEMPLOG7_GPIO_0
Definition: templog7.h:251
void templog7_cfg_setup(templog7_cfg_t *cfg)
Temp-Log 7 configuration object setup function.
err_t templog7_write_gpio(templog7_t *ctx, uint8_t data_in)
Temp-Log 7 write gpio function.
#define TEMPLOG7_EEPROM_ADDR_BLOCK
Definition: templog7.h:199
templog7_gpio_sel_t
Temp-Log 7 Click gpio selector.
Definition: templog7.h:250
pin_name_t gp1
Definition: templog7.h:309
uint8_t status
Definition: templog7.h:263
err_t templog7_start_measurement(templog7_t *ctx)
Temp-Log 7 start measurement function.
int16_t temp_limit_low
Definition: templog7.h:267
int16_t temperature
Definition: templog7.h:262
err_t templog7_clear_eeprom(templog7_t *ctx)
Temp-Log 7 clear EEPROM function.
err_t templog7_copy_scratchpad_2(templog7_t *ctx)
Temp-Log 7 copy scratchpad 2 function.
templog7_gpio_sel_t gpio_sel
Definition: templog7.h:314
err_t templog7_write_scratchpad_2(templog7_t *ctx, templog7_scratchpad_2_t *scratchpad)
Temp-Log 7 write scratchpad 2 function.
uint8_t config_1
Definition: templog7.h:264
err_t templog7_init(templog7_t *ctx, templog7_cfg_t *cfg)
Temp-Log 7 initialization function.
Temp-Log 7 scratchpad 1 object.
Definition: templog7.h:261
uint8_t templog7_get_alert_pin(templog7_t *ctx)
Temp-Log 7 get alert pin function.
Temp-Log 7 Click context object.
Definition: templog7.h:289
digital_in_t alert
Definition: templog7.h:291
int16_t temp_offset
Definition: templog7.h:269
uint8_t short_addr
Definition: templog7.h:266
int16_t temp_limit_high
Definition: templog7.h:268
templog7_return_value_t
Temp-Log 7 Click return value data.
Definition: templog7.h:323
void templog7_gpio_selection(templog7_cfg_t *cfg, templog7_gpio_sel_t gpio_sel)
Temp-Log 7 driver interface setup function.
err_t templog7_write_eeprom(templog7_t *ctx, uint16_t address, uint8_t *data_in, uint16_t len)
Temp-Log 7 write EEPROM function.
err_t templog7_read_scratchpad_2(templog7_t *ctx, templog7_scratchpad_2_t *scratchpad)
Temp-Log 7 read scratchpad 2 function.
err_t templog7_read_scratchpad_1(templog7_t *ctx, templog7_scratchpad_1_t *scratchpad)
Temp-Log 7 read scratchpad 1 function.
@ TEMPLOG7_GPIO_1
Definition: templog7.h:252
uint8_t address
Definition: templog7.h:297
one_wire_t ow
Definition: templog7.h:294
uint8_t config_2
Definition: templog7.h:265
Temp-Log 7 scratchpad 2 object.
Definition: templog7.h:278
err_t templog7_copy_scratchpad_1(templog7_t *ctx)
Temp-Log 7 copy scratchpad 1 function.
err_t templog7_write_scratchpad_1(templog7_t *ctx, templog7_scratchpad_1_t *scratchpad)
Temp-Log 7 write scratchpad 1 function.
Temp-Log 7 Click configuration object.
Definition: templog7.h:306