Midnight Sun Firmware
Loading...
Searching...
No Matches
log.h
1#pragma once
2
3/************************************************************************************************
4 * @file log.h
5 *
6 * @brief Header file for the logging library used to debug all modules
7 *
8 * @date 2024-11-02
9 * @author Midnight Sun Team #24 - MSXVI
10 ************************************************************************************************/
11
12/* Standard library Headers */
13#include <stdio.h>
14#include <stdlib.h>
15
16/* Inter-component Headers */
17#include "FreeRTOS.h"
18#include "task.h"
19
20/* Intra-component Headers */
21#include "gpio.h"
22#include "ms_semaphore.h"
23#include "tasks.h"
24#include "uart.h"
25
32#define MAX_LOG_SIZE (size_t)200
33#define LOG_TIMEOUT_MS 10
34
35#ifdef STM32L433xx
36#define LOG_UART_PORT UART_PORT_1
37#define LOG_GPIO_PORT GPIO_PORT_B
38#define LOG_TX_PIN 6
39#define LOG_RX_PIN 7
40#endif
41
42#ifdef STM32L4P5xx
43#define LOG_UART_PORT UART_PORT_1
44#define LOG_GPIO_PORT GPIO_PORT_A
45#define LOG_TX_PIN 9
46#define LOG_RX_PIN 10
47#endif
48
49#ifdef STM32L496xx
50#define LOG_UART_PORT UART_PORT_3
51#define LOG_GPIO_PORT GPIO_PORT_C
52#define LOG_TX_PIN 10
53#define LOG_RX_PIN 11
54#endif
55
56#ifndef LOG_UART_PORT
57#define LOG_UART_PORT UART_PORT_1
58#endif
59
60#ifndef LOG_GPIO_PORT
61#define LOG_GPIO_PORT GPIO_PORT_B
62#endif
63
64#ifndef LOG_TX_PIN
65#define LOG_TX_PIN 6
66#endif
67
68#ifndef LOG_RX_PIN
69#define LOG_RX_PIN 7
70#endif
71
72#ifndef IN_ORDER_LOGS
73#define IN_ORDER_LOGS 1
74#endif
75
76typedef enum {
81} LogLevel;
82
83extern char g_log_buffer[MAX_LOG_SIZE];
84extern Mutex s_log_mutex;
85extern UartSettings log_uart_settings;
86
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__)
90
91#define log_init() \
92 { uart_init(LOG_UART_PORT, &log_uart_settings); }
93
94#ifdef MS_PLATFORM_X86
95#define LOG(level, fmt, ...) printf("[%u] %s:%u: " fmt, (level), __FILE__, __LINE__, ##__VA_ARGS__)
96#else
97#define LOG(level, fmt, ...) \
98 do { \
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); \
102 } \
103 } while (0)
104#endif
105
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