From nobody Tue Dec 16 14:24:38 2025 Received: from mail-vs1-f43.google.com (mail-vs1-f43.google.com [209.85.217.43]) (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 181D21C5F05; Tue, 14 Jan 2025 15:39:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.217.43 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736869143; cv=none; b=Dv95NoCZfGXPCAx5SGpaovAi6TBbQc3UUr6+gWJ7MulxBzGwpvkorUQgSWtpYBaiU4889tRtR4ggZj2AI+pwnIAXLtabwRcY8ca5kx+IOFRxPxrgvgoHJxPviP2/ihAfl0JqF4ndJPNTkPtprSZfuzrko5EWKVCHc4m0Gb8jyFg= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1736869143; c=relaxed/simple; bh=pTA1KT1omz6Jtu7hSa+/9bR4cO+DIqnOMm+HbwjeObk=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=LF3f68NwieoRzzg8C/qaghcBb65sIM8keL6a5tUcL8CJHU6zA2er1up4BV10ON7ZspfeDWLYryHWuiFbWCauh2jWMGAhqW7OyRMtYC7KAldzf6JeT1Xh1cKqsnbJBxctkCyhG34M0F6ZlfCJ2lWva3kPf+zuJZYze/7C9thMc2Y= 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=avI04Bkw; arc=none smtp.client-ip=209.85.217.43 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="avI04Bkw" Received: by mail-vs1-f43.google.com with SMTP id ada2fe7eead31-4aff04f17c7so4084066137.0; Tue, 14 Jan 2025 07:39:00 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1736869139; x=1737473939; 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=7lzJTFhmN1BxMUX/j4LJQiLOaklLgy/NsQ51qNX2xpA=; b=avI04BkwRLwJ9rDJjN0wBIsiVUYizLXpxPhl1sV4bjROxrICD0iFpjuhwJO2DEn0A4 syb0z8Q6v41uE89a0W+WACkhymbQ8s4rdr4e8s+fXHo8beUn7IvrCLEAXfKHASt/WKoD 2jnZYj+nMNxMTDPS/fMIHDHidV0ssicFxOOUZ1hK/zsmSj49JaFHMbURGhjtFITfN2lp SplK4IBvB4xveLl7y5VFFApBrUNoYnTnPgcFGly290k+oSJH3eiYI0z+2kq255cvjW5N 06RVEs8hnMaMfJZrIOquipZYVJACZW8gxLuZN0YV/MDXRX5+h+mi0hoPAYkEOHC5W9lk TaPw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1736869139; x=1737473939; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=7lzJTFhmN1BxMUX/j4LJQiLOaklLgy/NsQ51qNX2xpA=; b=GHaxM+oxWjiV1TSqi7bkbrJTWRmXP8FH2NTGnWARQIHCZzwpJV3+zfIRQkx6R189Md Bak7ymRO5N1i44Vxp9XYhClW0J+cAAR/g+vHBns7P8SuoYRpu1KwbJRTz6phR2H1jUiC 4E3LjNr36JsWO4YYAoC1SQaoFMCAPf7oiIdHm0mHrLs0Q//7pVEpccZjHKl/FFVv0M3Z LogYKPDB+uiz6vtkqvKXSnZF+NuX/fiMHYQ3qizGCkLx2fWjakBniFYN+BRnUrJlP+OX 92DsLVsAsbm3m4uN9cfHF9BxxpNB/dPHHmNSdzUJl7/wIBwbX9J5TxmPmaJ5sqr+NIPz d5XA== X-Forwarded-Encrypted: i=1; AJvYcCW6jliPt+zCYWpwz+HpwcpOXjTG3C4i6zj7OKApe8YydylSdGJXP4+IEEEbwz8UvFTa4TMw3adYCr5ddu6n@vger.kernel.org, AJvYcCXN9wbuNa9qg91tyrA9t1ZLLvdV0CNzrrlb9VvINLShDdnY9LB4IEwV3l5jGhausvKwFyrRfnmPwNSd@vger.kernel.org X-Gm-Message-State: AOJu0YyM8NLiUJJ9hIlgAh1BszLjkNfhu0byD5YerDSUoj+5RR2kMtTI +YhT7/eL1bqEaNtwCM7amKOf0mOceXesvkQ3YZvRDar/S5F8rualPani6g== X-Gm-Gg: ASbGncsN7m0V2pYQv1U7wMaSMvXmike/i48riSUYn8MD1UXTWhnKtj+7DA651X+Y4FW OuZNfDNyWv0t577w7GWqD53Dqq+Xr2+EyZoX7O7Nf/H3kzMooIlJVFfTKjFSygDLxB0pxs4rKol HzEQqxnqY/qcsMlT52sjx3qiQzrme2jzXyE1/k9LXA4OID8xmVgSBnf1Uvz70s1fEMkeNFylQYh oSWMM6i/GQzm8B98ymGuCTNAstEv7f+1QMdj0+lcNeaohvmIqj2ZY7wPE9GDazl X-Google-Smtp-Source: AGHT+IHvmNRGPQQrYOgZO8LbA6ZBaBgFeTbW+nYp5dJ5rzV/j/cPEkwnmA5ckW7no7p0um9q7aHQBw== X-Received: by 2002:a05:6122:a14:b0:518:7d3a:dd13 with SMTP id 71dfb90a1353d-51c7c7d009dmr17172335e0c.7.1736869139225; Tue, 14 Jan 2025 07:38:59 -0800 (PST) Received: from localhost.localdomain ([2800:bf0:82:1159:1ea9:11b1:7af9:1277]) by smtp.gmail.com with ESMTPSA id 71dfb90a1353d-51cd7c56d30sm277e0c.14.2025.01.14.07.38.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Jan 2025 07:38:58 -0800 (PST) From: Kurt Borja To: platform-driver-x86@vger.kernel.org Cc: "Rafael J. Wysocki" , "Len Brown" , linux-acpi@vger.kernel.org, linux-kernel@vger.kernel.org, "Mario Limonciello" , "Armin Wolf" , "Joshua Grisham" , "Derek J. Clark" , =?UTF-8?q?Ilpo=20J=C3=A4rvinen?= , "Hans de Goede" , "Kurt Borja" , "Maximilian Luz" , "Lee, Chun-Yi" , "Shyam Sundar S K" , "Corentin Chary" , "Luke D. Jones" , "Lyndon Sanche" , "Ike Panhc" , "Henrique de Moraes Holschuh" , "Mark Pearson" , "Alexis Belmonte" , "Ai Chao" , "Gergo Koteles" , Dell.Client.Kernel@dell.com, ibm-acpi-devel@lists.sourceforge.net Subject: [PATCH v2 15/18] ACPI: platform_profile: Remove platform_profile_handler from exported symbols Date: Tue, 14 Jan 2025 10:37:23 -0500 Message-ID: <20250114153726.11802-16-kuurtb@gmail.com> X-Mailer: git-send-email 2.47.1 In-Reply-To: <20250114153726.11802-1-kuurtb@gmail.com> References: <20250114153726.11802-1-kuurtb@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: quoted-printable Content-Type: text/plain; charset="utf-8" In order to protect the platform_profile_handler from API consumers, allocate it in platform_profile_register() and modify it's signature accordingly. Remove the platform_profile_handler from all consumer drivers and replace them with a pointer to the class device, which is now returned from platform_profile_register(). Replace *pprof with a pointer to the class device in the rest of exported symbols. Signed-off-by: Kurt Borja Reviewed-by: Mario Limonciello --- drivers/acpi/platform_profile.c | 87 ++++++++++++------- .../surface/surface_platform_profile.c | 11 ++- drivers/platform/x86/acer-wmi.c | 18 ++-- drivers/platform/x86/amd/pmf/pmf.h | 2 +- drivers/platform/x86/amd/pmf/sps.c | 17 ++-- drivers/platform/x86/asus-wmi.c | 20 ++--- drivers/platform/x86/dell/alienware-wmi.c | 9 +- drivers/platform/x86/dell/dell-pc.c | 22 ++--- drivers/platform/x86/hp/hp-wmi.c | 19 ++-- drivers/platform/x86/ideapad-laptop.c | 14 +-- .../platform/x86/inspur_platform_profile.c | 9 +- drivers/platform/x86/thinkpad_acpi.c | 14 ++- include/linux/platform_profile.h | 12 ++- 13 files changed, 125 insertions(+), 129 deletions(-) diff --git a/drivers/acpi/platform_profile.c b/drivers/acpi/platform_profil= e.c index 34e22b006ccc..2fae5e2fc962 100644 --- a/drivers/acpi/platform_profile.c +++ b/drivers/acpi/platform_profile.c @@ -4,6 +4,7 @@ =20 #include #include +#include #include #include #include @@ -213,9 +214,17 @@ static struct attribute *profile_attrs[] =3D { }; ATTRIBUTE_GROUPS(profile); =20 +static void pprof_device_release(struct device *dev) +{ + struct platform_profile_handler *pprof =3D to_pprof_handler(dev); + + kfree(pprof); +} + static const struct class platform_profile_class =3D { .name =3D "platform-profile", .dev_groups =3D profile_groups, + .dev_release =3D pprof_device_release, }; =20 /** @@ -409,10 +418,10 @@ static const struct attribute_group platform_profile_= group =3D { .is_visible =3D profile_class_is_visible, }; =20 -void platform_profile_notify(struct platform_profile_handler *pprof) +void platform_profile_notify(struct device *dev) { scoped_cond_guard(mutex_intr, return, &profile_lock) { - _notify_class_profile(&pprof->class_dev, NULL); + _notify_class_profile(dev, NULL); } sysfs_notify(acpi_kobj, NULL, "platform_profile"); } @@ -461,40 +470,51 @@ int platform_profile_cycle(void) } EXPORT_SYMBOL_GPL(platform_profile_cycle); =20 -int platform_profile_register(struct platform_profile_handler *pprof, void= *drvdata) +struct device *platform_profile_register(struct device *dev, const char *n= ame, + void *drvdata, + const struct platform_profile_ops *ops) { + int minor; int err; =20 - /* Sanity check the profile handler */ - if (!pprof || !pprof->ops->profile_set || !pprof->ops->profile_get || - !pprof->ops->probe) { + /* Sanity check */ + if (!dev || !name || !ops || !ops->profile_get || + !ops->profile_set || !ops->probe) { pr_err("platform_profile: handler is invalid\n"); - return -EINVAL; + return ERR_PTR(-EINVAL); } =20 - err =3D pprof->ops->probe(drvdata, pprof->choices); + struct platform_profile_handler *pprof __free(kfree) =3D kzalloc( + sizeof(*pprof), GFP_KERNEL); + if (!pprof) + return ERR_PTR(-ENOMEM); + + err =3D ops->probe(drvdata, pprof->choices); if (err < 0) - return err; + return ERR_PTR(err); =20 if (bitmap_empty(pprof->choices, PLATFORM_PROFILE_LAST)) { pr_err("platform_profile: no available profiles\n"); - return -EINVAL; + return ERR_PTR(-EINVAL); } =20 guard(mutex)(&profile_lock); =20 /* create class interface for individual handler */ - pprof->minor =3D ida_alloc(&platform_profile_ida, GFP_KERNEL); - if (pprof->minor < 0) - return pprof->minor; + minor =3D ida_alloc(&platform_profile_ida, GFP_KERNEL); + if (minor < 0) + return ERR_PTR(minor); =20 + pprof->name =3D name; + pprof->ops =3D ops; + pprof->minor =3D minor; pprof->class_dev.class =3D &platform_profile_class; - pprof->class_dev.parent =3D pprof->dev; + pprof->class_dev.parent =3D dev; dev_set_drvdata(&pprof->class_dev, drvdata); dev_set_name(&pprof->class_dev, "platform-profile-%d", pprof->minor); err =3D device_register(&pprof->class_dev); if (err) { - put_device(&pprof->class_dev); + put_device(&no_free_ptr(pprof)->class_dev); goto cleanup_ida; } =20 @@ -504,20 +524,21 @@ int platform_profile_register(struct platform_profile= _handler *pprof, void *drvd if (err) goto cleanup_cur; =20 - return 0; + return &no_free_ptr(pprof)->class_dev; =20 cleanup_cur: - device_unregister(&pprof->class_dev); + device_unregister(&no_free_ptr(pprof)->class_dev); =20 cleanup_ida: - ida_free(&platform_profile_ida, pprof->minor); + ida_free(&platform_profile_ida, minor); =20 - return err; + return ERR_PTR(err); } EXPORT_SYMBOL_GPL(platform_profile_register); =20 -int platform_profile_remove(struct platform_profile_handler *pprof) +int platform_profile_remove(struct device *dev) { + struct platform_profile_handler *pprof =3D to_pprof_handler(dev); int id; guard(mutex)(&profile_lock); =20 @@ -535,30 +556,32 @@ EXPORT_SYMBOL_GPL(platform_profile_remove); =20 static void devm_platform_profile_release(struct device *dev, void *res) { - struct platform_profile_handler **pprof =3D res; + struct device **ppdev =3D res; =20 - platform_profile_remove(*pprof); + platform_profile_remove(*ppdev); } =20 -int devm_platform_profile_register(struct platform_profile_handler *pprof,= void *drvdata) +struct device *devm_platform_profile_register(struct device *dev, const ch= ar *name, + void *drvdata, + const struct platform_profile_ops *ops) { - struct platform_profile_handler **dr; - int ret; + struct device *ppdev; + struct device **dr; =20 dr =3D devres_alloc(devm_platform_profile_release, sizeof(*dr), GFP_KERNE= L); if (!dr) - return -ENOMEM; + return ERR_PTR(-ENOMEM); =20 - ret =3D platform_profile_register(pprof, drvdata); - if (ret) { + ppdev =3D platform_profile_register(dev, name, drvdata, ops); + if (IS_ERR(dev)) { devres_free(dr); - return ret; + return ppdev; } =20 - *dr =3D pprof; - devres_add(pprof->dev, dr); + *dr =3D ppdev; + devres_add(dev, dr); =20 - return 0; + return ppdev; } EXPORT_SYMBOL_GPL(devm_platform_profile_register); =20 diff --git a/drivers/platform/surface/surface_platform_profile.c b/drivers/= platform/surface/surface_platform_profile.c index bbdc873cb788..275269a6efc1 100644 --- a/drivers/platform/surface/surface_platform_profile.c +++ b/drivers/platform/surface/surface_platform_profile.c @@ -40,7 +40,7 @@ struct ssam_tmp_profile_info { =20 struct ssam_platform_profile_device { struct ssam_device *sdev; - struct platform_profile_handler handler; + struct device *ppdev; bool has_fan; }; =20 @@ -228,13 +228,12 @@ static int surface_platform_profile_probe(struct ssam= _device *sdev) tpd->sdev =3D sdev; ssam_device_set_drvdata(sdev, tpd); =20 - tpd->handler.name =3D "Surface Platform Profile"; - tpd->handler.dev =3D &sdev->dev; - tpd->handler.ops =3D &ssam_platform_profile_ops; - tpd->has_fan =3D device_property_read_bool(&sdev->dev, "has_fan"); =20 - return devm_platform_profile_register(&tpd->handler, tpd); + tpd->ppdev =3D devm_platform_profile_register( + &sdev->dev, "Surface Platform Profile", tpd, &ssam_platform_profile_ops); + + return PTR_ERR_OR_ZERO(tpd->ppdev); } =20 static const struct ssam_device_id ssam_platform_profile_match[] =3D { diff --git a/drivers/platform/x86/acer-wmi.c b/drivers/platform/x86/acer-wm= i.c index 39ec236b7cdb..3e39465b3783 100644 --- a/drivers/platform/x86/acer-wmi.c +++ b/drivers/platform/x86/acer-wmi.c @@ -758,7 +758,7 @@ static const struct dmi_system_id non_acer_quirks[] __i= nitconst =3D { {} }; =20 -static struct platform_profile_handler platform_profile_handler; +static struct device *platform_profile_device; static bool platform_profile_support; =20 /* @@ -1937,16 +1937,10 @@ static const struct platform_profile_ops acer_preda= tor_v4_platform_profile_ops =3D static int acer_platform_profile_setup(struct platform_device *device) { if (quirks->predator_v4) { - int err; - - platform_profile_handler.name =3D "acer-wmi"; - platform_profile_handler.dev =3D &device->dev; - platform_profile_handler.ops =3D - &acer_predator_v4_platform_profile_ops; - - err =3D devm_platform_profile_register(&platform_profile_handler, NULL); - if (err) - return err; + platform_profile_device =3D devm_platform_profile_register( + &device->dev, "acer-wmi", NULL, &acer_predator_v4_platform_profile_ops); + if (IS_ERR(platform_profile_device)) + return PTR_ERR(platform_profile_device); =20 platform_profile_support =3D true; =20 @@ -2033,7 +2027,7 @@ static int acer_thermal_profile_change(void) if (tp !=3D ACER_PREDATOR_V4_THERMAL_PROFILE_TURBO_WMI) last_non_turbo_profile =3D tp; =20 - platform_profile_notify(&platform_profile_handler); + platform_profile_notify(platform_profile_device); } =20 return 0; diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/= pmf/pmf.h index d99b3556205b..41b2b91b8fdc 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -338,7 +338,7 @@ struct amd_pmf_dev { struct mutex lock; /* protects the PMF interface */ u32 supported_func; enum platform_profile_option current_profile; - struct platform_profile_handler pprof; + struct device *ppdev; /* platform profile class device */ struct dentry *dbgfs_dir; int hb_interval; /* SBIOS heartbeat interval */ struct delayed_work heart_beat; diff --git a/drivers/platform/x86/amd/pmf/sps.c b/drivers/platform/x86/amd/= pmf/sps.c index 7c7ed2b9de01..a96fc6887cf0 100644 --- a/drivers/platform/x86/amd/pmf/sps.c +++ b/drivers/platform/x86/amd/pmf/sps.c @@ -404,8 +404,6 @@ static const struct platform_profile_ops amd_pmf_profil= e_ops =3D { =20 int amd_pmf_init_sps(struct amd_pmf_dev *dev) { - int err; - dev->current_profile =3D PLATFORM_PROFILE_BALANCED; =20 if (is_apmf_func_supported(dev, APMF_FUNC_STATIC_SLIDER_GRANULAR)) { @@ -420,15 +418,12 @@ int amd_pmf_init_sps(struct amd_pmf_dev *dev) amd_pmf_set_sps_power_limits(dev); } =20 - dev->pprof.name =3D "amd-pmf"; - dev->pprof.dev =3D dev->dev; - dev->pprof.ops =3D &amd_pmf_profile_ops; - /* Create platform_profile structure and register */ - err =3D devm_platform_profile_register(&dev->pprof, dev); - if (err) - dev_err(dev->dev, "Failed to register SPS support, this is most likely a= n SBIOS bug: %d\n", - err); + dev->ppdev =3D devm_platform_profile_register( + dev->dev, "amd-pmf", dev, &amd_pmf_profile_ops); + if (IS_ERR(dev->ppdev)) + dev_err(dev->dev, "Failed to register SPS support, this is most likely a= n SBIOS bug: %ld\n", + PTR_ERR(dev->ppdev)); =20 - return err; + return PTR_ERR_OR_ZERO(dev->ppdev); } diff --git a/drivers/platform/x86/asus-wmi.c b/drivers/platform/x86/asus-wm= i.c index f8437cff66df..4ad99cf9df1a 100644 --- a/drivers/platform/x86/asus-wmi.c +++ b/drivers/platform/x86/asus-wmi.c @@ -313,7 +313,7 @@ struct asus_wmi { bool mid_fan_curve_available; struct fan_curve_data custom_fan_curves[3]; =20 - struct platform_profile_handler platform_profile_handler; + struct device *platform_profile_device; bool platform_profile_support; =20 // The RSOC controls the maximum charging percentage. @@ -3789,7 +3789,7 @@ static ssize_t throttle_thermal_policy_store(struct d= evice *dev, * Ensure that platform_profile updates userspace with the change to ensu= re * that platform_profile and throttle_thermal_policy_mode are in sync. */ - platform_profile_notify(&asus->platform_profile_handler); + platform_profile_notify(asus->platform_profile_device); =20 return count; } @@ -3891,17 +3891,13 @@ static int platform_profile_setup(struct asus_wmi *= asus) =20 dev_info(dev, "Using throttle_thermal_policy for platform_profile support= \n"); =20 - asus->platform_profile_handler.name =3D "asus-wmi"; - asus->platform_profile_handler.dev =3D dev; - asus->platform_profile_handler.ops =3D &asus_wmi_platform_profile_ops; + asus->platform_profile_device =3D devm_platform_profile_register( + dev, "asus-wmi", asus, &asus_wmi_platform_profile_ops); + if (IS_ERR(asus->platform_profile_device)) { + pr_err("%s, failed at devm_platform_profile_register: %ld\n", + __func__, PTR_ERR(asus->platform_profile_device)); =20 - err =3D devm_platform_profile_register(&asus->platform_profile_handler, a= sus); - if (err =3D=3D -EEXIST) { - pr_warn("%s, a platform_profile handler is already registered\n", __func= __); - return 0; - } else if (err) { - pr_err("%s, failed at devm_platform_profile_register: %d\n", __func__, e= rr); - return err; + return PTR_ERR(asus->platform_profile_device); } =20 asus->platform_profile_support =3D true; diff --git a/drivers/platform/x86/dell/alienware-wmi.c b/drivers/platform/x= 86/dell/alienware-wmi.c index 0146d2f93be6..99db93846a63 100644 --- a/drivers/platform/x86/dell/alienware-wmi.c +++ b/drivers/platform/x86/dell/alienware-wmi.c @@ -1135,11 +1135,12 @@ static const struct platform_profile_ops awcc_platf= orm_profile_ops =3D { =20 static int create_thermal_profile(struct platform_device *platform_device) { - pp_handler.name =3D "alienware-wmi"; - pp_handler.dev =3D &platform_device->dev; - pp_handler.ops =3D &awcc_platform_profile_ops; + struct device *ppdev; =20 - return devm_platform_profile_register(&pp_handler, NULL); + ppdev =3D devm_platform_profile_register( + &platform_device->dev, "alienware-wmi", NULL, &awcc_platform_profile_ops= ); + + return PTR_ERR_OR_ZERO(ppdev); } =20 /* diff --git a/drivers/platform/x86/dell/dell-pc.c b/drivers/platform/x86/del= l/dell-pc.c index 2759bb608b1a..8d60e1b223de 100644 --- a/drivers/platform/x86/dell/dell-pc.c +++ b/drivers/platform/x86/dell/dell-pc.c @@ -109,8 +109,6 @@ MODULE_DEVICE_TABLE(dmi, dell_device_table); #define DELL_ACC_SET_FIELD GENMASK(11, 8) #define DELL_THERMAL_SUPPORTED GENMASK(3, 0) =20 -static struct platform_profile_handler *thermal_handler; - enum thermal_mode_bits { DELL_BALANCED =3D BIT(0), DELL_COOL_BOTTOM =3D BIT(1), @@ -254,6 +252,7 @@ static const struct platform_profile_ops dell_pc_platfo= rm_profile_ops =3D { =20 static int thermal_init(void) { + struct device *ppdev; int ret; =20 /* If thermal commands are not supported, exit without error */ @@ -271,26 +270,17 @@ static int thermal_init(void) if (IS_ERR(platform_device)) return PTR_ERR(platform_device); =20 - thermal_handler =3D devm_kzalloc(&platform_device->dev, sizeof(*thermal_h= andler), GFP_KERNEL); - if (!thermal_handler) { - ret =3D -ENOMEM; - goto cleanup_platform_device; - } - thermal_handler->name =3D "dell-pc"; - thermal_handler->dev =3D &platform_device->dev; - thermal_handler->ops =3D &dell_pc_platform_profile_ops; - /* Clean up if failed */ - ret =3D devm_platform_profile_register(thermal_handler, NULL); - if (ret) + ppdev =3D devm_platform_profile_register( + &platform_device->dev, "dell-pc", NULL, &dell_pc_platform_profile_ops); + if (IS_ERR(ppdev)) { + ret =3D PTR_ERR(ppdev); goto cleanup_thermal_handler; + } =20 return 0; =20 cleanup_thermal_handler: - thermal_handler =3D NULL; - -cleanup_platform_device: platform_device_unregister(platform_device); =20 return ret; diff --git a/drivers/platform/x86/hp/hp-wmi.c b/drivers/platform/x86/hp/hp-= wmi.c index 1304dfc65aab..d1f9bd287986 100644 --- a/drivers/platform/x86/hp/hp-wmi.c +++ b/drivers/platform/x86/hp/hp-wmi.c @@ -273,7 +273,7 @@ static DEFINE_MUTEX(active_platform_profile_lock); static struct input_dev *hp_wmi_input_dev; static struct input_dev *camera_shutter_input_dev; static struct platform_device *hp_wmi_platform_dev; -static struct platform_profile_handler platform_profile_handler; +static struct device *platform_profile_device; static struct notifier_block platform_power_source_nb; static enum platform_profile_option active_platform_profile; static bool platform_profile_support; @@ -1602,6 +1602,7 @@ static const struct platform_profile_ops hp_wmi_platf= orm_profile_ops =3D { =20 static int thermal_profile_setup(struct platform_device *device) { + const struct platform_profile_ops *ops; int err, tp; =20 if (is_omen_thermal_profile()) { @@ -1617,7 +1618,7 @@ static int thermal_profile_setup(struct platform_devi= ce *device) if (err < 0) return err; =20 - platform_profile_handler.ops =3D &platform_profile_omen_ops; + ops =3D &platform_profile_omen_ops; } else if (is_victus_thermal_profile()) { err =3D platform_profile_victus_get_ec(&active_platform_profile); if (err < 0) @@ -1631,7 +1632,7 @@ static int thermal_profile_setup(struct platform_devi= ce *device) if (err < 0) return err; =20 - platform_profile_handler.ops =3D &platform_profile_victus_ops; + ops =3D &platform_profile_victus_ops; } else { tp =3D thermal_profile_get(); =20 @@ -1646,15 +1647,13 @@ static int thermal_profile_setup(struct platform_de= vice *device) if (err) return err; =20 - platform_profile_handler.ops =3D &hp_wmi_platform_profile_ops; + ops =3D &hp_wmi_platform_profile_ops; } =20 - platform_profile_handler.name =3D "hp-wmi"; - platform_profile_handler.dev =3D &device->dev; - - err =3D devm_platform_profile_register(&platform_profile_handler, NULL); - if (err) - return err; + platform_profile_device =3D devm_platform_profile_register( + &device->dev, "hp-wmi", NULL, ops); + if (IS_ERR(platform_profile_device)) + return PTR_ERR(platform_profile_device); =20 platform_profile_support =3D true; =20 diff --git a/drivers/platform/x86/ideapad-laptop.c b/drivers/platform/x86/i= deapad-laptop.c index 87c1e087770a..6065a7421a02 100644 --- a/drivers/platform/x86/ideapad-laptop.c +++ b/drivers/platform/x86/ideapad-laptop.c @@ -142,7 +142,7 @@ enum { =20 struct ideapad_dytc_priv { enum platform_profile_option current_profile; - struct platform_profile_handler pprof; + struct device *ppdev; /* platform profile device */ struct mutex mutex; /* protects the DYTC interface */ struct ideapad_private *priv; }; @@ -1050,7 +1050,7 @@ static void dytc_profile_refresh(struct ideapad_priva= te *priv) =20 if (profile !=3D priv->dytc->current_profile) { priv->dytc->current_profile =3D profile; - platform_profile_notify(&priv->dytc->pprof); + platform_profile_notify(priv->dytc->ppdev); } } =20 @@ -1117,15 +1117,15 @@ static int ideapad_dytc_profile_init(struct ideapad= _private *priv) =20 mutex_init(&priv->dytc->mutex); =20 - priv->dytc->pprof.name =3D "ideapad-laptop"; - priv->dytc->pprof.dev =3D &priv->platform_device->dev; priv->dytc->priv =3D priv; - priv->dytc->pprof.ops =3D &dytc_profile_ops; =20 /* Create platform_profile structure and register */ - err =3D devm_platform_profile_register(&priv->dytc->pprof, &priv->dytc); - if (err) + priv->dytc->ppdev =3D devm_platform_profile_register( + &priv->platform_device->dev, "ideapad-laptop", &priv->dytc, &dytc_profil= e_ops); + if (IS_ERR(priv->dytc->ppdev)) { + err =3D PTR_ERR(priv->dytc->ppdev); goto pp_reg_failed; + } =20 /* Ensure initial values are correct */ dytc_profile_refresh(priv); diff --git a/drivers/platform/x86/inspur_platform_profile.c b/drivers/platf= orm/x86/inspur_platform_profile.c index e1631de6ad86..8b71c4242939 100644 --- a/drivers/platform/x86/inspur_platform_profile.c +++ b/drivers/platform/x86/inspur_platform_profile.c @@ -32,7 +32,7 @@ enum inspur_tmp_profile { =20 struct inspur_wmi_priv { struct wmi_device *wdev; - struct platform_profile_handler handler; + struct device *ppdev; }; =20 static int inspur_wmi_perform_query(struct wmi_device *wdev, @@ -190,11 +190,10 @@ static int inspur_wmi_probe(struct wmi_device *wdev, = const void *context) priv->wdev =3D wdev; dev_set_drvdata(&wdev->dev, priv); =20 - priv->handler.name =3D "inspur-wmi"; - priv->handler.dev =3D &wdev->dev; - priv->handler.ops =3D &inspur_platform_profile_ops; + priv->ppdev =3D devm_platform_profile_register( + &wdev->dev, "inspur-wmi", priv, &inspur_platform_profile_ops); =20 - return devm_platform_profile_register(&priv->handler, priv); + return PTR_ERR_OR_ZERO(priv->ppdev); } =20 static const struct wmi_device_id inspur_wmi_id_table[] =3D { diff --git a/drivers/platform/x86/thinkpad_acpi.c b/drivers/platform/x86/th= inkpad_acpi.c index 54ff3e6b8b1a..2a3dd0d149a1 100644 --- a/drivers/platform/x86/thinkpad_acpi.c +++ b/drivers/platform/x86/thinkpad_acpi.c @@ -962,6 +962,7 @@ static const struct proc_ops dispatch_proc_ops =3D { static struct platform_device *tpacpi_pdev; static struct platform_device *tpacpi_sensors_pdev; static struct device *tpacpi_hwmon; +static struct device *tpacpi_pprof; static struct input_dev *tpacpi_inputdev; static struct mutex tpacpi_inputdev_send_mutex; static LIST_HEAD(tpacpi_all_drivers); @@ -10553,11 +10554,6 @@ static const struct platform_profile_ops dytc_prof= ile_ops =3D { .profile_set =3D dytc_profile_set, }; =20 -static struct platform_profile_handler dytc_profile =3D { - .name =3D "thinkpad-acpi", - .ops =3D &dytc_profile_ops, -}; - static void dytc_profile_refresh(void) { enum platform_profile_option profile; @@ -10586,7 +10582,7 @@ static void dytc_profile_refresh(void) err =3D convert_dytc_to_profile(funcmode, perfmode, &profile); if (!err && profile !=3D dytc_current_profile) { dytc_current_profile =3D profile; - platform_profile_notify(&dytc_profile); + platform_profile_notify(tpacpi_pprof); } } =20 @@ -10647,14 +10643,14 @@ static int tpacpi_dytc_profile_init(struct ibm_in= it_struct *iibm) dbg_printk(TPACPI_DBG_INIT, "DYTC version %d: thermal mode available\n", dytc_version); =20 - dytc_profile.dev =3D &tpacpi_pdev->dev; /* Create platform_profile structure and register */ - err =3D devm_platform_profile_register(&dytc_profile, NULL); + tpacpi_pprof =3D devm_platform_profile_register( + &tpacpi_pdev->dev, "thinkpad-acpi", NULL, &dytc_profile_ops); /* * If for some reason platform_profiles aren't enabled * don't quit terminally. */ - if (err) + if (IS_ERR(tpacpi_pprof)) return -ENODEV; =20 /* Ensure initial values are correct */ diff --git a/include/linux/platform_profile.h b/include/linux/platform_prof= ile.h index 5ad1ab7b75e4..778d4c661c3c 100644 --- a/include/linux/platform_profile.h +++ b/include/linux/platform_profile.h @@ -45,10 +45,14 @@ struct platform_profile_handler { const struct platform_profile_ops *ops; }; =20 -int platform_profile_register(struct platform_profile_handler *pprof, void= *drvdata); -int platform_profile_remove(struct platform_profile_handler *pprof); -int devm_platform_profile_register(struct platform_profile_handler *pprof,= void *drvdata); +struct device *platform_profile_register(struct device *dev, const char *n= ame, + void *drvdata, + const struct platform_profile_ops *ops); +int platform_profile_remove(struct device *dev); +struct device *devm_platform_profile_register(struct device *dev, const ch= ar *name, + void *drvdata, + const struct platform_profile_ops *ops); int platform_profile_cycle(void); -void platform_profile_notify(struct platform_profile_handler *pprof); +void platform_profile_notify(struct device *dev); =20 #endif /*_PLATFORM_PROFILE_H_*/ --=20 2.47.1