diff options
| author | Hawking Zhang <Hawking.Zhang@amd.com> | 2018-09-17 20:19:48 +0800 | 
|---|---|---|
| committer | Alex Deucher <alexander.deucher@amd.com> | 2018-09-19 12:37:39 -0500 | 
| commit | 27e39d3dd365d661b5f6b5b09ad86ee142e11de0 (patch) | |
| tree | f645189b4effd175b3cce8e32f43f33986dd1f7c /drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c | |
| parent | 801281fe09ffc8720336131669a946276e21fe4e (diff) | |
drm/amdgpu: fix unknown vram mem type for vega20
vega20 should use umc_info v3_3 instead of v3_1. There are
serveral versions of umc_info for vega series. Compared to
various versions of these structures, vram_info strucure is
unified for vega series. The patch switch to query mem_type
from vram_info structure for all the vega series dGPU.
Signed-off-by: Hawking Zhang <Hawking.Zhang@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c | 14 | 
1 files changed, 9 insertions, 5 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c index 5461d0d55111..b61e1dc61b4c 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c @@ -117,6 +117,10 @@ union igp_info {  union umc_info {  	struct atom_umc_info_v3_1 v31;  }; + +union vram_info { +	struct atom_vram_info_header_v2_3 v23; +};  /*   * Return vram width from integrated system info table, if available,   * or 0 if not. @@ -195,7 +199,7 @@ int amdgpu_atomfirmware_get_vram_type(struct amdgpu_device *adev)  	int index;  	u16 data_offset, size;  	union igp_info *igp_info; -	union umc_info *umc_info; +	union vram_info *vram_info;  	u8 frev, crev;  	u8 mem_type; @@ -204,7 +208,7 @@ int amdgpu_atomfirmware_get_vram_type(struct amdgpu_device *adev)  						    integratedsysteminfo);  	else  		index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1, -						    umc_info); +						    vram_info);  	if (amdgpu_atom_parse_data_header(mode_info->atom_context,  					  index, &size,  					  &frev, &crev, &data_offset)) { @@ -219,11 +223,11 @@ int amdgpu_atomfirmware_get_vram_type(struct amdgpu_device *adev)  				return 0;  			}  		} else { -			umc_info = (union umc_info *) +			vram_info = (union vram_info *)  				(mode_info->atom_context->bios + data_offset);  			switch (crev) { -			case 1: -				mem_type = umc_info->v31.vram_type; +			case 3: +				mem_type = vram_info->v23.vram_module[0].memory_type;  				return convert_atom_mem_type_to_vram_type(adev, mem_type);  			default:  				return 0; | 
