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.

пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 7 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. /* Teensyduino Core Library
  2. * http://www.pjrc.com/teensy/
  3. * Copyright (c) 2013 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. #ifndef USBserial_h_
  31. #define USBserial_h_
  32. #include "usb_desc.h"
  33. #if (defined(CDC_STATUS_INTERFACE) && defined(CDC_DATA_INTERFACE)) || defined(USB_DISABLED)
  34. #include <inttypes.h>
  35. #if F_CPU >= 20000000 && !defined(USB_DISABLED)
  36. // C language implementation
  37. #ifdef __cplusplus
  38. extern "C" {
  39. #endif
  40. int usb_serial_getchar(void);
  41. int usb_serial_peekchar(void);
  42. int usb_serial_available(void);
  43. int usb_serial_read(void *buffer, uint32_t size);
  44. void usb_serial_flush_input(void);
  45. int usb_serial_putchar(uint8_t c);
  46. int usb_serial_write(const void *buffer, uint32_t size);
  47. int usb_serial_write_buffer_free(void);
  48. void usb_serial_flush_output(void);
  49. extern uint32_t usb_cdc_line_coding[2];
  50. extern volatile uint32_t usb_cdc_line_rtsdtr_millis;
  51. extern volatile uint32_t systick_millis_count;
  52. extern volatile uint8_t usb_cdc_line_rtsdtr;
  53. extern volatile uint8_t usb_cdc_transmit_flush_timer;
  54. extern volatile uint8_t usb_configuration;
  55. #ifdef __cplusplus
  56. }
  57. #endif
  58. #define USB_SERIAL_DTR 0x01
  59. #define USB_SERIAL_RTS 0x02
  60. // C++ interface
  61. #ifdef __cplusplus
  62. #include "Stream.h"
  63. class usb_serial_class : public Stream
  64. {
  65. public:
  66. constexpr usb_serial_class() {}
  67. void begin(long) {
  68. uint32_t millis_begin = systick_millis_count;
  69. while (!(*this)) {
  70. // wait up to 1 second for Arduino Serial Monitor
  71. if ((uint32_t)(systick_millis_count - millis_begin) > 1000) break;
  72. }
  73. }
  74. void end() { /* TODO: flush output and shut down USB port */ };
  75. virtual int available() { return usb_serial_available(); }
  76. virtual int read() { return usb_serial_getchar(); }
  77. virtual int peek() { return usb_serial_peekchar(); }
  78. virtual void flush() { usb_serial_flush_output(); } // TODO: actually wait for data to leave USB...
  79. virtual void clear(void) { usb_serial_flush_input(); }
  80. virtual size_t write(uint8_t c) { return usb_serial_putchar(c); }
  81. virtual size_t write(const uint8_t *buffer, size_t size) { return usb_serial_write(buffer, size); }
  82. size_t write(unsigned long n) { return write((uint8_t)n); }
  83. size_t write(long n) { return write((uint8_t)n); }
  84. size_t write(unsigned int n) { return write((uint8_t)n); }
  85. size_t write(int n) { return write((uint8_t)n); }
  86. virtual int availableForWrite() { return usb_serial_write_buffer_free(); }
  87. using Print::write;
  88. void send_now(void) { usb_serial_flush_output(); }
  89. uint32_t baud(void) { return usb_cdc_line_coding[0]; }
  90. uint8_t stopbits(void) { uint8_t b = usb_cdc_line_coding[1]; if (!b) b = 1; return b; }
  91. uint8_t paritytype(void) { return usb_cdc_line_coding[1] >> 8; } // 0=none, 1=odd, 2=even
  92. uint8_t numbits(void) { return usb_cdc_line_coding[1] >> 16; }
  93. uint8_t dtr(void) { return (usb_cdc_line_rtsdtr & USB_SERIAL_DTR) ? 1 : 0; }
  94. uint8_t rts(void) { return (usb_cdc_line_rtsdtr & USB_SERIAL_RTS) ? 1 : 0; }
  95. operator bool() { return usb_configuration &&
  96. (usb_cdc_line_rtsdtr & (USB_SERIAL_DTR | USB_SERIAL_RTS)) &&
  97. ((uint32_t)(systick_millis_count - usb_cdc_line_rtsdtr_millis) >= 25);
  98. }
  99. size_t readBytes(char *buffer, size_t length) {
  100. size_t count=0;
  101. unsigned long startMillis = millis();
  102. do {
  103. count += usb_serial_read(buffer + count, length - count);
  104. if (count >= length) return count;
  105. } while(millis() - startMillis < _timeout);
  106. setReadError();
  107. return count;
  108. }
  109. };
  110. extern usb_serial_class Serial;
  111. extern void serialEvent(void);
  112. #endif // __cplusplus
  113. #else // F_CPU < 20000000
  114. // Allow Arduino programs using Serial to compile, but Serial will do nothing.
  115. #ifdef __cplusplus
  116. #include "Stream.h"
  117. class usb_serial_class : public Stream
  118. {
  119. public:
  120. constexpr usb_serial_class() {}
  121. void begin(long) { };
  122. void end() { };
  123. virtual int available() { return 0; }
  124. virtual int read() { return -1; }
  125. virtual int peek() { return -1; }
  126. virtual void flush() { }
  127. virtual void clear() { }
  128. virtual size_t write(uint8_t c) { return 1; }
  129. virtual size_t write(const uint8_t *buffer, size_t size) { return size; }
  130. size_t write(unsigned long n) { return 1; }
  131. size_t write(long n) { return 1; }
  132. size_t write(unsigned int n) { return 1; }
  133. size_t write(int n) { return 1; }
  134. int availableForWrite() { return 0; }
  135. using Print::write;
  136. void send_now(void) { }
  137. uint32_t baud(void) { return 0; }
  138. uint8_t stopbits(void) { return 1; }
  139. uint8_t paritytype(void) { return 0; }
  140. uint8_t numbits(void) { return 8; }
  141. uint8_t dtr(void) { return 1; }
  142. uint8_t rts(void) { return 1; }
  143. operator bool() { return true; }
  144. };
  145. extern usb_serial_class Serial;
  146. extern void serialEvent(void);
  147. #endif // __cplusplus
  148. #endif // F_CPU
  149. #endif // CDC_STATUS_INTERFACE && CDC_DATA_INTERFACE
  150. #endif // USBserial_h_