Teensy 4.1 core updated for C++20
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

81 line
3.0KB

  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 SERIAL2_TX_BUFFER_SIZE
  33. #define SERIAL2_TX_BUFFER_SIZE 40 // number of outgoing bytes to buffer
  34. #endif
  35. #ifndef SERIAL2_RX_BUFFER_SIZE
  36. #define SERIAL2_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_Serial2()
  40. {
  41. Serial2.IRQHandler();
  42. }
  43. void serial_event_check_serial2()
  44. {
  45. if (Serial2.available()) serialEvent2();
  46. }
  47. // Serial2
  48. static BUFTYPE tx_buffer2[SERIAL2_TX_BUFFER_SIZE];
  49. static BUFTYPE rx_buffer2[SERIAL2_RX_BUFFER_SIZE];
  50. uint8_t _serialEvent2_default __attribute__((weak)) PROGMEM = 0 ;
  51. static HardwareSerial::hardware_t UART4_Hardware = {
  52. 1, IRQ_LPUART4, &IRQHandler_Serial2,
  53. &serial_event_check_serial2, &_serialEvent2_default,
  54. CCM_CCGR1, CCM_CCGR1_LPUART4(CCM_CCGR_ON),
  55. #if defined(__IMXRT1052__)
  56. {{6,2, &IOMUXC_LPUART4_RX_SELECT_INPUT, 2}, {0xff, 0xff, nullptr, 0}},
  57. {{7,2, nullptr, 0}, {0xff, 0xff, nullptr, 0}},
  58. #elif defined(__IMXRT1062__)
  59. {{7,2, &IOMUXC_LPUART4_RX_SELECT_INPUT, 2}, {0xff, 0xff, nullptr, 0}},
  60. {{8,2, &IOMUXC_LPUART4_TX_SELECT_INPUT, 2}, {0xff, 0xff, nullptr, 0}},
  61. #endif
  62. 0xff, // No CTS pin
  63. 0, // No CTS
  64. IRQ_PRIORITY, 38, 24, // IRQ, rts_low_watermark, rts_high_watermark
  65. XBARA1_OUT_LPUART4_TRG_INPUT
  66. };
  67. HardwareSerial Serial2(&IMXRT_LPUART4, &UART4_Hardware, tx_buffer2, SERIAL2_TX_BUFFER_SIZE,
  68. rx_buffer2, SERIAL2_RX_BUFFER_SIZE);
  69. void serialEvent2() __attribute__((weak));
  70. void serialEvent2() {Serial2.disableSerialEvents(); } // No use calling this so disable if called...