My Marlin configs for Fabrikator Mini and CTC i3 Pro B
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.

MarlinSerial.h 6.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  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 "../../inc/MarlinConfigPre.h"
  33. #include <WString.h>
  34. #ifndef SERIAL_PORT
  35. #define SERIAL_PORT 0
  36. #endif
  37. // The presence of the UBRRH register is used to detect a UART.
  38. #define UART_PRESENT(port) ((port == 0 && (defined(UBRRH) || defined(UBRR0H))) || \
  39. (port == 1 && defined(UBRR1H)) || (port == 2 && defined(UBRR2H)) || \
  40. (port == 3 && defined(UBRR3H)))
  41. // These are macros to build serial port register names for the selected SERIAL_PORT (C preprocessor
  42. // requires two levels of indirection to expand macro values properly)
  43. #define SERIAL_REGNAME(registerbase,number,suffix) SERIAL_REGNAME_INTERNAL(registerbase,number,suffix)
  44. #if SERIAL_PORT == 0 && (!defined(UBRR0H) || !defined(UDR0)) // use un-numbered registers if necessary
  45. #define SERIAL_REGNAME_INTERNAL(registerbase,number,suffix) registerbase##suffix
  46. #else
  47. #define SERIAL_REGNAME_INTERNAL(registerbase,number,suffix) registerbase##number##suffix
  48. #endif
  49. // Registers used by MarlinSerial class (expanded depending on selected serial port)
  50. #define M_UCSRxA SERIAL_REGNAME(UCSR,SERIAL_PORT,A) // defines M_UCSRxA to be UCSRnA where n is the serial port number
  51. #define M_UCSRxB SERIAL_REGNAME(UCSR,SERIAL_PORT,B)
  52. #define M_RXENx SERIAL_REGNAME(RXEN,SERIAL_PORT,)
  53. #define M_TXENx SERIAL_REGNAME(TXEN,SERIAL_PORT,)
  54. #define M_TXCx SERIAL_REGNAME(TXC,SERIAL_PORT,)
  55. #define M_RXCIEx SERIAL_REGNAME(RXCIE,SERIAL_PORT,)
  56. #define M_UDREx SERIAL_REGNAME(UDRE,SERIAL_PORT,)
  57. #define M_FEx SERIAL_REGNAME(FE,SERIAL_PORT,)
  58. #define M_DORx SERIAL_REGNAME(DOR,SERIAL_PORT,)
  59. #define M_UPEx SERIAL_REGNAME(UPE,SERIAL_PORT,)
  60. #define M_UDRIEx SERIAL_REGNAME(UDRIE,SERIAL_PORT,)
  61. #define M_UDRx SERIAL_REGNAME(UDR,SERIAL_PORT,)
  62. #define M_UBRRxH SERIAL_REGNAME(UBRR,SERIAL_PORT,H)
  63. #define M_UBRRxL SERIAL_REGNAME(UBRR,SERIAL_PORT,L)
  64. #define M_RXCx SERIAL_REGNAME(RXC,SERIAL_PORT,)
  65. #define M_USARTx_RX_vect SERIAL_REGNAME(USART,SERIAL_PORT,_RX_vect)
  66. #define M_U2Xx SERIAL_REGNAME(U2X,SERIAL_PORT,)
  67. #define M_USARTx_UDRE_vect SERIAL_REGNAME(USART,SERIAL_PORT,_UDRE_vect)
  68. #define DEC 10
  69. #define HEX 16
  70. #define OCT 8
  71. #define BIN 2
  72. #define BYTE 0
  73. #ifndef USBCON
  74. // We're using a ring buffer (I think), in which rx_buffer_head is the index of the
  75. // location to which to write the next incoming character and rx_buffer_tail is the
  76. // index of the location from which to read.
  77. #if RX_BUFFER_SIZE > 256
  78. typedef uint16_t ring_buffer_pos_t;
  79. #else
  80. typedef uint8_t ring_buffer_pos_t;
  81. #endif
  82. #if ENABLED(SERIAL_STATS_DROPPED_RX)
  83. extern uint8_t rx_dropped_bytes;
  84. #endif
  85. #if ENABLED(SERIAL_STATS_RX_BUFFER_OVERRUNS)
  86. extern uint8_t rx_buffer_overruns;
  87. #endif
  88. #if ENABLED(SERIAL_STATS_RX_FRAMING_ERRORS)
  89. extern uint8_t rx_framing_errors;
  90. #endif
  91. #if ENABLED(SERIAL_STATS_MAX_RX_QUEUED)
  92. extern ring_buffer_pos_t rx_max_enqueued;
  93. #endif
  94. class MarlinSerial {
  95. public:
  96. MarlinSerial() {};
  97. static void begin(const long);
  98. static void end();
  99. static int peek(void);
  100. static int read(void);
  101. static void flush(void);
  102. static ring_buffer_pos_t available(void);
  103. static void write(const uint8_t c);
  104. static void flushTX(void);
  105. #if ENABLED(SERIAL_STATS_DROPPED_RX)
  106. FORCE_INLINE static uint32_t dropped() { return rx_dropped_bytes; }
  107. #endif
  108. #if ENABLED(SERIAL_STATS_RX_BUFFER_OVERRUNS)
  109. FORCE_INLINE static uint32_t buffer_overruns() { return rx_buffer_overruns; }
  110. #endif
  111. #if ENABLED(SERIAL_STATS_RX_FRAMING_ERRORS)
  112. FORCE_INLINE static uint32_t framing_errors() { return rx_framing_errors; }
  113. #endif
  114. #if ENABLED(SERIAL_STATS_MAX_RX_QUEUED)
  115. FORCE_INLINE static ring_buffer_pos_t rxMaxEnqueued() { return rx_max_enqueued; }
  116. #endif
  117. FORCE_INLINE static void write(const char* str) { while (*str) write(*str++); }
  118. FORCE_INLINE static void write(const uint8_t* buffer, size_t size) { while (size--) write(*buffer++); }
  119. FORCE_INLINE static void print(const String& s) { for (int i = 0; i < (int)s.length(); i++) write(s[i]); }
  120. FORCE_INLINE static void print(const char* str) { write(str); }
  121. static void print(char, int = BYTE);
  122. static void print(unsigned char, int = BYTE);
  123. static void print(int, int = DEC);
  124. static void print(unsigned int, int = DEC);
  125. static void print(long, int = DEC);
  126. static void print(unsigned long, int = DEC);
  127. static void print(double, int = 2);
  128. static void println(const String& s);
  129. static void println(const char[]);
  130. static void println(char, int = BYTE);
  131. static void println(unsigned char, int = BYTE);
  132. static void println(int, int = DEC);
  133. static void println(unsigned int, int = DEC);
  134. static void println(long, int = DEC);
  135. static void println(unsigned long, int = DEC);
  136. static void println(double, int = 2);
  137. static void println(void);
  138. operator bool() { return true; }
  139. private:
  140. static void printNumber(unsigned long, const uint8_t);
  141. static void printFloat(double, uint8_t);
  142. };
  143. extern MarlinSerial customizedSerial;
  144. #endif // !USBCON
  145. // Use the UART for Bluetooth in AT90USB configurations
  146. #if defined(USBCON) && ENABLED(BLUETOOTH)
  147. extern HardwareSerial bluetoothSerial;
  148. #endif
  149. #endif // _MARLINSERIAL_H_