How Rearranging a Kid's Room Broke My Zigbee Network (and How I Fixed It)
Overview
A few days ago, my wife decided that we - sorry, I — needed to rearrange our kid's room. This involved unplugging various things, including my IKEA VINDSTYRKA air quality sensor.
Fast forward to today: I noticed my zigbee2mqtt
container had been restarting multiple times. Weird.
But everything seemed to be working fine — devices were updating, automations were triggering, life was good. Then I plugged the sensor back in, and... Home Assistant didn’t recognize it. Did I forget to pair it after playing around with it? Who knows. But no problem, right? Just press the button four times and let the magic happen.
Well, magic didn't happen. Instead, my zigbee2mqtt
container restarted. Uh-oh.
The Troubleshooting Rabbit Hole
At this point, I had a feeling something was off. So I tried the usual troubleshooting steps:
- Restarted my SLZB-06M Zigbee coordinator (connected via Ethernet).
- Restarted the
zigbee2mqtt
andmqtt
containers. - Tried to rejoin the sensor again.
Same result. Failure. Logs weren’t helpful, just cryptic messages from the Zigbee underworld.
1Using '/app/data' as data directory
2Starting Zigbee2MQTT without watchdog.
3[2025-03-28 09:30:49] info: z2m: Logging to console, file (filename: log.log)
4[2025-03-28 09:30:49] info: z2m: Starting Zigbee2MQTT version 2.1.3 (commit #ba337bd329aeb4ca17735c0cf09b31293c8cff06)
5[2025-03-28 09:30:49] info: z2m: Starting zigbee-herdsman (3.2.7)
6[2025-03-28 09:30:49] info: zh:ember: Using default stack config.
7[2025-03-28 09:30:49] info: zh:ember: ======== Ember Adapter Starting ========
8[2025-03-28 09:30:49] info: zh:ember:ezsp: ======== EZSP starting ========
9[2025-03-28 09:30:49] info: zh:ember:uart:ash: ======== ASH Adapter reset ========
10[2025-03-28 09:30:49] info: zh:ember:uart:ash: Socket ready
11[2025-03-28 09:30:49] info: zh:ember:uart:ash: ======== ASH starting ========
12[2025-03-28 09:30:51] info: zh:ember:uart:ash: ======== ASH connected ========
13[2025-03-28 09:30:51] info: zh:ember:uart:ash: ======== ASH started ========
14[2025-03-28 09:30:51] info: zh:ember:ezsp: ======== EZSP started ========
15[2025-03-28 09:30:51] info: zh:ember: Adapter EZSP protocol version (14) lower than Host. Switched.
16[2025-03-28 09:30:51] info: zh:ember: Adapter version info: {"ezsp":14,"revision":"8.0.2 [GA]","build":397,"major":8,"minor":0,"patch":2,"special":0,"type":170}
17[2025-03-28 09:30:51] info: zh:ember: [STACK STATUS] Network up.
18[2025-03-28 09:30:52] info: zh:ember: [INIT TC] Adapter network matches config.
19[2025-03-28 09:30:52] info: zh:ember: [CONCENTRATOR] Started source route discovery. 1246ms until next broadcast.
20[2025-03-28 09:30:52] info: z2m: zigbee-herdsman started (resumed)
21[...]
22[2025-03-28 09:22:37] info: zh:controller: Interview for '0xd44867fffe5b1c0c' started
23[2025-03-28 09:22:37] info: z2m: Device '0xd44867fffe5b1c0c' joined
24[2025-03-28 09:22:37] info: z2m: Starting interview of '0xd44867fffe5b1c0c'
25[2025-03-28 09:22:37] info: z2m:mqtt: MQTT publish: topic 'zigbee2mqtt/bridge/event', payload '{"data":{"friendly_name":"0xd44867fffe5b1c0c","ieee_address":"0xd44867fffe5b1c0c"},"type":"device_joined"}'
26[2025-03-28 09:22:37] info: z2m:mqtt: MQTT publish: topic 'zigbee2mqtt/bridge/event', payload '{"data":{"friendly_name":"0xd44867fffe5b1c0c","ieee_address":"0xd44867fffe5b1c0c","status":"started"},"type":"device_interview"}'
27[2025-03-28 09:22:37] error: zh:ember:uart:ash: Received ERROR from adapter, with code=ERROR_EXCEEDED_MAXIMUM_ACK_TIMEOUT_COUNT.
28[2025-03-28 09:22:37] error: zh:ember:uart:ash: ASH disconnected | Adapter status: ASH_NCP_FATAL_ERROR
29[2025-03-28 09:22:37] error: zh:ember:uart:ash: Error while parsing received frame, status=ASH_NCP_FATAL_ERROR.
30[2025-03-28 09:22:37] error: zh:ember: Adapter fatal error: HOST_FATAL_ERROR
31[2025-03-28 09:22:37] info: zh:ember:uart:ash: ASH COUNTERS since last clear:
32[2025-03-28 09:22:37] info: zh:ember:uart:ash: Total frames: RX=92, TX=134
33[2025-03-28 09:22:37] info: zh:ember:uart:ash: Cancelled : RX=0, TX=0
34[2025-03-28 09:22:37] info: zh:ember:uart:ash: DATA frames : RX=72, TX=41
35[2025-03-28 09:22:37] info: zh:ember:uart:ash: DATA bytes : RX=1284, TX=501
36[2025-03-28 09:22:37] info: zh:ember:uart:ash: Retry frames: RX=17, TX=0
37[2025-03-28 09:22:37] info: zh:ember:uart:ash: ACK frames : RX=0, TX=91
38[2025-03-28 09:22:37] info: zh:ember:uart:ash: NAK frames : RX=0, TX=0
39[2025-03-28 09:22:37] info: zh:ember:uart:ash: nRdy frames : RX=0, TX=0
40[2025-03-28 09:22:37] info: zh:ember:uart:ash: CRC errors : RX=0
41[2025-03-28 09:22:37] info: zh:ember:uart:ash: Comm errors : RX=0
42[2025-03-28 09:22:37] info: zh:ember:uart:ash: Length < minimum: RX=0
43[2025-03-28 09:22:37] info: zh:ember:uart:ash: Length > maximum: RX=0
44[2025-03-28 09:22:37] info: zh:ember:uart:ash: Bad controls : RX=0
45[2025-03-28 09:22:37] info: zh:ember:uart:ash: Bad lengths : RX=0
46[2025-03-28 09:22:37] info: zh:ember:uart:ash: Bad ACK numbers : RX=0
47[2025-03-28 09:22:37] info: zh:ember:uart:ash: Out of buffers : RX=0
48[2025-03-28 09:22:37] info: zh:ember:uart:ash: Retry dupes : RX=17
49[2025-03-28 09:22:37] info: zh:ember:uart:ash: Out of sequence : RX=0
50[2025-03-28 09:22:37] info: zh:ember:uart:ash: ACK timeouts : RX=0
51[2025-03-28 09:22:37] error: zh:ember:uart:ash: Error while parsing received frame, status=ASH_NCP_FATAL_ERROR.
52[2025-03-28 09:22:37] info: zh:ember:uart:ash: ======== ASH stopped ========
53[2025-03-28 09:22:37] info: zh:ember:ezsp: ======== EZSP stopped ========
54[2025-03-28 09:22:37] info: zh:ember: ======== Ember Adapter Stopped ========
55[2025-03-28 09:22:37] error: z2m: Adapter disconnected, stopping
56[2025-03-28 09:22:49] info: z2m:mqtt: MQTT publish: topic 'zigbee2mqtt/bridge/state', payload '{"state":"offline"}'
57[2025-03-28 09:22:49] info: z2m: Disconnecting from MQTT server
58[2025-03-28 09:22:49] info: z2m: Stopping zigbee-herdsman...
59[2025-03-28 09:22:49] info: z2m: Stopped zigbee-herdsman
60[2025-03-28 09:22:49] info: z2m: Stopped Zigbee2MQTT
Turning to the Internet (And Realizing No One Had a Fix)
Like any responsible tech enthusiast, I turned to the Internet — GitHub issues, forums, random Reddit threads. And, as expected, I found discussions, but none of the solutions worked for me. Some people suggested downgrading firmware, others said to sacrifice a goat (or was it just reset the Zigbee network? Hard to tell).
The Fix That Worked
Since nothing else was helping, I decided to go nuclear: flash the firmware. Here’s what I did:
- Flashed the
Zigbee Router 20250220
firmware. - Flashed the
Zigbee Coordinator 20250220
firmware.
And boom! Everything was back to normal. The sensor paired without issues, no more zigbee2mqtt restarts, and my smart home was happy again.
Lessons Learned
Never underestimate the chaos a simple room rearrangement can cause.
When in doubt, firmware flashing is sometimes the way to go.
Maybe keep a backup Zigbee coordinator handy? (Future me, take note.)
Hopefully, this helps someone avoid spending hours chasing ghost issues. If you're dealing with zigbee2mqtt
restarting when adding a device, give firmware flashing a shot. Just, you know, be careful not to brick your hardware.
Happy Zigbee-ing!
Posts in this series
- Waste Collection Schedule in HomeAssistant
- How Rearranging a Kid's Room Broke My Zigbee Network (and How I Fixed It)