ApfelNetzwerk/embedded/components/ds18b20/ds18b20.h

100 lines
2.2 KiB
C
Raw Normal View History

2024-10-14 00:31:33 +02:00
#ifndef DS18B20_H
#define DS18B20_H
#include "onewire.h"
2024-10-14 01:19:50 +02:00
typedef enum
{
TEMP_RES_9_BIT = 0,
2024-10-14 00:31:33 +02:00
TEMP_RES_10_BIT = 1,
TEMP_RES_11_BIT = 2,
TEMP_RES_12_BIT = 3
} ds18b20_temp_res_t;
2024-10-14 01:19:50 +02:00
typedef enum
{
2024-10-14 00:31:33 +02:00
_SCRATCH_WRITE = 0x4E,
2024-10-14 01:19:50 +02:00
_SCRATCH_READ = 0xBE,
_SCRATCH_COPY = 0x48,
_CONVERT_T = 0x44
2024-10-14 00:31:33 +02:00
} ds18b20_commands_t;
typedef uint8_t ds18b20_scratchpad_t[9];
2024-10-14 01:19:50 +02:00
typedef struct
{
2024-10-14 00:31:33 +02:00
onewire_bus_handle_t bus;
ds18b20_temp_res_t res;
ds18b20_scratchpad_t scratchpad;
} ds18b20_handler_t;
/**
* @brief Initialize DS18B20
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
* @param pin Data pin
* @param resolution Temperature resolution
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @retval 1: Success
* @retval 0: Incorrect pin or gpio configuration failed (Logs tells which happened)
*/
uint8_t ds18b20_init(ds18b20_handler_t *device, gpio_num_t pin, ds18b20_temp_res_t resolution);
/**
* @brief Send command to DS18B20
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
2024-10-14 01:19:50 +02:00
* @param command Function command
2024-10-14 00:31:33 +02:00
*/
void ds18b20_send_command(ds18b20_handler_t *device, ds18b20_commands_t command);
/**
* @brief Write to scratchpad
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
*/
void ds18b20_write_scratchpad(ds18b20_handler_t *device);
/**
* @brief Read from scratchpad
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
*/
void ds18b20_read_scratchpad(ds18b20_handler_t *device);
/**
* @brief Copy to scratchpad
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
*/
void ds18b20_copy_scratchpad(ds18b20_handler_t *device);
/**
* @brief Print scratchpad bytes
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
*/
void ds18b20_print_scratchpad(ds18b20_handler_t *device);
/**
* @brief Initialize temperature conversion and wait for conversion
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* Function sends CONV_T command and waits for X ms according to `ds18b20_temp_conv_time` static array
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @warning Should be called before `ds18b20_convert_temp()` function
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
*/
void ds18b20_convert_temp(ds18b20_handler_t *device);
/**
* @brief Read temperature from scratchpad
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* Function reads temperature from scratchpad and converts it to Celsius.
* @warning `ds18b20_convert_temp()` have to be called before for updated temperature.
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param device DS18B20 handler
*/
float ds18b20_read_temp(ds18b20_handler_t *device);
#endif