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

MarlinSerial.h 6.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  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. HardwareSerial.h - Hardware serial library for Wiring
  24. Copyright (c) 2006 Nicholas Zambetti. All right reserved.
  25. Modified 28 September 2010 by Mark Sproul
  26. */
  27. #ifndef MarlinSerial_h
  28. #define MarlinSerial_h
  29. #include "Marlin.h"
  30. #ifndef CRITICAL_SECTION_START
  31. #define CRITICAL_SECTION_START unsigned char _sreg = SREG; cli();
  32. #define CRITICAL_SECTION_END SREG = _sreg;
  33. #endif
  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 (these are expanded
  50. // depending on selected serial port
  51. #define M_UCSRxA SERIAL_REGNAME(UCSR,SERIAL_PORT,A) // defines M_UCSRxA to be UCSRnA where n is the serial port number
  52. #define M_UCSRxB SERIAL_REGNAME(UCSR,SERIAL_PORT,B)
  53. #define M_RXENx SERIAL_REGNAME(RXEN,SERIAL_PORT,)
  54. #define M_TXENx SERIAL_REGNAME(TXEN,SERIAL_PORT,)
  55. #define M_RXCIEx SERIAL_REGNAME(RXCIE,SERIAL_PORT,)
  56. #define M_UDREx SERIAL_REGNAME(UDRE,SERIAL_PORT,)
  57. #define M_UDRx SERIAL_REGNAME(UDR,SERIAL_PORT,)
  58. #define M_UBRRxH SERIAL_REGNAME(UBRR,SERIAL_PORT,H)
  59. #define M_UBRRxL SERIAL_REGNAME(UBRR,SERIAL_PORT,L)
  60. #define M_RXCx SERIAL_REGNAME(RXC,SERIAL_PORT,)
  61. #define M_USARTx_RX_vect SERIAL_REGNAME(USART,SERIAL_PORT,_RX_vect)
  62. #define M_U2Xx SERIAL_REGNAME(U2X,SERIAL_PORT,)
  63. #define DEC 10
  64. #define HEX 16
  65. #define OCT 8
  66. #define BIN 2
  67. #define BYTE 0
  68. #ifndef USBCON
  69. // Define constants and variables for buffering incoming serial data. We're
  70. // using a ring buffer (I think), in which rx_buffer_head is the index of the
  71. // location to which to write the next incoming character and rx_buffer_tail
  72. // is the index of the location from which to read.
  73. // 256 is the max limit due to uint8_t head and tail. Use only powers of 2. (...,16,32,64,128,256)
  74. #ifndef RX_BUFFER_SIZE
  75. #define RX_BUFFER_SIZE 128
  76. #endif
  77. #if !((RX_BUFFER_SIZE == 256) ||(RX_BUFFER_SIZE == 128) ||(RX_BUFFER_SIZE == 64) ||(RX_BUFFER_SIZE == 32) ||(RX_BUFFER_SIZE == 16) ||(RX_BUFFER_SIZE == 8) ||(RX_BUFFER_SIZE == 4) ||(RX_BUFFER_SIZE == 2))
  78. #error "RX_BUFFER_SIZE has to be a power of 2 and >= 2"
  79. #endif
  80. struct ring_buffer {
  81. unsigned char buffer[RX_BUFFER_SIZE];
  82. volatile uint8_t head;
  83. volatile uint8_t tail;
  84. };
  85. #if UART_PRESENT(SERIAL_PORT)
  86. extern ring_buffer rx_buffer;
  87. #endif
  88. #if ENABLED(EMERGENCY_PARSER)
  89. #include "language.h"
  90. void emergency_parser(unsigned char c);
  91. #endif
  92. class MarlinSerial { //: public Stream
  93. public:
  94. MarlinSerial();
  95. void begin(long);
  96. void end();
  97. int peek(void);
  98. int read(void);
  99. void flush(void);
  100. FORCE_INLINE uint8_t available(void) {
  101. CRITICAL_SECTION_START;
  102. uint8_t h = rx_buffer.head;
  103. uint8_t t = rx_buffer.tail;
  104. CRITICAL_SECTION_END;
  105. return (uint8_t)(RX_BUFFER_SIZE + h - t) & (RX_BUFFER_SIZE - 1);
  106. }
  107. FORCE_INLINE void write(uint8_t c) {
  108. while (!TEST(M_UCSRxA, M_UDREx))
  109. ;
  110. M_UDRx = c;
  111. }
  112. FORCE_INLINE void checkRx(void) {
  113. if (TEST(M_UCSRxA, M_RXCx)) {
  114. unsigned char c = M_UDRx;
  115. CRITICAL_SECTION_START;
  116. uint8_t h = rx_buffer.head;
  117. uint8_t i = (uint8_t)(h + 1) & (RX_BUFFER_SIZE - 1);
  118. // if we should be storing the received character into the location
  119. // just before the tail (meaning that the head would advance to the
  120. // current location of the tail), we're about to overflow the buffer
  121. // and so we don't write the character or advance the head.
  122. if (i != rx_buffer.tail) {
  123. rx_buffer.buffer[h] = c;
  124. rx_buffer.head = i;
  125. }
  126. CRITICAL_SECTION_END;
  127. #if ENABLED(EMERGENCY_PARSER)
  128. emergency_parser(c);
  129. #endif
  130. }
  131. }
  132. private:
  133. void printNumber(unsigned long, uint8_t);
  134. void printFloat(double, uint8_t);
  135. public:
  136. FORCE_INLINE void write(const char* str) { while (*str) write(*str++); }
  137. FORCE_INLINE void write(const uint8_t* buffer, size_t size) { while (size--) write(*buffer++); }
  138. FORCE_INLINE void print(const String& s) { for (int i = 0; i < (int)s.length(); i++) write(s[i]); }
  139. FORCE_INLINE void print(const char* str) { write(str); }
  140. void print(char, int = BYTE);
  141. void print(unsigned char, int = BYTE);
  142. void print(int, int = DEC);
  143. void print(unsigned int, int = DEC);
  144. void print(long, int = DEC);
  145. void print(unsigned long, int = DEC);
  146. void print(double, int = 2);
  147. void println(const String& s);
  148. void println(const char[]);
  149. void println(char, int = BYTE);
  150. void println(unsigned char, int = BYTE);
  151. void println(int, int = DEC);
  152. void println(unsigned int, int = DEC);
  153. void println(long, int = DEC);
  154. void println(unsigned long, int = DEC);
  155. void println(double, int = 2);
  156. void println(void);
  157. };
  158. extern MarlinSerial customizedSerial;
  159. #endif // !USBCON
  160. // Use the UART for Bluetooth in AT90USB configurations
  161. #if defined(USBCON) && ENABLED(BLUETOOTH)
  162. extern HardwareSerial bluetoothSerial;
  163. #endif
  164. #endif