get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/1.0/patches/2198412/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 2198412,
    "url": "http://patchwork.ozlabs.org/api/1.0/patches/2198412/?format=api",
    "project": {
        "id": 22,
        "url": "http://patchwork.ozlabs.org/api/1.0/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": "<20260219202514.5781-15-andrei.otcheretianski@intel.com>",
    "date": "2026-02-19T20:24:30",
    "name": "[14/58] NAN: Add support for parsing element container attributes",
    "commit_ref": null,
    "pull_url": null,
    "state": "accepted",
    "archived": false,
    "hash": "e32ba2534c62ab5611a8bfbc13d579adce42c31d",
    "submitter": {
        "id": 62065,
        "url": "http://patchwork.ozlabs.org/api/1.0/people/62065/?format=api",
        "name": "Andrei Otcheretianski",
        "email": "andrei.otcheretianski@intel.com"
    },
    "delegate": null,
    "mbox": "http://patchwork.ozlabs.org/project/hostap/patch/20260219202514.5781-15-andrei.otcheretianski@intel.com/mbox/",
    "series": [
        {
            "id": 492721,
            "url": "http://patchwork.ozlabs.org/api/1.0/series/492721/?format=api",
            "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/2198412/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=xJ4WSUPr;\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=mIkeq0fT;\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 4fH4fV1pQDz1xpY\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 20 Feb 2026 07:26:42 +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 1vtAbH-0000000BwMl-1rFs;\n\tThu, 19 Feb 2026 20:26:15 +0000",
            "from mgamail.intel.com ([198.175.65.10])\n\tby bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux))\n\tid 1vtAbE-0000000BwCB-0U5r\n\tfor hostap@lists.infradead.org;\n\tThu, 19 Feb 2026 20:26:13 +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:12 -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:09 -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=1mRFDqPcV+YT7tDmZt8y85GdHkbJXVCDZuSjnIc+JT8=; b=xJ4WSUPrK6DdRE\n\tDdGnB+YpVF1Jejs9JwUhsL25IqDlOa6q3aKchmlQvmOonRD36zN2WprVXmrWHdbQozgkkIbukfOYO\n\t2jPxtFhI/3UYqP/pC6EjJZHWsAnxuVDbY5Sc1R8jzP7hLsPNk7s9UsFyoRk9lJcSyhhNG+gc47cSp\n\tWFZqXOsRXOo0dzyKQfgXIS7jac2ibinJ8Y5Amc6kVuScozbxWT29GC7GTZZ4AuivglrOYldY4aPdB\n\tY6ZbF37mDjry879EnwE0X5aeFAwJFQ7r2X8L1rbXH5Slq2y6An+hjpLcbKNHYn4e05wyV7CilTt8x\n\tDiUmXqKSPSxZfavNlzSA==;",
            "v=1; a=rsa-sha256; c=relaxed/simple;\n  d=intel.com; i=@intel.com; q=dns/txt; s=Intel;\n  t=1771532772; x=1803068772;\n  h=from:to:cc:subject:date:message-id:in-reply-to:\n   references:mime-version:content-transfer-encoding;\n  bh=Gr7pWDYPXM+5X2OKXqy+Mv8R6qIg0lUsQZp+KJSqZCM=;\n  b=mIkeq0fTEBNYGoaWxEbUZT1E2JV1uj9S822+fsXbctFiZBFSxq25JL8M\n   3nqmaR0aJ2MoJAwecTp5YUHwqKppgXYkIyrqwOb7sX5AWXaSelTv0T2ku\n   VtnrztXUmAQZHT2tYm3W/TUekucrGKjdxB7CNMG0z2wJaV0Fey9ftpzvX\n   S4ojVhYjTDqVV7ZLLHHtFf2tafROFI2oRGGmvqy23LOdhquZJFReW7bSR\n   1i8DlPUN+yym+SewkdixL0bukE7y2Dp8NB4eeAS27N6HelgTUnBSdX1ZM\n   MonOBIafxG13cKMG/IukZ4zupwN+SX6OS4Buq67ytsb71sEM2Md2p6m4Y\n   A==;"
        ],
        "X-CSE-ConnectionGUID": [
            "UfOYuY1kT2Oi0+r5SRV1eg==",
            "beSmFPOoQkKBPk+AzifVHA=="
        ],
        "X-CSE-MsgGUID": [
            "Rs4o5ppqTbe1gcLpGc867A==",
            "BdZXjc75SnSE1sHpyOPfww=="
        ],
        "X-IronPort-AV": [
            "E=McAfee;i=\"6800,10657,11706\"; a=\"90039977\"",
            "E=Sophos;i=\"6.21,300,1763452800\";\n   d=\"scan'208\";a=\"90039977\"",
            "E=Sophos;i=\"6.21,300,1763452800\";\n   d=\"scan'208\";a=\"219153785\""
        ],
        "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 14/58] NAN: Add support for parsing element container\n attributes",
        "Date": "Thu, 19 Feb 2026 22:24:30 +0200",
        "Message-ID": "<20260219202514.5781-15-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_122612_246406_74521988 ",
        "X-CRM114-Status": "GOOD (  14.42  )",
        "X-Spam-Score": "-4.4 (----)",
        "X-Spam-Report": "Spam detection software,\n running on the system \"bombadil.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> Support parsing and\n   storing multiple element container attributes. Signed-off-by: Ilan Peer\n <ilan.peer@intel.com>\n    --- src/nan/nan.c | 56 +++++++++++++++++++++++++++++++++++++++++++++++++\n   src/nan/nan_i.h | 17 +++++++++++++++ 2 files changed, 73 insertions(+)\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.10 listed in list.dnswl.org]\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 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]\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_EF          Message has a valid DKIM or DK signature from\n                             envelope-from domain\n -0.1 DKIM_VALID             Message has at least one valid DKIM or DK\n signature\n  0.1 DKIM_SIGNED            Message has a DKIM or DK signature,\n not necessarily valid\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\nSupport parsing and storing multiple element container\nattributes.\n\nSigned-off-by: Ilan Peer <ilan.peer@intel.com>\n---\n src/nan/nan.c   | 56 +++++++++++++++++++++++++++++++++++++++++++++++++\n src/nan/nan_i.h | 17 +++++++++++++++\n 2 files changed, 73 insertions(+)",
    "diff": "diff --git a/src/nan/nan.c b/src/nan/nan.c\nindex 2f30a33527..c5ec3f446e 100644\n--- a/src/nan/nan.c\n+++ b/src/nan/nan.c\n@@ -68,6 +68,19 @@ static void nan_peer_flush_dev_capa(struct nan_peer_info *info)\n \t}\n }\n \n+\n+static void nan_peer_flush_elem_container(struct nan_peer_info *info)\n+{\n+\tstruct nan_elem_container_entry *cur, *next;\n+\n+\tdl_list_for_each_safe(cur, next, &info->element_container,\n+\t\t\t      struct nan_elem_container_entry, list) {\n+\t\tdl_list_del(&cur->list);\n+\t\tos_free(cur);\n+\t}\n+}\n+\n+\n static void nan_del_peer(struct nan_data *nan, struct nan_peer *peer)\n {\n \tif (!peer)\n@@ -99,6 +112,7 @@ static void nan_del_peer(struct nan_data *nan, struct nan_peer *peer)\n \tdl_list_del(&peer->list);\n \tnan_peer_flush_avail(&peer->info);\n \tnan_peer_flush_dev_capa(&peer->info);\n+\tnan_peer_flush_elem_container(&peer->info);\n \tos_free(peer);\n }\n \n@@ -844,6 +858,45 @@ static void nan_parse_peer_device_capa(struct nan_data *nan,\n }\n \n \n+static void nan_parse_peer_elem_container(struct nan_data *nan,\n+\t\t\t\t\t  struct nan_peer *peer,\n+\t\t\t\t\t  const struct nan_attrs *attrs)\n+{\n+\tstruct nan_attrs_entry *attr;\n+\n+\tdl_list_for_each(attr, &attrs->element_container, struct nan_attrs_entry,\n+\t\t\t list) {\n+\t\tstruct nan_elem_container_entry *entry, *next;\n+\t\tu8 map_id = *attr->ptr;\n+\n+\t\t/* Guarantee that there is only a single entry for each map ID */\n+\t\tdl_list_for_each_safe(entry, next, &peer->info.element_container,\n+\t\t\t\t struct nan_elem_container_entry, list) {\n+\n+\t\t\tif (entry->map_id == map_id) {\n+\t\t\t\tdl_list_del(&entry->list);\n+\t\t\t\tos_free(entry);\n+\t\t\t\tbreak;\n+\t\t\t}\n+\t\t}\n+\n+\t\tentry = os_zalloc(sizeof(*entry) + attr->len - 1);\n+\t\tif (!entry) {\n+\t\t\twpa_printf(MSG_DEBUG,\n+\t\t\t\t   \"NAN: Failed to allocate element container entry\");\n+\t\t\treturn;\n+\t\t}\n+\n+\t\tdl_list_init(&entry->list);\n+\t\tdl_list_add(&peer->info.element_container, &entry->list);\n+\n+\t\tentry->map_id = map_id;\n+\t\tentry->len = attr->len - 1;\n+\t\tos_memcpy(entry->data, attr->ptr + 1, entry->len);\n+\t}\n+}\n+\n+\n /*\n  * nan_parse_device_attrs - Parse device attributes and build availability info\n  *\n@@ -878,6 +931,7 @@ int nan_parse_device_attrs(struct nan_data *nan, struct nan_peer *peer,\n \n \tnan_merge_peer_info(&peer->info, &info);\n \tnan_parse_peer_device_capa(nan, peer, &attrs);\n+\tnan_parse_peer_elem_container(nan, peer, &attrs);\n \n \tnan_peer_dump(nan, peer);\n \tret = 0;\n@@ -924,6 +978,8 @@ static struct nan_peer *nan_alloc_peer(struct nan_data *nan)\n \n \tdl_list_init(&peer->info.avail_entries);\n \tdl_list_init(&peer->info.dev_capa);\n+\tdl_list_init(&peer->info.element_container);\n+\n \tdl_list_add(&nan->peer_list, &peer->list);\n \tdl_list_init(&peer->ndps);\n \treturn peer;\ndiff --git a/src/nan/nan_i.h b/src/nan/nan_i.h\nindex a2fed5bf2f..d80dd4dc06 100644\n--- a/src/nan/nan_i.h\n+++ b/src/nan/nan_i.h\n@@ -172,6 +172,21 @@ struct nan_dev_capa_entry {\n \tstruct nan_device_capabilities capa;\n };\n \n+/*\n+ * struct nan_elem_container_entry - NAN element container entry\n+ *\n+ * @list: Used for linking in the element container entries list.\n+ * @map_id: Map id of the element container.\n+ * @len: Length of data.\n+ * @data: Pointer to the data.\n+ */\n+struct nan_elem_container_entry {\n+\tstruct dl_list list;\n+\tu8 map_id;\n+\tu16 len;\n+\tu8 data[];\n+};\n+\n /*\n  * struct nan_peer_info - NAN peer information\n  *\n@@ -179,12 +194,14 @@ struct nan_dev_capa_entry {\n  * @seq_id: Sequence id of the last availability update.\n  * @avail_entries: List of availability entries of the peer.\n  * @dev_capa: List of device capabilities of the peer.\n+ * @element_container: List of element container entries of the peer.\n  */\n struct nan_peer_info {\n \tstruct os_reltime last_seen;\n \tu8 seq_id;\n \tstruct dl_list avail_entries;\n \tstruct dl_list dev_capa;\n+\tstruct dl_list element_container;\n };\n \n /**\n",
    "prefixes": [
        "14/58"
    ]
}