Commit 20bf2f6f authored by Zhigang Luo's avatar Zhigang Luo Committed by Alex Deucher

drm/amd/amdgpu: L1 Policy(1/5) - removed VM settings for mmhub and gfxhub from VF

Signed-off-by: default avatarZhigang Luo <zhigang.luo@amd.com>
Signed-off-by: default avatarJane Jian <jane.jian@amd.com>
Reviewed-by: default avatarEmily Deng <Emily.Deng@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 61130c74
...@@ -1308,11 +1308,12 @@ static int gmc_v9_0_hw_init(void *handle) ...@@ -1308,11 +1308,12 @@ static int gmc_v9_0_hw_init(void *handle)
value = true; value = true;
gfxhub_v1_0_set_fault_enable_default(adev, value); gfxhub_v1_0_set_fault_enable_default(adev, value);
if (adev->asic_type == CHIP_ARCTURUS) if (!amdgpu_sriov_vf(adev)) {
mmhub_v9_4_set_fault_enable_default(adev, value); if (adev->asic_type == CHIP_ARCTURUS)
else mmhub_v9_4_set_fault_enable_default(adev, value);
mmhub_v1_0_set_fault_enable_default(adev, value); else
mmhub_v1_0_set_fault_enable_default(adev, value);
}
for (i = 0; i < adev->num_vmhubs; ++i) for (i = 0; i < adev->num_vmhubs; ++i)
gmc_v9_0_flush_gpu_tlb(adev, 0, i, 0); gmc_v9_0_flush_gpu_tlb(adev, 0, i, 0);
......
...@@ -128,45 +128,53 @@ static void mmhub_v9_4_init_system_aperture_regs(struct amdgpu_device *adev, ...@@ -128,45 +128,53 @@ static void mmhub_v9_4_init_system_aperture_regs(struct amdgpu_device *adev,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
adev->gmc.agp_start >> 24); adev->gmc.agp_start >> 24);
/* Program the system aperture low logical page number. */ if (!amdgpu_sriov_vf(adev)) {
WREG32_SOC15_OFFSET(MMHUB, 0, /* Program the system aperture low logical page number. */
mmVMSHAREDVC0_MC_VM_SYSTEM_APERTURE_LOW_ADDR, WREG32_SOC15_OFFSET(
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, MMHUB, 0, mmVMSHAREDVC0_MC_VM_SYSTEM_APERTURE_LOW_ADDR,
min(adev->gmc.fb_start, adev->gmc.agp_start) >> 18); hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
WREG32_SOC15_OFFSET(MMHUB, 0, min(adev->gmc.fb_start, adev->gmc.agp_start) >> 18);
mmVMSHAREDVC0_MC_VM_SYSTEM_APERTURE_HIGH_ADDR, WREG32_SOC15_OFFSET(
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, MMHUB, 0, mmVMSHAREDVC0_MC_VM_SYSTEM_APERTURE_HIGH_ADDR,
max(adev->gmc.fb_end, adev->gmc.agp_end) >> 18); hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
max(adev->gmc.fb_end, adev->gmc.agp_end) >> 18);
/* Set default page address. */ /* Set default page address. */
value = adev->vram_scratch.gpu_addr - adev->gmc.vram_start + value = adev->vram_scratch.gpu_addr - adev->gmc.vram_start +
adev->vm_manager.vram_base_offset; adev->vm_manager.vram_base_offset;
WREG32_SOC15_OFFSET(MMHUB, 0, WREG32_SOC15_OFFSET(
MMHUB, 0,
mmVMSHAREDPF0_MC_VM_SYSTEM_APERTURE_DEFAULT_ADDR_LSB, mmVMSHAREDPF0_MC_VM_SYSTEM_APERTURE_DEFAULT_ADDR_LSB,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
(u32)(value >> 12)); (u32)(value >> 12));
WREG32_SOC15_OFFSET(MMHUB, 0, WREG32_SOC15_OFFSET(
MMHUB, 0,
mmVMSHAREDPF0_MC_VM_SYSTEM_APERTURE_DEFAULT_ADDR_MSB, mmVMSHAREDPF0_MC_VM_SYSTEM_APERTURE_DEFAULT_ADDR_MSB,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
(u32)(value >> 44)); (u32)(value >> 44));
/* Program "protection fault". */ /* Program "protection fault". */
WREG32_SOC15_OFFSET(MMHUB, 0, WREG32_SOC15_OFFSET(
mmVML2PF0_VM_L2_PROTECTION_FAULT_DEFAULT_ADDR_LO32, MMHUB, 0,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, mmVML2PF0_VM_L2_PROTECTION_FAULT_DEFAULT_ADDR_LO32,
(u32)(adev->dummy_page_addr >> 12)); hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
WREG32_SOC15_OFFSET(MMHUB, 0, (u32)(adev->dummy_page_addr >> 12));
mmVML2PF0_VM_L2_PROTECTION_FAULT_DEFAULT_ADDR_HI32, WREG32_SOC15_OFFSET(
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, MMHUB, 0,
(u32)((u64)adev->dummy_page_addr >> 44)); mmVML2PF0_VM_L2_PROTECTION_FAULT_DEFAULT_ADDR_HI32,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
(u32)((u64)adev->dummy_page_addr >> 44));
tmp = RREG32_SOC15_OFFSET(MMHUB, 0, tmp = RREG32_SOC15_OFFSET(
mmVML2PF0_VM_L2_PROTECTION_FAULT_CNTL2, MMHUB, 0, mmVML2PF0_VM_L2_PROTECTION_FAULT_CNTL2,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET); hubid * MMHUB_INSTANCE_REGISTER_OFFSET);
tmp = REG_SET_FIELD(tmp, VML2PF0_VM_L2_PROTECTION_FAULT_CNTL2, tmp = REG_SET_FIELD(tmp, VML2PF0_VM_L2_PROTECTION_FAULT_CNTL2,
ACTIVE_PAGE_MIGRATION_PTE_READ_RETRY, 1); ACTIVE_PAGE_MIGRATION_PTE_READ_RETRY, 1);
WREG32_SOC15_OFFSET(MMHUB, 0, mmVML2PF0_VM_L2_PROTECTION_FAULT_CNTL2, WREG32_SOC15_OFFSET(MMHUB, 0,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET, tmp); mmVML2PF0_VM_L2_PROTECTION_FAULT_CNTL2,
hubid * MMHUB_INSTANCE_REGISTER_OFFSET,
tmp);
}
} }
static void mmhub_v9_4_init_tlb_regs(struct amdgpu_device *adev, int hubid) static void mmhub_v9_4_init_tlb_regs(struct amdgpu_device *adev, int hubid)
...@@ -372,10 +380,12 @@ int mmhub_v9_4_gart_enable(struct amdgpu_device *adev) ...@@ -372,10 +380,12 @@ int mmhub_v9_4_gart_enable(struct amdgpu_device *adev)
mmhub_v9_4_init_gart_aperture_regs(adev, i); mmhub_v9_4_init_gart_aperture_regs(adev, i);
mmhub_v9_4_init_system_aperture_regs(adev, i); mmhub_v9_4_init_system_aperture_regs(adev, i);
mmhub_v9_4_init_tlb_regs(adev, i); mmhub_v9_4_init_tlb_regs(adev, i);
mmhub_v9_4_init_cache_regs(adev, i); if (!amdgpu_sriov_vf(adev))
mmhub_v9_4_init_cache_regs(adev, i);
mmhub_v9_4_enable_system_domain(adev, i); mmhub_v9_4_enable_system_domain(adev, i);
mmhub_v9_4_disable_identity_aperture(adev, i); if (!amdgpu_sriov_vf(adev))
mmhub_v9_4_disable_identity_aperture(adev, i);
mmhub_v9_4_setup_vmid_config(adev, i); mmhub_v9_4_setup_vmid_config(adev, i);
mmhub_v9_4_program_invalidation(adev, i); mmhub_v9_4_program_invalidation(adev, i);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment