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.

endstops.h 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  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. * endstops.h - manages endstops
  24. */
  25. #ifndef __ENDSTOPS_H__
  26. #define __ENDSTOPS_H__
  27. #include "../inc/MarlinConfig.h"
  28. #include <stdint.h>
  29. #define VALIDATE_HOMING_ENDSTOPS
  30. enum EndstopEnum : char {
  31. X_MIN,
  32. Y_MIN,
  33. Z_MIN,
  34. Z_MIN_PROBE,
  35. X_MAX,
  36. Y_MAX,
  37. Z_MAX,
  38. X2_MIN,
  39. X2_MAX,
  40. Y2_MIN,
  41. Y2_MAX,
  42. Z2_MIN,
  43. Z2_MAX,
  44. Z3_MIN,
  45. Z3_MAX
  46. };
  47. class Endstops {
  48. public:
  49. #if ENABLED(X_DUAL_ENDSTOPS) || ENABLED(Y_DUAL_ENDSTOPS) || Z_MULTI_ENDSTOPS
  50. typedef uint16_t esbits_t;
  51. #if ENABLED(X_DUAL_ENDSTOPS)
  52. static float x2_endstop_adj;
  53. #endif
  54. #if ENABLED(Y_DUAL_ENDSTOPS)
  55. static float y2_endstop_adj;
  56. #endif
  57. #if Z_MULTI_ENDSTOPS
  58. static float z2_endstop_adj;
  59. #endif
  60. #if ENABLED(Z_TRIPLE_ENDSTOPS)
  61. static float z3_endstop_adj;
  62. #endif
  63. #else
  64. typedef uint8_t esbits_t;
  65. #endif
  66. private:
  67. static bool enabled, enabled_globally;
  68. static esbits_t live_state;
  69. static volatile uint8_t hit_state; // Use X_MIN, Y_MIN, Z_MIN and Z_MIN_PROBE as BIT index
  70. #if ENABLED(ENDSTOP_NOISE_FILTER)
  71. static esbits_t validated_live_state;
  72. static uint8_t endstop_poll_count; // Countdown from threshold for polling
  73. #endif
  74. public:
  75. Endstops() {};
  76. /**
  77. * Initialize the endstop pins
  78. */
  79. static void init();
  80. /**
  81. * Are endstops or the probe set to abort the move?
  82. */
  83. FORCE_INLINE static bool abort_enabled() {
  84. return (enabled
  85. #if HAS_BED_PROBE
  86. || z_probe_enabled
  87. #endif
  88. );
  89. }
  90. /**
  91. * Periodic call to poll endstops if required. Called from temperature ISR
  92. */
  93. static void poll();
  94. /**
  95. * Update endstops bits from the pins. Apply filtering to get a verified state.
  96. * If abort_enabled() and moving towards a triggered switch, abort the current move.
  97. * Called from ISR contexts.
  98. */
  99. static void update();
  100. /**
  101. * Get Endstop hit state.
  102. */
  103. FORCE_INLINE static uint8_t trigger_state() { return hit_state; }
  104. /**
  105. * Get current endstops state
  106. */
  107. FORCE_INLINE static esbits_t state() {
  108. return
  109. #if ENABLED(ENDSTOP_NOISE_FILTER)
  110. validated_live_state
  111. #else
  112. live_state
  113. #endif
  114. ;
  115. }
  116. /**
  117. * Report endstop hits to serial. Called from loop().
  118. */
  119. static void event_handler();
  120. /**
  121. * Report endstop positions in response to M119
  122. */
  123. static void M119();
  124. // Enable / disable endstop checking globally
  125. static void enable_globally(const bool onoff=true);
  126. // Enable / disable endstop checking
  127. static void enable(const bool onoff=true);
  128. // Disable / Enable endstops based on ENSTOPS_ONLY_FOR_HOMING and global enable
  129. static void not_homing();
  130. #if ENABLED(VALIDATE_HOMING_ENDSTOPS)
  131. // If the last move failed to trigger an endstop, call kill
  132. static void validate_homing_move();
  133. #else
  134. FORCE_INLINE static void validate_homing_move() { hit_on_purpose(); }
  135. #endif
  136. // Clear endstops (i.e., they were hit intentionally) to suppress the report
  137. FORCE_INLINE static void hit_on_purpose() { hit_state = 0; }
  138. // Enable / disable endstop z-probe checking
  139. #if HAS_BED_PROBE
  140. static volatile bool z_probe_enabled;
  141. static void enable_z_probe(const bool onoff=true);
  142. #endif
  143. // Debugging of endstops
  144. #if ENABLED(PINS_DEBUGGING)
  145. static bool monitor_flag;
  146. static void monitor();
  147. static void run_monitor();
  148. #endif
  149. };
  150. extern Endstops endstops;
  151. #endif // __ENDSTOPS_H__