From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-dy1-f170.google.com (mail-dy1-f170.google.com [74.125.82.170]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 89EC1383985 for ; Tue, 12 May 2026 23:58:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=74.125.82.170 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778630298; cv=none; b=k6hlWV93TOo4zy8SKrfy+D5UfsnIjv3R46nGmUmIR+YCnEDGSkI/aEBo4qttVr+4cr4+Jyum/Cj25wTe49ptngT3QCVYyMCU8lH2N4nWEgnf0sOH1IfLIPE7ulko55DNo1SZ0c33NG5fDE5D6sve2eR0Uy9xrgstv6qTQ2FSnFQ= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778630298; c=relaxed/simple; bh=4d42TBYxhrEKUs/Ex72+YVx038OFOO6Efovah/WgVDE=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=jKqhefzM0xLPbmlpWu2+XdY4eEhK++g8Ufvc08NkKeeAsxG1zFOZUpUGEKmaOBoCrw97hN0qRe7S2VzkKLxZHYOxadXvWPHRmmDMg7Za4jRgbDLvi1jJ+rxscHcPdt9iIGg7p7sfyqZhPZsKCmysRdkQYczosefzt5Qwn/ba19Q= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=QYGxL6ot; arc=none smtp.client-ip=74.125.82.170 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="QYGxL6ot" Received: by mail-dy1-f170.google.com with SMTP id 5a478bee46e88-2ef8d6ba48bso3634339eec.1 for ; Tue, 12 May 2026 16:58:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1778630296; x=1779235096; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=81SlTE+HhOzFbiYLIxMeZjJ33RF64bMO8xaQDR8dKPg=; b=QYGxL6otiLtlmK447P56IU8e+uvYGajYv18BA2L4uaNUnAKhMUSE/t4980Mr0UtHvT fasEutzWwVveju9C2J5JfxfxOaNqsGGuGfAhh7U+R3cbvytEbGEOBwAleaJP4oxJrW5J XI8x+o9xFbhVlDSYeEwXKVWwpN7MdfhgyVe+NYShHmcxqP7BszNcUKC+/83oPfifJJpe s1FSXp5cqdlHd6F5mOUfDZTlJPaIYSXL7uYEcpPQsqlYcixp+DPsSs9cdvl5aoHN5389 zsUYupWueuRoYzQFz4VQwThB6bQUe6QWRcMzSKNUzgV/NrpswTPkkZbtVEbrXtW4Srgs vYEQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1778630296; x=1779235096; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=81SlTE+HhOzFbiYLIxMeZjJ33RF64bMO8xaQDR8dKPg=; b=lnhcTk319JRFONMyrtc4KKKu3jdOvx+sC1WiQlrpZ0x7wd14PvwCuZ+cmOEWwpCeBq zuX0Tb4g15VBH3HOJt6EVXMQgQu4VPXHXr1XL1NVl96oDGF5SjPEv3P1F+Grl//IDmcS b2G6FUfHp6Ls9TI91DIAMZioKSia2gsSfYzCHvONlTApZ5tFg+ieQz+ZDZOYH+R+MMpV tlbpAqEZIw09Ru4wrb25hBwkQhISghs3ZNdAh62CZyRlHA1JI+ypM2qB5sbU1Z5eP6n8 zV4jiIawcx7d6EuDH7oXosw6/DEtzarWHTFsjodueDte2C+LLzQ0CFbmeJ1wi066/zgQ 4UrQ== X-Forwarded-Encrypted: i=1; AFNElJ+w2+KEIpgC8uNc7WyXWN7kYd/uIkCaub2WMNh6qm/IfJ7a20bQyOwA5GafAKiS5nFCmnhSzgJtfU0wT/I=@vger.kernel.org X-Gm-Message-State: AOJu0Yzv8C31LFjNu23i2MPJv2YrRyZ0VYdjKnzfQnnPL/6Y5XUVoKh5 hk+Df5F3wLvUpphyDPXFIyyzNrUTScOr/2k7jGxR9bDqRfD0WQ8tpFNv X-Gm-Gg: Acq92OE8sBmVrRMFBAKsTvfjjbtMtcKDpwE+hZLcrFhZWwIrA1rAYDOAoksBzRC6Hh4 J5FSvcbKx9vrpaf/nOuV4MPKXbvTGfyp/JTncTXSNH1F59Pld0sFjjxpHOTsjmvFWrSg2d8BWuX DU7AaTsKBn7hyM2wMwyXiHkftEgBEHczfbhiCfdbG+XUjH6sQ3YG9PjnQhMArTI2AadkPc8/hjC ADvo7jNPtKOY2yyx1TxuBVkqKG911R+yrCJLSJ0Hij/QM09oTT6GF1gQyMFG+F7UttMm0pl83yi k2BAUay5zLuYYk59Bo+dD+nz6PzP4oN2lJkV2eBQBm1d0Wi7zchE98anNzFJyNLjPbyvwaXOxbP vx88MS9a5Fv3GxkmveTzVQMdNNWOsq+T9vXtwqqI52BOiZFn0HbSA508HuFMhpgo+WcvMylbWZ1 3rEVb409tNvKpAwJ/T65PE6GxKkWFnUiYzyLGNUT1TLqpHME3J5/GqOJLV+PcRkFWFC0r6pTZ3L 4sV X-Received: by 2002:a05:7300:5720:b0:2c1:7480:ff9b with SMTP id 5a478bee46e88-2ff95e5e1cemr2922195eec.18.1778630295708; Tue, 12 May 2026 16:58:15 -0700 (PDT) Received: from lappy (108-228-232-20.lightspeed.sndgca.sbcglobal.net. [108.228.232.20]) by smtp.gmail.com with ESMTPSA id 5a478bee46e88-2f888e3e285sm23625851eec.27.2026.05.12.16.58.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 May 2026 16:58:15 -0700 (PDT) From: "Derek J. Clark" To: =?UTF-8?q?Ilpo=20J=C3=A4rvinen?= , Hans de Goede Cc: Mark Pearson , Armin Wolf , Jonathan Corbet , Rong Zhang , Kurt Borja , "Derek J . Clark" , "Pierre-Loup A . Griffais" , =?UTF-8?q?N=C3=ADcolas=20F=20=2E=20R=20=2E=20A=20=2E=20Prado?= , marshall@shzj.cc, hyacinth@shzj.cc, platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v13 6/7] platform/x86: lenovo-wmi-helpers: Add helper for creating per-device debugfs dir Date: Tue, 12 May 2026 23:58:07 +0000 Message-ID: <20260512235808.691046-7-derekjohn.clark@gmail.com> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260512235808.691046-1-derekjohn.clark@gmail.com> References: <20260512235808.691046-1-derekjohn.clark@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: Rong Zhang We are about to add debugfs support for lenovo-wmi-capdata. Let's setup a debugfs directory called "lenovo_wmi" for tidiness, so that any lenovo-wmi-* device can put its subdirectory under the directory. Subdirectories will be named after the corresponding WMI devices. Signed-off-by: Rong Zhang Signed-off-by: Derek J. Clark --- v13: - Fix alphabetical include order. v7: - Use subsys_initcall() instead of module_init(). --- drivers/platform/x86/lenovo/wmi-helpers.c | 34 +++++++++++++++++++++++ drivers/platform/x86/lenovo/wmi-helpers.h | 2 ++ 2 files changed, 36 insertions(+) diff --git a/drivers/platform/x86/lenovo/wmi-helpers.c b/drivers/platform/x86/lenovo/wmi-helpers.c index 7a198259e393..8f5766c391eb 100644 --- a/drivers/platform/x86/lenovo/wmi-helpers.c +++ b/drivers/platform/x86/lenovo/wmi-helpers.c @@ -18,6 +18,8 @@ #include #include +#include +#include #include #include #include @@ -185,6 +187,38 @@ int lwmi_tm_notifier_call(enum thermal_mode *mode) } EXPORT_SYMBOL_NS_GPL(lwmi_tm_notifier_call, "LENOVO_WMI_HELPERS"); +static struct dentry *lwmi_debugfs_dir; + +/** + * lwmi_debugfs_create_dir() - Helper function for creating a debugfs directory + * for a device. + * @wdev: Pointer to the WMI device to be called. + * + * Caller must remove the directory with debugfs_remove_recursive() on device + * removal. + * + * Return: Pointer to the created directory. + */ +struct dentry *lwmi_debugfs_create_dir(struct wmi_device *wdev) +{ + return debugfs_create_dir(dev_name(&wdev->dev), lwmi_debugfs_dir); +} +EXPORT_SYMBOL_NS_GPL(lwmi_debugfs_create_dir, "LENOVO_WMI_HELPERS"); + +static int __init lwmi_helpers_init(void) +{ + lwmi_debugfs_dir = debugfs_create_dir("lenovo_wmi", NULL); + + return 0; +} +subsys_initcall(lwmi_helpers_init) + +static void __exit lwmi_helpers_exit(void) +{ + debugfs_remove_recursive(lwmi_debugfs_dir); +} +module_exit(lwmi_helpers_exit) + MODULE_AUTHOR("Derek J. Clark "); MODULE_DESCRIPTION("Lenovo WMI Helpers Driver"); MODULE_LICENSE("GPL"); diff --git a/drivers/platform/x86/lenovo/wmi-helpers.h b/drivers/platform/x86/lenovo/wmi-helpers.h index ed7db3ebba6c..039fe61003ce 100644 --- a/drivers/platform/x86/lenovo/wmi-helpers.h +++ b/drivers/platform/x86/lenovo/wmi-helpers.h @@ -16,6 +16,8 @@ struct wmi_method_args_32 { u32 arg1; }; +struct dentry *lwmi_debugfs_create_dir(struct wmi_device *wdev); + enum lwmi_event_type { LWMI_GZ_GET_THERMAL_MODE = 0x01, }; -- 2.53.0