{"id":2229870,"url":"http://patchwork.ozlabs.org/api/1.1/patches/2229870/?format=json","web_url":"http://patchwork.ozlabs.org/project/hostap/patch/20260428200639.40243-62-andrei.otcheretianski@intel.com/","project":{"id":22,"url":"http://patchwork.ozlabs.org/api/1.1/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":"<20260428200639.40243-62-andrei.otcheretianski@intel.com>","date":"2026-04-28T20:06:02","name":"[RFC,61/97] tests: Verify NAN max idle period","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"892244c9019262b3e2fdc83742589881f2e5788b","submitter":{"id":62065,"url":"http://patchwork.ozlabs.org/api/1.1/people/62065/?format=json","name":"Andrei Otcheretianski","email":"andrei.otcheretianski@intel.com"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/hostap/patch/20260428200639.40243-62-andrei.otcheretianski@intel.com/mbox/","series":[{"id":501927,"url":"http://patchwork.ozlabs.org/api/1.1/series/501927/?format=json","web_url":"http://patchwork.ozlabs.org/project/hostap/list/?series=501927","date":"2026-04-28T20:05:05","name":"NAN: Group keys support, schedule update and more","version":1,"mbox":"http://patchwork.ozlabs.org/series/501927/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2229870/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2229870/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=tuXdrPIl;\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=casper.20170209 header.b=n9G45U4N;\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=G8XIwrw2;\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 4g4s7p30sMz1xrS\n\tfor <incoming@patchwork.ozlabs.org>; Wed, 29 Apr 2026 06:13:24 +1000 (AEST)","from localhost ([::1] helo=bombadil.infradead.org)\n\tby bombadil.infradead.org with esmtp (Exim 4.98.2 #2 (Red Hat Linux))\n\tid 1wHonc-00000002JTG-2UEt;\n\tTue, 28 Apr 2026 20:12:52 +0000","from casper.infradead.org ([2001:8b0:10b:1236::1])\n\tby bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux))\n\tid 1wHokO-00000002F3A-489h\n\tfor hostap@bombadil.infradead.org;\n\tTue, 28 Apr 2026 20:09:33 +0000","from mgamail.intel.com ([198.175.65.16])\n\tby casper.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux))\n\tid 1wHokK-00000004NBq-1gea\n\tfor hostap@lists.infradead.org;\n\tTue, 28 Apr 2026 20:09:31 +0000","from fmviesa001.fm.intel.com ([10.60.135.141])\n  by orvoesa108.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 28 Apr 2026 13:08:49 -0700","from iapp347.iil.intel.com (HELO 87c02287900a.iil.intel.com)\n ([10.167.28.6])\n  by smtpauth.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 28 Apr 2026 13:08:48 -0700"],"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=8y7gCckY1IJhJrMQWMZ3m9ePkrJbZG15m8q99bYNMV0=; b=tuXdrPIlKc76Sp\n\t8YwdGnNIwf2amrfWaNS3AkXQnmnLcpLQM2lJsVVg5/3TLtffS4LMJQKgErThLPliKlNuDBsTUxBIW\n\tAKi7P/SoUFX1wPyEvxu0V0dWI/8SiKifpo5V/HuF6izJsj+t5Md/p1joIgpaGjtU/MOQgddjLeFn4\n\tV+N5tPnZUpUQTXEo50dNxdpk8mH3CJazQkhrb0UeKZ3TktFb9w5HuqI/fgw2343TqHzAePa/4lMDD\n\tA889EiHuzCiUA+k9WL2KN5N4XCZ/1LatS7E7l6AVAq+xqDDx8lA5jkzl/Hu2y+srSYyYb/RN1+aMD\n\tGKCZF+PaCdwK43JPylUA==;","v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed;\n\td=infradead.org; s=casper.20170209; h=Content-Transfer-Encoding:MIME-Version:\n\tReferences:In-Reply-To:Message-ID:Date:Subject:Cc:To:From:Sender:Reply-To:\n\tContent-Type:Content-ID:Content-Description;\n\tbh=xgNqdJVKkqNPQzgGfviszNnoigNUOrCTYDXre5NMwAk=; b=n9G45U4NAY1WDhUmomG7N/gUuW\n\tanM/qv5qe7k/MEYUq+jOhsqQBtC8gLf4w8R5Nq34hEe+vQj1Q+Qsi03gTiMVV0klVOFnK500qBR5d\n\tm1vRiQc4yJX2d0LD+SA9bhI9/+MH8JLmZ6wGkiOYyk7S8/GiUIRZMlq5KTboHX+RELgUXiCPeam/Y\n\tN3TX6as6ASnNcu8EufR5DhNH7SIudcPswlz9EIJclEpvJvZTmwHSYPTEVUcsM4z2CipDgH0tGBrW2\n\tynPdi1iRPhtwgihzgcqRun+5TAECLGvWgnaKUAy7q8h4ZPFxQqQPm77n/WgXPetJy/cnKO0KxiW4F\n\tLqh1J1Xw==;","v=1; a=rsa-sha256; c=relaxed/simple;\n  d=intel.com; i=@intel.com; q=dns/txt; s=Intel;\n  t=1777406968; x=1808942968;\n  h=from:to:cc:subject:date:message-id:in-reply-to:\n   references:mime-version:content-transfer-encoding;\n  bh=2ioS5XkZK3PefDR1CIdtkCIX4BeuGpyaqCyZFkjkgJw=;\n  b=G8XIwrw2RNNoj35vPJEzMt4PybXTTwLjPTcfbYyhL6qCJypgYsZYd8Ij\n   VBEKa3BX/bnHuvEZjl86xM7QcGflib3cQ6vfaevA/cgpEIv+krnQESwAr\n   MiC72n3fvLkMzfqvMOLfw0+mir16DYDh2/WLBDeV/M73kNhWl78e54wUL\n   mYdbGWMxtI3gqNVNVvRL8ZT6PeaNDxseHvvjRlVdALJzX/6l3TxyZkSzX\n   2xc9+CfFxV5B1jxJsKZVnEUuTYyb/HVwgc0D6/+EvO+0Ue5keLRY4SRuI\n   VTr0HADSCuBOZ4YYdrI6fvCI3gxqTP7nh9cAPXPU56F9KYZNGEE4uvnqS\n   A==;"],"X-CSE-ConnectionGUID":["57n3/XsORsyZdu4Ha9wxBw==","1W2U2+P4Q6eyZOWRUETp3A=="],"X-CSE-MsgGUID":["SsupINXsSRCc9jUq+WSPHw==","fqiX9C+2S/qv3ssL0JD5CQ=="],"X-IronPort-AV":["E=McAfee;i=\"6800,10657,11770\"; a=\"78519484\"","E=Sophos;i=\"6.23,204,1770624000\";\n   d=\"scan'208\";a=\"78519484\"","E=Sophos;i=\"6.23,204,1770624000\";\n   d=\"scan'208\";a=\"257610644\""],"X-ExtLoop1":"1","From":"Andrei Otcheretianski <andrei.otcheretianski@intel.com>","To":"hostap@lists.infradead.org","Cc":"vamsin@qti.qualcomm.com,\n\tmaheshkkv@google.com,\n\tIlan Peer <ilan.peer@intel.com>","Subject":"[RFC 61/97] tests: Verify NAN max idle period","Date":"Tue, 28 Apr 2026 23:06:02 +0300","Message-ID":"<20260428200639.40243-62-andrei.otcheretianski@intel.com>","X-Mailer":"git-send-email 2.53.0","In-Reply-To":"<20260428200639.40243-1-andrei.otcheretianski@intel.com>","References":"<20260428200639.40243-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-20260428_210928_779487_67D84185 ","X-CRM114-Status":"UNSURE (   8.92  )","X-CRM114-Notice":"Please train this message.","X-Spam-Score":"-4.4 (----)","X-Spam-Report":"SpamAssassin version 4.0.1 on casper.infradead.org summary:\n Content analysis details:   (-4.4 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.16 listed in list.dnswl.org]\n  0.0 SPF_HELO_NONE          SPF: HELO does not publish an SPF Record\n -0.0 SPF_PASS               SPF: sender matches SPF record\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.1 DKIM_VALID_AU          Message has a valid DKIM or DK signature from\n author's\n                             domain\n -1.9 BAYES_00               BODY: Bayes spam probability is 0 to 1%\n                             [score: 0.0000]\n -0.0 DKIMWL_WL_HIGH         DKIMwl.org - High trust sender","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 testing coverage to verify that NAN idle max period\nis handled as expected, i.e., NDP/NDL are terminated\nwhen there is no traffic.\n\nSigned-off-by: Ilan Peer <ilan.peer@intel.com>\n---\n tests/hwsim/test_nan.py | 49 +++++++++++++++++++++++++++++++++++++----\n 1 file changed, 45 insertions(+), 4 deletions(-)","diff":"diff --git a/tests/hwsim/test_nan.py b/tests/hwsim/test_nan.py\nindex 24da9dc629..56ffd734d2 100644\n--- a/tests/hwsim/test_nan.py\n+++ b/tests/hwsim/test_nan.py\n@@ -1177,7 +1177,8 @@ def _nan_test_connectivity(pub, sub):\n     test_connectivity(wpas_ndi_pub, wpas_ndi_sub, tos=0, ifname1=pub.ndi_name, ifname2=sub.ndi_name,\n                       max_tries=3, timeout=5, broadcast=False)\n \n-def _run_nan_dp(counter=False, csid=None, wrong_pwd=False, use_pmk=False, use_interface_id=False):\n+def _run_nan_dp(counter=False, csid=None, wrong_pwd=False, use_pmk=False,\n+                use_interface_id=False, verify_max_idle_period=False):\n     if use_pmk:\n         pmk = \"00112233445566778899aabbccddeeff00112233445566778899aabbccddeeff\"\n         pwd = None\n@@ -1205,6 +1206,10 @@ def _run_nan_dp(counter=False, csid=None, wrong_pwd=False, use_pmk=False, use_in\n         capa = pub.wpas.request(\"NAN_PEER_INFO \" + saddr + \" capa\")\n         logger.info(\"\\n\" + capa)\n \n+        if verify_max_idle_period:\n+            pub.set(\"max_ndl_idle_period\", \"10\")\n+            sub.set(\"max_ndl_idle_period\", \"10\")\n+\n         result = _nan_ndp_request_and_accept(pub, sub, pid, sid, paddr, saddr, req_ssi=\"aabbcc\",\n                                              resp_ssi=\"ddeeff\", csid=csid, password=pwd, pmk=pmk,\n                                              counter=counter, wrong_pwd=wrong_pwd,\n@@ -1217,14 +1222,45 @@ def _run_nan_dp(counter=False, csid=None, wrong_pwd=False, use_pmk=False, use_in\n         ndp_id, init_ndi = result\n \n         _nan_test_connectivity(pub, sub)\n-        _nan_ndp_terminate(pub, sub, paddr, init_ndi, ndp_id)\n+\n+        if not verify_max_idle_period:\n+            _nan_ndp_terminate(pub, sub, paddr, init_ndi, ndp_id)\n+            return\n+        else:\n+            sub_sched = pub.wpas.request(\"NAN_PEER_INFO \" + saddr + \" schedule\")\n+            m = re.search(r'\\bmax_idle_period\\s*=\\s*(\\d+)', sub_sched)\n+            if not m:\n+                raise Exception(\"max_idle_period not found in peer schedule\")\n+\n+            if int(m.group(1)) != 10:\n+                raise Exception(f\"Unexpected max_idle_period value in peer schedule: {m.group(1)}\")\n+\n+            pub_sched = sub.wpas.request(\"NAN_PEER_INFO \" + paddr + \" schedule\")\n+            m = re.search(r'\\bmax_idle_period\\s*=\\s*(\\d+)', pub_sched)\n+            if not m:\n+                raise Exception(\"max_idle_period not found in peer schedule\")\n+\n+            if int(m.group(1)) != 10:\n+                raise Exception(f\"Unexpected max_idle_period value in peer schedule: {m.group(1)}\")\n+\n+            # Verify that the NDP is terminated due to max idle period (no traffic).\n+            # While the max idle period is set to 10 seconds, wait longer as there is traffic\n+            # generated internally by the kernel, e.g., IPv6 router solicitation messages.\n+            ev = pub.wpas.wait_event([\"NAN-NDP-DISCONNECTED\"], timeout=30)\n+            if ev is None or \"locally_generated=1\" not in ev or \"reason=1\" not in ev:\n+                raise Exception(f\"NAN-NDP-DISCONNECTED event not seen on publisher or invalid data\")\n+\n+            ev = sub.wpas.wait_event([\"NAN-NDP-DISCONNECTED\"], timeout=30)\n+            if ev is None or \"locally_generated=1\" not in ev or \"reason=1\" not in ev:\n+                raise Exception(f\"NAN-NDP-DISCONNECTED event not seen on subscriber or invalid data\")\n \n def run_nan_dp(country=\"US\", counter=False, csid=None, wrong_pwd=False, use_pmk=False,\n-               use_interface_id=False):\n+               use_interface_id=False, verify_max_idle_period=False):\n     set_country(country)\n     try:\n         _run_nan_dp(counter=counter, csid=csid, wrong_pwd=wrong_pwd, use_pmk=use_pmk,\n-                    use_interface_id=use_interface_id)\n+                    use_interface_id=use_interface_id,\n+                    verify_max_idle_period=verify_max_idle_period)\n     finally:\n         set_country(\"00\")\n \n@@ -1788,3 +1824,8 @@ def test_nan_ndp_reconnect_after_terminate(dev, apdev, params):\n         _run_nan_ndp_reconnect_after_terminate()\n     finally:\n         set_country(\"00\")\n+\n+@long_duration_test\n+def test_nan_dp_max_idle_period(dev, apdev, params):\n+    \"\"\"NAN DP open with max idle period verification\"\"\"\n+    run_nan_dp(use_interface_id=True, verify_max_idle_period=True)\n","prefixes":["RFC","61/97"]}