From d378575a68231651408ed814c6607dabb8ff4860 Mon Sep 17 00:00:00 2001 From: Robert Pelnar Date: Thu, 2 Aug 2018 17:07:09 +0200 Subject: [PATCH] SNMM_V2 - default retraction declared as variable --- Firmware/Marlin_main.cpp | 31 +++++++++++++------ Firmware/ultralcd.cpp | 4 +-- .../variants/1_75mm_MK2-RAMBo10a-E3Dv6full.h | 5 --- .../variants/1_75mm_MK2-RAMBo13a-E3Dv6full.h | 5 --- .../variants/1_75mm_MK25-RAMBo10a-E3Dv6full.h | 5 --- .../variants/1_75mm_MK25-RAMBo13a-E3Dv6full.h | 5 --- .../variants/1_75mm_MK3-EINSy10a-E3Dv6full.h | 5 --- .../1_75mm_MK3-MMU-EINSy10a-E3Dv6full.h | 5 --- 8 files changed, 23 insertions(+), 42 deletions(-) diff --git a/Firmware/Marlin_main.cpp b/Firmware/Marlin_main.cpp index 699368ec..3c61f592 100644 --- a/Firmware/Marlin_main.cpp +++ b/Firmware/Marlin_main.cpp @@ -297,6 +297,17 @@ byte b[2]; int value; }; +//used for PINDA temp calibration and pause print +#define DEFAULT_RETRACTION 1 +#define DEFAULT_RETRACTION_MM 4 //MM + +#ifdef SNMM_V2 +float default_retraction = DEFAULT_RETRACTION; +#else //SNMM_V2 +float default_retraction = DEFAULT_RETRACTION_MM; +#endif //SNMM_V2 + + float homing_feedrate[] = HOMING_FEEDRATE; // Currently only the extruder axis may be switched to a relative mode. // Other axes are always absolute or relative based on the common relative_mode flag. @@ -672,12 +683,12 @@ void crashdet_disable() void crashdet_stop_and_save_print() { - stop_and_save_print_to_ram(10, -DEFAULT_RETRACTION); //XY - no change, Z 10mm up, E -1mm retract + stop_and_save_print_to_ram(10, -default_retraction); //XY - no change, Z 10mm up, E -1mm retract } void crashdet_restore_print_and_continue() { - restore_print_from_ram_and_continue(DEFAULT_RETRACTION); //XYZ = orig, E +1mm unretract + restore_print_from_ram_and_continue(default_retraction); //XYZ = orig, E +1mm unretract // babystep_apply(); } @@ -4611,7 +4622,7 @@ if((eSoundMode==e_SOUND_MODE_LOUD)||(eSoundMode==e_SOUND_MODE_ONCE)) // SERIAL_ECHOLNPGM("Go home finished"); //unretract (after PINDA preheat retraction) if (degHotend(active_extruder) > EXTRUDE_MINTEMP && temp_cal_active == true && calibration_status_pinda() == true && target_temperature_bed >= 50) { - current_position[E_AXIS] += DEFAULT_RETRACTION; + current_position[E_AXIS] += default_retraction; plan_buffer_line(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS], 400, active_extruder); } KEEPALIVE_STATE(NOT_BUSY); @@ -7980,7 +7991,7 @@ void temp_compensation_start() { custom_message_state = PINDA_HEAT_T + 1; lcd_update(2); if (degHotend(active_extruder) > EXTRUDE_MINTEMP) { - current_position[E_AXIS] -= DEFAULT_RETRACTION; + current_position[E_AXIS] -= default_retraction; } plan_buffer_line(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS], 400, active_extruder); @@ -8119,7 +8130,7 @@ void long_pause() //long pause print pause_lastpos[E_AXIS] = current_position[E_AXIS]; //retract - current_position[E_AXIS] -= DEFAULT_RETRACTION; + current_position[E_AXIS] -= default_retraction; plan_buffer_line(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS], 400, active_extruder); //lift z @@ -8218,7 +8229,7 @@ void uvlo_() current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], - current_position[E_AXIS] - DEFAULT_RETRACTION, + current_position[E_AXIS] - default_retraction, 95, active_extruder); st_synchronize(); @@ -8228,7 +8239,7 @@ void uvlo_() current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS] + UVLO_Z_AXIS_SHIFT + float((1024 - z_microsteps + 7) >> 4) / axis_steps_per_unit[Z_AXIS], - current_position[E_AXIS] - DEFAULT_RETRACTION, + current_position[E_AXIS] - default_retraction, 40, active_extruder); st_synchronize(); @@ -8238,7 +8249,7 @@ void uvlo_() current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS] + UVLO_Z_AXIS_SHIFT + float((1024 - z_microsteps + 7) >> 4) / axis_steps_per_unit[Z_AXIS], - current_position[E_AXIS] - DEFAULT_RETRACTION, + current_position[E_AXIS] - default_retraction, 40, active_extruder); st_synchronize(); disable_e0(); @@ -8432,7 +8443,7 @@ void recover_print(uint8_t automatic) { if(automatic == 0){ enquecommand_P(PSTR("G1 E5 F120")); //Extrude some filament to stabilize pessure } - enquecommand_P(PSTR("G1 E" STRINGIFY(-DEFAULT_RETRACTION)" F480")); + enquecommand_P(PSTR("G1 E" STRINGIFY(-default_retraction)" F480")); printf_P(_N("After waiting for temp:\nCurrent pos X_AXIS:%.3f\nCurrent pos Y_AXIS:%.3f\n"), current_position[X_AXIS], current_position[Y_AXIS]); @@ -8570,7 +8581,7 @@ void restore_print_from_eeprom() { strcpy_P(cmd, PSTR("G1 Z")); strcat(cmd, ftostr32(eeprom_read_float((float*)(EEPROM_UVLO_CURRENT_POSITION_Z)))); enquecommand(cmd); // Unretract. - enquecommand_P(PSTR("G1 E" STRINGIFY(2*DEFAULT_RETRACTION)" F480")); + enquecommand_P(PSTR("G1 E" STRINGIFY(2*default_retraction)" F480")); // Set the feedrate saved at the power panic. sprintf_P(cmd, PSTR("G1 F%d"), feedrate_rec); enquecommand(cmd); diff --git a/Firmware/ultralcd.cpp b/Firmware/ultralcd.cpp index 4b20c9fb..0fc87184 100644 --- a/Firmware/ultralcd.cpp +++ b/Firmware/ultralcd.cpp @@ -1112,11 +1112,11 @@ void lcd_commands() if (axis_relative_modes[3] == false) { enquecommand_P(PSTR("M83")); // set extruder to relative mode - enquecommand_P(PSTR("G1 E" STRINGIFY(DEFAULT_RETRACTION))); //unretract + enquecommand_P(PSTR("G1 E" STRINGIFY(default_retraction))); //unretract enquecommand_P(PSTR("M82")); // set extruder to absolute mode } else { - enquecommand_P(PSTR("G1 E" STRINGIFY(DEFAULT_RETRACTION))); //unretract + enquecommand_P(PSTR("G1 E" STRINGIFY(default_retraction))); //unretract } lcd_commands_step = 1; diff --git a/Firmware/variants/1_75mm_MK2-RAMBo10a-E3Dv6full.h b/Firmware/variants/1_75mm_MK2-RAMBo10a-E3Dv6full.h index 6ca8b213..9783e9f6 100644 --- a/Firmware/variants/1_75mm_MK2-RAMBo10a-E3Dv6full.h +++ b/Firmware/variants/1_75mm_MK2-RAMBo10a-E3Dv6full.h @@ -414,11 +414,6 @@ THERMISTORS SETTINGS #define DEFAULT_PID_TEMP 210 -#ifdef SNMM -#define DEFAULT_RETRACTION 4 //used for PINDA temp calibration and pause print -#else -#define DEFAULT_RETRACTION 1 //used for PINDA temp calibration and pause print -#endif #define END_FILE_SECTION 20000 //number of bytes from end of file used for checking if file is complete diff --git a/Firmware/variants/1_75mm_MK2-RAMBo13a-E3Dv6full.h b/Firmware/variants/1_75mm_MK2-RAMBo13a-E3Dv6full.h index d6352ae5..3ac39750 100644 --- a/Firmware/variants/1_75mm_MK2-RAMBo13a-E3Dv6full.h +++ b/Firmware/variants/1_75mm_MK2-RAMBo13a-E3Dv6full.h @@ -414,11 +414,6 @@ THERMISTORS SETTINGS #define DEFAULT_PID_TEMP 210 -#ifdef SNMM -#define DEFAULT_RETRACTION 4 //used for PINDA temp calibration and pause print -#else -#define DEFAULT_RETRACTION 1 //used for PINDA temp calibration and pause print -#endif #define END_FILE_SECTION 20000 //number of bytes from end of file used for checking if file is complete diff --git a/Firmware/variants/1_75mm_MK25-RAMBo10a-E3Dv6full.h b/Firmware/variants/1_75mm_MK25-RAMBo10a-E3Dv6full.h index 309ad57a..304cde4b 100644 --- a/Firmware/variants/1_75mm_MK25-RAMBo10a-E3Dv6full.h +++ b/Firmware/variants/1_75mm_MK25-RAMBo10a-E3Dv6full.h @@ -476,11 +476,6 @@ #define MIN_PRINT_FAN_SPEED 75 -#ifdef SNMM -#define DEFAULT_RETRACTION 4 //used for PINDA temp calibration and pause print -#else -#define DEFAULT_RETRACTION 1 //used for PINDA temp calibration and pause print -#endif #define M600_TIMEOUT 600 //seconds diff --git a/Firmware/variants/1_75mm_MK25-RAMBo13a-E3Dv6full.h b/Firmware/variants/1_75mm_MK25-RAMBo13a-E3Dv6full.h index ad9d4a5b..9fccbfc2 100644 --- a/Firmware/variants/1_75mm_MK25-RAMBo13a-E3Dv6full.h +++ b/Firmware/variants/1_75mm_MK25-RAMBo13a-E3Dv6full.h @@ -477,11 +477,6 @@ #define MIN_PRINT_FAN_SPEED 75 -#ifdef SNMM -#define DEFAULT_RETRACTION 4 //used for PINDA temp calibration and pause print -#else -#define DEFAULT_RETRACTION 1 //used for PINDA temp calibration and pause print -#endif #define M600_TIMEOUT 600 //seconds diff --git a/Firmware/variants/1_75mm_MK3-EINSy10a-E3Dv6full.h b/Firmware/variants/1_75mm_MK3-EINSy10a-E3Dv6full.h index 06fe8cbd..dbce6a96 100644 --- a/Firmware/variants/1_75mm_MK3-EINSy10a-E3Dv6full.h +++ b/Firmware/variants/1_75mm_MK3-EINSy10a-E3Dv6full.h @@ -594,11 +594,6 @@ #define MIN_PRINT_FAN_SPEED 75 -#if defined (SNMM) || defined (SNMM_V2) -#define DEFAULT_RETRACTION 4 //used for PINDA temp calibration and pause print -#else -#define DEFAULT_RETRACTION 1 //used for PINDA temp calibration and pause print -#endif // How much shall the print head be lifted on power panic? // Ideally the Z axis will reach a zero phase of the stepper driver on power outage. To simplify this, diff --git a/Firmware/variants/1_75mm_MK3-MMU-EINSy10a-E3Dv6full.h b/Firmware/variants/1_75mm_MK3-MMU-EINSy10a-E3Dv6full.h index ed6d0c3d..d572c7b4 100644 --- a/Firmware/variants/1_75mm_MK3-MMU-EINSy10a-E3Dv6full.h +++ b/Firmware/variants/1_75mm_MK3-MMU-EINSy10a-E3Dv6full.h @@ -595,11 +595,6 @@ #define MIN_PRINT_FAN_SPEED 75 -#if defined (SNMM) || defined (SNMM_V2) -#define DEFAULT_RETRACTION 4 //used for PINDA temp calibration and pause print -#else -#define DEFAULT_RETRACTION 1 //used for PINDA temp calibration and pause print -#endif // How much shall the print head be lifted on power panic? // Ideally the Z axis will reach a zero phase of the stepper driver on power outage. To simplify this,