diff --git a/pytec/pytec/gui/model/thermostat.py b/pytec/pytec/gui/model/thermostat.py
index 6d511fc..f35354b 100644
--- a/pytec/pytec/gui/model/thermostat.py
+++ b/pytec/pytec/gui/model/thermostat.py
@@ -34,6 +34,7 @@ class Thermostat(QObject, metaclass=PropertyMeta):
         self._watch_task = None
         self._report_mode_task = None
         self._poll_for_report = True
+        self.connection_errored = False
         super().__init__(parent)
 
     async def run(self):
@@ -54,6 +55,10 @@ class Thermostat(QObject, metaclass=PropertyMeta):
                 self.task = asyncio.create_task(self.update_params())
             await asyncio.sleep(self._update_s)
 
+    @pyqtSlot()
+    def timed_out(self):
+        self.connection_errored = True
+
     async def get_hw_rev(self):
         self.hw_rev = await self._client.hw_rev()
         return self.hw_rev
@@ -104,6 +109,7 @@ class Thermostat(QObject, metaclass=PropertyMeta):
 
     async def end_session(self):
         await self._client.end_session()
+        self.connection_errored = False
 
     async def set_ipv4(self, ipv4):
         await self._client.set_param("ipv4", ipv4)
diff --git a/pytec/tec_qt.py b/pytec/tec_qt.py
index 37545d0..ce7c7ad 100644
--- a/pytec/tec_qt.py
+++ b/pytec/tec_qt.py
@@ -78,6 +78,9 @@ class MainWindow(QtWidgets.QMainWindow):
             self, self.client, self.report_refresh_spin.value()
         )
 
+        self.client.connection_error.connect(self.thermostat.timed_out)
+        self.client.connection_error.connect(self.bail)
+
         self.autotuners = PIDAutoTuner(self, self.client, 2)
 
         def get_ctrl_panel_config(args):
@@ -197,9 +200,12 @@ class MainWindow(QtWidgets.QMainWindow):
             self.thermostat_ctrl_menu.fan_pwm_warning.setToolTip("")
             self.clear_graphs()
             self.report_box.setChecked(False)
-            if not Thermostat.connecting or Thermostat.connected:
-                for ch in range(self.NUM_CHANNELS):
-                    if self.autotuners.get_state(ch) != PIDAutotuneState.STATE_OFF:
+            for ch in range(self.NUM_CHANNELS):
+                if self.autotuners.get_state(ch) != PIDAutotuneState.STATE_OFF:
+                    if self.thermostat.connection_errored:
+                        # Don't send any commands, just reset local state
+                        self.autotuners.autotuners[ch].setOff()
+                    else:
                         await self.autotuners.stop_pid_from_running(ch)
             await self.thermostat.set_report_mode(False)
             self.thermostat.stop_watching()