diff options
| author | Dave Airlie <[email protected]> | 2018-09-21 09:52:34 +1000 | 
|---|---|---|
| committer | Dave Airlie <[email protected]> | 2018-09-21 09:52:53 +1000 | 
| commit | 36c9c3c91128e2b892c9be0dd9ee9bd82cbe82ad (patch) | |
| tree | 687db2e37b7fdcb4bd756a078812d049da18c804 /drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c | |
| parent | 0320ac5188eab5c6e8b92b110d1eae967ac272d2 (diff) | |
| parent | 846311ae68f3c78365ebf3dff505c99e7da861cf (diff) | |
Merge branch 'drm-next-4.20' of git://people.freedesktop.org/~agd5f/linux into drm-next
This is a new pull for drm-next on top of last weeks with the following
changes:
- Fixed 64 bit divide
- Fixed vram type on vega20
- Misc vega20 fixes
- Misc DC fixes
- Fix GDS/GWS/OA domain handling
Previous changes from last week:
amdgpu/kfd:
- Picasso (new APU) support
- Raven2 (new APU) support
- Vega20 enablement
- ACP powergating improvements
- Add ABGR/XBGR display support
- VCN JPEG engine support
- Initial xGMI support
- Use load balancing for engine scheduling
- Lots of new documentation
- Rework and clean up i2c and aux handling in DC
- Add DP YCbCr 4:2:0 support in DC
- Add DMCU firmware loading for Raven (used for ABM and PSR)
- New debugfs features in DC
- LVDS support in DC
- Implement wave kill for gfx/compute (light weight reset for shaders)
- Use AGP aperture to avoid gart mappings when possible
- GPUVM performance improvements
- Bulk moves for more efficient GPUVM LRU handling
- Merge amdgpu and amdkfd into one module
- Enable gfxoff and stutter mode on Raven
- Misc cleanups
Scheduler:
- Load balancing support
- Bug fixes
ttm:
- Bulk move functionality
- Bug fixes
radeon:
- Misc cleanups
Signed-off-by: Dave Airlie <[email protected]>
From: Alex Deucher <[email protected]>
Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c | 16 | 
1 files changed, 10 insertions, 6 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c index 236915849cfe..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. @@ -174,7 +178,7 @@ static int convert_atom_mem_type_to_vram_type (struct amdgpu_device *adev,  		case ATOM_DGPU_VRAM_TYPE_GDDR5:  			vram_type = AMDGPU_VRAM_TYPE_GDDR5;  			break; -		case ATOM_DGPU_VRAM_TYPE_HBM: +		case ATOM_DGPU_VRAM_TYPE_HBM2:  			vram_type = AMDGPU_VRAM_TYPE_HBM;  			break;  		default: @@ -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; |