Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/1.0/patches/2197478/?format=api
{ "id": 2197478, "url": "http://patchwork.ozlabs.org/api/1.0/patches/2197478/?format=api", "project": { "id": 9, "url": "http://patchwork.ozlabs.org/api/1.0/projects/9/?format=api", "name": "Linux RTC development", "link_name": "rtc-linux", "list_id": "linux-rtc.vger.kernel.org", "list_email": "linux-rtc@vger.kernel.org", "web_url": "", "scm_url": "", "webscm_url": "" }, "msgid": "<4a2389ed-6ea4-4cff-aad6-a5a9f9bd13e7@kernel.org>", "date": "2026-02-17T22:30:17", "name": "[RFC,07/10] driver core: make struct bus_type groups members constant arrays", "commit_ref": null, "pull_url": null, "state": "handled-elsewhere", "archived": false, "hash": "92f82215740dfc0d0ecfecebdd5db9e2d04b14ff", "submitter": { "id": 88130, "url": "http://patchwork.ozlabs.org/api/1.0/people/88130/?format=api", "name": "Heiner Kallweit", "email": "hkall@kernel.org" }, "delegate": null, "mbox": "http://patchwork.ozlabs.org/project/rtc-linux/patch/4a2389ed-6ea4-4cff-aad6-a5a9f9bd13e7@kernel.org/mbox/", "series": [ { "id": 492492, "url": "http://patchwork.ozlabs.org/api/1.0/series/492492/?format=api", "date": "2026-02-17T22:24:26", "name": "driver core: constify groups arrays in several structs", "version": 1, "mbox": "http://patchwork.ozlabs.org/series/492492/mbox/" } ], "check": "pending", "checks": "http://patchwork.ozlabs.org/api/patches/2197478/checks/", "tags": {}, "headers": { "Return-Path": "\n <linux-rtc+bounces-5975-incoming=patchwork.ozlabs.org@vger.kernel.org>", "X-Original-To": [ "incoming@patchwork.ozlabs.org", "linux-rtc@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=kernel.org header.i=@kernel.org header.a=rsa-sha256\n header.s=k20201202 header.b=fsSVo1CX;\n\tdkim-atps=neutral", "legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=2600:3c0a:e001:db::12fc:5321; helo=sea.lore.kernel.org;\n envelope-from=linux-rtc+bounces-5975-incoming=patchwork.ozlabs.org@vger.kernel.org;\n receiver=patchwork.ozlabs.org)", "smtp.subspace.kernel.org;\n\tdkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org\n header.b=\"fsSVo1CX\"", "smtp.subspace.kernel.org;\n arc=none smtp.client-ip=10.30.226.201" ], "Received": [ "from sea.lore.kernel.org (sea.lore.kernel.org\n [IPv6:2600:3c0a:e001:db::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 4fFvVR0rs5z1xvq\n\tfor <incoming@patchwork.ozlabs.org>; Wed, 18 Feb 2026 09:30:39 +1100 (AEDT)", "from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sea.lore.kernel.org (Postfix) with ESMTP id 833973019904\n\tfor <incoming@patchwork.ozlabs.org>; Tue, 17 Feb 2026 22:30:23 +0000 (UTC)", "from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id 3BBDE2D781E;\n\tTue, 17 Feb 2026 22:30:22 +0000 (UTC)", "from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org\n [10.30.226.201])\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 183F713AA2F;\n\tTue, 17 Feb 2026 22:30:21 +0000 (UTC)", "by smtp.kernel.org (Postfix) with ESMTPSA id 679C7C4CEF7;\n\tTue, 17 Feb 2026 22:30:19 +0000 (UTC)" ], "ARC-Seal": "i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1771367422; cv=none;\n b=g/xIqJCuqVmwgGxAMuflqvCbJ64uFtdGRbfyVsV/OQpxdK1EeZpIxcvYrAp2ta9YUd752wxgCVENe1Yw/Kdag0fsLD4Dw2CriRhddP0zJRC8AtlycZcleg5U5ToSW4aCl78f76nEJmBs5WxUuntG3YokmHuv6lAt65ArLiR5FiA=", "ARC-Message-Signature": "i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1771367422; c=relaxed/simple;\n\tbh=VsVjc+rt/VTr9goq9phUEQQxFoTsYqWk1U/35E2GGPs=;\n\th=Message-ID:Date:MIME-Version:Subject:From:To:Cc:References:\n\t In-Reply-To:Content-Type;\n b=AChpQCLtrovklIpEua2O2ps2Sx9zr9KxAFTH27PrEV9N8e393yqqFyHvyDaC/6rULa3dCydeYnj6tzLpGHR/MQWuPb8vS+rAu9Ol2Yluukz2lKfKKt6dbjqBunIdfQjRXy7nHBRFbs+B3pVVh/gxpIuFcwJHADsJDakIaxAZCOg=", "ARC-Authentication-Results": "i=1; smtp.subspace.kernel.org;\n dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org\n header.b=fsSVo1CX; arc=none smtp.client-ip=10.30.226.201", "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org;\n\ts=k20201202; t=1771367421;\n\tbh=VsVjc+rt/VTr9goq9phUEQQxFoTsYqWk1U/35E2GGPs=;\n\th=Date:Subject:From:To:Cc:References:In-Reply-To:From;\n\tb=fsSVo1CX31qjds7XGu2AO2QgL3smsrdmvUwrB4pLu22V+z18sAorEMFPUHtEoiIcj\n\t R7nbj2JEWeh3y8Em4PH/7bxsMZ2E8xjWPCBVc/nF0PImbGBuv7AgrYMi0J34wn3F/b\n\t cwbYYayBZ5MuheMe8V/YVuNJ6ergCwT4lXLcY+hYYZtk5/odqXIkLk315gLT3DinD0\n\t GNId0r0Lo2H3HaVnpy6PpB1QBLN+Z6MSydCkh4/RjWYQc9HyvXVri2vkuleHxzzZXT\n\t KoWwrjvLDQivxQKf48XHmxugBcyFd3GVFa31oseTRpvLY87KI4/iq/gccXZZMKagpq\n\t s4jtRje6/6N8g==", "Message-ID": "<4a2389ed-6ea4-4cff-aad6-a5a9f9bd13e7@kernel.org>", "Date": "Tue, 17 Feb 2026 23:30:17 +0100", "Precedence": "bulk", "X-Mailing-List": "linux-rtc@vger.kernel.org", "List-Id": "<linux-rtc.vger.kernel.org>", "List-Subscribe": "<mailto:linux-rtc+subscribe@vger.kernel.org>", "List-Unsubscribe": "<mailto:linux-rtc+unsubscribe@vger.kernel.org>", "MIME-Version": "1.0", "User-Agent": "Mozilla Thunderbird", "Subject": "[PATCH RFC 07/10] driver core: make struct bus_type groups members\n constant arrays", "From": "Heiner Kallweit <hkall@kernel.org>", "To": "=?utf-8?q?Thomas_Wei=C3=9Fschuh?= <linux@weissschuh.net>,\n Greg Kroah-Hartman <gregkh@linuxfoundation.org>,\n \"Rafael J. Wysocki\" <rafael@kernel.org>, Danilo Krummrich <dakr@kernel.org>,\n Jason Gunthorpe <jgg@ziepe.ca>, Leon Romanovsky <leon@kernel.org>,\n Alexandre Belloni <alexandre.belloni@bootlin.com>", "Cc": "driver-core@lists.linux.dev,\n Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,\n linux-rdma@vger.kernel.org, linux-rtc@vger.kernel.org", "References": "<5d0951ec-42c9-453f-9966-ecca593c4153@kernel.org>", "Content-Language": "en-US", "In-Reply-To": "<5d0951ec-42c9-453f-9966-ecca593c4153@kernel.org>", "Content-Type": "text/plain; charset=UTF-8", "Content-Transfer-Encoding": "7bit" }, "content": "Constify the groupss arrays, allowing to assign constant arrays.\nAs a prerequisite this requires to constify the groups array argument\nin few functions.\n\nSigned-off-by: Heiner Kallweit <hkallweit1@gmail.com>\n---\n drivers/base/base.h | 6 ++++--\n drivers/base/driver.c | 4 ++--\n include/linux/device/bus.h | 6 +++---\n 3 files changed, 9 insertions(+), 7 deletions(-)", "diff": "diff --git a/drivers/base/base.h b/drivers/base/base.h\nindex 8c2175820da..b6852ba45cd 100644\n--- a/drivers/base/base.h\n+++ b/drivers/base/base.h\n@@ -202,8 +202,10 @@ static inline void dev_sync_state(struct device *dev)\n \t\tdev->driver->sync_state(dev);\n }\n \n-int driver_add_groups(const struct device_driver *drv, const struct attribute_group **groups);\n-void driver_remove_groups(const struct device_driver *drv, const struct attribute_group **groups);\n+int driver_add_groups(const struct device_driver *drv,\n+\t\t const struct attribute_group *const *groups);\n+void driver_remove_groups(const struct device_driver *drv,\n+\t\t\t const struct attribute_group *const *groups);\n void device_driver_detach(struct device *dev);\n \n static inline void device_set_driver(struct device *dev, const struct device_driver *drv)\ndiff --git a/drivers/base/driver.c b/drivers/base/driver.c\nindex 8ab010ddf70..c5ebf1fdad7 100644\n--- a/drivers/base/driver.c\n+++ b/drivers/base/driver.c\n@@ -203,13 +203,13 @@ void driver_remove_file(const struct device_driver *drv,\n EXPORT_SYMBOL_GPL(driver_remove_file);\n \n int driver_add_groups(const struct device_driver *drv,\n-\t\t const struct attribute_group **groups)\n+\t\t const struct attribute_group *const *groups)\n {\n \treturn sysfs_create_groups(&drv->p->kobj, groups);\n }\n \n void driver_remove_groups(const struct device_driver *drv,\n-\t\t\t const struct attribute_group **groups)\n+\t\t\t const struct attribute_group *const *groups)\n {\n \tsysfs_remove_groups(&drv->p->kobj, groups);\n }\ndiff --git a/include/linux/device/bus.h b/include/linux/device/bus.h\nindex 99c3c83ea52..00d8a080f93 100644\n--- a/include/linux/device/bus.h\n+++ b/include/linux/device/bus.h\n@@ -78,9 +78,9 @@ struct fwnode_handle;\n struct bus_type {\n \tconst char\t\t*name;\n \tconst char\t\t*dev_name;\n-\tconst struct attribute_group **bus_groups;\n-\tconst struct attribute_group **dev_groups;\n-\tconst struct attribute_group **drv_groups;\n+\tconst struct attribute_group *const *bus_groups;\n+\tconst struct attribute_group *const *dev_groups;\n+\tconst struct attribute_group *const *drv_groups;\n \n \tint (*match)(struct device *dev, const struct device_driver *drv);\n \tint (*uevent)(const struct device *dev, struct kobj_uevent_env *env);\n", "prefixes": [ "RFC", "07/10" ] }