mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-22 21:01:40 +03:00
917410a0a8
* fbt: reworking targets & assets handling WIP * fbt: dist fixes * fbt: moved SD card resources to owning apps * unit_tests: moved resources to app folder * github: updated unit_tests paths * github: packaging fixes * unit_tests: fixes * fbt: assets: internal cleanup * fbt: reworked assets handling * github: unit_tests: reintroducing fixes * minor cleanup * fbt: naming changes to reflect private nature of scons tools * fbt: resources: fixed dist archive paths * docs: updated paths * docs: updated more paths * docs: included "resources" parameter in app manifest docs; updated assets readme * updated gitignore for assets * github: updated action versions * unit_tests: restored timeout; scripts: assets: logging changes * gh: don't upload desktop animations for unit test run Co-authored-by: あく <alleteam@gmail.com>
90 lines
1.8 KiB
C
90 lines
1.8 KiB
C
/**
|
||
* @file furi_hal_uart.h
|
||
* @version 1.0
|
||
* @date 2021-11-19
|
||
*
|
||
* UART HAL api interface
|
||
*/
|
||
#pragma once
|
||
|
||
#include <stddef.h>
|
||
#include <stdint.h>
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
/**
|
||
* UART channels
|
||
*/
|
||
typedef enum {
|
||
FuriHalUartIdUSART1,
|
||
FuriHalUartIdLPUART1,
|
||
} FuriHalUartId;
|
||
|
||
/**
|
||
* UART events
|
||
*/
|
||
typedef enum {
|
||
UartIrqEventRXNE,
|
||
} UartIrqEvent;
|
||
|
||
/**
|
||
* Init UART
|
||
* Configures GPIO to UART function, сonfigures UART hardware, enables UART hardware
|
||
* @param channel UART channel
|
||
* @param baud baudrate
|
||
*/
|
||
void furi_hal_uart_init(FuriHalUartId channel, uint32_t baud);
|
||
|
||
/**
|
||
* Deinit UART
|
||
* Configures GPIO to analog, clears callback and callback context, disables UART hardware
|
||
* @param channel UART channel
|
||
*/
|
||
void furi_hal_uart_deinit(FuriHalUartId channel);
|
||
|
||
/**
|
||
* Suspend UART operation
|
||
* Disables UART hardware, settings and callbacks are preserved
|
||
* @param channel UART channel
|
||
*/
|
||
void furi_hal_uart_suspend(FuriHalUartId channel);
|
||
|
||
/**
|
||
* Resume UART operation
|
||
* Resumes UART hardware from suspended state
|
||
* @param channel UART channel
|
||
*/
|
||
void furi_hal_uart_resume(FuriHalUartId channel);
|
||
|
||
/**
|
||
* Changes UART baudrate
|
||
* @param channel UART channel
|
||
* @param baud baudrate
|
||
*/
|
||
void furi_hal_uart_set_br(FuriHalUartId channel, uint32_t baud);
|
||
|
||
/**
|
||
* Transmits data
|
||
* @param channel UART channel
|
||
* @param buffer data
|
||
* @param buffer_size data size (in bytes)
|
||
*/
|
||
void furi_hal_uart_tx(FuriHalUartId channel, uint8_t* buffer, size_t buffer_size);
|
||
|
||
/**
|
||
* Sets UART event callback
|
||
* @param channel UART channel
|
||
* @param callback callback pointer
|
||
* @param context callback context
|
||
*/
|
||
void furi_hal_uart_set_irq_cb(
|
||
FuriHalUartId channel,
|
||
void (*callback)(UartIrqEvent event, uint8_t data, void* context),
|
||
void* context);
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif
|