Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/2216474/?format=api
{ "id": 2216474, "url": "http://patchwork.ozlabs.org/api/patches/2216474/?format=api", "web_url": "http://patchwork.ozlabs.org/project/linux-gpio/patch/20260326-gpio-hogs-multiple-v2-1-7c3813460e4f@oss.qualcomm.com/", "project": { "id": 42, "url": "http://patchwork.ozlabs.org/api/projects/42/?format=api", "name": "Linux GPIO development", "link_name": "linux-gpio", "list_id": "linux-gpio.vger.kernel.org", "list_email": "linux-gpio@vger.kernel.org", "web_url": "", "scm_url": "", "webscm_url": "", "list_archive_url": "", "list_archive_url_format": "", "commit_url_format": "" }, "msgid": "<20260326-gpio-hogs-multiple-v2-1-7c3813460e4f@oss.qualcomm.com>", "list_archive_url": null, "date": "2026-03-26T14:18:18", "name": "[v2] gpiolib: fix hogs with multiple lines", "commit_ref": null, "pull_url": null, "state": "new", "archived": false, "hash": "96a085a5ee459c8ade4303173eb734cf850322c7", "submitter": { "id": 92196, "url": "http://patchwork.ozlabs.org/api/people/92196/?format=api", "name": "Bartosz Golaszewski", "email": "bartosz.golaszewski@oss.qualcomm.com" }, "delegate": null, "mbox": "http://patchwork.ozlabs.org/project/linux-gpio/patch/20260326-gpio-hogs-multiple-v2-1-7c3813460e4f@oss.qualcomm.com/mbox/", "series": [ { "id": 497601, "url": "http://patchwork.ozlabs.org/api/series/497601/?format=api", "web_url": "http://patchwork.ozlabs.org/project/linux-gpio/list/?series=497601", "date": "2026-03-26T14:18:18", "name": "[v2] gpiolib: fix hogs with multiple lines", "version": 2, "mbox": "http://patchwork.ozlabs.org/series/497601/mbox/" } ], "comments": "http://patchwork.ozlabs.org/api/patches/2216474/comments/", "check": "pending", "checks": "http://patchwork.ozlabs.org/api/patches/2216474/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "\n <linux-gpio+bounces-34213-incoming=patchwork.ozlabs.org@vger.kernel.org>", "X-Original-To": [ "incoming@patchwork.ozlabs.org", "linux-gpio@vger.kernel.org" ], "Delivered-To": "patchwork-incoming@legolas.ozlabs.org", "Authentication-Results": [ "legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=qualcomm.com header.i=@qualcomm.com header.a=rsa-sha256\n header.s=qcppdkim1 header.b=MuObGuZ7;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com\n header.a=rsa-sha256 header.s=google header.b=jSCZ0AEh;\n\tdkim-atps=neutral", "legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=2600:3c15:e001:75::12fc:5321; helo=sin.lore.kernel.org;\n envelope-from=linux-gpio+bounces-34213-incoming=patchwork.ozlabs.org@vger.kernel.org;\n receiver=patchwork.ozlabs.org)", "smtp.subspace.kernel.org;\n\tdkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com\n header.b=\"MuObGuZ7\";\n\tdkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com\n header.b=\"jSCZ0AEh\"", "smtp.subspace.kernel.org;\n arc=none smtp.client-ip=205.220.180.131", "smtp.subspace.kernel.org;\n dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com", "smtp.subspace.kernel.org;\n spf=pass smtp.mailfrom=oss.qualcomm.com" ], "Received": [ "from sin.lore.kernel.org (sin.lore.kernel.org\n [IPv6:2600:3c15:e001:75::12fc:5321])\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 4fhR0b0Ptgz1y1x\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 27 Mar 2026 01:26:23 +1100 (AEDT)", "from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sin.lore.kernel.org (Postfix) with ESMTP id D65CA3006D6C\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 26 Mar 2026 14:19:31 +0000 (UTC)", "from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id 028003F8810;\n\tThu, 26 Mar 2026 14:18:35 +0000 (UTC)", "from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com\n [205.220.180.131])\n\t(using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby smtp.subspace.kernel.org (Postfix) with ESMTPS id 4FDEA39184A\n\tfor <linux-gpio@vger.kernel.org>; Thu, 26 Mar 2026 14:18:27 +0000 (UTC)", "from pps.filterd (m0279868.ppops.net [127.0.0.1])\n\tby mx0a-0031df01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id\n 62QCsH6Z052332\n\tfor <linux-gpio@vger.kernel.org>; Thu, 26 Mar 2026 14:18:27 GMT", "from mail-vs1-f70.google.com (mail-vs1-f70.google.com\n [209.85.217.70])\n\tby mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 4d4q1t351u-1\n\t(version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NOT)\n\tfor <linux-gpio@vger.kernel.org>; Thu, 26 Mar 2026 14:18:26 +0000 (GMT)", "by mail-vs1-f70.google.com with SMTP id\n ada2fe7eead31-5ffaa85b95bso1469354137.1\n for <linux-gpio@vger.kernel.org>;\n Thu, 26 Mar 2026 07:18:26 -0700 (PDT)", "from brgl-qcom.local ([2a01:cb1d:dc:7e00:f36c:4a15:cca2:5268])\n by smtp.gmail.com with ESMTPSA id\n 5b1f17b1804b1-48722ca344dsm28405845e9.12.2026.03.26.07.18.23\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Thu, 26 Mar 2026 07:18:24 -0700 (PDT)" ], "ARC-Seal": "i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1774534713; cv=none;\n b=rhOJPChgGMqEgLGoXBCY4lWW2KTm/4NUU+5sQ9zDqt9+tKZ+xv5QYmcW+2+vR/eZ3OwDRwZXRUxRWVlnDfS+ldwpOawSE5mWB2D1CfpWXWe6QHMztynqOaYppGfk8q61tym8M+KHXmt9foYY28DpIQg4bvAiqevyc9C7upmeFQ8=", "ARC-Message-Signature": "i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1774534713; c=relaxed/simple;\n\tbh=621EXQPHHp1oek5UIpVZlw/H7Y1Xhl7Qy8Kc/NSLT2Q=;\n\th=From:Date:Subject:MIME-Version:Content-Type:Message-Id:To:Cc;\n b=m9NYn7e6keezUWTl18qTmh5SKYJJhsLEpixxN9HJWtduoZysD8uEqqSHPHDY8bMQ7ZyIGBBl9sD59vX1YlgJg7NsSAVTNvqf6D+jG0CoBjRPY1FhK28T9n7tpTpC3IpCRw4SRScSIRqd7Q2v43d01avEfnfm2mzarY7bePMTP4w=", "ARC-Authentication-Results": "i=1; smtp.subspace.kernel.org;\n dmarc=pass (p=reject dis=none) header.from=oss.qualcomm.com;\n spf=pass smtp.mailfrom=oss.qualcomm.com;\n dkim=pass (2048-bit key) header.d=qualcomm.com header.i=@qualcomm.com\n header.b=MuObGuZ7;\n dkim=pass (2048-bit key) header.d=oss.qualcomm.com header.i=@oss.qualcomm.com\n header.b=jSCZ0AEh; arc=none smtp.client-ip=205.220.180.131", "DKIM-Signature": [ "v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h=\n\tcc:content-transfer-encoding:content-type:date:from:message-id\n\t:mime-version:subject:to; s=qcppdkim1; bh=GRric16bnLzc3ebet/NeXU\n\t0VKg20Q/aQFLGLCvrJZJ4=; b=MuObGuZ7xH678q1Be9ZSZOINz+AadwYZ9kFmbh\n\tEhvpca4qN+8yysO8SP5gKOuO/4jSL2pMg45ks/6LMVImkaStr6xsB+7aMHOTxAQ+\n\tEVTG9rJqhm8+z4UkbR0rcyXK6oahAuMpE470Abg7m6XZQ4nGSxNXdc1D+zyZbzoL\n\tcC0Q44kISZEMl8dZNGC3ORC/P0bKH2JIz3rNPXl0aLLlXBdWMZ3sztR2V6VsImjr\n\tV0lcBDdt+2wKs/cBn/U9/jalBz0o8d3SoWupRWYgvj+Nn5wW9bybE7Vp9COM/EDP\n\tHZy5NMATU7MTRyu20o1e1MFIjayChx0u1mCdX07BTzzYnIVg==", "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=oss.qualcomm.com; s=google; t=1774534706; x=1775139506;\n darn=vger.kernel.org;\n h=cc:to:message-id:content-transfer-encoding:mime-version:subject\n :date:from:from:to:cc:subject:date:message-id:reply-to;\n bh=GRric16bnLzc3ebet/NeXU0VKg20Q/aQFLGLCvrJZJ4=;\n b=jSCZ0AEhCGG+03nLOFa4ojeFRcyaUS9i3SxNEFKtb4P83/Wk1VRjakoM7nppEdO6yR\n VQPrZO93Kb3CBT05j2+JG+BfAn8/hDU/z6rYkpaSQPocEAvXkrvNGbHlqe4GYmKy/RGv\n CSjfQBJreaQzM1kmg65rZh2MJwwga5AYSYP6gtb39KOsiKHcMXG96cKDZSe2RAdBKePX\n qNBMfCs8g1Bim3qm+qccpIDraReIQlZMYNpGL1lY6Az9MXCM9of56umpm9aG28EeQOlB\n qHnoPyP3w3NqvDyI4cJ++d91ZWRArBR5ISv6qFo3wAEXs5Tr4ybGWxhtrBdeANcicbyS\n ptOQ==" ], "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20251104; t=1774534706; x=1775139506;\n h=cc:to:message-id:content-transfer-encoding:mime-version:subject\n :date:from:x-gm-gg:x-gm-message-state:from:to:cc:subject:date\n :message-id:reply-to;\n bh=GRric16bnLzc3ebet/NeXU0VKg20Q/aQFLGLCvrJZJ4=;\n b=OUpC/ncEQJshBimjP7XiTWV3H34BeaXFtK8qOc6bwRR0bIXuJT2+XWeyayw38t2bax\n WxBv4mHMy9wV4GP995EcPvR5mr2TPsEqbfXvOiHjJGnv6Rcgk3YEkDDGqqFUbyTCPHH3\n jNs0A74C4fEqiOQfPwkWmk7+AUnM1hfAh+PYHb20ANNQ69IV287OWOmp2pF69ZFicloe\n JnPmqEmw+g3HQd3rlG4rHkVGPvW7Ni8Ex91rMhCjuaEsTitP5KNBdNlOXmEigRXgjLRv\n jBKRp/wr3ZmXyfdx69NHQPXOwAUuCfS6gNVS8Sv3RzWYeFxVl0wGKMezEjUNpIRbvrW5\n okwA==", "X-Gm-Message-State": "AOJu0Yy/AjZCV6Pzf3haobRv9ps1pzazcqE0fGD0GK9lpzNmUVZyk1b0\n\tOYL1q9ZTI1Atu1YJ0eHi33w/UjlA7FKoVNPkDoc2o8TP/uAlpzlkBulaD6RwJfp0+mKN7faRfq9\n\tWQrir+CuwHSobtcfF9slPhu2y1v1zT26y5LVnmrGeyC6gUcbRBiq2mTE8DKZzsfZk", "X-Gm-Gg": "ATEYQzyxVIKchQnCRxT6Ri2n8lLj9IJDiKaPJBKnyZ5y2r0sinI7qGoEYwVXIzzF9UI\n\t8xXd1Kl+l61TMH52/9y48Oup7Qh+EneQyaUpUCY293es6dkd6euWpm1LCVtkmSgu307kgbkd2br\n\tHRwc810zz/gekD6jhwPJVqKK673A/ksZ6XOBcsOjCoc/iSWm9o7UUNa0YY3fyGwXDNlyHu0EP2g\n\twKJfWh4GcV3EtXKcNuB52NbHwoddVdXQslHNcd758UxaGHgNqStF26ZPy7OK+9gWK4f1ofau67O\n\t5aFUxRRQJ2yZx2CmwFqABU5n6km94bT1mH+bVhsUL2l2Ln0bmhO4/8J8m6yXHfkHfuU0+TZ3fJ0\n\tYB0Z979VgmYI3fBmQ7c9t29yhTYS94gfdq4MIELG2rUmeQF2CX6y4", "X-Received": [ "by 2002:a05:6102:4b0f:b0:602:91f2:6af6 with SMTP id\n ada2fe7eead31-60387292b42mr3666438137.17.1774534705905;\n Thu, 26 Mar 2026 07:18:25 -0700 (PDT)", "by 2002:a05:6102:4b0f:b0:602:91f2:6af6 with SMTP id\n ada2fe7eead31-60387292b42mr3666405137.17.1774534705399;\n Thu, 26 Mar 2026 07:18:25 -0700 (PDT)" ], "From": "Bartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com>", "Date": "Thu, 26 Mar 2026 15:18:18 +0100", "Subject": "[PATCH v2] gpiolib: fix hogs with multiple lines", "Precedence": "bulk", "X-Mailing-List": "linux-gpio@vger.kernel.org", "List-Id": "<linux-gpio.vger.kernel.org>", "List-Subscribe": "<mailto:linux-gpio+subscribe@vger.kernel.org>", "List-Unsubscribe": "<mailto:linux-gpio+unsubscribe@vger.kernel.org>", "MIME-Version": "1.0", "Content-Type": "text/plain; charset=\"utf-8\"", "Content-Transfer-Encoding": "7bit", "Message-Id": "<20260326-gpio-hogs-multiple-v2-1-7c3813460e4f@oss.qualcomm.com>", "X-B4-Tracking": "v=1; b=H4sIAClAxWkC/32NQQqDMBBFryKz7ohJqpGueo/iwuqoA2rSjEqLe\n PemHqCbD+/Df38HocAkcEt2CLSxsJsj6EsCzVDPPSG3kUFnusiMzrH37HBwveC0jgv7kVBZVba\n mbFSXPyEOfaCO36f0UUUeWBYXPufHpn7tX92mUKElU1tztV3WFncnkr7WemzcNKUxoDqO4wuwB\n k8yuwAAAA==", "X-Change-ID": "20260325-gpio-hogs-multiple-1718d38c1f5b", "To": "Linus Walleij <linusw@kernel.org>, Bartosz Golaszewski <brgl@kernel.org>,\n Mika Westerberg <mika.westerberg@linux.intel.com>,\n Andy Shevchenko <andriy.shevchenko@linux.intel.com>,\n Geert Uytterhoeven <geert+renesas@glider.be>", "Cc": "linux-gpio@vger.kernel.org, linux-kernel@vger.kernel.org,\n Geert Uytterhoeven <geert@linux-m68k.org>,\n Bartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com>", "X-Mailer": "b4 0.14.2", "X-Developer-Signature": "v=1; a=openpgp-sha256; l=5124;\n i=bartosz.golaszewski@oss.qualcomm.com; h=from:subject:message-id;\n bh=621EXQPHHp1oek5UIpVZlw/H7Y1Xhl7Qy8Kc/NSLT2Q=;\n b=owEBbQKS/ZANAwAKAQWdLsv/NoTDAcsmYgBpxUArTpjhGsVZVIEntVMWwNw3iQyN+Y78frkYb\n 5UhD+ibRAyJAjMEAAEKAB0WIQSR5RMt5bVGHXuiZfwFnS7L/zaEwwUCacVAKwAKCRAFnS7L/zaE\n wzl6D/9ldtf3KeWmDokFrdBitjh2JJKcql0g7eFtpgGt1FVnIOTbZOA2FiONBfwgts4iz8tU/KR\n WRUJ9ZtFn/JQGf0LHfMlm6tOOZYNR6kJ5n+u9DlK3xE1YPuiGbJUXxUAty/NxZj7vYu/RTmlmEj\n 6tAaHH93aT9sr2SmRIy5QHmVHXd6rgEJTYGMdvsZB6nEohH/udJQfbnbEHPxgVvxwLCZpLgUBTG\n u2iycFLnJT0rhJdW1IgXRJazcQ9C5X3osncY8+TkKbGWnI9KOu2rL2q/Mr7slrmOYfZho/R6A2j\n XAiCjt9uoUN0fpNkSliZ/N54XIUbYaSCtsEuqOVqq5o2xyqd2hd+hnvPm8pfg59bsq5DHlG9Q55\n Msdayck32M6uBLIEIAWxBGItz9E1dY19ldmIwoFNfpkXwtVtopW85SgyEQfilgaZM+SLgVRwJwy\n 7aMk66JgeMbFGYPdWyNLhfF/3SF7Bi8oc85P7tZsY2Yu9HQ6hq2jT9J5P3a/IOBSKVchZJ9p0/T\n TvbgB5+8sOV8tfconne9rp9aMStaBpFlXC7W9Gc3ZyN6aGiykRODRcyKyf/YdTCDM89TJRUc6LW\n qYVTVKk04aYGnTOIWig5jDb202Xj+uFESABrtrtsHV+ku1N8bc53WiWB1Go4SlZspdAeVFBHxut\n k3ulxNiAy25pS4Q==", "X-Developer-Key": "i=bartosz.golaszewski@oss.qualcomm.com; a=openpgp;\n fpr=169DEB6C0BC3C46013D2C79F11A72EA01471D772", "X-Authority-Analysis": "v=2.4 cv=e7cLiKp/ c=1 sm=1 tr=0 ts=69c54032 cx=c_pps\n a=N1BjEkVkxJi3uNfLdpvX3g==:117 a=xqWC_Br6kY4A:10 a=IkcTkHD0fZMA:10\n a=Yq5XynenixoA:10 a=s4-Qcg_JpJYA:10 a=VkNPw1HP01LnGYTKEx00:22\n a=u7WPNUs3qKkmUXheDGA7:22 a=ZpdpYltYx_vBUK5n70dp:22 a=VwQbUJbxAAAA:8\n a=pGLkceISAAAA:8 a=bC-a23v3AAAA:8 a=EUspDBNiAAAA:8 a=tBb2bbeoAAAA:8\n a=BPk_T5_A67p-JLsZVCIA:9 a=QEXdDO2ut3YA:10 a=crWF4MFLhNY0qMRaF8an:22\n a=FO4_E8m0qiDe52t0p3_H:22 a=Oj-tNtZlA1e06AYgeCfH:22", "X-Proofpoint-GUID": "UuDaZOXrPFAWfXopVMhlkAoppR-LP8VZ", "X-Proofpoint-ORIG-GUID": "UuDaZOXrPFAWfXopVMhlkAoppR-LP8VZ", "X-Proofpoint-Spam-Details-Enc": "AW1haW4tMjYwMzI2MDEwMCBTYWx0ZWRfXwCzabLQ/bxqv\n KbnOq/b4vqV5idD2vjvbY9mQQGn3v4IqtSnYPmJcKIQ7NH3Kzf9avu7IW6vw8JiT34X4yWPFp2G\n lg2AR/+fp9jL+KDDgfJhBJ5svPOkXDuL8nIYwPmB5HKqOKfqGWb9z9UPG5PXtgKW3IkMRHlsWOD\n Z1lvKwjOwQhv8Rn1xHcRwM5HswuGm4IyPLSMAsnn01m7cDRLrXSJf8m2T63MmE09TBvXgccdsrM\n J4L9YQ7TRNrM0c5MihybyJJIzsIxWnwELYf467ArlD3enCekte6UhP8MZMBTbozqifwv5V1Q6HQ\n pIAPZL/WGZc9vA3uy76YKRow0Jl28qlo4pQNFTGioEhU/iSxm16gKmMBrZwE2m78ltA2L1QoXhf\n /xQbkvNoYLhkLFYSKg9WBNOGfNacvRDVGJ4+YBeYupq5Pj8a84CpZoFCv2REsEYBHDyhmhHhkD6\n 4k6p6dtG8kHpzXoWblA==", "X-Proofpoint-Virus-Version": "vendor=baseguard\n engine=ICAP:2.0.293,Aquarius:18.0.1143,Hydra:6.1.51,FMLib:17.12.100.49\n definitions=2026-03-26_03,2026-03-26_01,2025-10-01_01", "X-Proofpoint-Spam-Details": "rule=outbound_notspam policy=outbound score=0\n priorityscore=1501 impostorscore=0 spamscore=0 bulkscore=0 phishscore=0\n suspectscore=0 clxscore=1015 lowpriorityscore=0 malwarescore=0 adultscore=0\n classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0\n reason=mlx scancount=1 engine=8.22.0-2603050001 definitions=main-2603260100" }, "content": "After moving GPIO hog handling into GPIOLIB core, we accidentally stopped\nsupporting devicetree hog definitions with multiple lines like so:\n\n\thog {\n\t\tgpio-hog;\n\t\tgpios = <3 0>, <4 GPIO_ACTIVE_LOW>;\n\t\toutput-high;\n\t\tline-name = \"foo\";\n\t};\n\nRestore this functionality to fix reported regressions.\n\nFixes: d1d564ec4992 (\"gpio: move hogs into GPIO core\")\nReported-by: Geert Uytterhoeven <geert@linux-m68k.org>\nCloses: https://lore.kernel.org/all/CAMuHMdX6RuZXAozrF5m625ZepJTVVr4pcyKczSk12MedWvoejw@mail.gmail.com/\nTested-by: Geert Uytterhoeven <geert+renesas@glider.be>\nSigned-off-by: Bartosz Golaszewski <bartosz.golaszewski@oss.qualcomm.com>\n---\nChanges in v2:\n- Use a default value of 2 for the number of GPIO cells\n- Use kzalloc_objs() instead of kcalloc()\n- Propagate the error number from fwnode_property_read_u32()\n- Remove special cases forced by the lack of default cells value\n- Link to v1: https://patch.msgid.link/20260325-gpio-hogs-multiple-v1-1-7e3a7347f0d6@oss.qualcomm.com\n---\n drivers/gpio/gpiolib.c | 92 +++++++++++++++++++++++++++++---------------------\n 1 file changed, 54 insertions(+), 38 deletions(-)\n\n\n---\nbase-commit: 880e76d276421113e3017d1b950bf932dc4e3ce3\nchange-id: 20260325-gpio-hogs-multiple-1718d38c1f5b\n\nBest regards,", "diff": "diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c\nindex 7ee45ccdf1265e94b68fe8fa0d10dbc6adccd93a..cc36f1d1f3edb2b5c8609ab5ba72b23e6db480bd 100644\n--- a/drivers/gpio/gpiolib.c\n+++ b/drivers/gpio/gpiolib.c\n@@ -938,12 +938,18 @@ int gpiochip_add_hog(struct gpio_chip *gc, struct fwnode_handle *fwnode)\n \tstruct fwnode_handle *gc_node = dev_fwnode(&gc->gpiodev->dev);\n \tstruct fwnode_reference_args gpiospec;\n \tenum gpiod_flags dflags;\n+\tconst char *name = NULL;\n \tstruct gpio_desc *desc;\n \tunsigned long lflags;\n-\tconst char *name;\n+\tsize_t num_hogs;\n \tint ret, argc;\n-\tu32 gpios[3]; /* We support up to three-cell bindings. */\n-\tu32 cells;\n+\t/*\n+\t * For devicetree-based systems, this needs to be defined in bindings\n+\t * and there's no real default value. For other firmware descriptions\n+\t * it makes the most sense to use 2 cells for the GPIO offset and\n+\t * request flags.\n+\t */\n+\tu32 cells = 2;\n \n \tlflags = GPIO_LOOKUP_FLAGS_DEFAULT;\n \tdflags = GPIOD_ASIS;\n@@ -952,42 +958,22 @@ int gpiochip_add_hog(struct gpio_chip *gc, struct fwnode_handle *fwnode)\n \targc = fwnode_property_count_u32(fwnode, \"gpios\");\n \tif (argc < 0)\n \t\treturn argc;\n-\tif (argc > 3)\n-\t\treturn -EINVAL;\n \n-\tret = fwnode_property_read_u32_array(fwnode, \"gpios\", gpios, argc);\n-\tif (ret < 0)\n+\tret = fwnode_property_read_u32(gc_node, \"#gpio-cells\", &cells);\n+\tif (ret && is_of_node(fwnode))\n \t\treturn ret;\n+\tif (!ret && (argc % cells))\n+\t\treturn -EINVAL;\n \n-\tif (is_of_node(fwnode)) {\n-\t\t/*\n-\t\t * OF-nodes need some additional special handling for\n-\t\t * translating of devicetree flags.\n-\t\t */\n-\t\tret = fwnode_property_read_u32(gc_node, \"#gpio-cells\", &cells);\n-\t\tif (ret)\n-\t\t\treturn ret;\n-\t\tif (!ret && argc != cells)\n-\t\t\treturn -EINVAL;\n-\n-\t\tmemset(&gpiospec, 0, sizeof(gpiospec));\n-\t\tgpiospec.fwnode = fwnode;\n-\t\tgpiospec.nargs = argc;\n+\tnum_hogs = argc / cells;\n \n-\t\tfor (int i = 0; i < argc; i++)\n-\t\t\tgpiospec.args[i] = gpios[i];\n+\tu32 *gpios __free(kfree) = kzalloc_objs(*gpios, argc);\n+\tif (!gpios)\n+\t\treturn -ENOMEM;\n \n-\t\tret = of_gpiochip_get_lflags(gc, &gpiospec, &lflags);\n-\t\tif (ret)\n-\t\t\treturn ret;\n-\t} else {\n-\t\t/*\n-\t\t * GPIO_ACTIVE_LOW is currently the only lookup flag\n-\t\t * supported for non-OF firmware nodes.\n-\t\t */\n-\t\tif (gpios[1])\n-\t\t\tlflags |= GPIO_ACTIVE_LOW;\n-\t}\n+\tret = fwnode_property_read_u32_array(fwnode, \"gpios\", gpios, argc);\n+\tif (ret < 0)\n+\t\treturn ret;\n \n \tif (fwnode_property_present(fwnode, \"input\"))\n \t\tdflags |= GPIOD_IN;\n@@ -1000,11 +986,41 @@ int gpiochip_add_hog(struct gpio_chip *gc, struct fwnode_handle *fwnode)\n \n \tfwnode_property_read_string(fwnode, \"line-name\", &name);\n \n-\tdesc = gpiochip_get_desc(gc, gpios[0]);\n-\tif (IS_ERR(desc))\n-\t\treturn PTR_ERR(desc);\n+\tfor (unsigned int i = 0; i < num_hogs; i++) {\n+\t\tif (is_of_node(fwnode)) {\n+\t\t\t/*\n+\t\t\t * OF-nodes need some additional special handling for\n+\t\t\t * translating of devicetree flags.\n+\t\t\t */\n+\t\t\tmemset(&gpiospec, 0, sizeof(gpiospec));\n+\t\t\tgpiospec.fwnode = fwnode;\n+\t\t\tgpiospec.nargs = cells;\n+\n+\t\t\tfor (int j = 0; j < cells; j++)\n+\t\t\t\tgpiospec.args[j] = gpios[i * cells + j];\n+\n+\t\t\tret = of_gpiochip_get_lflags(gc, &gpiospec, &lflags);\n+\t\t\tif (ret)\n+\t\t\t\treturn ret;\n+\t\t} else {\n+\t\t\t/*\n+\t\t\t * GPIO_ACTIVE_LOW is currently the only lookup flag\n+\t\t\t * supported for non-OF firmware nodes.\n+\t\t\t */\n+\t\t\tif (gpios[i * cells + 1])\n+\t\t\t\tlflags |= GPIO_ACTIVE_LOW;\n+\t\t}\n+\n+\t\tdesc = gpiochip_get_desc(gc, gpios[i * cells]);\n+\t\tif (IS_ERR(desc))\n+\t\t\treturn PTR_ERR(desc);\n \n-\treturn gpiod_hog(desc, name, lflags, dflags);\n+\t\tret = gpiod_hog(desc, name, lflags, dflags);\n+\t\tif (ret)\n+\t\t\treturn ret;\n+\t}\n+\n+\treturn 0;\n }\n \n static int gpiochip_hog_lines(struct gpio_chip *gc)\n", "prefixes": [ "v2" ] }