|
|
@ -28,25 +28,93 @@ |
|
|
|
#include "../../../module/planner.h" |
|
|
|
#include "../../../module/stepper.h" |
|
|
|
|
|
|
|
#if ENABLED(EXTRA_LIN_ADVANCE_K) |
|
|
|
float saved_extruder_advance_K[EXTRUDERS]; |
|
|
|
uint8_t lin_adv_slot = 0; |
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* M900: Get or Set Linear Advance K-factor |
|
|
|
* |
|
|
|
* K<factor> Set advance K factor |
|
|
|
* T<tool> Which tool to address |
|
|
|
* K<factor> Set current advance K factor (Slot 0). |
|
|
|
* L<factor> Set secondary advance K factor (Slot 1). Requires EXTRA_LIN_ADVANCE_K. |
|
|
|
* S<0/1> Activate slot 0 or 1. Requires EXTRA_LIN_ADVANCE_K. |
|
|
|
*/ |
|
|
|
void GcodeSuite::M900() { |
|
|
|
|
|
|
|
#if EXTRUDERS < 2 |
|
|
|
constexpr uint8_t tmp_extruder = 0; |
|
|
|
#else |
|
|
|
const uint8_t tmp_extruder = parser.seenval('T') ? parser.value_int() : active_extruder; |
|
|
|
const uint8_t tmp_extruder = parser.intval('T', active_extruder); |
|
|
|
if (tmp_extruder >= EXTRUDERS) { |
|
|
|
SERIAL_ECHOLNPGM("?T value out of range."); |
|
|
|
return; |
|
|
|
} |
|
|
|
#endif |
|
|
|
|
|
|
|
#if ENABLED(EXTRA_LIN_ADVANCE_K) |
|
|
|
|
|
|
|
bool ext_slot = bitRead(lin_adv_slot, tmp_extruder); |
|
|
|
|
|
|
|
if (parser.seenval('S')) { |
|
|
|
const bool slot = parser.value_bool(); |
|
|
|
if (ext_slot != slot) { |
|
|
|
ext_slot = slot; |
|
|
|
bitWrite(lin_adv_slot, tmp_extruder, slot); |
|
|
|
planner.synchronize(); |
|
|
|
const float temp = planner.extruder_advance_K[tmp_extruder]; |
|
|
|
planner.extruder_advance_K[tmp_extruder] = saved_extruder_advance_K[tmp_extruder]; |
|
|
|
saved_extruder_advance_K[tmp_extruder] = temp; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (parser.seenval('K')) { |
|
|
|
const float newK = parser.floatval('K'); |
|
|
|
const float newK = parser.value_float(); |
|
|
|
if (WITHIN(newK, 0, 10)) { |
|
|
|
if (ext_slot) |
|
|
|
saved_extruder_advance_K[tmp_extruder] = newK; |
|
|
|
else { |
|
|
|
planner.synchronize(); |
|
|
|
planner.extruder_advance_K[tmp_extruder] = newK; |
|
|
|
} |
|
|
|
} |
|
|
|
else |
|
|
|
SERIAL_ECHOLNPGM("?K value out of range (0-10)."); |
|
|
|
} |
|
|
|
|
|
|
|
if (parser.seenval('L')) { |
|
|
|
const float newL = parser.value_float(); |
|
|
|
if (WITHIN(newL, 0, 10)) { |
|
|
|
if (!ext_slot) |
|
|
|
saved_extruder_advance_K[tmp_extruder] = newL; |
|
|
|
else { |
|
|
|
planner.synchronize(); |
|
|
|
planner.extruder_advance_K[tmp_extruder] = newL; |
|
|
|
} |
|
|
|
} |
|
|
|
else |
|
|
|
SERIAL_ECHOLNPGM("?L value out of range (0-10)."); |
|
|
|
} |
|
|
|
|
|
|
|
if (!parser.seen_any()) { |
|
|
|
#if EXTRUDERS < 2 |
|
|
|
SERIAL_ECHOLNPAIR("Advance S", ext_slot, " K", planner.extruder_advance_K[0]); |
|
|
|
SERIAL_ECHOLNPAIR("(Slot ", 1 - ext_slot, " K", saved_extruder_advance_K[0], ")"); |
|
|
|
#else |
|
|
|
LOOP_L_N(i, EXTRUDERS) { |
|
|
|
const int slot = (int)bitRead(lin_adv_slot, i); |
|
|
|
SERIAL_ECHOLNPAIR("Advance T", int(i), " S", slot, " K", planner.extruder_advance_K[i]); |
|
|
|
SERIAL_ECHOLNPAIR("(Slot ", 1 - slot, " K", saved_extruder_advance_K[i], ")"); |
|
|
|
SERIAL_EOL(); |
|
|
|
} |
|
|
|
#endif |
|
|
|
} |
|
|
|
|
|
|
|
#else |
|
|
|
|
|
|
|
if (parser.seenval('K')) { |
|
|
|
const float newK = parser.value_float(); |
|
|
|
if (WITHIN(newK, 0, 10)) { |
|
|
|
planner.synchronize(); |
|
|
|
planner.extruder_advance_K[tmp_extruder] = newK; |
|
|
@ -67,6 +135,8 @@ void GcodeSuite::M900() { |
|
|
|
SERIAL_EOL(); |
|
|
|
#endif |
|
|
|
} |
|
|
|
|
|
|
|
#endif |
|
|
|
} |
|
|
|
|
|
|
|
#endif // LIN_ADVANCE
|
|
|
|