|
@@ -72,7 +72,7 @@
|
72
|
72
|
|
73
|
73
|
#if HAS_SERVOS
|
74
|
74
|
#include "servo.h"
|
75
|
|
-#endif
|
|
75
|
+#endif
|
76
|
76
|
|
77
|
77
|
#if HAS_BED_PROBE
|
78
|
78
|
#include "../module/probe.h"
|
|
@@ -181,9 +181,7 @@ typedef struct SettingsDataStruct {
|
181
|
181
|
//
|
182
|
182
|
// SERVO_ANGLES
|
183
|
183
|
//
|
184
|
|
- #if HAS_SERVOS
|
185
|
|
- uint8_t servo_angles[NUM_SERVOS][2];
|
186
|
|
- #endif
|
|
184
|
+ uint16_t servo_angles[MAX_SERVOS][2]; // M281 P L U
|
187
|
185
|
|
188
|
186
|
//
|
189
|
187
|
// DELTA / [XYZ]_DUAL_ENDSTOPS
|
|
@@ -543,10 +541,26 @@ void MarlinSettings::postprocess() {
|
543
|
541
|
EEPROM_WRITE(storage_slot);
|
544
|
542
|
#endif // AUTO_BED_LEVELING_UBL
|
545
|
543
|
|
546
|
|
- #if HAS_SERVOS
|
547
|
|
- EEPROM_WRITE(servo_angles);
|
|
544
|
+ #if !HAS_SERVOS || DISABLED(EDITABLE_SERVO_ANGLES)
|
|
545
|
+ #if ENABLED(SWITCHING_EXTRUDER)
|
|
546
|
+ constexpr uint16_t sesa[][2] = SWITCHING_EXTRUDER_SERVO_ANGLES;
|
|
547
|
+ #endif
|
|
548
|
+ constexpr uint16_t servo_angles[MAX_SERVOS][2] = {
|
|
549
|
+ #if ENABLED(SWITCHING_EXTRUDER)
|
|
550
|
+ [SWITCHING_EXTRUDER_SERVO_NR] = { sesa[0], sesa[1] }
|
|
551
|
+ #if EXTRUDERS > 3
|
|
552
|
+ , [SWITCHING_EXTRUDER_E23_SERVO_NR] = { sesa[2], sesa[3] }
|
|
553
|
+ #endif
|
|
554
|
+ #elif ENABLED(SWITCHING_NOZZLE)
|
|
555
|
+ [SWITCHING_NOZZLE_SERVO_NR] = SWITCHING_NOZZLE_SERVO_ANGLES
|
|
556
|
+ #elif defined(Z_SERVO_ANGLES) && defined(Z_PROBE_SERVO_NR)
|
|
557
|
+ [Z_PROBE_SERVO_NR] = Z_SERVO_ANGLES
|
|
558
|
+ #endif
|
|
559
|
+ };
|
548
|
560
|
#endif
|
549
|
561
|
|
|
562
|
+ EEPROM_WRITE(servo_angles);
|
|
563
|
+
|
550
|
564
|
// 11 floats for DELTA / [XYZ]_DUAL_ENDSTOPS
|
551
|
565
|
#if ENABLED(DELTA)
|
552
|
566
|
|
|
@@ -1153,10 +1167,10 @@ void MarlinSettings::postprocess() {
|
1153
|
1167
|
//
|
1154
|
1168
|
// SERVO_ANGLES
|
1155
|
1169
|
//
|
1156
|
|
- #if HAS_SERVOS
|
1157
|
|
- EEPROM_READ(servo_angles);
|
|
1170
|
+ #if !HAS_SERVOS || DISABLED(EDITABLE_SERVO_ANGLES)
|
|
1171
|
+ uint16_t servo_angles[MAX_SERVOS][2];
|
1158
|
1172
|
#endif
|
1159
|
|
-
|
|
1173
|
+ EEPROM_READ(servo_angles);
|
1160
|
1174
|
|
1161
|
1175
|
//
|
1162
|
1176
|
// DELTA Geometry or Dual Endstops offsets
|
|
@@ -1801,32 +1815,39 @@ void MarlinSettings::reset(PORTARG_SOLO) {
|
1801
|
1815
|
// Servo Angles
|
1802
|
1816
|
//
|
1803
|
1817
|
|
1804
|
|
- #if HAS_SERVOS
|
|
1818
|
+ #if HAS_SERVOS && ENABLED(EDITABLE_SERVO_ANGLES)
|
|
1819
|
+
|
1805
|
1820
|
#if ENABLED(SWITCHING_EXTRUDER)
|
|
1821
|
+
|
1806
|
1822
|
#if EXTRUDERS > 3
|
1807
|
1823
|
#define REQ_ANGLES 4
|
1808
|
1824
|
#else
|
1809
|
1825
|
#define REQ_ANGLES 2
|
1810
|
1826
|
#endif
|
1811
|
|
- const uint8_t extruder_angles[2] = SWITCHING_EXTRUDER_SERVO_ANGLES;
|
|
1827
|
+ constexpr uint16_t extruder_angles[] = SWITCHING_EXTRUDER_SERVO_ANGLES;
|
1812
|
1828
|
static_assert(COUNT(extruder_angles) == REQ_ANGLES, "SWITCHING_EXTRUDER_SERVO_ANGLES needs " STRINGIFY(REQ_ANGLES) " angles.");
|
1813
|
1829
|
servo_angles[SWITCHING_EXTRUDER_SERVO_NR][0] = extruder_angles[0];
|
1814
|
1830
|
servo_angles[SWITCHING_EXTRUDER_SERVO_NR][1] = extruder_angles[1];
|
1815
|
|
- #endif
|
|
1831
|
+ #if EXTRUDERS > 3
|
|
1832
|
+ servo_angles[SWITCHING_EXTRUDER_E23_SERVO_NR][0] = extruder_angles[2];
|
|
1833
|
+ servo_angles[SWITCHING_EXTRUDER_E23_SERVO_NR][1] = extruder_angles[3];
|
|
1834
|
+ #endif
|
1816
|
1835
|
|
1817
|
|
- #if ENABLED(SWITCHING_NOZZLE)
|
1818
|
|
- const uint8_t nozzel_angles[2] = SWITCHING_NOZZLE_SERVO_ANGLES;
|
1819
|
|
- servo_angles[SWITCHING_NOZZLE_SERVO_NR][0] = nozzel_angles[0];
|
1820
|
|
- servo_angles[SWITCHING_NOZZLE_SERVO_NR][1] = nozzel_angles[1];
|
1821
|
|
- #endif
|
|
1836
|
+ #elif ENABLED(SWITCHING_NOZZLE)
|
1822
|
1837
|
|
1823
|
|
- #if defined(Z_SERVO_ANGLES) && defined(Z_PROBE_SERVO_NR)
|
1824
|
|
- const uint8_t z_probe_angles[2] = Z_SERVO_ANGLES;
|
|
1838
|
+ constexpr uint16_t nozzle_angles[2] = SWITCHING_NOZZLE_SERVO_ANGLES;
|
|
1839
|
+ servo_angles[SWITCHING_NOZZLE_SERVO_NR][0] = nozzle_angles[0];
|
|
1840
|
+ servo_angles[SWITCHING_NOZZLE_SERVO_NR][1] = nozzle_angles[1];
|
|
1841
|
+
|
|
1842
|
+ #elif defined(Z_SERVO_ANGLES) && defined(Z_PROBE_SERVO_NR)
|
|
1843
|
+
|
|
1844
|
+ constexpr uint16_t z_probe_angles[2] = Z_SERVO_ANGLES;
|
1825
|
1845
|
servo_angles[Z_PROBE_SERVO_NR][0] = z_probe_angles[0];
|
1826
|
1846
|
servo_angles[Z_PROBE_SERVO_NR][1] = z_probe_angles[1];
|
|
1847
|
+
|
1827
|
1848
|
#endif
|
1828
|
1849
|
|
1829
|
|
- #endif
|
|
1850
|
+ #endif // HAS_SERVOS && EDITABLE_SERVO_ANGLES
|
1830
|
1851
|
|
1831
|
1852
|
#if ENABLED(DELTA)
|
1832
|
1853
|
const float adj[ABC] = DELTA_ENDSTOP_ADJ,
|
|
@@ -2306,19 +2327,34 @@ void MarlinSettings::reset(PORTARG_SOLO) {
|
2306
|
2327
|
|
2307
|
2328
|
#endif // HAS_LEVELING
|
2308
|
2329
|
|
2309
|
|
- #if HAS_SERVOS
|
|
2330
|
+ #if HAS_SERVOS && ENABLED(EDITABLE_SERVO_ANGLES)
|
|
2331
|
+
|
2310
|
2332
|
if (!forReplay) {
|
2311
|
2333
|
CONFIG_ECHO_START;
|
2312
|
2334
|
SERIAL_ECHOLNPGM_P(port, "Servo Angles:");
|
2313
|
2335
|
}
|
2314
|
2336
|
for (uint8_t i = 0; i < NUM_SERVOS; i++) {
|
2315
|
|
- CONFIG_ECHO_START;
|
2316
|
|
- SERIAL_ECHOPAIR_P(port, " M281 P", i);
|
2317
|
|
- SERIAL_ECHOPAIR_P(port, " L",servo_angles[i][0]);
|
2318
|
|
- SERIAL_ECHOPAIR_P(port, " U",servo_angles[i][1]);
|
2319
|
|
- SERIAL_EOL_P(port);
|
|
2337
|
+ switch (i) {
|
|
2338
|
+ #if ENABLED(SWITCHING_EXTRUDER)
|
|
2339
|
+ case SWITCHING_EXTRUDER_SERVO_NR:
|
|
2340
|
+ #if EXTRUDERS > 3
|
|
2341
|
+ case SWITCHING_EXTRUDER_E23_SERVO_NR:
|
|
2342
|
+ #endif
|
|
2343
|
+ #elif ENABLED(SWITCHING_NOZZLE)
|
|
2344
|
+ case SWITCHING_NOZZLE_SERVO_NR:
|
|
2345
|
+ #elif defined(Z_SERVO_ANGLES) && defined(Z_PROBE_SERVO_NR)
|
|
2346
|
+ case Z_PROBE_SERVO_NR:
|
|
2347
|
+ #endif
|
|
2348
|
+ CONFIG_ECHO_START;
|
|
2349
|
+ SERIAL_ECHOPAIR_P(port, " M281 P", int(i));
|
|
2350
|
+ SERIAL_ECHOPAIR_P(port, " L", servo_angles[i][0]);
|
|
2351
|
+ SERIAL_ECHOPAIR_P(port, " U", servo_angles[i][1]);
|
|
2352
|
+ SERIAL_EOL_P(port);
|
|
2353
|
+ default: break;
|
|
2354
|
+ }
|
2320
|
2355
|
}
|
2321
|
|
- #endif
|
|
2356
|
+
|
|
2357
|
+ #endif // HAS_SERVOS && EDITABLE_SERVO_ANGLES
|
2322
|
2358
|
|
2323
|
2359
|
#if ENABLED(DELTA)
|
2324
|
2360
|
|