|
@ -396,12 +396,16 @@ bool axis_relative_modes[] = AXIS_RELATIVE_MODES, |
|
|
float filament_size[EXTRUDERS] = ARRAY_BY_EXTRUDERS1(DEFAULT_NOMINAL_FILAMENT_DIA), |
|
|
float filament_size[EXTRUDERS] = ARRAY_BY_EXTRUDERS1(DEFAULT_NOMINAL_FILAMENT_DIA), |
|
|
volumetric_multiplier[EXTRUDERS] = ARRAY_BY_EXTRUDERS1(1.0); |
|
|
volumetric_multiplier[EXTRUDERS] = ARRAY_BY_EXTRUDERS1(1.0); |
|
|
|
|
|
|
|
|
// The distance that XYZ has been offset by G92. Reset by G28.
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
float position_shift[XYZ] = { 0 }; |
|
|
|
|
|
|
|
|
|
|
|
// This offset is added to the configured home position.
|
|
|
// The distance that XYZ has been offset by G92. Reset by G28.
|
|
|
// Set by M206, M428, or menu item. Saved to EEPROM.
|
|
|
float position_shift[XYZ] = { 0 }; |
|
|
float home_offset[XYZ] = { 0 }; |
|
|
|
|
|
|
|
|
// This offset is added to the configured home position.
|
|
|
|
|
|
// Set by M206, M428, or menu item. Saved to EEPROM.
|
|
|
|
|
|
float home_offset[XYZ] = { 0 }; |
|
|
|
|
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
// Software Endstops are based on the configured limits.
|
|
|
// Software Endstops are based on the configured limits.
|
|
|
#if ENABLED(min_software_endstops) || ENABLED(max_software_endstops) |
|
|
#if ENABLED(min_software_endstops) || ENABLED(max_software_endstops) |
|
@ -1333,7 +1337,9 @@ bool get_target_extruder_from_command(int code) { |
|
|
|
|
|
|
|
|
#endif // DUAL_X_CARRIAGE
|
|
|
#endif // DUAL_X_CARRIAGE
|
|
|
|
|
|
|
|
|
/**
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) || ENABLED(DUAL_X_CARRIAGE) || ENABLED(DELTA) |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
* Software endstops can be used to monitor the open end of |
|
|
* Software endstops can be used to monitor the open end of |
|
|
* an axis that has a hardware endstop on the other end. Or |
|
|
* an axis that has a hardware endstop on the other end. Or |
|
|
* they can prevent axes from moving past endstops and grinding. |
|
|
* they can prevent axes from moving past endstops and grinding. |
|
@ -1342,8 +1348,8 @@ bool get_target_extruder_from_command(int code) { |
|
|
* the software endstop positions must be refreshed to remain |
|
|
* the software endstop positions must be refreshed to remain |
|
|
* at the same positions relative to the machine. |
|
|
* at the same positions relative to the machine. |
|
|
*/ |
|
|
*/ |
|
|
void update_software_endstops(AxisEnum axis) { |
|
|
void update_software_endstops(const AxisEnum axis) { |
|
|
float offs = LOGICAL_POSITION(0, axis); |
|
|
const float offs = LOGICAL_POSITION(0, axis); |
|
|
|
|
|
|
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
if (axis == X_AXIS) { |
|
|
if (axis == X_AXIS) { |
|
@ -1376,8 +1382,10 @@ void update_software_endstops(AxisEnum axis) { |
|
|
#if ENABLED(DEBUG_LEVELING_FEATURE) |
|
|
#if ENABLED(DEBUG_LEVELING_FEATURE) |
|
|
if (DEBUGGING(LEVELING)) { |
|
|
if (DEBUGGING(LEVELING)) { |
|
|
SERIAL_ECHOPAIR("For ", axis_codes[axis]); |
|
|
SERIAL_ECHOPAIR("For ", axis_codes[axis]); |
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
SERIAL_ECHOPAIR(" axis:\n home_offset = ", home_offset[axis]); |
|
|
SERIAL_ECHOPAIR(" axis:\n home_offset = ", home_offset[axis]); |
|
|
SERIAL_ECHOPAIR("\n position_shift = ", position_shift[axis]); |
|
|
SERIAL_ECHOPAIR("\n position_shift = ", position_shift[axis]); |
|
|
|
|
|
#endif |
|
|
SERIAL_ECHOPAIR("\n soft_endstop_min = ", soft_endstop_min[axis]); |
|
|
SERIAL_ECHOPAIR("\n soft_endstop_min = ", soft_endstop_min[axis]); |
|
|
SERIAL_ECHOLNPAIR("\n soft_endstop_max = ", soft_endstop_max[axis]); |
|
|
SERIAL_ECHOLNPAIR("\n soft_endstop_max = ", soft_endstop_max[axis]); |
|
|
} |
|
|
} |
|
@ -1387,10 +1395,12 @@ void update_software_endstops(AxisEnum axis) { |
|
|
if (axis == Z_AXIS) |
|
|
if (axis == Z_AXIS) |
|
|
delta_clip_start_height = soft_endstop_max[axis] - delta_safe_distance_from_top(); |
|
|
delta_clip_start_height = soft_endstop_max[axis] - delta_safe_distance_from_top(); |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
} |
|
|
#endif // NO_WORKSPACE_OFFSETS
|
|
|
|
|
|
|
|
|
/**
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
|
|
|
/**
|
|
|
* Change the home offset for an axis, update the current |
|
|
* Change the home offset for an axis, update the current |
|
|
* position and the software endstops to retain the same |
|
|
* position and the software endstops to retain the same |
|
|
* relative distance to the new home. |
|
|
* relative distance to the new home. |
|
@ -1398,11 +1408,12 @@ void update_software_endstops(AxisEnum axis) { |
|
|
* Since this changes the current_position, code should |
|
|
* Since this changes the current_position, code should |
|
|
* call sync_plan_position soon after this. |
|
|
* call sync_plan_position soon after this. |
|
|
*/ |
|
|
*/ |
|
|
static void set_home_offset(AxisEnum axis, float v) { |
|
|
static void set_home_offset(AxisEnum axis, float v) { |
|
|
current_position[axis] += v - home_offset[axis]; |
|
|
current_position[axis] += v - home_offset[axis]; |
|
|
home_offset[axis] = v; |
|
|
home_offset[axis] = v; |
|
|
update_software_endstops(axis); |
|
|
update_software_endstops(axis); |
|
|
} |
|
|
} |
|
|
|
|
|
#endif // NO_WORKSPACE_OFFSETS
|
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
|
* Set an axis' current position to its home position (after homing). |
|
|
* Set an axis' current position to its home position (after homing). |
|
@ -1433,8 +1444,10 @@ static void set_axis_is_at_home(AxisEnum axis) { |
|
|
|
|
|
|
|
|
axis_known_position[axis] = axis_homed[axis] = true; |
|
|
axis_known_position[axis] = axis_homed[axis] = true; |
|
|
|
|
|
|
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
position_shift[axis] = 0; |
|
|
position_shift[axis] = 0; |
|
|
update_software_endstops(axis); |
|
|
update_software_endstops(axis); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
if (axis == X_AXIS && (active_extruder == 1 || dual_x_carriage_mode == DXC_DUPLICATION_MODE)) { |
|
|
if (axis == X_AXIS && (active_extruder == 1 || dual_x_carriage_mode == DXC_DUPLICATION_MODE)) { |
|
@ -1507,8 +1520,10 @@ static void set_axis_is_at_home(AxisEnum axis) { |
|
|
|
|
|
|
|
|
#if ENABLED(DEBUG_LEVELING_FEATURE) |
|
|
#if ENABLED(DEBUG_LEVELING_FEATURE) |
|
|
if (DEBUGGING(LEVELING)) { |
|
|
if (DEBUGGING(LEVELING)) { |
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
SERIAL_ECHOPAIR("> home_offset[", axis_codes[axis]); |
|
|
SERIAL_ECHOPAIR("> home_offset[", axis_codes[axis]); |
|
|
SERIAL_ECHOLNPAIR("] = ", home_offset[axis]); |
|
|
SERIAL_ECHOLNPAIR("] = ", home_offset[axis]); |
|
|
|
|
|
#endif |
|
|
DEBUG_POS("", current_position); |
|
|
DEBUG_POS("", current_position); |
|
|
SERIAL_ECHOPAIR("<<< set_axis_is_at_home(", axis_codes[axis]); |
|
|
SERIAL_ECHOPAIR("<<< set_axis_is_at_home(", axis_codes[axis]); |
|
|
SERIAL_CHAR(')'); |
|
|
SERIAL_CHAR(')'); |
|
@ -4603,8 +4618,10 @@ inline void gcode_G92() { |
|
|
|
|
|
|
|
|
if (i != E_AXIS) { |
|
|
if (i != E_AXIS) { |
|
|
didXYZ = true; |
|
|
didXYZ = true; |
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
position_shift[i] += v - p; // Offset the coordinate space
|
|
|
position_shift[i] += v - p; // Offset the coordinate space
|
|
|
update_software_endstops((AxisEnum)i); |
|
|
update_software_endstops((AxisEnum)i); |
|
|
|
|
|
#endif |
|
|
} |
|
|
} |
|
|
#endif |
|
|
#endif |
|
|
} |
|
|
} |
|
@ -6334,10 +6351,12 @@ inline void gcode_M205() { |
|
|
if (code_seen('E')) planner.max_jerk[E_AXIS] = code_value_axis_units(E_AXIS); |
|
|
if (code_seen('E')) planner.max_jerk[E_AXIS] = code_value_axis_units(E_AXIS); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/**
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
* M206: Set Additional Homing Offset (X Y Z). SCARA aliases T=X, P=Y |
|
|
* M206: Set Additional Homing Offset (X Y Z). SCARA aliases T=X, P=Y |
|
|
*/ |
|
|
*/ |
|
|
inline void gcode_M206() { |
|
|
inline void gcode_M206() { |
|
|
LOOP_XYZ(i) |
|
|
LOOP_XYZ(i) |
|
|
if (code_seen(axis_codes[i])) |
|
|
if (code_seen(axis_codes[i])) |
|
|
set_home_offset((AxisEnum)i, code_value_axis_units(i)); |
|
|
set_home_offset((AxisEnum)i, code_value_axis_units(i)); |
|
@ -6349,7 +6368,9 @@ inline void gcode_M206() { |
|
|
|
|
|
|
|
|
SYNC_PLAN_POSITION_KINEMATIC(); |
|
|
SYNC_PLAN_POSITION_KINEMATIC(); |
|
|
report_current_position(); |
|
|
report_current_position(); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#endif // NO_WORKSPACE_OFFSETS
|
|
|
|
|
|
|
|
|
#if ENABLED(DELTA) |
|
|
#if ENABLED(DELTA) |
|
|
/**
|
|
|
/**
|
|
@ -7173,7 +7194,9 @@ void quickstop_stepper() { |
|
|
|
|
|
|
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|
/**
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
* M428: Set home_offset based on the distance between the |
|
|
* M428: Set home_offset based on the distance between the |
|
|
* current_position and the nearest "reference point." |
|
|
* current_position and the nearest "reference point." |
|
|
* If an axis is past center its endstop position |
|
|
* If an axis is past center its endstop position |
|
@ -7184,7 +7207,7 @@ void quickstop_stepper() { |
|
|
* |
|
|
* |
|
|
* Use M206 to set these values directly. |
|
|
* Use M206 to set these values directly. |
|
|
*/ |
|
|
*/ |
|
|
inline void gcode_M428() { |
|
|
inline void gcode_M428() { |
|
|
bool err = false; |
|
|
bool err = false; |
|
|
LOOP_XYZ(i) { |
|
|
LOOP_XYZ(i) { |
|
|
if (axis_homed[i]) { |
|
|
if (axis_homed[i]) { |
|
@ -7211,7 +7234,9 @@ inline void gcode_M428() { |
|
|
BUZZ(200, 659); |
|
|
BUZZ(200, 659); |
|
|
BUZZ(200, 698); |
|
|
BUZZ(200, 698); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#endif // NO_WORKSPACE_OFFSETS
|
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
|
* M500: Store settings in EEPROM |
|
|
* M500: Store settings in EEPROM |
|
@ -8081,10 +8106,14 @@ void tool_change(const uint8_t tmp_extruder, const float fr_mm_s/*=0.0*/, bool n |
|
|
// The newly-selected extruder XY is actually at...
|
|
|
// The newly-selected extruder XY is actually at...
|
|
|
current_position[X_AXIS] += xydiff[X_AXIS]; |
|
|
current_position[X_AXIS] += xydiff[X_AXIS]; |
|
|
current_position[Y_AXIS] += xydiff[Y_AXIS]; |
|
|
current_position[Y_AXIS] += xydiff[Y_AXIS]; |
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) || ENABLED(DUAL_X_CARRIAGE) |
|
|
for (uint8_t i = X_AXIS; i <= Y_AXIS; i++) { |
|
|
for (uint8_t i = X_AXIS; i <= Y_AXIS; i++) { |
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
position_shift[i] += xydiff[i]; |
|
|
position_shift[i] += xydiff[i]; |
|
|
|
|
|
#endif |
|
|
update_software_endstops((AxisEnum)i); |
|
|
update_software_endstops((AxisEnum)i); |
|
|
} |
|
|
} |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
// Set the new active extruder
|
|
|
// Set the new active extruder
|
|
|
active_extruder = tmp_extruder; |
|
|
active_extruder = tmp_extruder; |
|
@ -8639,9 +8668,12 @@ void process_next_command() { |
|
|
case 205: //M205: Set advanced settings
|
|
|
case 205: //M205: Set advanced settings
|
|
|
gcode_M205(); |
|
|
gcode_M205(); |
|
|
break; |
|
|
break; |
|
|
|
|
|
|
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
case 206: // M206: Set home offsets
|
|
|
case 206: // M206: Set home offsets
|
|
|
gcode_M206(); |
|
|
gcode_M206(); |
|
|
break; |
|
|
break; |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
#if ENABLED(DELTA) |
|
|
#if ENABLED(DELTA) |
|
|
case 665: // M665: Set delta configurations
|
|
|
case 665: // M665: Set delta configurations
|
|
@ -8805,9 +8837,11 @@ void process_next_command() { |
|
|
break; |
|
|
break; |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
case 428: // M428: Apply current_position to home_offset
|
|
|
case 428: // M428: Apply current_position to home_offset
|
|
|
gcode_M428(); |
|
|
gcode_M428(); |
|
|
break; |
|
|
break; |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
case 500: // M500: Store settings in EEPROM
|
|
|
case 500: // M500: Store settings in EEPROM
|
|
|
gcode_M500(); |
|
|
gcode_M500(); |
|
@ -10488,8 +10522,12 @@ void setup() { |
|
|
// This also updates variables in the planner, elsewhere
|
|
|
// This also updates variables in the planner, elsewhere
|
|
|
Config_RetrieveSettings(); |
|
|
Config_RetrieveSettings(); |
|
|
|
|
|
|
|
|
|
|
|
#if DISABLED(NO_WORKSPACE_OFFSETS) |
|
|
// Initialize current position based on home_offset
|
|
|
// Initialize current position based on home_offset
|
|
|
memcpy(current_position, home_offset, sizeof(home_offset)); |
|
|
memcpy(current_position, home_offset, sizeof(home_offset)); |
|
|
|
|
|
#else |
|
|
|
|
|
ZERO(current_position); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
// Vital to init stepper/planner equivalent for current_position
|
|
|
// Vital to init stepper/planner equivalent for current_position
|
|
|
SYNC_PLAN_POSITION_KINEMATIC(); |
|
|
SYNC_PLAN_POSITION_KINEMATIC(); |
|
|