Unverified Commit 6f5e63dd authored by Mario Limonciello's avatar Mario Limonciello Committed by Ilpo Järvinen
Browse files

ACPI: platform_profile: Add device pointer into platform profile handler



In order to let platform profile handlers manage platform profile
for their driver the core code will need a pointer to the device.

Add this to the structure and use it in the trivial driver cases.

Reviewed-by: default avatarArmin Wolf <W_Armin@gmx.de>
Reviewed-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Reviewed-by: default avatarMaximilian Luz <luzmaximilian@gmail.com>
Reviewed-by: default avatarMark Pearson <mpearson-lenovo@squebb.ca>
Signed-off-by: default avatarMario Limonciello <mario.limonciello@amd.com>
Link: https://lore.kernel.org/r/20241206031918.1537-4-mario.limonciello@amd.com


Signed-off-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
parent 7c63fe4d
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -212,6 +212,7 @@ static int surface_platform_profile_probe(struct ssam_device *sdev)
	tpd->sdev = sdev;

	tpd->handler.name = "Surface Platform Profile";
	tpd->handler.dev = &sdev->dev;
	tpd->handler.profile_get = ssam_platform_profile_get;
	tpd->handler.profile_set = ssam_platform_profile_set;

+3 −2
Original line number Diff line number Diff line
@@ -1873,12 +1873,13 @@ acer_predator_v4_platform_profile_set(struct platform_profile_handler *pprof,
	return 0;
}

static int acer_platform_profile_setup(void)
static int acer_platform_profile_setup(struct platform_device *device)
{
	if (quirks->predator_v4) {
		int err;

		platform_profile_handler.name = "acer-wmi";
		platform_profile_handler.dev = &device->dev;
		platform_profile_handler.profile_get =
			acer_predator_v4_platform_profile_get;
		platform_profile_handler.profile_set =
@@ -2531,7 +2532,7 @@ static int acer_platform_probe(struct platform_device *device)
		goto error_rfkill;

	if (has_cap(ACER_CAP_PLATFORM_PROFILE)) {
		err = acer_platform_profile_setup();
		err = acer_platform_profile_setup(device);
		if (err)
			goto error_platform_profile;
	}
+1 −0
Original line number Diff line number Diff line
@@ -406,6 +406,7 @@ int amd_pmf_init_sps(struct amd_pmf_dev *dev)
	}

	dev->pprof.name = "amd-pmf";
	dev->pprof.dev = dev->dev;
	dev->pprof.profile_get = amd_pmf_profile_get;
	dev->pprof.profile_set = amd_pmf_profile_set;

+1 −0
Original line number Diff line number Diff line
@@ -3877,6 +3877,7 @@ static int platform_profile_setup(struct asus_wmi *asus)
	dev_info(dev, "Using throttle_thermal_policy for platform_profile support\n");

	asus->platform_profile_handler.name = "asus-wmi";
	asus->platform_profile_handler.dev = dev;
	asus->platform_profile_handler.profile_get = asus_wmi_platform_profile_get;
	asus->platform_profile_handler.profile_set = asus_wmi_platform_profile_set;

+3 −2
Original line number Diff line number Diff line
@@ -1108,7 +1108,7 @@ static int thermal_profile_set(struct platform_profile_handler *pprof,
	return wmax_thermal_control(supported_thermal_profiles[profile]);
}

static int create_thermal_profile(void)
static int create_thermal_profile(struct platform_device *platform_device)
{
	u32 out_data;
	u8 sys_desc[4];
@@ -1157,6 +1157,7 @@ static int create_thermal_profile(void)
	pp_handler.profile_get = thermal_profile_get;
	pp_handler.profile_set = thermal_profile_set;
	pp_handler.name = "alienware-wmi";
	pp_handler.dev = &platform_device->dev;

	return platform_profile_register(&pp_handler);
}
@@ -1225,7 +1226,7 @@ static int __init alienware_wmi_init(void)
	}

	if (quirks->thermal) {
		ret = create_thermal_profile();
		ret = create_thermal_profile(platform_device);
		if (ret)
			goto fail_prep_thermal_profile;
	}
Loading