|  |  |  | @@ -137,27 +137,28 @@ void report_alarm_message(int8_t alarm_code) | 
		
	
		
			
				|  |  |  |  | // TODO: Install silence feedback messages option in settings | 
		
	
		
			
				|  |  |  |  | void report_feedback_message(uint8_t message_code) | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR("[MSG:")); | 
		
	
		
			
				|  |  |  |  |   switch(message_code) { | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_CRITICAL_EVENT: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Reset to continue")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Reset to continue")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_ALARM_LOCK: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("['$H'|'$X' to unlock")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("'$H'|'$X' to unlock")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_ALARM_UNLOCK: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Caution: Unlocked")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Caution: Unlocked")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_ENABLED: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Enabled")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Enabled")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_DISABLED: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Disabled")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Disabled")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_SAFETY_DOOR_AJAR: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Check Door")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Check Door")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_CHECK_LIMITS: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Check Limits")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Check Limits")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_PROGRAM_END: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Pgm End")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Pgm End")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_RESTORE_DEFAULTS: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Restoring defaults")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Restoring defaults")); break; | 
		
	
		
			
				|  |  |  |  |     case MESSAGE_SPINDLE_RESTORE: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[Restoring spindle")); break; | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("Restoring spindle")); break; | 
		
	
		
			
				|  |  |  |  |   } | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR("]\r\n")); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
	
		
			
				
					
					|  |  |  | @@ -172,7 +173,7 @@ void report_init_message() | 
		
	
		
			
				|  |  |  |  | // Grbl help message | 
		
	
		
			
				|  |  |  |  | void report_grbl_help() { | 
		
	
		
			
				|  |  |  |  |   #ifdef REPORT_GUI_MODE | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("[$$ $# $G $I $N $x=val $Nx=line $J=line $C $X $H ~ ! ? ctrl-x]\r\n")); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("[HLP:$$ $# $G $I $N $x=val $Nx=line $J=line $C $X $H ~ ! ? ctrl-x]\r\n")); | 
		
	
		
			
				|  |  |  |  |   #else | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("$$ (view Grbl settings)\r\n" | 
		
	
		
			
				|  |  |  |  |                         "$# (view # parameters)\r\n" | 
		
	
	
		
			
				
					
					|  |  |  | @@ -193,38 +194,102 @@ void report_grbl_help() { | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | static void report_int_setting(uint8_t n, int val) | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  |     serial_write('$'); | 
		
	
		
			
				|  |  |  |  |     print_uint8_base10(n); | 
		
	
		
			
				|  |  |  |  |     serial_write('='); | 
		
	
		
			
				|  |  |  |  |     print_uint8_base10(val); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n")); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | static void report_float_setting(uint8_t n, float val, uint8_t decimal_places) | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  |     serial_write('$'); | 
		
	
		
			
				|  |  |  |  |     print_uint8_base10(n); | 
		
	
		
			
				|  |  |  |  |     serial_write('='); | 
		
	
		
			
				|  |  |  |  |     printFloat(val, decimal_places); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n")); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Grbl global settings print out. | 
		
	
		
			
				|  |  |  |  | // NOTE: The numbering scheme here must correlate to storing in settings.c | 
		
	
		
			
				|  |  |  |  | void report_grbl_settings() { | 
		
	
		
			
				|  |  |  |  |   // Print Grbl settings. | 
		
	
		
			
				|  |  |  |  |   #ifdef REPORT_GUI_MODE | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("$0=")); print_uint8_base10(settings.pulse_microseconds); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$1=")); print_uint8_base10(settings.stepper_idle_lock_time); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$2=")); print_uint8_base10(settings.step_invert_mask); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$3=")); print_uint8_base10(settings.dir_invert_mask); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$4=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_INVERT_ST_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$5=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_INVERT_LIMIT_PINS)); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$6=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_INVERT_PROBE_PIN)); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$10=")); print_uint8_base10(settings.status_report_mask); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$11=")); printFloat_SettingValue(settings.junction_deviation); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$12=")); printFloat_SettingValue(settings.arc_tolerance); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$13=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_REPORT_INCHES)); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$20=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_SOFT_LIMIT_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$21=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_HARD_LIMIT_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$22=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_HOMING_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$23=")); print_uint8_base10(settings.homing_dir_mask); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$24=")); printFloat_SettingValue(settings.homing_feed_rate); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$25=")); printFloat_SettingValue(settings.homing_seek_rate); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$26=")); print_uint8_base10(settings.homing_debounce_delay); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$27=")); printFloat_SettingValue(settings.homing_pulloff); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$30=")); printFloat_RPMValue(settings.rpm_max); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("\r\n$31=")); printFloat_RPMValue(settings.rpm_min); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     report_int_setting(0,settings.pulse_microseconds); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(1,settings.stepper_idle_lock_time); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(2,settings.step_invert_mask); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(3,settings.dir_invert_mask); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(4,bit_istrue(settings.flags,BITFLAG_INVERT_ST_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(5,bit_istrue(settings.flags,BITFLAG_INVERT_LIMIT_PINS)); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(6,bit_istrue(settings.flags,BITFLAG_INVERT_PROBE_PIN)); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(10,settings.status_report_mask); | 
		
	
		
			
				|  |  |  |  |     report_float_setting(11,settings.junction_deviation,N_DECIMAL_SETTINGVALUE); | 
		
	
		
			
				|  |  |  |  |     report_float_setting(12,settings.arc_tolerance,N_DECIMAL_SETTINGVALUE); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(13,bit_istrue(settings.flags,BITFLAG_REPORT_INCHES)); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(20,bit_istrue(settings.flags,BITFLAG_SOFT_LIMIT_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(21,bit_istrue(settings.flags,BITFLAG_HARD_LIMIT_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(22,bit_istrue(settings.flags,BITFLAG_HOMING_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(23,settings.homing_dir_mask); | 
		
	
		
			
				|  |  |  |  |     report_float_setting(24,settings.homing_feed_rate,N_DECIMAL_SETTINGVALUE); | 
		
	
		
			
				|  |  |  |  |     report_float_setting(25,settings.homing_seek_rate,N_DECIMAL_SETTINGVALUE); | 
		
	
		
			
				|  |  |  |  |     report_int_setting(26,settings.homing_debounce_delay); | 
		
	
		
			
				|  |  |  |  |     report_float_setting(27,settings.homing_pulloff,N_DECIMAL_SETTINGVALUE); | 
		
	
		
			
				|  |  |  |  |     report_float_setting(30,settings.rpm_max,N_DECIMAL_RPMVALUE); | 
		
	
		
			
				|  |  |  |  |     report_float_setting(31,settings.rpm_min,N_DECIMAL_RPMVALUE); | 
		
	
		
			
				|  |  |  |  |     #ifdef VARIABLE_SPINDLE | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("\r\n$32=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_LASER_MODE)); | 
		
	
		
			
				|  |  |  |  |       report_int_setting(32,bit_istrue(settings.flags,BITFLAG_LASER_MODE)); | 
		
	
		
			
				|  |  |  |  |     #else | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("\r\n$32=0\r\n")); | 
		
	
		
			
				|  |  |  |  |       report_int_setting(32,0); | 
		
	
		
			
				|  |  |  |  |     #endif | 
		
	
		
			
				|  |  |  |  |     // Print axis settings | 
		
	
		
			
				|  |  |  |  |     uint8_t idx, set_idx; | 
		
	
		
			
				|  |  |  |  |     uint8_t val = AXIS_SETTINGS_START_VAL; | 
		
	
		
			
				|  |  |  |  |     for (set_idx=0; set_idx<AXIS_N_SETTINGS; set_idx++) { | 
		
	
		
			
				|  |  |  |  |       for (idx=0; idx<N_AXIS; idx++) { | 
		
	
		
			
				|  |  |  |  |         switch (set_idx) { | 
		
	
		
			
				|  |  |  |  |           case 0: report_float_setting(val+idx,settings.steps_per_mm[idx],N_DECIMAL_SETTINGVALUE); break; | 
		
	
		
			
				|  |  |  |  |           case 1: report_float_setting(val+idx,settings.max_rate[idx],N_DECIMAL_SETTINGVALUE); break; | 
		
	
		
			
				|  |  |  |  |           case 2: report_float_setting(val+idx,settings.acceleration[idx]/(60*60),N_DECIMAL_SETTINGVALUE); break; | 
		
	
		
			
				|  |  |  |  |           case 3: report_float_setting(val+idx,-settings.max_travel[idx],N_DECIMAL_SETTINGVALUE); break; | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |       } | 
		
	
		
			
				|  |  |  |  |       val += AXIS_SETTINGS_INCREMENT; | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("$0=")); print_uint8_base10(settings.pulse_microseconds); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$1=")); print_uint8_base10(settings.stepper_idle_lock_time); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$2=")); print_uint8_base10(settings.step_invert_mask); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$3=")); print_uint8_base10(settings.dir_invert_mask); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$4=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_INVERT_ST_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$5=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_INVERT_LIMIT_PINS)); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$6=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_INVERT_PROBE_PIN)); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$10=")); print_uint8_base10(settings.status_report_mask); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$11=")); printFloat_SettingValue(settings.junction_deviation); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$12=")); printFloat_SettingValue(settings.arc_tolerance); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$13=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_REPORT_INCHES)); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$20=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_SOFT_LIMIT_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$21=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_HARD_LIMIT_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$22=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_HOMING_ENABLE)); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$23=")); print_uint8_base10(settings.homing_dir_mask); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$24=")); printFloat_SettingValue(settings.homing_feed_rate); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$25=")); printFloat_SettingValue(settings.homing_seek_rate); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$26=")); print_uint8_base10(settings.homing_debounce_delay); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$27=")); printFloat_SettingValue(settings.homing_pulloff); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$30=")); printFloat_RPMValue(settings.rpm_max); | 
		
	
		
			
				|  |  |  |  |     // printPgmString(PSTR("\r\n$31=")); printFloat_RPMValue(settings.rpm_min); | 
		
	
		
			
				|  |  |  |  |     // #ifdef VARIABLE_SPINDLE | 
		
	
		
			
				|  |  |  |  |     //   printPgmString(PSTR("\r\n$32=")); print_uint8_base10(bit_istrue(settings.flags,BITFLAG_LASER_MODE)); | 
		
	
		
			
				|  |  |  |  |     //   printPgmString(PSTR("\r\n")); | 
		
	
		
			
				|  |  |  |  |     // #else | 
		
	
		
			
				|  |  |  |  |     //   printPgmString(PSTR("\r\n$32=0\r\n")); | 
		
	
		
			
				|  |  |  |  |     // #endif | 
		
	
		
			
				|  |  |  |  |   #else | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR("$0=")); print_uint8_base10(settings.pulse_microseconds); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR(" (step pulse, usec)\r\n$1=")); print_uint8_base10(settings.stepper_idle_lock_time); | 
		
	
		
			
				|  |  |  |  |     printPgmString(PSTR(" (step idle delay, msec)\r\n$2=")); print_uint8_base10(settings.step_invert_mask); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -252,25 +317,20 @@ void report_grbl_settings() { | 
		
	
		
			
				|  |  |  |  |     #else | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR(" (rpm min)\r\n$32=0 (laser mode, bool)\r\n")); | 
		
	
		
			
				|  |  |  |  |     #endif | 
		
	
		
			
				|  |  |  |  |   #endif | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   // Print axis settings | 
		
	
		
			
				|  |  |  |  |   uint8_t idx, set_idx; | 
		
	
		
			
				|  |  |  |  |   uint8_t val = AXIS_SETTINGS_START_VAL; | 
		
	
		
			
				|  |  |  |  |   for (set_idx=0; set_idx<AXIS_N_SETTINGS; set_idx++) { | 
		
	
		
			
				|  |  |  |  |     for (idx=0; idx<N_AXIS; idx++) { | 
		
	
		
			
				|  |  |  |  |       serial_write('$'); | 
		
	
		
			
				|  |  |  |  |       print_uint8_base10(val+idx); | 
		
	
		
			
				|  |  |  |  |       serial_write('='); | 
		
	
		
			
				|  |  |  |  |       switch (set_idx) { | 
		
	
		
			
				|  |  |  |  |         case 0: printFloat_SettingValue(settings.steps_per_mm[idx]); break; | 
		
	
		
			
				|  |  |  |  |         case 1: printFloat_SettingValue(settings.max_rate[idx]); break; | 
		
	
		
			
				|  |  |  |  |         case 2: printFloat_SettingValue(settings.acceleration[idx]/(60*60)); break; | 
		
	
		
			
				|  |  |  |  |         case 3: printFloat_SettingValue(-settings.max_travel[idx]); break; | 
		
	
		
			
				|  |  |  |  |       } | 
		
	
		
			
				|  |  |  |  |       #ifdef REPORT_GUI_MODE | 
		
	
		
			
				|  |  |  |  |         printPgmString(PSTR("\r\n")); | 
		
	
		
			
				|  |  |  |  |       #else | 
		
	
		
			
				|  |  |  |  |     // Print axis settings | 
		
	
		
			
				|  |  |  |  |     uint8_t idx, set_idx; | 
		
	
		
			
				|  |  |  |  |     uint8_t val = AXIS_SETTINGS_START_VAL; | 
		
	
		
			
				|  |  |  |  |     for (set_idx=0; set_idx<AXIS_N_SETTINGS; set_idx++) { | 
		
	
		
			
				|  |  |  |  |       for (idx=0; idx<N_AXIS; idx++) { | 
		
	
		
			
				|  |  |  |  |         serial_write('$'); | 
		
	
		
			
				|  |  |  |  |         print_uint8_base10(val+idx); | 
		
	
		
			
				|  |  |  |  |         serial_write('='); | 
		
	
		
			
				|  |  |  |  |         switch (set_idx) { | 
		
	
		
			
				|  |  |  |  |           case 0: printFloat_SettingValue(settings.steps_per_mm[idx]); break; | 
		
	
		
			
				|  |  |  |  |           case 1: printFloat_SettingValue(settings.max_rate[idx]); break; | 
		
	
		
			
				|  |  |  |  |           case 2: printFloat_SettingValue(settings.acceleration[idx]/(60*60)); break; | 
		
	
		
			
				|  |  |  |  |           case 3: printFloat_SettingValue(-settings.max_travel[idx]); break; | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |         serial_write(' '); | 
		
	
		
			
				|  |  |  |  |         serial_write('('); | 
		
	
		
			
				|  |  |  |  |         switch (idx) { | 
		
	
	
		
			
				
					
					|  |  |  | @@ -285,10 +345,11 @@ void report_grbl_settings() { | 
		
	
		
			
				|  |  |  |  |           case 3: printPgmString(PSTR(" max travel, mm")); break; | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |         printPgmString(PSTR(")\r\n")); | 
		
	
		
			
				|  |  |  |  |       #endif | 
		
	
		
			
				|  |  |  |  |       } | 
		
	
		
			
				|  |  |  |  |       val += AXIS_SETTINGS_INCREMENT; | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  |     val += AXIS_SETTINGS_INCREMENT; | 
		
	
		
			
				|  |  |  |  |   } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   #endif | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
	
		
			
				
					
					|  |  |  | @@ -352,24 +413,26 @@ void report_ngc_parameters() | 
		
	
		
			
				|  |  |  |  | // Print current gcode parser mode state | 
		
	
		
			
				|  |  |  |  | void report_gcode_modes() | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR("[GC:G")); | 
		
	
		
			
				|  |  |  |  |   switch (gc_state.modal.motion) { | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_SEEK : printPgmString(PSTR("[G0")); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_LINEAR : printPgmString(PSTR("[G1")); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_CW_ARC : printPgmString(PSTR("[G2")); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_CCW_ARC : printPgmString(PSTR("[G3")); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_NONE : printPgmString(PSTR("[G80")); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_SEEK : serial_write('0'); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_LINEAR : serial_write('1'); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_CW_ARC : serial_write('2'); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_CCW_ARC : serial_write('3'); break; | 
		
	
		
			
				|  |  |  |  |     case MOTION_MODE_NONE : printPgmString(PSTR("80")); break; | 
		
	
		
			
				|  |  |  |  |     default: | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("[G38.")); | 
		
	
		
			
				|  |  |  |  |       printPgmString(PSTR("38.")); | 
		
	
		
			
				|  |  |  |  |       print_uint8_base10(gc_state.modal.motion - (MOTION_MODE_PROBE_TOWARD-2)); | 
		
	
		
			
				|  |  |  |  |   } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR(" G")); | 
		
	
		
			
				|  |  |  |  |   print_uint8_base10(gc_state.modal.coord_select+54); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR(" G1")); | 
		
	
		
			
				|  |  |  |  |   switch (gc_state.modal.plane_select) { | 
		
	
		
			
				|  |  |  |  |     case PLANE_SELECT_XY : printPgmString(PSTR(" G17")); break; | 
		
	
		
			
				|  |  |  |  |     case PLANE_SELECT_ZX : printPgmString(PSTR(" G18")); break; | 
		
	
		
			
				|  |  |  |  |     case PLANE_SELECT_YZ : printPgmString(PSTR(" G19")); break; | 
		
	
		
			
				|  |  |  |  |     case PLANE_SELECT_XY : serial_write('7'); break; | 
		
	
		
			
				|  |  |  |  |     case PLANE_SELECT_ZX : serial_write('8'); break; | 
		
	
		
			
				|  |  |  |  |     case PLANE_SELECT_YZ : serial_write('9'); break; | 
		
	
		
			
				|  |  |  |  |   } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   if (gc_state.modal.units == UNITS_MODE_MM) { printPgmString(PSTR(" G21")); } | 
		
	
	
		
			
				
					
					|  |  |  | @@ -381,26 +444,29 @@ void report_gcode_modes() | 
		
	
		
			
				|  |  |  |  |   if (gc_state.modal.feed_rate == FEED_RATE_MODE_INVERSE_TIME) { printPgmString(PSTR(" G93")); } | 
		
	
		
			
				|  |  |  |  |   else { printPgmString(PSTR(" G94")); } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR(" M")); | 
		
	
		
			
				|  |  |  |  |   switch (gc_state.modal.program_flow) { | 
		
	
		
			
				|  |  |  |  |     case PROGRAM_FLOW_RUNNING : printPgmString(PSTR(" M0")); break; | 
		
	
		
			
				|  |  |  |  |     case PROGRAM_FLOW_PAUSED : printPgmString(PSTR(" M1")); break; | 
		
	
		
			
				|  |  |  |  |     case PROGRAM_FLOW_COMPLETED : printPgmString(PSTR(" M2")); break; | 
		
	
		
			
				|  |  |  |  |     case PROGRAM_FLOW_RUNNING : serial_write('0'); break; | 
		
	
		
			
				|  |  |  |  |     case PROGRAM_FLOW_PAUSED : serial_write('1'); break; | 
		
	
		
			
				|  |  |  |  |     case PROGRAM_FLOW_COMPLETED : serial_write('2'); break; | 
		
	
		
			
				|  |  |  |  |   } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR(" M")); | 
		
	
		
			
				|  |  |  |  |   switch (gc_state.modal.spindle) { | 
		
	
		
			
				|  |  |  |  |     case SPINDLE_ENABLE_CW : printPgmString(PSTR(" M3")); break; | 
		
	
		
			
				|  |  |  |  |     case SPINDLE_ENABLE_CCW : printPgmString(PSTR(" M4")); break; | 
		
	
		
			
				|  |  |  |  |     case SPINDLE_DISABLE : printPgmString(PSTR(" M5")); break; | 
		
	
		
			
				|  |  |  |  |     case SPINDLE_ENABLE_CW : serial_write('3'); break; | 
		
	
		
			
				|  |  |  |  |     case SPINDLE_ENABLE_CCW : serial_write('4'); break; | 
		
	
		
			
				|  |  |  |  |     case SPINDLE_DISABLE : serial_write('5'); break; | 
		
	
		
			
				|  |  |  |  |   } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR(" M")); | 
		
	
		
			
				|  |  |  |  |   #ifdef ENABLE_M7 | 
		
	
		
			
				|  |  |  |  |     if (gc_state.modal.coolant) { // Note: Multiple coolant states may be active at the same time. | 
		
	
		
			
				|  |  |  |  |       if (gc_state.modal.coolant & PL_COND_FLAG_COOLANT_MIST) { printPgmString(PSTR(" M7")); } | 
		
	
		
			
				|  |  |  |  |       if (gc_state.modal.coolant & PL_COND_FLAG_COOLANT_FLOOD) { printPgmString(PSTR(" M8")); } | 
		
	
		
			
				|  |  |  |  |     } else { printPgmString(PSTR(" M9")); } | 
		
	
		
			
				|  |  |  |  |       if (gc_state.modal.coolant & PL_COND_FLAG_COOLANT_MIST) { serial_write('7'); } | 
		
	
		
			
				|  |  |  |  |       if (gc_state.modal.coolant & PL_COND_FLAG_COOLANT_FLOOD) { serial_write('8'); } | 
		
	
		
			
				|  |  |  |  |     } else { serial_write('9'); } | 
		
	
		
			
				|  |  |  |  |   #else | 
		
	
		
			
				|  |  |  |  |     if (gc_state.modal.coolant) { printPgmString(PSTR(" M8")); } | 
		
	
		
			
				|  |  |  |  |     else { printPgmString(PSTR(" M9")); } | 
		
	
		
			
				|  |  |  |  |     if (gc_state.modal.coolant) { serial_write('8'); } | 
		
	
		
			
				|  |  |  |  |     else { serial_write('9'); } | 
		
	
		
			
				|  |  |  |  |   #endif | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR(" T")); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -427,11 +493,18 @@ void report_startup_line(uint8_t n, char *line) | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR("\r\n")); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void report_execute_startup_message(char *line, uint8_t status_code) | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  |   serial_write('>'); | 
		
	
		
			
				|  |  |  |  |   printString(line); // Echo startup line to indicate execution. | 
		
	
		
			
				|  |  |  |  |   serial_write(':'); | 
		
	
		
			
				|  |  |  |  |   report_status_message(status_code); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | // Prints build info line | 
		
	
		
			
				|  |  |  |  | void report_build_info(char *line) | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR("[" GRBL_VERSION "." GRBL_VERSION_BUILD ":")); | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR("[VER:" GRBL_VERSION "." GRBL_VERSION_BUILD ":")); | 
		
	
		
			
				|  |  |  |  |   printString(line); | 
		
	
		
			
				|  |  |  |  |   printPgmString(PSTR("]\r\n")); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
	
		
			
				
					
					|  |  |  |   |