22#include "ms_semaphore.h"
32#define MAX_LOG_SIZE (size_t)200
33#define LOG_TIMEOUT_MS 10
36#define LOG_UART_PORT UART_PORT_1
37#define LOG_GPIO_PORT GPIO_PORT_B
43#define LOG_UART_PORT UART_PORT_1
44#define LOG_GPIO_PORT GPIO_PORT_A
50#define LOG_UART_PORT UART_PORT_3
51#define LOG_GPIO_PORT GPIO_PORT_C
57#define LOG_UART_PORT UART_PORT_1
61#define LOG_GPIO_PORT GPIO_PORT_B
73#define IN_ORDER_LOGS 1
83extern char g_log_buffer[MAX_LOG_SIZE];
84extern Mutex s_log_mutex;
87#define LOG_DEBUG(fmt, ...) LOG(LOG_LEVEL_DEBUG, fmt, ##__VA_ARGS__)
88#define LOG_WARN(fmt, ...) LOG(LOG_LEVEL_WARN, fmt, ##__VA_ARGS__)
89#define LOG_CRITICAL(fmt, ...) LOG(LOG_LEVEL_CRITICAL, fmt, ##__VA_ARGS__)
92 { uart_init(LOG_UART_PORT, &log_uart_settings); }
95#define LOG(level, fmt, ...) printf("[%u] %s:%u: " fmt, (level), __FILE__, __LINE__, ##__VA_ARGS__)
97#define LOG(level, fmt, ...) \
99 if (xTaskGetSchedulerState() == taskSCHEDULER_RUNNING) { \
100 size_t msg_size = (size_t)snprintf(g_log_buffer, MAX_LOG_SIZE, "\r[%u] %s:%u: " fmt, (level), __FILE__, __LINE__, ##__VA_ARGS__); \
101 uart_tx(LOG_UART_PORT, (uint8_t *)g_log_buffer, msg_size); \
LogLevel
Definition: log.h:76
@ LOG_LEVEL_CRITICAL
Definition: log.h:79
@ NUM_LOG_LEVELS
Definition: log.h:80
@ LOG_LEVEL_DEBUG
Definition: log.h:77
@ LOG_LEVEL_WARN
Definition: log.h:78
Semaphore object with handle and buffer.
Definition: ms_semaphore.h:32
UART Settings.
Definition: network.h:67