diff options
| author | Yang Wang <[email protected]> | 2023-08-01 16:53:23 +0800 | 
|---|---|---|
| committer | Alex Deucher <[email protected]> | 2023-08-07 17:14:06 -0400 | 
| commit | 25e6373a5b8efc623443f2699d2b929bf3067d76 (patch) | |
| tree | a7ef1f06bd418f656ae11698588dade4c897bc60 /drivers/gpu/drm/amd/pm/amdgpu_pm.c | |
| parent | 50709d18f4a659cf7c1c6287498412f367442646 (diff) | |
drm/amd/pm: fix variable dereferenced issue in amdgpu_device_attr_create()
- fix variable ('attr') dereferenced issue.
- using condition check instead of BUG_ON().
Fixes: 4e01847c38f7 ("drm/amdgpu: optimize amdgpu device attribute code")
Cc: Dan Carpenter <[email protected]>
Signed-off-by: Yang Wang <[email protected]>
Reviewed-by: Kenneth Feng <[email protected]>
Signed-off-by: Alex Deucher <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/pm/amdgpu_pm.c')
| -rw-r--r-- | drivers/gpu/drm/amd/pm/amdgpu_pm.c | 10 | 
1 files changed, 7 insertions, 3 deletions
diff --git a/drivers/gpu/drm/amd/pm/amdgpu_pm.c b/drivers/gpu/drm/amd/pm/amdgpu_pm.c index 3922dd274f30..383b2b778456 100644 --- a/drivers/gpu/drm/amd/pm/amdgpu_pm.c +++ b/drivers/gpu/drm/amd/pm/amdgpu_pm.c @@ -2171,15 +2171,19 @@ static int amdgpu_device_attr_create(struct amdgpu_device *adev,  				     uint32_t mask, struct list_head *attr_list)  {  	int ret = 0; -	struct device_attribute *dev_attr = &attr->dev_attr; -	const char *name = dev_attr->attr.name;  	enum amdgpu_device_attr_states attr_states = ATTR_STATE_SUPPORTED;  	struct amdgpu_device_attr_entry *attr_entry; +	struct device_attribute *dev_attr; +	const char *name;  	int (*attr_update)(struct amdgpu_device *adev, struct amdgpu_device_attr *attr,  			   uint32_t mask, enum amdgpu_device_attr_states *states) = default_attr_update; -	BUG_ON(!attr); +	if (!attr) +		return -EINVAL; + +	dev_attr = &attr->dev_attr; +	name = dev_attr->attr.name;  	attr_update = attr->attr_update ? attr->attr_update : default_attr_update;  |