ApfelNetzwerk/embedded/components/onewire/onewire.h

123 lines
2.8 KiB
C
Raw Normal View History

2024-10-14 00:31:33 +02:00
#ifndef ONEWIRE_H
#define ONEWIRE_H
#include "freertos/FreeRTOS.h"
#include "freertos/semphr.h"
#include "driver/gpio.h"
#include "esp_types.h"
#include "esp_err.h"
2024-10-14 01:19:50 +02:00
#define _ONEWIRE_WRITE1_LOW 6
#define _ONEWIRE_WRITE1_WAIT 64
#define _ONEWIRE_WRITE0_LOW 60
#define _ONEWIRE_WRITE0_WAIT 10
#define _ONEWIRE_READ_WAIT 9
#define _ONEWIRE_READ_RECOVERY 55
#define _ONEWIRE_RESET_WAIT 480
#define _ONEWIRE_PRESENCE_WAIT 70
#define _ONEWIRE_RESET_RECOVERY 410
2024-10-14 00:31:33 +02:00
2024-10-14 01:19:50 +02:00
#define _BLOCK_TIME pdMS_TO_TICKS(1000)
#define _SEMFAIL_MSG "Failed to obtain semaphore. (%s)"
2024-10-14 00:31:33 +02:00
static const char *TAG_ONEWIRE = "ONEWIRE";
2024-10-14 01:19:50 +02:00
typedef enum
{
_ROM_READ = 0x33,
2024-10-14 00:31:33 +02:00
_ROM_SEARCH = 0xF0,
2024-10-14 01:19:50 +02:00
_ROM_MATCH = 0x55,
_ROM_SKIP = 0xCC
2024-10-14 00:31:33 +02:00
} onewire_rom_commands_t;
2024-10-14 01:19:50 +02:00
typedef struct
{
2024-10-14 00:31:33 +02:00
gpio_num_t pin;
SemaphoreHandle_t mutex;
} onewire_bus_handle_t;
/**
* @brief Configure gpio pins for onewire communication
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* Set `custom_config` to NULL for default config.
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param pin Bus pin
* @param custom_config Custom gpio config
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 onewire_configure_gpio(gpio_num_t pin, gpio_config_t *custom_config);
/**
* @brief Initalize onewire bus
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* Set `custom_config` to NULL for default config.
* @warning MUST be called before any other library function!
2024-10-14 01:19:50 +02:00
*
* @param bus Bus handle
2024-10-14 00:31:33 +02:00
* @param pin Bus pin
* @param custom_config Custom gpio config
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @retval 1: Success
* @retval 0: `bus` is NULL or gpio configuration failed (Logs tells which happened)
*/
uint8_t onewire_init(onewire_bus_handle_t *bus, gpio_num_t bus_pin, gpio_config_t *custom_config);
/**
* @brief Send reset pulse
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param bus Bus handle
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @retval 1: Success (device sent presence pulse)
* @retval -1: Failed to obtain semaphore for gpio handling
* @retval 0: Device failed to return presence pulse
*/
uint8_t onewire_reset(onewire_bus_handle_t *bus);
/**
* @brief Write bit
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param bus Bus handle
* @param bit Bit to send
*/
void onewire_write_bit(onewire_bus_handle_t *bus, uint8_t bit);
/**
* @brief Write byte
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param bus Bus handle
* @param bit Byte to send
*/
void onewire_write_byte(onewire_bus_handle_t *bus, uint8_t byte);
/**
* @brief Read bit
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param bus Bus handle
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @retval 1: Device returned 1
* @retval 0: Device returned 0
* @retval -1: Failed to obtain semaphore for gpio handling
*/
uint8_t onewire_read_bit(onewire_bus_handle_t *bus);
/**
* @brief Read bit
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param bus Bus handle
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @return Byte returned by device
*/
uint8_t onewire_read_byte(onewire_bus_handle_t *bus);
/**
* @brief Send command to device
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
* @param bus Bus handle
* @param command Onewire rom command
2024-10-14 01:19:50 +02:00
*
2024-10-14 00:31:33 +02:00
*/
void onewire_send_command(onewire_bus_handle_t *bus, onewire_rom_commands_t command);
#endif