-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlog.h
82 lines (70 loc) · 2.59 KB
/
log.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
* log.h
*
* Created on: Dec 18, 2018
* Author: Dan Walkes
*/
#ifndef SRC_LOG_H_
#define SRC_LOG_H_
#include "stdio.h"
#include <inttypes.h>
#include "letimer.h"
/**
* Instructions for using this module:
* 1) #include "log.h" in the C file where you'd like to add logging
* 2) Reference macros LOG_XXX to log at specific thresholds. Use printf style argument
* lists with each macro to support printing variables.
* * ERROR for unexpected conditions which should never occur.
* * WARN for potential issues which may occur
* * INFO for infrequent status updates
* * DEBUG for detailed updates, useful when troubleshooting a specific
* code path
* 3) Call logInit() once in the main init routine, before any logging is attempted and after any timing capability for
* loggerGetTimestamp() is complete.
* For the Blue Gecko platform, logging can be viewed with Tera Term or similar terminal emulator.
* Select the "JLink CDC UART Port" and baud rate 115200.
* All logging is off by default (compiled out of the build)
* * To turn on you should #define INCLUDE_LOGGING 1 in your project files or setup a build configuration for
* this purpose.
* Even after turning logging on with INCLUDE_LOGGING, debug logging is off by default.
* * To turn debug logging on for a specific .c file, #define INCLUDE_LOG_DEBUG 1 at the top of the file
* before the #include "log.h" reference.
* * To turn on for all files #define INCLUDE_LOG_DEBUG 1 in the project configuration.
*/
#ifndef LOG_ERROR
#define LOG_ERROR(message,...) \
LOG_DO(message,"[ERROR]", ##__VA_ARGS__)
#endif
#ifndef LOG_WARN
#define LOG_WARN(message,...) \
LOG_DO(message,"[WARN ]", ##__VA_ARGS__)
#endif
#ifndef LOG_INFO
#define LOG_INFO(message,...) \
LOG_DO(message,"[INFO ]", ##__VA_ARGS__)
#endif
#if INCLUDE_LOG_DEBUG
#ifndef LOG_DEBUG
#define LOG_DEBUG(message,...) \
LOG_DO(message,"[DEBUG]",##__VA_ARGS__)
#define LOG_DEBUG_CODE(code) code
#endif
#else
#define LOG_DEBUG(message,...)
#define LOG_DEBUG_CODE(code)
#endif
#if INCLUDE_LOGGING
#define LOG_DO(message,level, ...) printf( "%6"PRIu32":%s: " message "\n", loggerGetTimestamp(), level, ##__VA_ARGS__ )
//#define LOG_DO(message,level, ...) printf( "%5"PRIu32":%s:%s:%s: " message "\n", loggerGetTimestamp(), level, __FILE__,__func__, ##__VA_ARGS__ )
void logInit();
uint32_t loggerGetTimestamp();
void logFlush();
#else
/**
* Remove all logging related code on builds where logging is not enabled
*/
#define LOG_DO(message,level, ...)
static inline void logInit() {}
static inline void logFlush() {}
#endif
#endif /* SRC_LOG_H_ */