diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/kv_dpm.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/kv_dpm.c | 53 | 
1 files changed, 34 insertions, 19 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/kv_dpm.c b/drivers/gpu/drm/amd/amdgpu/kv_dpm.c index 3bbf2ccfca89..f68d7abe1ed9 100644 --- a/drivers/gpu/drm/amd/amdgpu/kv_dpm.c +++ b/drivers/gpu/drm/amd/amdgpu/kv_dpm.c @@ -64,7 +64,7 @@ static int kv_set_thermal_temperature_range(struct amdgpu_device *adev,  					    int min_temp, int max_temp);  static int kv_init_fps_limits(struct amdgpu_device *adev); -static void kv_dpm_powergate_uvd(struct amdgpu_device *adev, bool gate); +static void kv_dpm_powergate_uvd(void *handle, bool gate);  static void kv_dpm_powergate_vce(struct amdgpu_device *adev, bool gate);  static void kv_dpm_powergate_samu(struct amdgpu_device *adev, bool gate);  static void kv_dpm_powergate_acp(struct amdgpu_device *adev, bool gate); @@ -1245,8 +1245,9 @@ static void kv_update_requested_ps(struct amdgpu_device *adev,  	adev->pm.dpm.requested_ps = &pi->requested_rps;  } -static void kv_dpm_enable_bapm(struct amdgpu_device *adev, bool enable) +static void kv_dpm_enable_bapm(void *handle, bool enable)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	int ret; @@ -1672,8 +1673,9 @@ static int kv_update_acp_dpm(struct amdgpu_device *adev, bool gate)  	return kv_enable_acp_dpm(adev, !gate);  } -static void kv_dpm_powergate_uvd(struct amdgpu_device *adev, bool gate) +static void kv_dpm_powergate_uvd(void *handle, bool gate)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	int ret; @@ -1868,10 +1870,11 @@ static int kv_enable_nb_dpm(struct amdgpu_device *adev,  	return ret;  } -static int kv_dpm_force_performance_level(struct amdgpu_device *adev, +static int kv_dpm_force_performance_level(void *handle,  					  enum amd_dpm_forced_level level)  {  	int ret; +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	if (level == AMD_DPM_FORCED_LEVEL_HIGH) {  		ret = kv_force_dpm_highest(adev); @@ -1892,8 +1895,9 @@ static int kv_dpm_force_performance_level(struct amdgpu_device *adev,  	return 0;  } -static int kv_dpm_pre_set_power_state(struct amdgpu_device *adev) +static int kv_dpm_pre_set_power_state(void *handle)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	struct amdgpu_ps requested_ps = *adev->pm.dpm.requested_ps;  	struct amdgpu_ps *new_ps = &requested_ps; @@ -1907,8 +1911,9 @@ static int kv_dpm_pre_set_power_state(struct amdgpu_device *adev)  	return 0;  } -static int kv_dpm_set_power_state(struct amdgpu_device *adev) +static int kv_dpm_set_power_state(void *handle)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	struct amdgpu_ps *new_ps = &pi->requested_rps;  	struct amdgpu_ps *old_ps = &pi->current_rps; @@ -1981,8 +1986,9 @@ static int kv_dpm_set_power_state(struct amdgpu_device *adev)  	return 0;  } -static void kv_dpm_post_set_power_state(struct amdgpu_device *adev) +static void kv_dpm_post_set_power_state(void *handle)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	struct amdgpu_ps *new_ps = &pi->requested_rps; @@ -2848,9 +2854,10 @@ static int kv_dpm_init(struct amdgpu_device *adev)  }  static void -kv_dpm_debugfs_print_current_performance_level(struct amdgpu_device *adev, +kv_dpm_debugfs_print_current_performance_level(void *handle,  					       struct seq_file *m)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	u32 current_index =  		(RREG32_SMC(ixTARGET_AND_CURRENT_PROFILE_INDEX) & @@ -2875,11 +2882,12 @@ kv_dpm_debugfs_print_current_performance_level(struct amdgpu_device *adev,  }  static void -kv_dpm_print_power_state(struct amdgpu_device *adev, -			 struct amdgpu_ps *rps) +kv_dpm_print_power_state(void *handle, void *request_ps)  {  	int i; +	struct amdgpu_ps *rps = (struct amdgpu_ps *)request_ps;  	struct kv_ps *ps = kv_get_ps(rps); +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	amdgpu_dpm_print_class_info(rps->class, rps->class2);  	amdgpu_dpm_print_cap_info(rps->caps); @@ -2905,13 +2913,14 @@ static void kv_dpm_fini(struct amdgpu_device *adev)  	amdgpu_free_extended_power_table(adev);  } -static void kv_dpm_display_configuration_changed(struct amdgpu_device *adev) +static void kv_dpm_display_configuration_changed(void *handle)  {  } -static u32 kv_dpm_get_sclk(struct amdgpu_device *adev, bool low) +static u32 kv_dpm_get_sclk(void *handle, bool low)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	struct kv_ps *requested_state = kv_get_ps(&pi->requested_rps); @@ -2921,18 +2930,20 @@ static u32 kv_dpm_get_sclk(struct amdgpu_device *adev, bool low)  		return requested_state->levels[requested_state->num_levels - 1].sclk;  } -static u32 kv_dpm_get_mclk(struct amdgpu_device *adev, bool low) +static u32 kv_dpm_get_mclk(void *handle, bool low)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	return pi->sys_info.bootup_uma_clk;  }  /* get temperature in millidegrees */ -static int kv_dpm_get_temp(struct amdgpu_device *adev) +static int kv_dpm_get_temp(void *handle)  {  	u32 temp;  	int actual_temp = 0; +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	temp = RREG32_SMC(0xC0300E0C); @@ -3222,14 +3233,17 @@ static inline bool kv_are_power_levels_equal(const struct kv_pl *kv_cpl1,  		  (kv_cpl1->force_nbp_state == kv_cpl2->force_nbp_state));  } -static int kv_check_state_equal(struct amdgpu_device *adev, -				struct amdgpu_ps *cps, -				struct amdgpu_ps *rps, +static int kv_check_state_equal(void *handle, +				void *current_ps, +				void *request_ps,  				bool *equal)  {  	struct kv_ps *kv_cps;  	struct kv_ps *kv_rps;  	int i; +	struct amdgpu_ps *cps = (struct amdgpu_ps *)current_ps; +	struct amdgpu_ps *rps = (struct amdgpu_ps *)request_ps; +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	if (adev == NULL || cps == NULL || rps == NULL || equal == NULL)  		return -EINVAL; @@ -3262,9 +3276,10 @@ static int kv_check_state_equal(struct amdgpu_device *adev,  	return 0;  } -static int kv_dpm_read_sensor(struct amdgpu_device *adev, int idx, +static int kv_dpm_read_sensor(void *handle, int idx,  			      void *value, int *size)  { +	struct amdgpu_device *adev = (struct amdgpu_device *)handle;  	struct kv_power_info *pi = kv_get_pi(adev);  	uint32_t sclk;  	u32 pl_index = @@ -3312,7 +3327,7 @@ const struct amd_ip_funcs kv_dpm_ip_funcs = {  	.set_powergating_state = kv_dpm_set_powergating_state,  }; -static const struct amdgpu_dpm_funcs kv_dpm_funcs = { +static const struct amd_pm_funcs kv_dpm_funcs = {  	.get_temperature = &kv_dpm_get_temp,  	.pre_set_power_state = &kv_dpm_pre_set_power_state,  	.set_power_state = &kv_dpm_set_power_state, | 

