diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_atomfirmware.c | 33 |
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 | |||
99 | union 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 | */ | ||
107 | int 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 | } | ||