luat_log_air105.c 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /*
  2. * Copyright (c) 2022 OpenLuat & AirM2M
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  5. * this software and associated documentation files (the "Software"), to deal in
  6. * the Software without restriction, including without limitation the rights to
  7. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  8. * the Software, and to permit persons to whom the Software is furnished to do so,
  9. * subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in all
  12. * copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  16. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  17. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  18. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  19. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  20. */
  21. #include "luat_base.h"
  22. #include "luat_log.h"
  23. #include "luat_cmux.h"
  24. #include "luat_conf_bsp.h"
  25. #include "app_interface.h"
  26. extern luat_cmux_t cmux_ctx;
  27. void DBG_DirectOut(void *Data, uint32_t Len);
  28. void luat_nprint(char *s, size_t l) {
  29. #ifdef LUAT_USE_SHELL
  30. if (cmux_ctx.state == 1 && cmux_ctx.log_state ==1){
  31. luat_cmux_write(LUAT_CMUX_CH_LOG, CMUX_FRAME_UIH & ~ CMUX_CONTROL_PF,s, l);
  32. }else
  33. #endif
  34. DBG_DirectOut(s, l);
  35. }
  36. void luat_log_write(char *s, size_t l) {
  37. #ifdef LUAT_USE_SHELL
  38. if (cmux_ctx.state == 1 && cmux_ctx.log_state ==1){
  39. luat_cmux_write(LUAT_CMUX_CH_LOG, CMUX_FRAME_UIH & ~ CMUX_CONTROL_PF,s, l);
  40. }else
  41. #endif
  42. DBG_DirectOut(s, l);
  43. }
  44. static void luat_cmux_write_cb(uint8_t *data, uint32_t len){
  45. luat_cmux_write(LUAT_CMUX_CH_LOG, CMUX_FRAME_UIH & ~ CMUX_CONTROL_PF,data, len);
  46. }
  47. void luat_cmux_log_set(uint8_t state) {
  48. if (state == 1){
  49. DBG_SetTxCB(luat_cmux_write_cb);
  50. }else if(state == 0){
  51. DBG_SetTxCB(add_printf_data);
  52. }
  53. }