@ -211,72 +211,37 @@ bool axis_relative_modes[] = AXIS_RELATIVE_MODES;
 
			
		
	
		
		
			
				
					
					int  feedmultiply  =  100 ;  //100->1 200->2
 int  feedmultiply  =  100 ;  //100->1 200->2
  
			
		
	
		
		
			
				
					
					int  saved_feedmultiply ; int  saved_feedmultiply ;  
			
		
	
		
		
			
				
					
					int  extrudemultiply  =  100 ;  //100->1 200->2
 int  extrudemultiply  =  100 ;  //100->1 200->2
  
			
		
	
		
		
			
				
					
					int  extruder_multiply [ EXTRUDERS ]  =  {  100 int  extruder_multiply [ EXTRUDERS ]  =  ARRAY_BY_EXTRUDERS ( 100 ,  100 ,  100 ,  100 ) ;  
			
				
				
			
		
	
		
		
			
				
					
					  # if EXTRUDERS > 1 
 
			
		
	
		
		
			
				
					
					    ,  100 
 
			
		
	
		
		
			
				
					
					    # if EXTRUDERS > 2 
 
			
		
	
		
		
			
				
					
					      ,  100 
 
			
		
	
		
		
			
				
					
					      # if EXTRUDERS > 3 
 
			
		
	
		
		
			
				
					
					        ,  100 
 
			
		
	
		
		
			
				
					
					      # endif 
 
			
		
	
		
		
			
				
					
					    # endif 
 
			
		
	
		
		
			
				
					
					  # endif 
 
			
		
	
		
		
			
				
					
					} ;  
			
		
	
		
		
	
		
		
			
				
					
					bool  volumetric_enabled  =  false ; bool  volumetric_enabled  =  false ;  
			
		
	
		
		
			
				
					
					float  filament_size [ EXTRUDERS ]  =  {  DEFAULT_NOMINAL_FILAMENT_DIA float  filament_size [ EXTRUDERS ]  =  ARRAY_BY_EXTRUDERS ( DEFAULT_NOMINAL_FILAMENT_DIA ,  DEFAULT_NOMINAL_FILAMENT_DIA ,  DEFAULT_NOMINAL_FILAMENT_DIA ,  DEFAULT_NOMINAL_FILAMENT_DIA ) ;  
			
				
				
			
		
	
		
		
			
				
					
					  # if EXTRUDERS > 1 
float  volumetric_multiplier [ EXTRUDERS ]  =  ARRAY_BY_EXTRUDERS ( 1.0 ,  1.0 ,  1.0 ,  1.0 ) ;  
			
				
				
			
		
	
		
		
			
				
					
					      ,  DEFAULT_NOMINAL_FILAMENT_DIA 
float  current_position [ NUM_AXIS ]  =  {  0.0  } ;  
			
				
				
			
		
	
		
		
			
				
					
					    # if EXTRUDERS > 2 
float  home_offset [ 3 ]  =  {  0  } ;  
			
				
				
			
		
	
		
		
			
				
					
					       ,  DEFAULT_NOMINAL_FILAMENT_DIA 
 
			
		
	
		
		
			
				
					
					      # if EXTRUDERS > 3 
 
			
		
	
		
		
			
				
					
					        ,  DEFAULT_NOMINAL_FILAMENT_DIA 
 
			
		
	
		
		
			
				
					
					      # endif 
 
			
		
	
		
		
			
				
					
					    # endif 
 
			
		
	
		
		
			
				
					
					  # endif 
 
			
		
	
		
		
			
				
					
					} ;  
			
		
	
		
		
			
				
					
					float  volumetric_multiplier [ EXTRUDERS ]  =  { 1.0  
			
		
	
		
		
			
				
					
					  # if EXTRUDERS > 1 
 
			
		
	
		
		
			
				
					
					    ,  1.0 
 
			
		
	
		
		
			
				
					
					    # if EXTRUDERS > 2 
 
			
		
	
		
		
			
				
					
					      ,  1.0 
 
			
		
	
		
		
			
				
					
					      # if EXTRUDERS > 3 
 
			
		
	
		
		
			
				
					
					        ,  1.0 
 
			
		
	
		
		
			
				
					
					      # endif 
 
			
		
	
		
		
			
				
					
					    # endif 
 
			
		
	
		
		
			
				
					
					  # endif 
 
			
		
	
		
		
			
				
					
					} ;  
			
		
	
		
		
			
				
					
					float  current_position [ NUM_AXIS ]  =  {  0.0 ,  0.0 ,  0.0 ,  0.0  } ;  
			
		
	
		
		
			
				
					
					float  home_offset [ 3 ]  =  {  0 ,  0 ,  0  } ;  
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					# ifdef DELTA # ifdef DELTA  
			
		
	
		
		
			
				
					
					  float  endstop_adj [ 3 ]  =  {  0 ,  0 ,  0 } ; 
  float  endstop_adj [ 3 ]  =  {  0  } ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					# elif defined(Z_DUAL_ENDSTOPS) # elif defined(Z_DUAL_ENDSTOPS)  
			
		
	
		
		
			
				
					
					  float  z_endstop_adj  =  0 ; 
  float  z_endstop_adj  =  0 ; 
 
			
		
	
		
		
			
				
					
					# endif # endif  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					float  min_pos [ 3 ]  =  {  X_MIN_POS ,  Y_MIN_POS ,  Z_MIN_POS  } ; float  min_pos [ 3 ]  =  {  X_MIN_POS ,  Y_MIN_POS ,  Z_MIN_POS  } ;  
			
		
	
		
		
			
				
					
					float  max_pos [ 3 ]  =  {  X_MAX_POS ,  Y_MAX_POS ,  Z_MAX_POS  } ; float  max_pos [ 3 ]  =  {  X_MAX_POS ,  Y_MAX_POS ,  Z_MAX_POS  } ;  
			
		
	
		
		
			
				
					
					bool  axis_known_position [ 3 ]  =  {  false ,  false ,  false } ; bool  axis_known_position [ 3 ]  =  {  false  } ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					// Extruder offset
 // Extruder offset
  
			
		
	
		
		
			
				
					
					# if EXTRUDERS > 1 # if EXTRUDERS > 1  
			
		
	
		
		
			
				
					
					# ifndef DUAL_X_CARRIAGE   # ifndef EXTRUDER_OFFSET_X 
 
			
				
				
			
		
	
		
		
			
				
					
					  # define NUM_EXTRUDER_OFFSETS 2  // only in XY plane
 
    # define EXTRUDER_OFFSET_X 0 
 
			
				
				
			
		
	
		
		
			
				
					
					# else   # endif 
 
			
				
				
			
		
	
		
		
			
				
					
					  # define NUM_EXTRUDER_OFFSETS 3  // supports offsets in XYZ plane
 
  # ifndef EXTRUDER_OFFSET_Y 
 
			
				
				
			
		
	
		
		
			
				
					
					# endif     # define EXTRUDER_OFFSET_Y 0 
 
			
				
				
			
		
	
		
		
			
				
					
					float  extruder_offset [ NUM_EXTRUDER_OFFSETS ] [ EXTRUDERS ]  =  {  
			
		
	
		
		
			
				
					
					  # if defined(EXTRUDER_OFFSET_X) 
 
			
		
	
		
		
			
				
					
					    EXTRUDER_OFFSET_X 
 
			
		
	
		
		
			
				
					
					  # else 
 
			
		
	
		
		
			
				
					
					    0 
 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					  # endif 
  # endif 
 
			
		
	
		
		
			
				
					
					  , 
  # ifndef DUAL_X_CARRIAGE 
 
			
				
				
			
		
	
		
		
			
				
					
					  # if defined(EXTRUDER_OFFSET_Y) 
    # define NUM_EXTRUDER_OFFSETS 2  // only in XY plane
 
 
			
				
				
			
		
	
		
		
			
				
					
					    EXTRUDER_OFFSET_Y 
 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					  # else 
  # else 
 
			
		
	
		
		
			
				
					
					    0 
    # define NUM_EXTRUDER_OFFSETS 3  // supports offsets in XYZ plane
 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  # endif 
  # endif 
 
			
		
	
		
		
			
				
					
					} ;   # define _EXY { EXTRUDER_OFFSET_X, EXTRUDER_OFFSET_Y } 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  float  extruder_offset [ EXTRUDERS ] [ NUM_EXTRUDER_OFFSETS ]  =  ARRAY_BY_EXTRUDERS ( _EXY ,  _EXY ,  _EXY ,  _EXY ) ; 
 
			
		
	
		
		
			
				
					
					# endif # endif  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					uint8_t  active_extruder  =  0 ; uint8_t  active_extruder  =  0 ;  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -295,28 +260,8 @@ int fanSpeed = 0;
 
			
		
	
		
		
			
				
					
					# ifdef FWRETRACT # ifdef FWRETRACT  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  bool  autoretract_enabled  =  false ; 
  bool  autoretract_enabled  =  false ; 
 
			
		
	
		
		
			
				
					
					  bool  retracted [ EXTRUDERS ]  =  {  false 
  bool  retracted [ EXTRUDERS ]  =  {  false  } ; 
 
			
				
				
			
		
	
		
		
			
				
					
					    # if EXTRUDERS > 1 
  bool  retracted_swap [ EXTRUDERS ]  =  {  false  } ; 
 
			
				
				
			
		
	
		
		
			
				
					
					      ,  false 
 
			
		
	
		
		
			
				
					
					      # if EXTRUDERS > 2 
 
			
		
	
		
		
			
				
					
					        ,  false 
 
			
		
	
		
		
			
				
					
					        # if EXTRUDERS > 3 
 
			
		
	
		
		
			
				
					
					          ,  false 
 
			
		
	
		
		
			
				
					
					        # endif 
 
			
		
	
		
		
			
				
					
					      # endif 
 
			
		
	
		
		
			
				
					
					    # endif 
 
			
		
	
		
		
			
				
					
					  } ; 
 
			
		
	
		
		
			
				
					
					  bool  retracted_swap [ EXTRUDERS ]  =  {  false 
 
			
		
	
		
		
			
				
					
					    # if EXTRUDERS > 1 
 
			
		
	
		
		
			
				
					
					      ,  false 
 
			
		
	
		
		
			
				
					
					      # if EXTRUDERS > 2 
 
			
		
	
		
		
			
				
					
					        ,  false 
 
			
		
	
		
		
			
				
					
					        # if EXTRUDERS > 3 
 
			
		
	
		
		
			
				
					
					          ,  false 
 
			
		
	
		
		
			
				
					
					        # endif 
 
			
		
	
		
		
			
				
					
					      # endif 
 
			
		
	
		
		
			
				
					
					    # endif 
 
			
		
	
		
		
			
				
					
					  } ; 
 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  float  retract_length  =  RETRACT_LENGTH ; 
  float  retract_length  =  RETRACT_LENGTH ; 
 
			
		
	
		
		
			
				
					
					  float  retract_length_swap  =  RETRACT_LENGTH_SWAP ; 
  float  retract_length_swap  =  RETRACT_LENGTH_SWAP ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -385,9 +330,9 @@ const char errormagic[] PROGMEM = "Error:";
 
			
		
	
		
		
			
				
					
					const  char  echomagic [ ]  PROGMEM  =  " echo: " ; const  char  echomagic [ ]  PROGMEM  =  " echo: " ;  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					const  char  axis_codes [ NUM_AXIS ]  =  { ' X ' ,  ' Y ' ,  ' Z ' ,  ' E ' } ; const  char  axis_codes [ NUM_AXIS ]  =  { ' X ' ,  ' Y ' ,  ' Z ' ,  ' E ' } ;  
			
		
	
		
		
			
				
					
					static  float  destination [ NUM_AXIS ]  =  {  0 ,  0 ,  0 ,  0 } ; static  float  destination [ NUM_AXIS ]  =  {  0  } ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					static  float  offset [ 3 ]  =  {  0 ,  0 ,  0 } ; static  float  offset [ 3 ]  =  {  0  } ;  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# ifndef DELTA # ifndef DELTA  
			
		
	
		
		
			
				
					
					  static  bool  home_all_axis  =  true ; 
  static  bool  home_all_axis  =  true ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -993,7 +938,7 @@ XYZ_CONSTS_FROM_CONFIG(signed char, home_dir,  HOME_DIR);
 
			
		
	
		
		
			
				
					
					      // second X-carriage offset when homed - otherwise X2_HOME_POS is used.
 
      // second X-carriage offset when homed - otherwise X2_HOME_POS is used.
 
 
			
		
	
		
		
			
				
					
					      // This allow soft recalibration of the second extruder offset position without firmware reflash
 
      // This allow soft recalibration of the second extruder offset position without firmware reflash
 
 
			
		
	
		
		
			
				
					
					      // (through the M218 command).
 
      // (through the M218 command).
 
 
			
		
	
		
		
			
				
					
					      return  ( extruder_offset [ X_AXIS ] [ 1 ]  >  0 )  ?  extruder_offset [ X_AXIS ] [ 1 ]  :  X2_HOME_POS ; 
      return  ( extruder_offset [ 1 ] [ X_AXIS ]  >  0 )  ?  extruder_offset [ 1 ] [ X_AXIS ]  :  X2_HOME_POS ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  } 
  } 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  static  int  x_home_dir ( int  extruder )  { 
  static  int  x_home_dir ( int  extruder )  { 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1017,14 +962,14 @@ static void axis_is_at_home(int axis) {
 
			
		
	
		
		
			
				
					
					      if  ( active_extruder  ! =  0 )  { 
      if  ( active_extruder  ! =  0 )  { 
 
			
		
	
		
		
			
				
					
					        current_position [ X_AXIS ]  =  x_home_pos ( active_extruder ) ; 
        current_position [ X_AXIS ]  =  x_home_pos ( active_extruder ) ; 
 
			
		
	
		
		
			
				
					
					        min_pos [ X_AXIS ]  =  X2_MIN_POS ; 
        min_pos [ X_AXIS ]  =  X2_MIN_POS ; 
 
			
		
	
		
		
			
				
					
					        max_pos [ X_AXIS ]  =  max ( extruder_offset [ X_AXIS ] [ 1 ] ,  X2_MAX_POS ) ; 
        max_pos [ X_AXIS ]  =  max ( extruder_offset [ 1 ] [ X_AXIS ] ,  X2_MAX_POS ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        return ; 
        return ; 
 
			
		
	
		
		
			
				
					
					      } 
      } 
 
			
		
	
		
		
			
				
					
					      else  if  ( dual_x_carriage_mode  = =  DXC_DUPLICATION_MODE )  { 
      else  if  ( dual_x_carriage_mode  = =  DXC_DUPLICATION_MODE )  { 
 
			
		
	
		
		
			
				
					
					        current_position [ X_AXIS ]  =  base_home_pos ( X_AXIS )  +  home_offset [ X_AXIS ] ; 
        current_position [ X_AXIS ]  =  base_home_pos ( X_AXIS )  +  home_offset [ X_AXIS ] ; 
 
			
		
	
		
		
			
				
					
					        min_pos [ X_AXIS ]  =  base_min_pos ( X_AXIS )  +  home_offset [ X_AXIS ] ; 
        min_pos [ X_AXIS ]  =  base_min_pos ( X_AXIS )  +  home_offset [ X_AXIS ] ; 
 
			
		
	
		
		
			
				
					
					        max_pos [ X_AXIS ]  =  min ( base_max_pos ( X_AXIS )  +  home_offset [ X_AXIS ] , 
        max_pos [ X_AXIS ]  =  min ( base_max_pos ( X_AXIS )  +  home_offset [ X_AXIS ] , 
 
			
		
	
		
		
			
				
					
					                                max ( extruder_offset [ X_AXIS ] [ 1 ] ,  X2_MAX_POS )  -  duplicate_extruder_x_offset ) ; 
                                max ( extruder_offset [ 1 ] [ X_AXIS ] ,  X2_MAX_POS )  -  duplicate_extruder_x_offset ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        return ; 
        return ; 
 
			
		
	
		
		
			
				
					
					      } 
      } 
 
			
		
	
		
		
			
				
					
					    } 
    } 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1077,12 +1022,18 @@ static void axis_is_at_home(int axis) {
 
			
		
	
		
		
			
				
					
					  # endif 
  # endif 
 
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					/**
  
			
		
	
		
		
			
				
					
					 *  Shorthand  to  tell  the  planner  our  current  position  ( in  mm ) . 
 
			
		
	
		
		
			
				
					
					 */ 
 
			
		
	
		
		
			
				
					
					inline  void  sync_plan_position ( )  {  
			
		
	
		
		
			
				
					
					  plan_set_position ( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ] ) ; 
 
			
		
	
		
		
			
				
					
					}  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# ifdef ENABLE_AUTO_BED_LEVELING # ifdef ENABLE_AUTO_BED_LEVELING  
			
		
	
		
		
			
				
					
					# ifdef AUTO_BED_LEVELING_GRID # ifdef AUTO_BED_LEVELING_GRID  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# ifndef DELTA # ifndef DELTA  
			
		
	
		
		
			
				
					
					static  void  set_bed_level_equation_lsq ( double  * plane_equation_coefficients )   static  void  set_bed_level_equation_lsq ( double  * plane_equation_coefficients )  { 
 
			
				
				
			
		
	
		
		
			
				
					
					{  
			
		
	
		
		
	
		
		
			
				
					
					    vector_3  planeNormal  =  vector_3 ( - plane_equation_coefficients [ 0 ] ,  - plane_equation_coefficients [ 1 ] ,  1 ) ; 
    vector_3  planeNormal  =  vector_3 ( - plane_equation_coefficients [ 0 ] ,  - plane_equation_coefficients [ 1 ] ,  1 ) ; 
 
			
		
	
		
		
			
				
					
					    planeNormal . debug ( " planeNormal " ) ; 
    planeNormal . debug ( " planeNormal " ) ; 
 
			
		
	
		
		
			
				
					
					    plan_bed_level_matrix  =  matrix_3x3 : : create_look_at ( planeNormal ) ; 
    plan_bed_level_matrix  =  matrix_3x3 : : create_look_at ( planeNormal ) ; 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1093,13 +1044,13 @@ static void set_bed_level_equation_lsq(double *plane_equation_coefficients)
 
			
		
	
		
		
			
				
					
					    //uncorrected_position.debug("position before");
 
    //uncorrected_position.debug("position before");
 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    vector_3  corrected_position  =  plan_get_position ( ) ; 
    vector_3  corrected_position  =  plan_get_position ( ) ; 
 
			
		
	
		
		
			
				
					
					//     // 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    current_position [ X_AXIS ]  =  corrected_position . x ; 
    current_position [ X_AXIS ]  =  corrected_position . x ; 
 
			
		
	
		
		
			
				
					
					    current_position [ Y_AXIS ]  =  corrected_position . y ; 
    current_position [ Y_AXIS ]  =  corrected_position . y ; 
 
			
		
	
		
		
			
				
					
					    current_position [ Z_AXIS ]  =  corrected_position. z ;  
    current_position [ Z_AXIS ]  =  zprobe_zoffset;  // was: corrected_position.z
  
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
    sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
			
				
					
					}    }  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					# endif # endif  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# else  // not AUTO_BED_LEVELING_GRID
 # else  // not AUTO_BED_LEVELING_GRID
  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1124,9 +1075,9 @@ static void set_bed_level_equation_3pts(float z_at_pt_1, float z_at_pt_2, float
 
			
		
	
		
		
			
				
					
					    vector_3  corrected_position  =  plan_get_position ( ) ; 
    vector_3  corrected_position  =  plan_get_position ( ) ; 
 
			
		
	
		
		
			
				
					
					    current_position [ X_AXIS ]  =  corrected_position . x ; 
    current_position [ X_AXIS ]  =  corrected_position . x ; 
 
			
		
	
		
		
			
				
					
					    current_position [ Y_AXIS ]  =  corrected_position . y ; 
    current_position [ Y_AXIS ]  =  corrected_position . y ; 
 
			
		
	
		
		
			
				
					
					    current_position [ Z_AXIS ]  =  corrected_position. z ;  
    current_position [ Z_AXIS ]  =  zprobe_zoffset;  // was: corrected_position.z
  
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
    sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# endif  // AUTO_BED_LEVELING_GRID
 # endif  // AUTO_BED_LEVELING_GRID
  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1172,18 +1123,14 @@ static void run_z_probe() {
 
			
		
	
		
		
			
				
					
					    endstops_hit_on_purpose ( ) ; 
    endstops_hit_on_purpose ( ) ; 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    // move back down slowly to find bed
 
    // move back down slowly to find bed
 
 
			
		
	
		
		
			
				
					
					    
    if  ( homing_bump_divisor [ Z_AXIS ]  > =  1 )  { 
 
			
				
				
			
		
	
		
		
			
				
					
					    if  ( homing_bump_divisor [ Z_AXIS ]  > =  1 ) 
 
			
		
	
		
		
			
				
					
					    { 
 
			
		
	
		
		
	
		
		
			
				
					
					      feedrate  =  homing_feedrate [ Z_AXIS ] / homing_bump_divisor [ Z_AXIS ] ; 
      feedrate  =  homing_feedrate [ Z_AXIS ] / homing_bump_divisor [ Z_AXIS ] ; 
 
			
		
	
		
		
			
				
					
					    }  
    }  
 
			
		
	
		
		
			
				
					
					    else 
    else  { 
 
			
				
				
			
		
	
		
		
			
				
					
					    { 
 
			
		
	
		
		
	
		
		
			
				
					
					      feedrate  =  homing_feedrate [ Z_AXIS ] / 10 ; 
      feedrate  =  homing_feedrate [ Z_AXIS ] / 10 ; 
 
			
		
	
		
		
			
				
					
					      SERIAL_ECHOLN ( " Warning: The Homing Bump Feedrate Divisor cannot be less then 1 " ) ; 
      SERIAL_ECHOLN ( " Warning: The Homing Bump Feedrate Divisor cannot be less then 1 " ) ; 
 
			
		
	
		
		
			
				
					
					    } 
    } 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    
 
			
		
	
		
		
			
				
					
					    zPosition  - =  home_retract_mm ( Z_AXIS )  *  2 ; 
    zPosition  - =  home_retract_mm ( Z_AXIS )  *  2 ; 
 
			
		
	
		
		
			
				
					
					    plan_buffer_line ( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  zPosition ,  current_position [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
    plan_buffer_line ( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  zPosition ,  current_position [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
 
			
		
	
		
		
			
				
					
					    st_synchronize ( ) ; 
    st_synchronize ( ) ; 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1191,7 +1138,7 @@ static void run_z_probe() {
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    current_position [ Z_AXIS ]  =  st_get_position_mm ( Z_AXIS ) ; 
    current_position [ Z_AXIS ]  =  st_get_position_mm ( Z_AXIS ) ; 
 
			
		
	
		
		
			
				
					
					    // make sure the planner knows where we are as it may be a bit different than we last said to move to
 
    // make sure the planner knows where we are as it may be a bit different than we last said to move to
 
 
			
		
	
		
		
			
				
					
					    plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
    sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    
    
 
			
		
	
		
		
			
				
					
					  # endif 
  # endif 
 
			
		
	
		
		
			
				
					
					} }  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1471,7 +1418,7 @@ static void homeaxis(int axis) {
 
			
		
	
		
		
			
				
					
					# endif # endif  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    current_position [ axis ]  =  0 ; 
    current_position [ axis ]  =  0 ; 
 
			
		
	
		
		
			
				
					
					    plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
    sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# ifndef Z_PROBE_SLED # ifndef Z_PROBE_SLED  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1497,7 +1444,7 @@ static void homeaxis(int axis) {
 
			
		
	
		
		
			
				
					
					    st_synchronize ( ) ; 
    st_synchronize ( ) ; 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    current_position [ axis ]  =  0 ; 
    current_position [ axis ]  =  0 ; 
 
			
		
	
		
		
			
				
					
					    plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
    sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    destination [ axis ]  =  - home_retract_mm ( axis )  *  axis_home_dir ; 
    destination [ axis ]  =  - home_retract_mm ( axis )  *  axis_home_dir ; 
 
			
		
	
		
		
			
				
					
					    plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
    plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
 
			
		
	
		
		
			
				
					
					    st_synchronize ( ) ; 
    st_synchronize ( ) ; 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1520,7 +1467,7 @@ static void homeaxis(int axis) {
 
			
		
	
		
		
			
				
					
					      if  ( axis = = Z_AXIS ) 
      if  ( axis = = Z_AXIS ) 
 
			
		
	
		
		
			
				
					
					      { 
      { 
 
			
		
	
		
		
			
				
					
					        feedrate  =  homing_feedrate [ axis ] ; 
        feedrate  =  homing_feedrate [ axis ] ; 
 
			
		
	
		
		
			
				
					
					        plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
        sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        if  ( axis_home_dir  >  0 ) 
        if  ( axis_home_dir  >  0 ) 
 
			
		
	
		
		
			
				
					
					        { 
        { 
 
			
		
	
		
		
			
				
					
					          destination [ axis ]  =  ( - 1 )  *  fabs ( z_endstop_adj ) ; 
          destination [ axis ]  =  ( - 1 )  *  fabs ( z_endstop_adj ) ; 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1540,7 +1487,7 @@ static void homeaxis(int axis) {
 
			
		
	
		
		
			
				
					
					# ifdef DELTA # ifdef DELTA  
			
		
	
		
		
			
				
					
					    // retrace by the amount specified in endstop_adj
 
    // retrace by the amount specified in endstop_adj
 
 
			
		
	
		
		
			
				
					
					    if  ( endstop_adj [ axis ]  *  axis_home_dir  <  0 )  { 
    if  ( endstop_adj [ axis ]  *  axis_home_dir  <  0 )  { 
 
			
		
	
		
		
			
				
					
					      plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
      sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      destination [ axis ]  =  endstop_adj [ axis ] ; 
      destination [ axis ]  =  endstop_adj [ axis ] ; 
 
			
		
	
		
		
			
				
					
					      plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
      plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
 
			
		
	
		
		
			
				
					
					      st_synchronize ( ) ; 
      st_synchronize ( ) ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1596,7 +1543,7 @@ void refresh_cmd_timeout(void)
 
			
		
	
		
		
			
				
					
					         calculate_delta ( current_position ) ;  // change cartesian kinematic to  delta kinematic;
 
         calculate_delta ( current_position ) ;  // change cartesian kinematic to  delta kinematic;
 
 
			
		
	
		
		
			
				
					
					         plan_set_position ( delta [ X_AXIS ] ,  delta [ Y_AXIS ] ,  delta [ Z_AXIS ] ,  current_position [ E_AXIS ] ) ; 
         plan_set_position ( delta [ X_AXIS ] ,  delta [ Y_AXIS ] ,  delta [ Z_AXIS ] ,  current_position [ E_AXIS ] ) ; 
 
			
		
	
		
		
			
				
					
					# else # else  
			
		
	
		
		
			
				
					
					         plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
         sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					# endif # endif  
			
		
	
		
		
			
				
					
					         prepare_move ( ) ; 
         prepare_move ( ) ; 
 
			
		
	
		
		
			
				
					
					      } 
      } 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1612,7 +1559,7 @@ void refresh_cmd_timeout(void)
 
			
		
	
		
		
			
				
					
					         calculate_delta ( current_position ) ;  // change cartesian kinematic  to  delta kinematic;
 
         calculate_delta ( current_position ) ;  // change cartesian kinematic  to  delta kinematic;
 
 
			
		
	
		
		
			
				
					
					         plan_set_position ( delta [ X_AXIS ] ,  delta [ Y_AXIS ] ,  delta [ Z_AXIS ] ,  current_position [ E_AXIS ] ) ; 
         plan_set_position ( delta [ X_AXIS ] ,  delta [ Y_AXIS ] ,  delta [ Z_AXIS ] ,  current_position [ E_AXIS ] ) ; 
 
			
		
	
		
		
			
				
					
					# else # else  
			
		
	
		
		
			
				
					
					         plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
         sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					# endif # endif  
			
		
	
		
		
			
				
					
					         //prepare_move();
 
         //prepare_move();
 
 
			
		
	
		
		
			
				
					
					      } 
      } 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1789,7 +1736,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    // Move all carriages up together until the first endstop is hit.
 
    // Move all carriages up together until the first endstop is hit.
 
 
			
		
	
		
		
			
				
					
					    for  ( int  i  =  X_AXIS ;  i  < =  Z_AXIS ;  i + + )  current_position [ i ]  =  0 ; 
    for  ( int  i  =  X_AXIS ;  i  < =  Z_AXIS ;  i + + )  current_position [ i ]  =  0 ; 
 
			
		
	
		
		
			
				
					
					    plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
    sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    for  ( int  i  =  X_AXIS ;  i  < =  Z_AXIS ;  i + + )  destination [ i ]  =  3  *  Z_MAX_LENGTH ; 
    for  ( int  i  =  X_AXIS ;  i  < =  Z_AXIS ;  i + + )  destination [ i ]  =  3  *  Z_MAX_LENGTH ; 
 
			
		
	
		
		
			
				
					
					    feedrate  =  1.732  *  homing_feedrate [ X_AXIS ] ; 
    feedrate  =  1.732  *  homing_feedrate [ X_AXIS ] ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1829,7 +1776,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					          extruder_duplication_enabled  =  false ; 
          extruder_duplication_enabled  =  false ; 
 
			
		
	
		
		
			
				
					
					        # endif 
        # endif 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					        plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
        sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        destination [ X_AXIS ]  =  1.5  *  max_length ( X_AXIS )  *  x_axis_home_dir ; 
        destination [ X_AXIS ]  =  1.5  *  max_length ( X_AXIS )  *  x_axis_home_dir ; 
 
			
		
	
		
		
			
				
					
					        destination [ Y_AXIS ]  =  1.5  *  max_length ( Y_AXIS )  *  home_dir ( Y_AXIS ) ; 
        destination [ Y_AXIS ]  =  1.5  *  max_length ( Y_AXIS )  *  home_dir ( Y_AXIS ) ; 
 
			
		
	
		
		
			
				
					
					        feedrate  =  homing_feedrate [ X_AXIS ] ; 
        feedrate  =  homing_feedrate [ X_AXIS ] ; 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1844,7 +1791,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					        axis_is_at_home ( X_AXIS ) ; 
        axis_is_at_home ( X_AXIS ) ; 
 
			
		
	
		
		
			
				
					
					        axis_is_at_home ( Y_AXIS ) ; 
        axis_is_at_home ( Y_AXIS ) ; 
 
			
		
	
		
		
			
				
					
					        plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
        sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        destination [ X_AXIS ]  =  current_position [ X_AXIS ] ; 
        destination [ X_AXIS ]  =  current_position [ X_AXIS ] ; 
 
			
		
	
		
		
			
				
					
					        destination [ Y_AXIS ]  =  current_position [ Y_AXIS ] ; 
        destination [ Y_AXIS ]  =  current_position [ Y_AXIS ] ; 
 
			
		
	
		
		
			
				
					
					        plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
        plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate / 60 ,  active_extruder ) ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1921,7 +1868,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					          feedrate  =  XY_TRAVEL_SPEED  /  60 ; 
          feedrate  =  XY_TRAVEL_SPEED  /  60 ; 
 
			
		
	
		
		
			
				
					
					          current_position [ Z_AXIS ]  =  0 ; 
          current_position [ Z_AXIS ]  =  0 ; 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					          plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
          sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					          plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate ,  active_extruder ) ; 
          plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate ,  active_extruder ) ; 
 
			
		
	
		
		
			
				
					
					          st_synchronize ( ) ; 
          st_synchronize ( ) ; 
 
			
		
	
		
		
			
				
					
					          current_position [ X_AXIS ]  =  destination [ X_AXIS ] ; 
          current_position [ X_AXIS ]  =  destination [ X_AXIS ] ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1973,7 +1920,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					      if  ( home_all_axis  | |  code_seen ( axis_codes [ Z_AXIS ] ) ) 
      if  ( home_all_axis  | |  code_seen ( axis_codes [ Z_AXIS ] ) ) 
 
			
		
	
		
		
			
				
					
					        current_position [ Z_AXIS ]  + =  zprobe_zoffset ;   //Add Z_Probe offset (the distance is negative)
 
        current_position [ Z_AXIS ]  + =  zprobe_zoffset ;   //Add Z_Probe offset (the distance is negative)
 
 
			
		
	
		
		
			
				
					
					    # endif 
    # endif 
 
			
		
	
		
		
			
				
					
					    plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
    sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  # endif  // else DELTA
 
  # endif  // else DELTA
 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1998,7 +1945,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					      plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate ,  active_extruder ) ; 
      plan_buffer_line ( destination [ X_AXIS ] ,  destination [ Y_AXIS ] ,  destination [ Z_AXIS ] ,  destination [ E_AXIS ] ,  feedrate ,  active_extruder ) ; 
 
			
		
	
		
		
			
				
					
					      st_synchronize ( ) ; 
      st_synchronize ( ) ; 
 
			
		
	
		
		
			
				
					
					      current_position [ Z_AXIS ]  =  MESH_HOME_SEARCH_Z ; 
      current_position [ Z_AXIS ]  =  MESH_HOME_SEARCH_Z ; 
 
			
		
	
		
		
			
				
					
					      plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
      sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      mbl . active  =  1 ; 
      mbl . active  =  1 ; 
 
			
		
	
		
		
			
				
					
					    } 
    } 
 
			
		
	
		
		
			
				
					
					  # endif 
  # endif 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2069,7 +2016,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					      int  ix ,  iy ; 
      int  ix ,  iy ; 
 
			
		
	
		
		
			
				
					
					      if  ( probe_point  = =  0 )  { 
      if  ( probe_point  = =  0 )  { 
 
			
		
	
		
		
			
				
					
					        current_position [ Z_AXIS ]  =  MESH_HOME_SEARCH_Z ; 
        current_position [ Z_AXIS ]  =  MESH_HOME_SEARCH_Z ; 
 
			
		
	
		
		
			
				
					
					        plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
        sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      }  else  { 
      }  else  { 
 
			
		
	
		
		
			
				
					
					        ix  =  ( probe_point - 1 )  %  MESH_NUM_X_POINTS ; 
        ix  =  ( probe_point - 1 )  %  MESH_NUM_X_POINTS ; 
 
			
		
	
		
		
			
				
					
					        iy  =  ( probe_point - 1 )  /  MESH_NUM_X_POINTS ; 
        iy  =  ( probe_point - 1 )  /  MESH_NUM_X_POINTS ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2242,7 +2189,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					        current_position [ X_AXIS ]  =  uncorrected_position . x ; 
        current_position [ X_AXIS ]  =  uncorrected_position . x ; 
 
			
		
	
		
		
			
				
					
					        current_position [ Y_AXIS ]  =  uncorrected_position . y ; 
        current_position [ Y_AXIS ]  =  uncorrected_position . y ; 
 
			
		
	
		
		
			
				
					
					        current_position [ Z_AXIS ]  =  uncorrected_position . z ; 
        current_position [ Z_AXIS ]  =  uncorrected_position . z ; 
 
			
		
	
		
		
			
				
					
					        plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
        sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					      # endif 
      # endif 
 
			
		
	
		
		
			
				
					
					    } 
    } 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2443,7 +2390,7 @@ inline void gcode_G28() {
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					        apply_rotation_xyz ( plan_bed_level_matrix ,  x_tmp ,  y_tmp ,  z_tmp ) ;          //Apply the correction sending the probe offset
 
        apply_rotation_xyz ( plan_bed_level_matrix ,  x_tmp ,  y_tmp ,  z_tmp ) ;          //Apply the correction sending the probe offset
 
 
			
		
	
		
		
			
				
					
					        current_position [ Z_AXIS ]  =  z_tmp  -  real_z  +  current_position [ Z_AXIS ] ;    //The difference is added to current position and sent to planner.
 
        current_position [ Z_AXIS ]  =  z_tmp  -  real_z  +  current_position [ Z_AXIS ] ;    //The difference is added to current position and sent to planner.
 
 
			
		
	
		
		
			
				
					
					        plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
        sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      } 
      } 
 
			
		
	
		
		
			
				
					
					    # endif  // !DELTA
 
    # endif  // !DELTA
 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -2504,7 +2451,7 @@ inline void gcode_G92() {
 
			
		
	
		
		
			
				
					
					        didXYZ  =  true ; 
        didXYZ  =  true ; 
 
			
		
	
		
		
			
				
					
					    } 
    } 
 
			
		
	
		
		
			
				
					
					  } 
  } 
 
			
		
	
		
		
			
				
					
					  if  ( didXYZ )  plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
  if  ( didXYZ )  sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					# ifdef ULTIPANEL # ifdef ULTIPANEL  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -3762,23 +3709,23 @@ inline void gcode_M206() {
 
			
		
	
		
		
			
				
					
					  inline  void  gcode_M218 ( )  { 
  inline  void  gcode_M218 ( )  { 
 
			
		
	
		
		
			
				
					
					    if  ( setTargetedHotend ( 218 ) )  return ; 
    if  ( setTargetedHotend ( 218 ) )  return ; 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( code_seen ( ' X ' ) )  extruder_offset [ X_AXIS] [  tmp_extruder]  =  code_value ( ) ; 
    if  ( code_seen ( ' X ' ) )  extruder_offset [ ] [ X_AXIS ]  =  code_value ( ) ; 
 
			
				
				
			
		
	
		
		
			
				
					
					    if  ( code_seen ( ' Y ' ) )  extruder_offset [ Y_AXIS] [  tmp_extruder]  =  code_value ( ) ; 
    if  ( code_seen ( ' Y ' ) )  extruder_offset [ ] [ Y_AXIS ]  =  code_value ( ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    # ifdef DUAL_X_CARRIAGE 
    # ifdef DUAL_X_CARRIAGE 
 
			
		
	
		
		
			
				
					
					      if  ( code_seen ( ' Z ' ) )  extruder_offset [ Z_AXIS] [  tmp_extruder]  =  code_value ( ) ; 
      if  ( code_seen ( ' Z ' ) )  extruder_offset [ ] [ Z_AXIS ]  =  code_value ( ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    # endif 
    # endif 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    SERIAL_ECHO_START ; 
    SERIAL_ECHO_START ; 
 
			
		
	
		
		
			
				
					
					    SERIAL_ECHOPGM ( MSG_HOTEND_OFFSET ) ; 
    SERIAL_ECHOPGM ( MSG_HOTEND_OFFSET ) ; 
 
			
		
	
		
		
			
				
					
					    for  ( tmp_extruder  =  0 ;  tmp_extruder  <  EXTRUDERS ;  tmp_extruder + + )  { 
    for  ( tmp_extruder  =  0 ;  tmp_extruder  <  EXTRUDERS ;  tmp_extruder + + )  { 
 
			
		
	
		
		
			
				
					
					      SERIAL_ECHO ( "   " ) ; 
      SERIAL_ECHO ( "   " ) ; 
 
			
		
	
		
		
			
				
					
					      SERIAL_ECHO ( extruder_offset [ X_AXIS] [  tmp_extruder] ) ; 
      SERIAL_ECHO ( extruder_offset [ ] [ X_AXIS ] ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      SERIAL_ECHO ( " , " ) ; 
      SERIAL_ECHO ( " , " ) ; 
 
			
		
	
		
		
			
				
					
					      SERIAL_ECHO ( extruder_offset [ Y_AXIS] [  tmp_extruder] ) ; 
      SERIAL_ECHO ( extruder_offset [ ] [ Y_AXIS ] ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      # ifdef DUAL_X_CARRIAGE 
      # ifdef DUAL_X_CARRIAGE 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO ( " , " ) ; 
        SERIAL_ECHO ( " , " ) ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO ( extruder_offset [ Z_AXIS] [  tmp_extruder] ) ; 
        SERIAL_ECHO ( extruder_offset [ ] [ Z_AXIS ] ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      # endif 
      # endif 
 
			
		
	
		
		
			
				
					
					    } 
    } 
 
			
		
	
		
		
			
				
					
					    SERIAL_EOL ; 
    SERIAL_EOL ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -4469,13 +4416,13 @@ inline void gcode_M503() {
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO_START ; 
        SERIAL_ECHO_START ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHOPGM ( MSG_HOTEND_OFFSET ) ; 
        SERIAL_ECHOPGM ( MSG_HOTEND_OFFSET ) ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO ( "   " ) ; 
        SERIAL_ECHO ( "   " ) ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO ( extruder_offset [ X_AXIS ] [ 0 ] ) ; 
        SERIAL_ECHO ( extruder_offset [ 0 ] [ X_AXIS ] ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        SERIAL_ECHO ( " , " ) ; 
        SERIAL_ECHO ( " , " ) ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO ( extruder_offset [ Y_AXIS ] [ 0 ] ) ; 
        SERIAL_ECHO ( extruder_offset [ 0 ] [ Y_AXIS ] ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        SERIAL_ECHO ( "   " ) ; 
        SERIAL_ECHO ( "   " ) ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO ( duplicate_extruder_x_offset ) ; 
        SERIAL_ECHO ( duplicate_extruder_x_offset ) ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHO ( " , " ) ; 
        SERIAL_ECHO ( " , " ) ; 
 
			
		
	
		
		
			
				
					
					        SERIAL_ECHOLN ( extruder_offset [ Y_AXIS ] [ 1 ] ) ; 
        SERIAL_ECHOLN ( extruder_offset [ 1 ] [ Y_AXIS ] ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        break ; 
        break ; 
 
			
		
	
		
		
			
				
					
					      case  DXC_FULL_CONTROL_MODE : 
      case  DXC_FULL_CONTROL_MODE : 
 
			
		
	
		
		
			
				
					
					      case  DXC_AUTO_PARK_MODE : 
      case  DXC_AUTO_PARK_MODE : 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -4610,11 +4557,11 @@ inline void gcode_T() {
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					          // apply Y & Z extruder offset (x offset is already used in determining home pos)
 
          // apply Y & Z extruder offset (x offset is already used in determining home pos)
 
 
			
		
	
		
		
			
				
					
					          current_position [ Y_AXIS ]  =  current_position [ Y_AXIS ]  - 
          current_position [ Y_AXIS ]  =  current_position [ Y_AXIS ]  - 
 
			
		
	
		
		
			
				
					
					                       extruder_offset [ Y_AXIS] [  active_extruder]  + 
                       extruder_offset [ ] [ Y_AXIS ]  + 
 
			
				
				
			
		
	
		
		
			
				
					
					                       extruder_offset [ Y_AXIS] [  tmp_extruder] ; 
                       extruder_offset [ ] [ Y_AXIS ] ; 
 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					          current_position [ Z_AXIS ]  =  current_position [ Z_AXIS ]  - 
          current_position [ Z_AXIS ]  =  current_position [ Z_AXIS ]  - 
 
			
		
	
		
		
			
				
					
					                       extruder_offset [ Z_AXIS] [  active_extruder]  + 
                       extruder_offset [ ] [ Z_AXIS ]  + 
 
			
				
				
			
		
	
		
		
			
				
					
					                       extruder_offset [ Z_AXIS] [  tmp_extruder] ; 
                       extruder_offset [ ] [ Z_AXIS ] ; 
 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					          active_extruder  =  tmp_extruder ; 
          active_extruder  =  tmp_extruder ; 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -4644,7 +4591,7 @@ inline void gcode_T() {
 
			
		
	
		
		
			
				
					
					        # else  // !DUAL_X_CARRIAGE
 
        # else  // !DUAL_X_CARRIAGE
 
 
			
		
	
		
		
			
				
					
					          // Offset extruder (only by XY)
 
          // Offset extruder (only by XY)
 
 
			
		
	
		
		
			
				
					
					          for  ( int  i = X_AXIS ;  i < = Y_AXIS ;  i + + ) 
          for  ( int  i = X_AXIS ;  i < = Y_AXIS ;  i + + ) 
 
			
		
	
		
		
			
				
					
					            current_position [ i ]  + =  extruder_offset [ i] [  tmp_extruder]  -  extruder_offset [ i] [  active_extruder] ; 
            current_position [ i ]  + =  extruder_offset [ ] [ i ]  -  extruder_offset [ ] [ i ] ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					          // Set the new active extruder and position
 
          // Set the new active extruder and position
 
 
			
		
	
		
		
			
				
					
					          active_extruder  =  tmp_extruder ; 
          active_extruder  =  tmp_extruder ; 
 
			
		
	
		
		
			
				
					
					        # endif  // !DUAL_X_CARRIAGE
 
        # endif  // !DUAL_X_CARRIAGE
 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -4653,7 +4600,7 @@ inline void gcode_T() {
 
			
		
	
		
		
			
				
					
					          //sent position to plan_set_position();
 
          //sent position to plan_set_position();
 
 
			
		
	
		
		
			
				
					
					          plan_set_position ( delta [ X_AXIS ] ,  delta [ Y_AXIS ] ,  delta [ Z_AXIS ] , current_position [ E_AXIS ] ) ; 
          plan_set_position ( delta [ X_AXIS ] ,  delta [ Y_AXIS ] ,  delta [ Z_AXIS ] , current_position [ E_AXIS ] ) ; 
 
			
		
	
		
		
			
				
					
					        # else 
        # else 
 
			
		
	
		
		
			
				
					
					          plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
          sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        # endif 
        # endif 
 
			
		
	
		
		
			
				
					
					        // Move to the old position if 'F' was in the parameters
 
        // Move to the old position if 'F' was in the parameters
 
 
			
		
	
		
		
			
				
					
					        if  ( make_move  & &  ! Stopped )  prepare_move ( ) ; 
        if  ( make_move  & &  ! Stopped )  prepare_move ( ) ; 
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -5494,7 +5441,7 @@ for (int s = 1; s <= steps; s++) {
 
			
		
	
		
		
			
				
					
					      plan_set_position ( inactive_extruder_x_pos ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ] ) ; 
      plan_set_position ( inactive_extruder_x_pos ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ] ) ; 
 
			
		
	
		
		
			
				
					
					      plan_buffer_line ( current_position [ X_AXIS ]  +  duplicate_extruder_x_offset ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] , 
      plan_buffer_line ( current_position [ X_AXIS ]  +  duplicate_extruder_x_offset ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] , 
 
			
		
	
		
		
			
				
					
					          current_position [ E_AXIS ] ,  max_feedrate [ X_AXIS ] ,  1 ) ; 
          current_position [ E_AXIS ] ,  max_feedrate [ X_AXIS ] ,  1 ) ; 
 
			
		
	
		
		
			
				
					
					      plan_set_position( current_position [ X_AXIS ] ,  current_position [ Y_AXIS ] ,  current_position [ Z_AXIS ] ,  current_position [ E_AXIS ]  ) ; 
      sync_plan_position(  ) ; 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      st_synchronize ( ) ; 
      st_synchronize ( ) ; 
 
			
		
	
		
		
			
				
					
					      extruder_duplication_enabled  =  true ; 
      extruder_duplication_enabled  =  true ; 
 
			
		
	
		
		
			
				
					
					      active_extruder_parked  =  false ; 
      active_extruder_parked  =  false ;