Teensy 4.1 core updated for C++20
Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

107 linhas
3.2KB

  1. /* Teensyduino Core Library
  2. * http://www.pjrc.com/teensy/
  3. * Copyright (c) 2019 PJRC.COM, LLC.
  4. *
  5. * Permission is hereby granted, free of charge, to any person obtaining
  6. * a copy of this software and associated documentation files (the
  7. * "Software"), to deal in the Software without restriction, including
  8. * without limitation the rights to use, copy, modify, merge, publish,
  9. * distribute, sublicense, and/or sell copies of the Software, and to
  10. * permit persons to whom the Software is furnished to do so, subject to
  11. * the following conditions:
  12. *
  13. * 1. The above copyright notice and this permission notice shall be
  14. * included in all copies or substantial portions of the Software.
  15. *
  16. * 2. If the Software is incorporated into a build system that allows
  17. * selection among a list of target devices, then similar target
  18. * devices manufactured by PJRC.COM must be included in the list of
  19. * target devices and selectable in the same manner.
  20. *
  21. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  22. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  23. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  24. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  25. * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  26. * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  27. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  28. * SOFTWARE.
  29. */
  30. #include <Arduino.h>
  31. #include "HardwareSerial.h"
  32. #ifndef SERIAL1_TX_BUFFER_SIZE
  33. #define SERIAL1_TX_BUFFER_SIZE 64 // number of outgoing bytes to buffer
  34. #endif
  35. #ifndef SERIAL1_RX_BUFFER_SIZE
  36. #define SERIAL1_RX_BUFFER_SIZE 64 // number of incoming bytes to buffer
  37. #endif
  38. #define IRQ_PRIORITY 64 // 0 = highest priority, 255 = lowest
  39. void IRQHandler_Serial1()
  40. {
  41. Serial1.IRQHandler();
  42. }
  43. void serial_event_check_serial1()
  44. {
  45. if (Serial1.available()) serialEvent1();
  46. }
  47. // Serial1
  48. static BUFTYPE tx_buffer1[SERIAL1_TX_BUFFER_SIZE];
  49. static BUFTYPE rx_buffer1[SERIAL1_RX_BUFFER_SIZE];
  50. const HardwareSerial::hardware_t UART6_Hardware = {
  51. 0, IRQ_LPUART6, &IRQHandler_Serial1, &serial_event_check_serial1,
  52. CCM_CCGR3, CCM_CCGR3_LPUART6(CCM_CCGR_ON),
  53. {{0,2, &IOMUXC_LPUART6_RX_SELECT_INPUT, 1}, {0xff, 0xff, nullptr, 0}},
  54. {{1,2, nullptr, 0}, {0xff, 0xff, nullptr, 0}},
  55. 0xff, // No CTS pin
  56. 0, // No CTS
  57. IRQ_PRIORITY, 38, 24, // IRQ, rts_low_watermark, rts_high_watermark
  58. };
  59. HardwareSerial Serial1(&IMXRT_LPUART6, &UART6_Hardware, tx_buffer1, SERIAL1_TX_BUFFER_SIZE,
  60. rx_buffer1, SERIAL1_RX_BUFFER_SIZE);
  61. void serialEvent1() __attribute__((weak));
  62. void serialEvent1() {Serial1.disableSerialEvents(); } // No use calling this so disable if called...
  63. // C wrapper functions to help take care of places that used to call these from standard C
  64. void serial_print(const char *p)
  65. {
  66. Serial1.write(p);
  67. }
  68. static void serial_phex1(uint32_t n)
  69. {
  70. n &= 15;
  71. if (n < 10) {
  72. Serial1.write('0' + n);
  73. } else {
  74. Serial1.write('A' - 10 + n);
  75. }
  76. }
  77. void serial_phex(uint32_t n)
  78. {
  79. serial_phex1(n >> 4);
  80. serial_phex1(n);
  81. }
  82. void serial_phex16(uint32_t n)
  83. {
  84. serial_phex(n >> 8);
  85. serial_phex(n);
  86. }
  87. void serial_phex32(uint32_t n)
  88. {
  89. serial_phex(n >> 24);
  90. serial_phex(n >> 16);
  91. serial_phex(n >> 8);
  92. serial_phex(n);
  93. }