[PATCH 29/35] NAN: Don't send sync SDFs with offchannel tx

Andrei Otcheretianski andrei.otcheretianski at intel.com
Mon Oct 20 05:28:04 PDT 2025


Synchronized NAN DE doesn't require offchannel transmissions.
Skip the radio work and offchannel transmission if freq and wait time
are not provided.

Signed-off-by: Andrei Otcheretianski <andrei.otcheretianski at intel.com>
---
 src/common/nan_de.c             |  3 ++-
 wpa_supplicant/nan_supplicant.c | 16 ++++++++++++++++
 2 files changed, 18 insertions(+), 1 deletion(-)

diff --git a/src/common/nan_de.c b/src/common/nan_de.c
index c6dd94f1ae..d883975c0a 100644
--- a/src/common/nan_de.c
+++ b/src/common/nan_de.c
@@ -353,7 +353,8 @@ static void nan_de_tx_sdf(struct nan_de *de, struct nan_de_service *srv,
 		wpabuf_put_buf(buf, srv->elems);
 	}
 
-	nan_de_tx(de, srv->freq, wait_time, dst, de->nmi, a3, buf);
+	nan_de_tx(de, srv->sync ? 0 : srv->freq, srv->sync ? 0 : wait_time,
+		  dst, de->nmi, a3, buf);
 	wpabuf_free(buf);
 }
 
diff --git a/wpa_supplicant/nan_supplicant.c b/wpa_supplicant/nan_supplicant.c
index 94226b81e3..9c6d8fdbd8 100644
--- a/wpa_supplicant/nan_supplicant.c
+++ b/wpa_supplicant/nan_supplicant.c
@@ -270,6 +270,22 @@ static int wpas_nan_de_tx(void *ctx, unsigned int freq, unsigned int wait_time,
 	struct wpa_supplicant *wpa_s = ctx;
 	struct wpas_nan_tx_work *twork;
 
+	if (!freq && !wait_time) {
+		int ret;
+
+		wpa_printf(MSG_DEBUG, "NAN: SYNC TX NAN SDF A1=" MACSTR " A2="
+			   MACSTR " A3=" MACSTR " len=%zu",
+			   MAC2STR(dst), MAC2STR(src), MAC2STR(bssid),
+			   wpabuf_len(buf));
+		ret = wpa_drv_send_action(wpa_s, 0, 0, dst, src, bssid,
+					  wpabuf_head(buf), wpabuf_len(buf),
+					  1);
+		if (ret)
+			wpa_printf(MSG_DEBUG,
+				   "NAN: Failed to send sync action frame (%d)",
+				   ret);
+		return ret;
+	}
 	if (wpa_s->nan_tx_work || wpa_s->nan_usd_listen_work) {
 		/* Reuse ongoing radio work */
 		return wpas_nan_de_tx_send(wpa_s, freq, wait_time, dst, src,
-- 
2.49.0




More information about the Hostap mailing list