diff --git a/package/madwifi/patches/378-adhoc_crash_fix.patch b/package/madwifi/patches/378-adhoc_crash_fix.patch
new file mode 100644
index 0000000000000000000000000000000000000000..e8b4c22b648965b740330377017d91032eb00eef
--- /dev/null
+++ b/package/madwifi/patches/378-adhoc_crash_fix.patch
@@ -0,0 +1,14 @@
+--- a/net80211/ieee80211_input.c
++++ b/net80211/ieee80211_input.c
+@@ -3522,6 +3522,11 @@
+ 		if (ic->ic_flags & IEEE80211_F_SCAN) {
+ 			ieee80211_add_scan(vap, &scan, wh, subtype, rssi, rtsf);
+ 		}
++
++		/* stop processing if the bss channel is not set up yet */
++		if (!ic->ic_bsschan || ic->ic_bsschan == IEEE80211_CHAN_ANYC)
++			break;
++
+ 		/* NB: Behavior of WDS-Link and Ad-Hoc is very similar here:
+ 		 * When we receive a beacon that belongs to the AP that we're
+ 		 * connected to, use it to refresh the local node info.