mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
drm/amdgpu: query vram_width from vram_info table
Driver will get channel_number and channel_width from vram_info table, then calculate vram_width by multiply channel_number by channel_width Signed-off-by: Hawking Zhang <Hawking.Zhang@amd.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com> Reviewed-by: Jack Xiao <Jack.Xiao@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
89d7a79c7b
commit
09fa0613bd
@ -127,22 +127,50 @@ union vram_info {
|
|||||||
int amdgpu_atomfirmware_get_vram_width(struct amdgpu_device *adev)
|
int amdgpu_atomfirmware_get_vram_width(struct amdgpu_device *adev)
|
||||||
{
|
{
|
||||||
struct amdgpu_mode_info *mode_info = &adev->mode_info;
|
struct amdgpu_mode_info *mode_info = &adev->mode_info;
|
||||||
int index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1,
|
int index;
|
||||||
integratedsysteminfo);
|
|
||||||
u16 data_offset, size;
|
u16 data_offset, size;
|
||||||
union igp_info *igp_info;
|
union igp_info *igp_info;
|
||||||
|
union vram_info *vram_info;
|
||||||
|
u32 mem_channel_number;
|
||||||
|
u32 mem_channel_width;
|
||||||
u8 frev, crev;
|
u8 frev, crev;
|
||||||
|
|
||||||
|
if (adev->flags & AMD_IS_APU)
|
||||||
|
index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1,
|
||||||
|
integratedsysteminfo);
|
||||||
|
else
|
||||||
|
index = get_index_into_master_table(atom_master_list_of_data_tables_v2_1,
|
||||||
|
vram_info);
|
||||||
|
|
||||||
/* get any igp specific overrides */
|
/* get any igp specific overrides */
|
||||||
if (amdgpu_atom_parse_data_header(mode_info->atom_context, index, &size,
|
if (amdgpu_atom_parse_data_header(mode_info->atom_context, index, &size,
|
||||||
&frev, &crev, &data_offset)) {
|
&frev, &crev, &data_offset)) {
|
||||||
igp_info = (union igp_info *)
|
if (adev->flags & AMD_IS_APU) {
|
||||||
(mode_info->atom_context->bios + data_offset);
|
igp_info = (union igp_info *)
|
||||||
switch (crev) {
|
(mode_info->atom_context->bios + data_offset);
|
||||||
case 11:
|
switch (crev) {
|
||||||
return igp_info->v11.umachannelnumber * 64;
|
case 11:
|
||||||
default:
|
mem_channel_number = igp_info->v11.umachannelnumber;
|
||||||
return 0;
|
/* channel width is 64 */
|
||||||
|
return mem_channel_number * 64;
|
||||||
|
default:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
vram_info = (union vram_info *)
|
||||||
|
(mode_info->atom_context->bios + data_offset);
|
||||||
|
switch (crev) {
|
||||||
|
case 3:
|
||||||
|
mem_channel_number = vram_info->v23.vram_module[0].channel_num;
|
||||||
|
mem_channel_width = vram_info->v23.vram_module[0].channel_width;
|
||||||
|
return mem_channel_number * (1 << mem_channel_width);
|
||||||
|
case 4:
|
||||||
|
mem_channel_number = vram_info->v24.vram_module[0].channel_num;
|
||||||
|
mem_channel_width = vram_info->v24.vram_module[0].channel_width;
|
||||||
|
return mem_channel_number * (1 << mem_channel_width);
|
||||||
|
default:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user