aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c
diff options
context:
space:
mode:
authorAlex Deucher <alexander.deucher@amd.com>2017-07-05 15:26:48 -0400
committerAlex Deucher <alexander.deucher@amd.com>2017-07-14 11:06:18 -0400
commit21f6bcb6d449d24b63dd1d5d030d34d88baa6a0f (patch)
treec68c13b906cfe8628405f4480b6c38e5b369915a /drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c
parent6c8855541492b3d812d55c9fe5a2ed17ddf022b8 (diff)
drm/amdgpu/atomfirmware: implement vram_width for APUs
Implement support using the new atomfirmware system info table. Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com> Acked-by: Christian König <christian.koenig@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.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c
index 9ddfe34d12af..a7d65f033883 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c
@@ -95,3 +95,36 @@ int amdgpu_atomfirmware_allocate_fb_scratch(struct amdgpu_device *adev)
95 ctx->scratch_size_bytes = usage_bytes; 95 ctx->scratch_size_bytes = usage_bytes;
96 return 0; 96 return 0;
97} 97}
98
99union igp_info {
100 struct atom_integrated_system_info_v1_11 v11;
101};
102
103/*
104 * Return vram width from integrated system info table, if available,
105 * or 0 if not.
106 */
107int amdgpu_atomfirmware_get_vram_width(struct amdgpu_device *adev)
108{
109 struct amdgpu_mode_info *mode_info = &adev->mode_info;
110 int index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1,
111 integratedsysteminfo);
112 u16 data_offset, size;
113 union igp_info *igp_info;
114 u8 frev, crev;
115
116 /* get any igp specific overrides */
117 if (amdgpu_atom_parse_data_header(mode_info->atom_context, index, &size,
118 &frev, &crev, &data_offset)) {
119 igp_info = (union igp_info *)
120 (mode_info->atom_context->bios + data_offset);
121 switch (crev) {
122 case 11:
123 return igp_info->v11.umachannelnumber * 64;
124 default:
125 return 0;
126 }
127 }
128
129 return 0;
130}