diff --git a/octoprint_firmwareupdater/__init__.py b/octoprint_firmwareupdater/__init__.py index e9b7a46..e677e22 100644 --- a/octoprint_firmwareupdater/__init__.py +++ b/octoprint_firmwareupdater/__init__.py @@ -510,6 +510,15 @@ def _flash_lpc1768(self, firmware=None, printer_port=None): if self._settings.get_boolean(["lpc1768_preflashreset"]): self._send_status("progress", subtype="boardreset") + + unmount_command = 'sudo umount ' + lpc1768_path + self._logger.info(u"Unmounting SD card: '{}'".format(unmount_command)) + try: + r = os.system(unmount_command) + except: + e = sys.exc_info()[0] + self._logger.error("Error executing unmount command '{}'".format(unmount_command)) + self._logger.info(u"Pre-flash reset: attempting to reset the board") if not self._reset_lpc1768(printer_port): self._logger.error(u"Reset failed") @@ -551,6 +560,14 @@ def _flash_lpc1768(self, firmware=None, printer_port=None): self._send_status("flasherror") return False + unmount_command = 'sudo umount ' + lpc1768_path + self._logger.info(u"Unmounting SD card: '{}'".format(unmount_command)) + try: + r = os.system(unmount_command) + except: + e = sys.exc_info()[0] + self._logger.error("Error executing unmount command '{}'".format(unmount_command)) + self._logger.info(u"Firmware update reset: attempting to reset the board") if not self._reset_lpc1768(printer_port): self._logger.error(u"Reset failed")