Merge pull request #6682 from thinkyhead/bf_M80_s_arg
"M80 S" to report the state of the PSU pin
This commit is contained in:
		| @@ -559,8 +559,8 @@ static uint8_t target_extruder; | |||||||
|  |  | ||||||
| #endif // FWRETRACT | #endif // FWRETRACT | ||||||
|  |  | ||||||
| #if ENABLED(ULTIPANEL) && HAS_POWER_SWITCH | #if HAS_POWER_SWITCH | ||||||
|   bool powersupply = |   bool powersupply_on = | ||||||
|     #if ENABLED(PS_DEFAULT_OFF) |     #if ENABLED(PS_DEFAULT_OFF) | ||||||
|       false |       false | ||||||
|     #else |     #else | ||||||
| @@ -7093,10 +7093,18 @@ inline void gcode_M140() { | |||||||
| #if HAS_POWER_SWITCH | #if HAS_POWER_SWITCH | ||||||
|  |  | ||||||
|   /** |   /** | ||||||
|    * M80: Turn on Power Supply |    * M80   : Turn on the Power Supply | ||||||
|  |    * M80 S : Report the current state and exit | ||||||
|    */ |    */ | ||||||
|   inline void gcode_M80() { |   inline void gcode_M80() { | ||||||
|     OUT_WRITE(PS_ON_PIN, PS_ON_AWAKE); //GND |  | ||||||
|  |     // S: Report the current power supply state and exit | ||||||
|  |     if (code_seen('S')) { | ||||||
|  |       serialprintPGM(powersupply_on ? PSTR("PS:1\n") : PSTR("PS:0\n")); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     OUT_WRITE(PS_ON_PIN, PS_ON_AWAKE); // GND | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * If you have a switch on suicide pin, this is useful |      * If you have a switch on suicide pin, this is useful | ||||||
| @@ -7112,8 +7120,9 @@ inline void gcode_M140() { | |||||||
|       tmc2130_init(); // Settings only stick when the driver has power |       tmc2130_init(); // Settings only stick when the driver has power | ||||||
|     #endif |     #endif | ||||||
|  |  | ||||||
|  |     powersupply_on = true; | ||||||
|  |  | ||||||
|     #if ENABLED(ULTIPANEL) |     #if ENABLED(ULTIPANEL) | ||||||
|       powersupply = true; |  | ||||||
|       LCD_MESSAGEPGM(WELCOME_MSG); |       LCD_MESSAGEPGM(WELCOME_MSG); | ||||||
|     #endif |     #endif | ||||||
|   } |   } | ||||||
| @@ -7128,25 +7137,26 @@ inline void gcode_M140() { | |||||||
| inline void gcode_M81() { | inline void gcode_M81() { | ||||||
|   thermalManager.disable_all_heaters(); |   thermalManager.disable_all_heaters(); | ||||||
|   stepper.finish_and_disable(); |   stepper.finish_and_disable(); | ||||||
|  |  | ||||||
|   #if FAN_COUNT > 0 |   #if FAN_COUNT > 0 | ||||||
|     for (uint8_t i = 0; i < FAN_COUNT; i++) fanSpeeds[i] = 0; |     for (uint8_t i = 0; i < FAN_COUNT; i++) fanSpeeds[i] = 0; | ||||||
|  |  | ||||||
|     #if ENABLED(PROBING_FANS_OFF) |     #if ENABLED(PROBING_FANS_OFF) | ||||||
|       fans_paused = false; |       fans_paused = false; | ||||||
|       ZERO(paused_fanSpeeds); |       ZERO(paused_fanSpeeds); | ||||||
|     #endif |     #endif | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   safe_delay(1000); // Wait 1 second before switching off |   safe_delay(1000); // Wait 1 second before switching off | ||||||
|  |  | ||||||
|   #if HAS_SUICIDE |   #if HAS_SUICIDE | ||||||
|     stepper.synchronize(); |     stepper.synchronize(); | ||||||
|     suicide(); |     suicide(); | ||||||
|   #elif HAS_POWER_SWITCH |   #elif HAS_POWER_SWITCH | ||||||
|     OUT_WRITE(PS_ON_PIN, PS_ON_ASLEEP); |     OUT_WRITE(PS_ON_PIN, PS_ON_ASLEEP); | ||||||
|  |     powersupply_on = false; | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(ULTIPANEL) |   #if ENABLED(ULTIPANEL) | ||||||
|     #if HAS_POWER_SWITCH |  | ||||||
|       powersupply = false; |  | ||||||
|     #endif |  | ||||||
|     LCD_MESSAGEPGM(MACHINE_NAME " " MSG_OFF "."); |     LCD_MESSAGEPGM(MACHINE_NAME " " MSG_OFF "."); | ||||||
|   #endif |   #endif | ||||||
| } | } | ||||||
| @@ -10133,7 +10143,7 @@ void process_next_command() { | |||||||
|         gcode_M81(); |         gcode_M81(); | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|       case 82: // M83: Set E axis normal mode (same as other axes) |       case 82: // M82: Set E axis normal mode (same as other axes) | ||||||
|         gcode_M82(); |         gcode_M82(); | ||||||
|         break; |         break; | ||||||
|       case 83: // M83: Set E axis relative mode |       case 83: // M83: Set E axis relative mode | ||||||
|   | |||||||
| @@ -98,7 +98,7 @@ uint16_t max_display_update_time = 0; | |||||||
|   typedef void (*screenFunc_t)(); |   typedef void (*screenFunc_t)(); | ||||||
|  |  | ||||||
|   #if HAS_POWER_SWITCH |   #if HAS_POWER_SWITCH | ||||||
|     extern bool powersupply; |     extern bool powersupply_on; | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(AUTO_BED_LEVELING_UBL) |   #if ENABLED(AUTO_BED_LEVELING_UBL) | ||||||
| @@ -2129,7 +2129,7 @@ void kill_screen(const char* lcd_msg) { | |||||||
|     // Switch power on/off |     // Switch power on/off | ||||||
|     // |     // | ||||||
|     #if HAS_POWER_SWITCH |     #if HAS_POWER_SWITCH | ||||||
|       if (powersupply) |       if (powersupply_on) | ||||||
|         MENU_ITEM(gcode, MSG_SWITCH_PS_OFF, PSTR("M81")); |         MENU_ITEM(gcode, MSG_SWITCH_PS_OFF, PSTR("M81")); | ||||||
|       else |       else | ||||||
|         MENU_ITEM(gcode, MSG_SWITCH_PS_ON, PSTR("M80")); |         MENU_ITEM(gcode, MSG_SWITCH_PS_ON, PSTR("M80")); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user