Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 64d03abe authored by Tom St Denis's avatar Tom St Denis Committed by Alex Deucher
Browse files

drm/amd/powerplay: Fix psm_set_user_performance_state()



We now pass a pointer to a pointer which seems to be
what they meant in the first place.  The previous version
was modifying a pointer passed by value.

Fixes bug that was introduced by

commit 332798d40c2e91:drm/amd/powerplay: delete eventmgr layer in poweprlay

Signed-off-by: default avatarTom St Denis <tom.stdenis@amd.com>
Reviewed-By: default avatarRex Zhu <Rex.Zhu@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent a216ab09
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -294,7 +294,7 @@ int hwmgr_handle_task(struct pp_instance *handle, enum amd_pp_task task_id,
	{
		enum amd_pm_state_type ps;
		enum PP_StateUILabel requested_ui_label;
		struct pp_power_state *requested_ps;
		struct pp_power_state *requested_ps = NULL;

		if (input == NULL) {
			ret = -EINVAL;
@@ -303,7 +303,7 @@ int hwmgr_handle_task(struct pp_instance *handle, enum amd_pp_task task_id,
		ps = *(unsigned long *)input;

		requested_ui_label = power_state_convert(ps);
		ret = psm_set_user_performance_state(hwmgr, requested_ui_label, requested_ps);
		ret = psm_set_user_performance_state(hwmgr, requested_ui_label, &requested_ps);
		if (ret)
			return ret;
		ret = psm_adjust_power_state_dynamic(hwmgr, false, requested_ps);
+4 −4
Original line number Diff line number Diff line
@@ -188,19 +188,19 @@ int psm_set_performance_states(struct pp_hwmgr *hwmgr)

int psm_set_user_performance_state(struct pp_hwmgr *hwmgr,
					enum PP_StateUILabel label_id,
					struct pp_power_state *state)
					struct pp_power_state **state)
{
	int table_entries;
	int i;

	table_entries = hwmgr->num_ps;
	state = hwmgr->ps;
	*state = hwmgr->ps;

restart_search:
	for (i = 0; i < table_entries; i++) {
		if (state->classification.ui_label & label_id)
		if ((*state)->classification.ui_label & label_id)
			return 0;
		state = (struct pp_power_state *)((unsigned long)state + hwmgr->ps_size);
		*state = (struct pp_power_state *)((uintptr_t)*state + hwmgr->ps_size);
	}

	switch (label_id) {
+1 −1
Original line number Diff line number Diff line
@@ -32,7 +32,7 @@ int psm_set_boot_states(struct pp_hwmgr *hwmgr);
int psm_set_performance_states(struct pp_hwmgr *hwmgr);
int psm_set_user_performance_state(struct pp_hwmgr *hwmgr,
					enum PP_StateUILabel label_id,
					struct pp_power_state *state);
					struct pp_power_state **state);
int psm_adjust_power_state_dynamic(struct pp_hwmgr *hwmgr,
				bool skip,
				struct pp_power_state *new_ps);