MarlinSerial.h 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (C) 2016 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
  4. *
  5. * Based on Sprinter and grbl.
  6. * Copyright (C) 2011 Camiel Gubbels / Erik van der Zalm
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. *
  21. */
  22. /**
  23. * MarlinSerial.h - Hardware serial library for Wiring
  24. * Copyright (c) 2006 Nicholas Zambetti. All right reserved.
  25. *
  26. * Modified 28 September 2010 by Mark Sproul
  27. * Modified 14 February 2016 by Andreas Hardtung (added tx buffer)
  28. * Modified 01 October 2017 by Eduardo José Tagle (added XON/XOFF)
  29. */
  30. #ifndef _MARLINSERIAL_H_
  31. #define _MARLINSERIAL_H_
  32. #include "MarlinConfig.h"
  33. #ifndef SERIAL_PORT
  34. #define SERIAL_PORT 0
  35. #endif
  36. // The presence of the UBRRH register is used to detect a UART.
  37. #define UART_PRESENT(port) ((port == 0 && (defined(UBRRH) || defined(UBRR0H))) || \
  38. (port == 1 && defined(UBRR1H)) || (port == 2 && defined(UBRR2H)) || \
  39. (port == 3 && defined(UBRR3H)))
  40. // These are macros to build serial port register names for the selected SERIAL_PORT (C preprocessor
  41. // requires two levels of indirection to expand macro values properly)
  42. #define SERIAL_REGNAME(registerbase,number,suffix) SERIAL_REGNAME_INTERNAL(registerbase,number,suffix)
  43. #if SERIAL_PORT == 0 && (!defined(UBRR0H) || !defined(UDR0)) // use un-numbered registers if necessary
  44. #define SERIAL_REGNAME_INTERNAL(registerbase,number,suffix) registerbase##suffix
  45. #else
  46. #define SERIAL_REGNAME_INTERNAL(registerbase,number,suffix) registerbase##number##suffix
  47. #endif
  48. // Registers used by MarlinSerial class (expanded depending on selected serial port)
  49. #define M_UCSRxA SERIAL_REGNAME(UCSR,SERIAL_PORT,A) // defines M_UCSRxA to be UCSRnA where n is the serial port number
  50. #define M_UCSRxB SERIAL_REGNAME(UCSR,SERIAL_PORT,B)
  51. #define M_RXENx SERIAL_REGNAME(RXEN,SERIAL_PORT,)
  52. #define M_TXENx SERIAL_REGNAME(TXEN,SERIAL_PORT,)
  53. #define M_TXCx SERIAL_REGNAME(TXC,SERIAL_PORT,)
  54. #define M_RXCIEx SERIAL_REGNAME(RXCIE,SERIAL_PORT,)
  55. #define M_UDREx SERIAL_REGNAME(UDRE,SERIAL_PORT,)
  56. #define M_FEx SERIAL_REGNAME(FE,SERIAL_PORT,)
  57. #define M_DORx SERIAL_REGNAME(DOR,SERIAL_PORT,)
  58. #define M_UPEx SERIAL_REGNAME(UPE,SERIAL_PORT,)
  59. #define M_UDRIEx SERIAL_REGNAME(UDRIE,SERIAL_PORT,)
  60. #define M_UDRx SERIAL_REGNAME(UDR,SERIAL_PORT,)
  61. #define M_UBRRxH SERIAL_REGNAME(UBRR,SERIAL_PORT,H)
  62. #define M_UBRRxL SERIAL_REGNAME(UBRR,SERIAL_PORT,L)
  63. #define M_RXCx SERIAL_REGNAME(RXC,SERIAL_PORT,)
  64. #define M_USARTx_RX_vect SERIAL_REGNAME(USART,SERIAL_PORT,_RX_vect)
  65. #define M_U2Xx SERIAL_REGNAME(U2X,SERIAL_PORT,)
  66. #define M_USARTx_UDRE_vect SERIAL_REGNAME(USART,SERIAL_PORT,_UDRE_vect)
  67. #define DEC 10
  68. #define HEX 16
  69. #define OCT 8
  70. #define BIN 2
  71. #define BYTE 0
  72. // Define constants and variables for buffering serial data.
  73. // Use only 0 or powers of 2 greater than 1
  74. // : [0, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, ...]
  75. #ifndef RX_BUFFER_SIZE
  76. #define RX_BUFFER_SIZE 128
  77. #endif
  78. // 256 is the max TX buffer limit due to uint8_t head and tail.
  79. #ifndef TX_BUFFER_SIZE
  80. #define TX_BUFFER_SIZE 32
  81. #endif
  82. #if USE_MARLINSERIAL
  83. #if RX_BUFFER_SIZE > 256
  84. typedef uint16_t ring_buffer_pos_t;
  85. #else
  86. typedef uint8_t ring_buffer_pos_t;
  87. #endif
  88. #if ENABLED(SERIAL_STATS_DROPPED_RX)
  89. extern uint8_t rx_dropped_bytes;
  90. #endif
  91. #if ENABLED(SERIAL_STATS_RX_BUFFER_OVERRUNS)
  92. extern uint8_t rx_buffer_overruns;
  93. #endif
  94. #if ENABLED(SERIAL_STATS_RX_FRAMING_ERRORS)
  95. extern uint8_t rx_framing_errors;
  96. #endif
  97. #if ENABLED(SERIAL_STATS_MAX_RX_QUEUED)
  98. extern ring_buffer_pos_t rx_max_enqueued;
  99. #endif
  100. class MarlinSerial {
  101. public:
  102. MarlinSerial() {};
  103. static void begin(const long);
  104. static void end();
  105. static int peek(void);
  106. static int read(void);
  107. static void flush(void);
  108. static ring_buffer_pos_t available(void);
  109. static void write(const uint8_t c);
  110. static void flushTX(void);
  111. #if ENABLED(SERIAL_STATS_DROPPED_RX)
  112. FORCE_INLINE static uint32_t dropped() { return rx_dropped_bytes; }
  113. #endif
  114. #if ENABLED(SERIAL_STATS_RX_BUFFER_OVERRUNS)
  115. FORCE_INLINE static uint32_t buffer_overruns() { return rx_buffer_overruns; }
  116. #endif
  117. #if ENABLED(SERIAL_STATS_RX_FRAMING_ERRORS)
  118. FORCE_INLINE static uint32_t framing_errors() { return rx_framing_errors; }
  119. #endif
  120. #if ENABLED(SERIAL_STATS_MAX_RX_QUEUED)
  121. FORCE_INLINE static ring_buffer_pos_t rxMaxEnqueued() { return rx_max_enqueued; }
  122. #endif
  123. FORCE_INLINE static void write(const char* str) { while (*str) write(*str++); }
  124. FORCE_INLINE static void write(const uint8_t* buffer, size_t size) { while (size--) write(*buffer++); }
  125. FORCE_INLINE static void print(const String& s) { for (int i = 0; i < (int)s.length(); i++) write(s[i]); }
  126. FORCE_INLINE static void print(const char* str) { write(str); }
  127. static void print(char, int = BYTE);
  128. static void print(unsigned char, int = BYTE);
  129. static void print(int, int = DEC);
  130. static void print(unsigned int, int = DEC);
  131. static void print(long, int = DEC);
  132. static void print(unsigned long, int = DEC);
  133. static void print(double, int = 2);
  134. static void println(const String& s);
  135. static void println(const char[]);
  136. static void println(char, int = BYTE);
  137. static void println(unsigned char, int = BYTE);
  138. static void println(int, int = DEC);
  139. static void println(unsigned int, int = DEC);
  140. static void println(long, int = DEC);
  141. static void println(unsigned long, int = DEC);
  142. static void println(double, int = 2);
  143. static void println(void);
  144. operator bool() { return true; }
  145. private:
  146. static void printNumber(unsigned long, const uint8_t);
  147. static void printFloat(double, uint8_t);
  148. };
  149. extern MarlinSerial customizedSerial;
  150. #endif // USE_MARLINSERIAL
  151. // Use the UART for Bluetooth in AT90USB configurations
  152. #if !USE_MARLINSERIAL && ENABLED(BLUETOOTH)
  153. extern HardwareSerial bluetoothSerial;
  154. #endif
  155. #endif // _MARLINSERIAL_H_