Skip to content

Commit dafa2fe

Browse files
040medienLMBernardo
authored andcommitted
🚸 SPI endstops for X/Y Dual and Core (MarlinFirmware#25371)
1 parent a2cd000 commit dafa2fe

File tree

2 files changed

+33
-42
lines changed

2 files changed

+33
-42
lines changed

Marlin/src/module/endstops.cpp

+27-42
Original file line numberDiff line numberDiff line change
@@ -1330,75 +1330,54 @@ void Endstops::update() {
13301330
bool hit = false;
13311331
#if X_SPI_SENSORLESS
13321332
if (tmc_spi_homing.x && (stepperX.test_stall_status()
1333-
#if ANY(CORE_IS_XY, MARKFORGED_XY, MARKFORGED_YX) && Y_SPI_SENSORLESS
1333+
#if Y_SPI_SENSORLESS && ANY(CORE_IS_XY, MARKFORGED_XY, MARKFORGED_YX)
13341334
|| stepperY.test_stall_status()
1335-
#elif CORE_IS_XZ && Z_SPI_SENSORLESS
1335+
#elif Z_SPI_SENSORLESS && CORE_IS_XZ
13361336
|| stepperZ.test_stall_status()
13371337
#endif
1338-
)) {
1339-
SBI(live_state, X_ENDSTOP);
1340-
hit = true;
1341-
}
1338+
)) { SBI(live_state, X_ENDSTOP); hit = true; }
1339+
#if ENABLED(X_DUAL_ENDSTOPS)
1340+
if (tmc_spi_homing.x && stepperX2.test_stall_status()) { SBI(live_state, X2_ENDSTOP); hit = true; }
1341+
#endif
13421342
#endif
13431343
#if Y_SPI_SENSORLESS
13441344
if (tmc_spi_homing.y && (stepperY.test_stall_status()
1345-
#if ANY(CORE_IS_XY, MARKFORGED_XY, MARKFORGED_YX) && X_SPI_SENSORLESS
1345+
#if X_SPI_SENSORLESS && ANY(CORE_IS_XY, MARKFORGED_XY, MARKFORGED_YX)
13461346
|| stepperX.test_stall_status()
1347-
#elif CORE_IS_YZ && Z_SPI_SENSORLESS
1347+
#elif Z_SPI_SENSORLESS && CORE_IS_YZ
13481348
|| stepperZ.test_stall_status()
13491349
#endif
1350-
)) {
1351-
SBI(live_state, Y_ENDSTOP);
1352-
hit = true;
1353-
}
1350+
)) { SBI(live_state, Y_ENDSTOP); hit = true; }
1351+
#if ENABLED(Y_DUAL_ENDSTOPS)
1352+
if (tmc_spi_homing.y && stepperY2.test_stall_status()) { SBI(live_state, Y2_ENDSTOP); hit = true; }
1353+
#endif
13541354
#endif
13551355
#if Z_SPI_SENSORLESS
13561356
if (tmc_spi_homing.z && (stepperZ.test_stall_status()
1357-
#if CORE_IS_XZ && X_SPI_SENSORLESS
1357+
#if X_SPI_SENSORLESS && CORE_IS_XZ
13581358
|| stepperX.test_stall_status()
1359-
#elif CORE_IS_YZ && Y_SPI_SENSORLESS
1359+
#elif Y_SPI_SENSORLESS && CORE_IS_YZ
13601360
|| stepperY.test_stall_status()
13611361
#endif
1362-
)) {
1363-
SBI(live_state, Z_ENDSTOP);
1364-
hit = true;
1365-
}
1362+
)) { SBI(live_state, Z_ENDSTOP); hit = true; }
13661363
#endif
13671364
#if I_SPI_SENSORLESS
1368-
if (tmc_spi_homing.i && stepperI.test_stall_status()) {
1369-
SBI(live_state, I_ENDSTOP);
1370-
hit = true;
1371-
}
1365+
if (tmc_spi_homing.i && stepperI.test_stall_status()) { SBI(live_state, I_ENDSTOP); hit = true; }
13721366
#endif
13731367
#if J_SPI_SENSORLESS
1374-
if (tmc_spi_homing.j && stepperJ.test_stall_status()) {
1375-
SBI(live_state, J_ENDSTOP);
1376-
hit = true;
1377-
}
1368+
if (tmc_spi_homing.j && stepperJ.test_stall_status()) { SBI(live_state, J_ENDSTOP); hit = true; }
13781369
#endif
13791370
#if K_SPI_SENSORLESS
1380-
if (tmc_spi_homing.k && stepperK.test_stall_status()) {
1381-
SBI(live_state, K_ENDSTOP);
1382-
hit = true;
1383-
}
1371+
if (tmc_spi_homing.k && stepperK.test_stall_status()) { SBI(live_state, K_ENDSTOP); hit = true; }
13841372
#endif
13851373
#if U_SPI_SENSORLESS
1386-
if (tmc_spi_homing.u && stepperU.test_stall_status()) {
1387-
SBI(live_state, U_ENDSTOP);
1388-
hit = true;
1389-
}
1374+
if (tmc_spi_homing.u && stepperU.test_stall_status()) { SBI(live_state, U_ENDSTOP); hit = true; }
13901375
#endif
13911376
#if V_SPI_SENSORLESS
1392-
if (tmc_spi_homing.v && stepperV.test_stall_status()) {
1393-
SBI(live_state, V_ENDSTOP);
1394-
hit = true;
1395-
}
1377+
if (tmc_spi_homing.v && stepperV.test_stall_status()) { SBI(live_state, V_ENDSTOP); hit = true; }
13961378
#endif
13971379
#if W_SPI_SENSORLESS
1398-
if (tmc_spi_homing.w && stepperW.test_stall_status()) {
1399-
SBI(live_state, W_ENDSTOP);
1400-
hit = true;
1401-
}
1380+
if (tmc_spi_homing.w && stepperW.test_stall_status()) { SBI(live_state, W_ENDSTOP); hit = true; }
14021381
#endif
14031382

14041383
if (TERN0(ENDSTOP_INTERRUPTS_FEATURE, hit)) update();
@@ -1408,7 +1387,13 @@ void Endstops::update() {
14081387

14091388
void Endstops::clear_endstop_state() {
14101389
TERN_(X_SPI_SENSORLESS, CBI(live_state, X_ENDSTOP));
1390+
#if BOTH(X_SPI_SENSORLESS, X_DUAL_ENDSTOPS)
1391+
CBI(live_state, X2_ENDSTOP);
1392+
#endif
14111393
TERN_(Y_SPI_SENSORLESS, CBI(live_state, Y_ENDSTOP));
1394+
#if BOTH(Y_SPI_SENSORLESS, Y_DUAL_ENDSTOPS)
1395+
CBI(live_state, Y2_ENDSTOP);
1396+
#endif
14121397
TERN_(Z_SPI_SENSORLESS, CBI(live_state, Z_ENDSTOP));
14131398
TERN_(I_SPI_SENSORLESS, CBI(live_state, I_ENDSTOP));
14141399
TERN_(J_SPI_SENSORLESS, CBI(live_state, J_ENDSTOP));

Marlin/src/module/endstops.h

+6
Original file line numberDiff line numberDiff line change
@@ -85,9 +85,15 @@ enum EndstopEnum : char {
8585
// Endstops can be either MIN or MAX but not both
8686
#if HAS_X_MIN || HAS_X_MAX
8787
, X_ENDSTOP = TERN(X_HOME_TO_MAX, X_MAX, X_MIN)
88+
#if ENABLED(X_DUAL_ENDSTOPS)
89+
, X2_ENDSTOP = TERN(X_HOME_TO_MAX, X2_MAX, X2_MIN)
90+
#endif
8891
#endif
8992
#if HAS_Y_MIN || HAS_Y_MAX
9093
, Y_ENDSTOP = TERN(Y_HOME_TO_MAX, Y_MAX, Y_MIN)
94+
#if ENABLED(Y_DUAL_ENDSTOPS)
95+
, Y2_ENDSTOP = TERN(Y_HOME_TO_MAX, Y2_MAX, Y2_MIN)
96+
#endif
9197
#endif
9298
#if HAS_Z_MIN || HAS_Z_MAX || HOMING_Z_WITH_PROBE
9399
, Z_ENDSTOP = TERN(Z_HOME_TO_MAX, Z_MAX, TERN(HOMING_Z_WITH_PROBE, Z_MIN_PROBE, Z_MIN))

0 commit comments

Comments
 (0)