Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/1.1/patches/2229870/?format=api
{ "id": 2229870, "url": "http://patchwork.ozlabs.org/api/1.1/patches/2229870/?format=api", "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=api", "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=api", "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=api", "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" ] }