luat_log_rtt.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. #include "luat_base.h"
  2. #include "luat_log.h"
  3. #include "rtthread.h"
  4. #include "luat_uart.h"
  5. #include "vsprintf.h"
  6. #define DBG_TAG "rtt.log"
  7. #define DBG_LVL DBG_INFO
  8. #include <rtdbg.h>
  9. static int log_uart_port = 0;
  10. void luat_print(const char* _str) {
  11. rt_kputs(_str);
  12. }
  13. void luat_nprint(char *s, size_t l) {
  14. char buf[2];
  15. buf[1] = 0x00;
  16. for (size_t i = 0; i < l; i++)
  17. {
  18. buf[0] = s[i];
  19. rt_kputs(buf);
  20. }
  21. }
  22. void luat_printf(const char* fmt, const char* value) {
  23. rt_kprintf(fmt, value);
  24. }
  25. static int LOG_LEVEL = LUAT_LOG_DEBUG;
  26. void luat_log_set_level(int level) {
  27. LOG_LEVEL = level;
  28. }
  29. int luat_log_get_level() {
  30. return LOG_LEVEL;
  31. }
  32. void luat_log_log(int level, const char* tag, const char* _fmt, ...) {
  33. va_list args;
  34. va_start(args, _fmt);
  35. #if defined(RT_USING_ULOG)
  36. /*
  37. #define LOG_LVL_ASSERT 0
  38. #define LOG_LVL_ERROR 3
  39. #define LOG_LVL_WARNING 4
  40. #define LOG_LVL_INFO 6
  41. #define LOG_LVL_DBG 7
  42. */
  43. switch (level)
  44. {
  45. case LUAT_LOG_DEBUG:
  46. level = LOG_LVL_DBG;
  47. break;
  48. case LUAT_LOG_INFO:
  49. level = LOG_LVL_INFO;
  50. break;
  51. case LUAT_LOG_WARN:
  52. level = LOG_LVL_WARNING;
  53. break;
  54. case LUAT_LOG_ERROR:
  55. level = LOG_LVL_ERROR;
  56. break;
  57. default:
  58. level = LOG_LVL_DBG;
  59. break;
  60. }
  61. ulog_output(level, tag, 1, _fmt, args);
  62. #else
  63. /*
  64. #define DBG_ERROR 0
  65. #define DBG_WARNING 1
  66. #define DBG_INFO 2
  67. #define DBG_LOG 3
  68. */
  69. switch (level)
  70. {
  71. case LUAT_LOG_DEBUG:
  72. level = DBG_LOG;
  73. break;
  74. case LUAT_LOG_INFO:
  75. level = DBG_INFO;
  76. break;
  77. case LUAT_LOG_WARN:
  78. level = DBG_WARNING;
  79. break;
  80. case LUAT_LOG_ERROR:
  81. level = DBG_ERROR;
  82. break;
  83. default:
  84. level = DBG_LOG;
  85. break;
  86. }
  87. dbg_log(level, _fmt, args);
  88. #endif
  89. va_end(args);
  90. }
  91. void luat_log_debug(const char* tag, const char* _fmt, ...) {
  92. if (LOG_LEVEL > LUAT_LOG_DEBUG) return;
  93. va_list args;
  94. va_start(args, _fmt);
  95. luat_log_log(LUAT_LOG_DEBUG, tag, _fmt, args);
  96. va_end(args);
  97. }
  98. void luat_log_info(const char* tag, const char* _fmt, ...) {
  99. if (LOG_LEVEL > LUAT_LOG_INFO) return;
  100. va_list args;
  101. va_start(args, _fmt);
  102. luat_log_log(LUAT_LOG_INFO, tag, _fmt, args);
  103. va_end(args);
  104. }
  105. void luat_log_warn(const char* tag, const char* _fmt, ...) {
  106. if (LOG_LEVEL > LUAT_LOG_WARN) return;
  107. va_list args;
  108. va_start(args, _fmt);
  109. luat_log_log(LUAT_LOG_WARN, tag, _fmt, args);
  110. va_end(args);
  111. }
  112. void luat_log_error(const char* tag, const char* _fmt, ...) {
  113. if (LOG_LEVEL > LUAT_LOG_ERROR) return;
  114. char buff[1024];
  115. va_list args;
  116. va_start(args, _fmt);
  117. size_t len = custom_vsprintf(buff, _fmt, args);
  118. if (len > 0) {
  119. luat_uart_write(log_uart_port, "E/", 2);
  120. luat_uart_write(log_uart_port, (void*)tag, strlen(tag));
  121. luat_uart_write(log_uart_port, "\t", 1);
  122. luat_uart_write(log_uart_port, buff, len);
  123. luat_uart_write(log_uart_port, "\n", 1);
  124. }
  125. va_end(args);
  126. }