| @@ -22,21 +22,24 @@ | ||||
|  | ||||
| #include "../gcode.h" | ||||
| #include "../../module/configuration_store.h" | ||||
| #include "../../core/serial.h" | ||||
| #include "../../inc/MarlinConfig.h" | ||||
|  | ||||
| #if NUM_SERIAL > 1 | ||||
|   #include "../../gcode/queue.h" | ||||
| #endif | ||||
|  | ||||
| #if ADD_PORT_ARG | ||||
|   #define CHAT_PORT command_queue_port[cmd_queue_index_r] | ||||
| #else | ||||
|   #define CHAT_PORT | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * M500: Store settings in EEPROM | ||||
|  */ | ||||
| void GcodeSuite::M500() { | ||||
|   (void)settings.save( | ||||
|     #if ENABLED(EEPROM_CHITCHAT) && NUM_SERIAL > 1 | ||||
|       command_queue_port[cmd_queue_index_r] | ||||
|     #endif | ||||
|   ); | ||||
|   (void)settings.save(CHAT_PORT); | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -44,8 +47,8 @@ void GcodeSuite::M500() { | ||||
|  */ | ||||
| void GcodeSuite::M501() { | ||||
|   (void)settings.load( | ||||
|     #if ENABLED(EEPROM_SETTINGS) && ENABLED(EEPROM_CHITCHAT) && NUM_SERIAL > 1 | ||||
|       command_queue_port[cmd_queue_index_r] | ||||
|     #if ENABLED(EEPROM_SETTINGS) | ||||
|       CHAT_PORT | ||||
|     #endif | ||||
|   ); | ||||
| } | ||||
| @@ -54,11 +57,7 @@ void GcodeSuite::M501() { | ||||
|  * M502: Revert to default settings | ||||
|  */ | ||||
| void GcodeSuite::M502() { | ||||
|   (void)settings.reset( | ||||
|     #if ENABLED(EEPROM_CHITCHAT) && NUM_SERIAL > 1 | ||||
|       command_queue_port[cmd_queue_index_r] | ||||
|     #endif | ||||
|   ); | ||||
|   (void)settings.reset(CHAT_PORT); | ||||
| } | ||||
|  | ||||
| #if DISABLED(DISABLE_M503) | ||||
| @@ -67,8 +66,9 @@ void GcodeSuite::M502() { | ||||
|    * M503: print settings currently in memory | ||||
|    */ | ||||
|   void GcodeSuite::M503() { | ||||
|     (void)settings.report(parser.seen('S') && !parser.value_bool() | ||||
|       #if ADD_PORT_ARG | ||||
|     (void)settings.report( | ||||
|       parser.seen('S') && !parser.value_bool() | ||||
|       #if NUM_SERIAL > 1 | ||||
|         , command_queue_port[cmd_queue_index_r] | ||||
|       #endif | ||||
|     ); | ||||
| @@ -81,9 +81,9 @@ void GcodeSuite::M502() { | ||||
|    * M504: Validate EEPROM Contents | ||||
|    */ | ||||
|   void GcodeSuite::M504() { | ||||
|     if (settings.validate()) { | ||||
|       SERIAL_ECHO_START(); | ||||
|       SERIAL_ECHOLNPGM("EEPROM OK"); | ||||
|     if (settings.validate(CHAT_PORT)) { | ||||
|       SERIAL_ECHO_START_P(command_queue_port[cmd_queue_index_r]); | ||||
|       SERIAL_ECHOLNPGM_P(command_queue_port[cmd_queue_index_r], "EEPROM OK"); | ||||
|     } | ||||
|   } | ||||
| #endif | ||||
|   | ||||
| @@ -1462,7 +1462,11 @@ void MarlinSettings::postprocess() { | ||||
|       const int8_t port/*=-1*/ | ||||
|     #endif | ||||
|   ) { | ||||
|     if (validate()) return _load( | ||||
|     if (validate( | ||||
|       #if ADD_PORT_ARG | ||||
|         port | ||||
|       #endif | ||||
|     )) return _load( | ||||
|       #if ADD_PORT_ARG | ||||
|         port | ||||
|       #endif | ||||
| @@ -1864,7 +1868,7 @@ void MarlinSettings::reset( | ||||
|    * Unless specifically disabled, M503 is available even without EEPROM | ||||
|    */ | ||||
|   void MarlinSettings::report(const bool forReplay | ||||
|     #if ADD_PORT_ARG | ||||
|     #if NUM_SERIAL > 1 | ||||
|       , const int8_t port/*=-1*/ | ||||
|     #endif | ||||
|   ) { | ||||
|   | ||||
| @@ -86,7 +86,7 @@ class MarlinSettings { | ||||
|  | ||||
|     #if DISABLED(DISABLE_M503) | ||||
|       static void report(const bool forReplay=false | ||||
|         #if ADD_PORT_ARG | ||||
|         #if NUM_SERIAL > 1 | ||||
|           , const int8_t port=-1 | ||||
|         #endif | ||||
|       ); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user