Teensy 4.1 core updated for C++20
Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.

debugprintf.c 2.2KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. #include "debug/printf.h"
  2. #ifdef PRINT_DEBUG_STUFF
  3. #include <stdarg.h>
  4. #include "imxrt.h"
  5. static void puint_debug(unsigned int num);
  6. __attribute__((section(".progmem")))
  7. void printf_debug(const char *format, ...)
  8. {
  9. va_list args;
  10. unsigned int val;
  11. int n;
  12. va_start(args, format);
  13. for (; *format != 0; format++) { // no-frills stand-alone printf
  14. if (*format == '%') {
  15. ++format;
  16. if (*format == '%') goto out;
  17. if (*format == '-') format++; // ignore size
  18. while (*format >= '0' && *format <= '9') format++; // ignore size
  19. if (*format == 'l') format++; // ignore long
  20. if (*format == '\0') break;
  21. if (*format == 's') {
  22. printf_debug((char *)va_arg(args, int));
  23. } else if (*format == 'd') {
  24. n = va_arg(args, int);
  25. if (n < 0) {
  26. n = -n;
  27. putchar_debug('-');
  28. }
  29. val = n;
  30. puint_debug(n);
  31. } else if (*format == 'u') {
  32. puint_debug(va_arg(args, unsigned int));
  33. } else if (*format == 'x' || *format == 'X') {
  34. val = va_arg(args, unsigned int);
  35. for (n=0; n < 8; n++) {
  36. unsigned int d = (val >> 28) & 15;
  37. putchar_debug((d < 10) ? d + '0' : d - 10 + 'A');
  38. val <<= 4;
  39. }
  40. } else if (*format == 'c' ) {
  41. putchar_debug((char)va_arg(args, int));
  42. }
  43. } else {
  44. out:
  45. if (*format == '\n') putchar_debug('\r');
  46. putchar_debug(*format);
  47. }
  48. }
  49. va_end(args);
  50. }
  51. static void puint_debug(unsigned int num)
  52. {
  53. char buf[12];
  54. unsigned int i = sizeof(buf)-2;
  55. buf[sizeof(buf)-1] = 0;
  56. while (1) {
  57. buf[i] = (num % 10) + '0';
  58. num /= 10;
  59. if (num == 0) break;
  60. i--;
  61. }
  62. printf_debug(buf + i);
  63. }
  64. __attribute__((section(".progmem")))
  65. void putchar_debug(char c)
  66. {
  67. while (!(LPUART3_STAT & LPUART_STAT_TDRE)) ; // wait
  68. LPUART3_DATA = c;
  69. }
  70. __attribute__((section(".progmem")))
  71. void printf_debug_init(void)
  72. {
  73. // turn on Serial4, run at 115200 baud using 24 MHz clock (works if PLL3 off)
  74. CCM_CCGR0 |= CCM_CCGR0_LPUART3(CCM_CCGR_ON);
  75. IOMUXC_SW_MUX_CTL_PAD_GPIO_AD_B1_06 = 2; // Arduino pin 17
  76. CCM_CSCDR1 = (CCM_CSCDR1 & ~CCM_CSCDR1_UART_CLK_PODF(0x3F)) | CCM_CSCDR1_UART_CLK_SEL;
  77. LPUART3_BAUD = LPUART_BAUD_OSR(25) | LPUART_BAUD_SBR(8);
  78. LPUART3_CTRL = LPUART_CTRL_TE;
  79. }
  80. #endif // PRINT_DEBUG_STUFF