From: Ian Jackson Date: Wed, 8 Aug 2012 17:30:34 +0000 (+0100) Subject: HOMEAXIS: make into a function X-Git-Tag: firmware-tested-2012-08-10^2~2^2~1 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=commitdiff_plain;h=656f93b5d2604b6c81d80dea3f7f9a5d23d0dd5a;p=marlin.git HOMEAXIS: make into a function Replace the large macro HOMEAXIS with a function. This avoids the compiler generating three copies of largely identical code. The saving is 704 bytes of program memory. Signed-off-by: Ian Jackson --- diff --git a/Marlin/Marlin.pde b/Marlin/Marlin.pde index ba8b3b8..c93825f 100644 --- a/Marlin/Marlin.pde +++ b/Marlin/Marlin.pde @@ -552,9 +552,15 @@ bool code_seen(char code) return (strchr_pointer != NULL); //Return True if a character was found } -static const PROGMEM float base_min_pos[3] = { X_MIN_POS, Y_MIN_POS, Z_MIN_POS }; -static const PROGMEM float base_max_pos[3] = { X_MAX_POS, Y_MAX_POS, Z_MAX_POS }; -static const PROGMEM float base_home_pos[3] = { X_HOME_POS, Y_HOME_POS, Z_HOME_POS }; +#define XYZ_CONSTS_FROM_CONFIG(type, array, CONFIG) \ +static const PROGMEM type array[3] = { X_##CONFIG, Y_##CONFIG, Z_##CONFIG }; + +XYZ_CONSTS_FROM_CONFIG(float, base_min_pos, MIN_POS); +XYZ_CONSTS_FROM_CONFIG(float, base_max_pos, MAX_POS); +XYZ_CONSTS_FROM_CONFIG(float, base_home_pos, HOME_POS); +XYZ_CONSTS_FROM_CONFIG(float, max_length, MAX_LENGTH); +XYZ_CONSTS_FROM_CONFIG(float, home_retract_mm, HOME_RETRACT_MM); +XYZ_CONSTS_FROM_CONFIG(signed char, home_dir, HOME_DIR); static void axis_is_at_home(int axis) { current_position[axis] = base_home_pos[axis] + add_homeing[axis]; @@ -562,32 +568,41 @@ static void axis_is_at_home(int axis) { max_pos[axis] = base_max_pos[axis] + add_homeing[axis]; } -#define HOMEAXIS(LETTER) \ - if ((LETTER##_MIN_PIN > -1 && LETTER##_HOME_DIR==-1) || (LETTER##_MAX_PIN > -1 && LETTER##_HOME_DIR==1))\ - { \ - current_position[LETTER##_AXIS] = 0; \ - plan_set_position(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS]); \ - destination[LETTER##_AXIS] = 1.5 * LETTER##_MAX_LENGTH * LETTER##_HOME_DIR; \ - feedrate = homing_feedrate[LETTER##_AXIS]; \ - plan_buffer_line(destination[X_AXIS], destination[Y_AXIS], destination[Z_AXIS], destination[E_AXIS], feedrate/60, active_extruder); \ - st_synchronize();\ - \ - current_position[LETTER##_AXIS] = 0;\ - plan_set_position(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS]);\ - destination[LETTER##_AXIS] = -LETTER##_HOME_RETRACT_MM * LETTER##_HOME_DIR;\ - plan_buffer_line(destination[X_AXIS], destination[Y_AXIS], destination[Z_AXIS], destination[E_AXIS], feedrate/60, active_extruder); \ - st_synchronize();\ - \ - destination[LETTER##_AXIS] = 2*LETTER##_HOME_RETRACT_MM * LETTER##_HOME_DIR;\ - feedrate = homing_feedrate[LETTER##_AXIS]/2 ; \ - plan_buffer_line(destination[X_AXIS], destination[Y_AXIS], destination[Z_AXIS], destination[E_AXIS], feedrate/60, active_extruder); \ - st_synchronize();\ - \ - axis_is_at_home(LETTER##_AXIS); \ - destination[LETTER##_AXIS] = current_position[LETTER##_AXIS]; \ - feedrate = 0.0;\ - endstops_hit_on_purpose();\ +static void homeaxis(int axis) { +#define HOMEAXIS_DO_BIT(LETTER) \ + ((LETTER##_MIN_PIN > -1 && LETTER##_HOME_DIR==-1) || (LETTER##_MAX_PIN > -1 && LETTER##_HOME_DIR==1) ? 1 << LETTER##_AXIS : 0) + + static PROGMEM const unsigned char doaxis = + HOMEAXIS_DO_BIT(X) | + HOMEAXIS_DO_BIT(Y) | + HOMEAXIS_DO_BIT(Z); + + if (doaxis & (1<