mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-09-10 01:17:17 +00:00
drm/amdgpu: Use firmware supported NPS modes
If firmware supported NPS modes are available through CAP register, use those values for supported NPS modes. Signed-off-by: Lijo Lazar <lijo.lazar@amd.com> Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
b2a9e562df
commit
30eb41f5d1
@ -1594,23 +1594,39 @@ static void gmc_v9_0_set_xgmi_ras_funcs(struct amdgpu_device *adev)
|
|||||||
|
|
||||||
static void gmc_v9_0_init_nps_details(struct amdgpu_device *adev)
|
static void gmc_v9_0_init_nps_details(struct amdgpu_device *adev)
|
||||||
{
|
{
|
||||||
|
enum amdgpu_memory_partition mode;
|
||||||
|
uint32_t supp_modes;
|
||||||
|
int i;
|
||||||
|
|
||||||
adev->gmc.supported_nps_modes = 0;
|
adev->gmc.supported_nps_modes = 0;
|
||||||
|
|
||||||
if (amdgpu_sriov_vf(adev) || (adev->flags & AMD_IS_APU))
|
if (amdgpu_sriov_vf(adev) || (adev->flags & AMD_IS_APU))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/*TODO: Check PSP version also which supports NPS switch. Otherwise keep
|
mode = gmc_v9_0_get_memory_partition(adev, &supp_modes);
|
||||||
|
|
||||||
|
/* Mode detected by hardware and supported modes available */
|
||||||
|
if ((mode != UNKNOWN_MEMORY_PARTITION_MODE) && supp_modes) {
|
||||||
|
for (i = AMDGPU_NPS1_PARTITION_MODE;
|
||||||
|
supp_modes && i <= AMDGPU_NPS8_PARTITION_MODE; i++) {
|
||||||
|
if (supp_modes & BIT(i - 1))
|
||||||
|
adev->gmc.supported_nps_modes |= BIT(i);
|
||||||
|
supp_modes &= supp_modes - 1;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/*TODO: Check PSP version also which supports NPS switch. Otherwise keep
|
||||||
* supported modes as 0.
|
* supported modes as 0.
|
||||||
*/
|
*/
|
||||||
switch (amdgpu_ip_version(adev, GC_HWIP, 0)) {
|
switch (amdgpu_ip_version(adev, GC_HWIP, 0)) {
|
||||||
case IP_VERSION(9, 4, 3):
|
case IP_VERSION(9, 4, 3):
|
||||||
case IP_VERSION(9, 4, 4):
|
case IP_VERSION(9, 4, 4):
|
||||||
adev->gmc.supported_nps_modes =
|
adev->gmc.supported_nps_modes =
|
||||||
BIT(AMDGPU_NPS1_PARTITION_MODE) |
|
BIT(AMDGPU_NPS1_PARTITION_MODE) |
|
||||||
BIT(AMDGPU_NPS4_PARTITION_MODE);
|
BIT(AMDGPU_NPS4_PARTITION_MODE);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user