{"id":2198423,"url":"http://patchwork.ozlabs.org/api/1.0/patches/2198423/?format=json","project":{"id":22,"url":"http://patchwork.ozlabs.org/api/1.0/projects/22/?format=json","name":"HostAP Development","link_name":"hostap","list_id":"hostap.lists.infradead.org","list_email":"hostap@lists.infradead.org","web_url":"","scm_url":"","webscm_url":""},"msgid":"<20260219202514.5781-21-andrei.otcheretianski@intel.com>","date":"2026-02-19T20:24:36","name":"[20/58] NAN: Add Tx status notification to NDL","commit_ref":null,"pull_url":null,"state":"accepted","archived":false,"hash":"9de0ed93b645c21dd18732288b9a08b480958ede","submitter":{"id":62065,"url":"http://patchwork.ozlabs.org/api/1.0/people/62065/?format=json","name":"Andrei Otcheretianski","email":"andrei.otcheretianski@intel.com"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/hostap/patch/20260219202514.5781-21-andrei.otcheretianski@intel.com/mbox/","series":[{"id":492721,"url":"http://patchwork.ozlabs.org/api/1.0/series/492721/?format=json","date":"2026-02-19T20:24:21","name":"NAN: Add NAN Data Path (NDP) support","version":1,"mbox":"http://patchwork.ozlabs.org/series/492721/mbox/"}],"check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2198423/checks/","tags":{},"headers":{"Return-Path":"\n <hostap-bounces+incoming=patchwork.ozlabs.org@lists.infradead.org>","X-Original-To":"incoming@patchwork.ozlabs.org","Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n secure) header.d=lists.infradead.org header.i=@lists.infradead.org\n header.a=rsa-sha256 header.s=bombadil.20210309 header.b=QVcnVnLS;\n\tdkim=fail reason=\"signature verification failed\" (2048-bit key;\n secure) header.d=infradead.org header.i=@infradead.org header.a=rsa-sha256\n header.s=desiato.20200630 header.b=AftcrAA1;\n\tdkim=fail reason=\"signature verification failed\" (2048-bit key;\n unprotected) header.d=intel.com header.i=@intel.com header.a=rsa-sha256\n header.s=Intel header.b=AJEayScx;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=none (no SPF record) smtp.mailfrom=lists.infradead.org\n (client-ip=2607:7c80:54:3::133; helo=bombadil.infradead.org;\n envelope-from=hostap-bounces+incoming=patchwork.ozlabs.org@lists.infradead.org;\n receiver=patchwork.ozlabs.org)"],"Received":["from bombadil.infradead.org (bombadil.infradead.org\n [IPv6:2607:7c80:54:3::133])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519 server-signature ECDSA (secp384r1) server-digest SHA384)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4fH4gm2tjYz1xpY\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 20 Feb 2026 07:27:48 +1100 (AEDT)","from localhost ([::1] helo=bombadil.infradead.org)\n\tby bombadil.infradead.org with esmtp (Exim 4.98.2 #2 (Red Hat Linux))\n\tid 1vtAcK-0000000Bxqw-1AcQ;\n\tThu, 19 Feb 2026 20:27:20 +0000","from desiato.infradead.org ([2001:8b0:10b:1:d65d:64ff:fe57:4e05])\n\tby bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux))\n\tid 1vtAc5-0000000BxVq-3mtS\n\tfor hostap@bombadil.infradead.org;\n\tThu, 19 Feb 2026 20:27:06 +0000","from mgamail.intel.com ([198.175.65.10])\n\tby desiato.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux))\n\tid 1vtAbc-00000001pxP-0Wvi\n\tfor hostap@lists.infradead.org;\n\tThu, 19 Feb 2026 20:27:00 +0000","from orviesa004.jf.intel.com ([10.64.159.144])\n  by orvoesa102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 19 Feb 2026 12:26:29 -0800","from aotchere-mobl1.ger.corp.intel.com (HELO\n aotchere-mobl1.intel.com) ([10.245.246.171])\n  by orviesa004-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 19 Feb 2026 12:26:25 -0800"],"DKIM-Signature":["v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed;\n\td=lists.infradead.org; s=bombadil.20210309; h=Sender:\n\tContent-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post:\n\tList-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To:\n\tMessage-ID:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description:\n\tResent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:\n\tList-Owner; bh=tIVXYf+CML5cwdW72cSLrbiUUnNVi4xbGZngdHRny9I=; b=QVcnVnLSwNPPeR\n\toNCqdxOL0vYL5fV86UwKkT1eP/ogrpFnLQpHuvttt1/bRtVpzK/AbFjeyidm6eT8pSZGRFrygWQMI\n\tjxda/Z54WKb8iYL8e5UssPFSD7+zPpYBAK04+EWvBj/ZWInTHwiTnofyY4FdwAPo6aGg9Vj9yye4d\n\t0Xb0ySH1QPkVFD2ZnlAyAzEjH6ruojf9KGODb98jt999VZvyNg++Y5pTVjhICfY55xNvUBACmBxr1\n\t1GCnJUJllbybrQ9Cqx08rLLQ4XXd5GNymNGwUKz7C0hkQANiPkUzso5g90ZPcivH1AW9ypqZafZm8\n\tXuZEUHfgdfTPRII1RKYQ==;","v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed;\n\td=infradead.org; s=desiato.20200630; h=Content-Transfer-Encoding:MIME-Version\n\t:References:In-Reply-To:Message-ID:Date:Subject:Cc:To:From:Sender:Reply-To:\n\tContent-Type:Content-ID:Content-Description;\n\tbh=TxJtn7kQC/Owq86P+an9EHr3XhS18JK0uU7meAwwMZM=; b=AftcrAA1dO5pDrRFjhh+OJbQuQ\n\txrXB6LkxEFTb2tXHiNf6ayGj6rzaYQTZkaK7paqYvDTpHM1/xczuO64/Rq0YpNfx1Xwnjd/NMX76l\n\ti0FHRWoE+be0QzELSWy5QZBobWFjUVZEXucFezx6NulLS+ZDyhXGYFps7WTBATzd9Ke7EXHUiQ571\n\tKPVkt4zzUOPyPGy3Az3T/LhV49sCviKhtLIC0gxGG4uH/YEETxyjGafUQxfCEG0BrkFIn3d/ueB4Z\n\t9MHVxX9Qx2jKGS4/Q3CkeCN7JC/z+RAAiFk5SQvs+//esLSmW5bWITvqzDY66cLuma05fByEFe+Af\n\tZ+tMEj4Q==;","v=1; a=rsa-sha256; c=relaxed/simple;\n  d=intel.com; i=@intel.com; q=dns/txt; s=Intel;\n  t=1771532797; x=1803068797;\n  h=from:to:cc:subject:date:message-id:in-reply-to:\n   references:mime-version:content-transfer-encoding;\n  bh=VLhU1J1/TKeiF0DivgEjLdMWIv+YHpNtvErmvot6uwI=;\n  b=AJEayScxAysFs02uHA4ZYhSatEvjtrrBCQ37A3UMI4FjL2neE2cyBH3H\n   rUpWs50YNAwanpAYIdoxf9yzvob+ZDiV7U7cHaEt6B9ont7B4hv0j3qxu\n   e29oEjCULFrmH77fc+xG+ckWPE2ZoHCUsx/RyuUTMe0VV9DxNMlbBzhPS\n   RYuLw2CKRpfPW3TtgMCF7Qr3gs8/y+i4WW6CwDN4QRyHy5ppr3U0w/I7J\n   mlJDnNRXhOS3VLYucmNX9ryD+BeSh4bSg8IjQ1bGnhiHBXUsShk0WTExO\n   bWs2Da/hbFUGhS/FKh4yzu3bz6cTb9BRo6cS9qqL5GCt5oz0myRBHId9m\n   w==;"],"X-CSE-ConnectionGUID":["MeEthalARRiZ//M3rVU8EA==","/dKGXxf3Sjm1jl//fR0Szw=="],"X-CSE-MsgGUID":["lQEIQolaStuPvQUgfjhXrQ==","B+/CovotTuijnxIGyMtg/w=="],"X-IronPort-AV":["E=McAfee;i=\"6800,10657,11706\"; a=\"90040006\"","E=Sophos;i=\"6.21,300,1763452800\";\n   d=\"scan'208\";a=\"90040006\"","E=Sophos;i=\"6.21,300,1763452800\";\n   d=\"scan'208\";a=\"219153829\""],"X-ExtLoop1":"1","From":"Andrei Otcheretianski <andrei.otcheretianski@intel.com>","To":"hostap@lists.infradead.org,\n\tvamsin@qti.qualcomm.com,\n\tvganneva@qti.qualcomm.com,\n\tmaheshkkv@google.com","Cc":"Ilan Peer <ilan.peer@intel.com>","Subject":"[PATCH 20/58] NAN: Add Tx status notification to NDL","Date":"Thu, 19 Feb 2026 22:24:36 +0200","Message-ID":"<20260219202514.5781-21-andrei.otcheretianski@intel.com>","X-Mailer":"git-send-email 2.52.0","In-Reply-To":"<20260219202514.5781-1-andrei.otcheretianski@intel.com>","References":"<20260219202514.5781-1-andrei.otcheretianski@intel.com>","MIME-Version":"1.0","X-CRM114-Version":"20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 ","X-CRM114-CacheID":"sfid-20260219_202658_232327_45D9CF37 ","X-CRM114-Status":"GOOD (  15.97  )","X-Spam-Score":"-2.5 (--)","X-Spam-Report":"Spam detection software,\n running on the system \"desiato.infradead.org\",\n has NOT identified this incoming email as spam.  The original\n message has been attached to this so you can view it or label\n similar future email.  If you have any questions, see\n the administrator of that system for details.\n Content preview:  From: Ilan Peer <ilan.peer@intel.com> Add a notification to\n    the NDL state machine to indicate successful transmission of a NAF. The\n notification\n    is used by the state machine to trigger appropriate operations such as\n setting\n    the state and [...]\n Content analysis details:   (-2.5 points, 5.0 required)\n  pts rule name              description\n ---- ----------------------\n --------------------------------------------------\n -2.3 RCVD_IN_DNSWL_MED      RBL: Sender listed at https://www.dnswl.org/,\n                             medium trust\n                             [198.175.65.10 listed in list.dnswl.org]\n -0.0 SPF_PASS               SPF: sender matches SPF record\n  0.0 SPF_HELO_NONE          SPF: HELO does not publish an SPF Record\n -0.1 DKIM_VALID_AU          Message has a valid DKIM or DK signature from\n author's\n                             domain\n -0.1 DKIM_VALID             Message has at least one valid DKIM or DK\n signature\n -0.1 DKIM_VALID_EF          Message has a valid DKIM or DK signature from\n                             envelope-from domain\n  0.1 DKIM_SIGNED            Message has a DKIM or DK signature,\n not necessarily valid\n  0.0 RCVD_IN_VALIDITY_SAFE_BLOCKED RBL: ADMINISTRATOR NOTICE: The query to\n                              Validity was blocked.  See\n                             https://knowledge.validity.com/hc/en-us/articles/20961730681243\n                              for more information.\n                             [198.175.65.10 listed in sa-accredit.habeas.com]\n  0.0 RCVD_IN_VALIDITY_CERTIFIED_BLOCKED RBL: ADMINISTRATOR NOTICE: The\n                             query to Validity was blocked.  See\n                             https://knowledge.validity.com/hc/en-us/articles/20961730681243\n                              for more information.\n                          [198.175.65.10 listed in\n sa-trusted.bondedsender.org]\n -0.0 DKIMWL_WL_HIGH         DKIMwl.org - High trust sender\n  0.0 RCVD_IN_VALIDITY_RPBL_BLOCKED RBL: ADMINISTRATOR NOTICE: The query to\n                              Validity was blocked.  See\n                             https://knowledge.validity.com/hc/en-us/articles/20961730681243\n                              for more information.\n                             [198.175.65.10 listed in\n bl.score.senderscore.com]","X-BeenThere":"hostap@lists.infradead.org","X-Mailman-Version":"2.1.34","Precedence":"list","List-Id":"<hostap.lists.infradead.org>","List-Unsubscribe":"<http://lists.infradead.org/mailman/options/hostap>,\n <mailto:hostap-request@lists.infradead.org?subject=unsubscribe>","List-Archive":"<http://lists.infradead.org/pipermail/hostap/>","List-Post":"<mailto:hostap@lists.infradead.org>","List-Help":"<mailto:hostap-request@lists.infradead.org?subject=help>","List-Subscribe":"<http://lists.infradead.org/mailman/listinfo/hostap>,\n <mailto:hostap-request@lists.infradead.org?subject=subscribe>","Content-Type":"text/plain; charset=\"us-ascii\"","Content-Transfer-Encoding":"7bit","Sender":"\"Hostap\" <hostap-bounces@lists.infradead.org>","Errors-To":"hostap-bounces+incoming=patchwork.ozlabs.org@lists.infradead.org"},"content":"From: Ilan Peer <ilan.peer@intel.com>\n\nAdd a notification to the NDL state machine to indicate\nsuccessful transmission of a NAF. The notification is used\nby the state machine to trigger appropriate operations such\nas setting the state and updating schedule as needed.\n\nSigned-off-by: Ilan Peer <ilan.peer@intel.com>\n---\n src/nan/nan_i.h   |  2 ++\n src/nan/nan_ndl.c | 90 +++++++++++++++++++++++++++++++++++++++++++++++\n 2 files changed, 92 insertions(+)","diff":"diff --git a/src/nan/nan_i.h b/src/nan/nan_i.h\nindex 7548e380a9..a6dd06677c 100644\n--- a/src/nan/nan_i.h\n+++ b/src/nan/nan_i.h\n@@ -426,4 +426,6 @@ int nan_ndl_add_qos_attr(struct nan_data *nan,\n \t\t\t struct wpabuf *buf);\n int nan_chan_to_chan_idx_map(struct nan_data *nan,\n \t\t\t     u8 op_class, u8 channel, u16 *chan_idx_map);\n+int nan_ndl_naf_sent(struct nan_data *nan, struct nan_peer *peer,\n+\t\t     enum nan_subtype subtype);\n #endif /* NAN_I_H */\ndiff --git a/src/nan/nan_ndl.c b/src/nan/nan_ndl.c\nindex d14f6bef21..64dce3f329 100644\n--- a/src/nan/nan_ndl.c\n+++ b/src/nan/nan_ndl.c\n@@ -1076,3 +1076,93 @@ int nan_ndl_add_qos_attr(struct nan_data *nan,\n \n \treturn 0;\n }\n+\n+\n+/*\n+ * nan_ndl_naf_sent - Indicate a NAF has been sent\n+ *\n+ * @nan: NAN module context from nan_init()\n+ * @peer: the peer with whom the NDL is being setup\n+ * @subtype: the NAN OUI subtype. See &enum nan_oui_subtype\n+ *\n+ * Notification, indicating to the NDL SM that a NAF was sent, so the\n+ * NDL SM could update its state.\n+ *\n+ * In case that the NDL setup negotiation is successfully done, the final\n+ * schedule is applied and the NDL is active. If the negotiation is done\n+ * and failed, the NDL state is reset.\n+ */\n+int nan_ndl_naf_sent(struct nan_data *nan, struct nan_peer *peer,\n+\t\t     enum nan_subtype subtype)\n+{\n+\tstruct nan_ndl *ndl;\n+\n+\tif (!peer || !peer->ndl)\n+\t\treturn -1;\n+\n+\tndl = peer->ndl;\n+\n+\tif (ndl->state == NAN_NDL_STATE_DONE)\n+\t\treturn 0;\n+\n+\twpa_printf(MSG_DEBUG,\n+\t\t   \"NAN: NDL: Tx done with peer=\" MACSTR \" state=%s, status=%u\",\n+\t\t   MAC2STR(peer->nmi_addr), nan_ndl_state_str(ndl->state),\n+\t\t   ndl->status);\n+\n+\t/* Note: due to races between the Tx status and Rx path, it is possible\n+\t * that the Tx status is received after the peer response was already\n+\t * processed (which can result with another frame being sent). In such a\n+\t * case the logic above fast-forwards the state, and the transitions\n+\t * here need to take this into consideration.\n+\t */\n+\tswitch (ndl->state) {\n+\tcase NAN_NDL_STATE_START:\n+\t\tif (subtype != NAN_SUBTYPE_DATA_PATH_REQUEST)\n+\t\t\treturn 0;\n+\t\tif (ndl->status != NAN_NDL_STATUS_CONTINUED) {\n+\t\t\twpa_printf(MSG_DEBUG,\n+\t\t\t\t   \"NAN: NDL: Tx sent: invalid continue status\");\n+\t\t\treturn -1;\n+\t\t}\n+\t\tnan_ndl_set_state(nan, ndl, NAN_NDL_STATE_REQ_SENT);\n+\t\treturn 0;\n+\tcase NAN_NDL_STATE_REQ_RECV:\n+\t\tif (subtype != NAN_SUBTYPE_DATA_PATH_RESPONSE)\n+\t\t\treturn 0;\n+\t\tif (ndl->status == NAN_NDL_STATUS_CONTINUED) {\n+\t\t\tnan_ndl_set_state(nan, ndl, NAN_NDL_STATE_RES_SENT);\n+\t\t\treturn 0;\n+\t\t}\n+\t\tbreak;\n+\tcase NAN_NDL_STATE_RES_RECV:\n+\t\tif (subtype != NAN_SUBTYPE_DATA_PATH_CONFIRM)\n+\t\t\treturn 0;\n+\t\tif (ndl->status == NAN_NDL_STATUS_CONTINUED) {\n+\t\t\twpa_printf(MSG_DEBUG,\n+\t\t\t\t   \"NAN: NDL: Tx sent: invalid continue status\");\n+\t\t\treturn -1;\n+\t\t}\n+\t\tbreak;\n+\tcase NAN_NDL_STATE_CON_RECV:\n+\tcase NAN_NDL_STATE_REQ_SENT:\n+\tcase NAN_NDL_STATE_RES_SENT:\n+\tcase NAN_NDL_STATE_CON_SENT:\n+\tcase NAN_NDL_STATE_DONE:\n+\tdefault:\n+\t\twpa_printf(MSG_DEBUG,\n+\t\t\t   \"NAN: NDL: Tx sent: unexpected state\");\n+\t\treturn 0;\n+\t}\n+\n+\tif (ndl->status == NAN_NDL_STATUS_ACCEPTED) {\n+\t\twpa_printf(MSG_DEBUG, \"NAN: NDL: schedule setup success\");\n+\t\tnan_ndl_set_state(nan, ndl, NAN_NDL_STATE_DONE);\n+\t\treturn 0;\n+\t}\n+\n+\t/* NDL is rejected and NAF already sent. Higher layer is expected to\n+\t * handle it.\n+\t */\n+\treturn 0;\n+}\n","prefixes":["20/58"]}