|
@@ -76,16 +76,16 @@ static void mmhub_v1_0_init_system_aperture_regs(struct amdgpu_device *adev)
|
|
|
uint64_t value;
|
|
|
uint32_t tmp;
|
|
|
|
|
|
- /* Disable AGP. */
|
|
|
+ /* Program the AGP BAR */
|
|
|
WREG32_SOC15(MMHUB, 0, mmMC_VM_AGP_BASE, 0);
|
|
|
- WREG32_SOC15(MMHUB, 0, mmMC_VM_AGP_TOP, 0);
|
|
|
- WREG32_SOC15(MMHUB, 0, mmMC_VM_AGP_BOT, 0x00FFFFFF);
|
|
|
+ WREG32_SOC15(MMHUB, 0, mmMC_VM_AGP_BOT, adev->gmc.agp_start >> 24);
|
|
|
+ WREG32_SOC15(MMHUB, 0, mmMC_VM_AGP_TOP, adev->gmc.agp_end >> 24);
|
|
|
|
|
|
/* Program the system aperture low logical page number. */
|
|
|
WREG32_SOC15(MMHUB, 0, mmMC_VM_SYSTEM_APERTURE_LOW_ADDR,
|
|
|
- adev->gmc.vram_start >> 18);
|
|
|
+ min(adev->gmc.vram_start, adev->gmc.agp_start) >> 18);
|
|
|
WREG32_SOC15(MMHUB, 0, mmMC_VM_SYSTEM_APERTURE_HIGH_ADDR,
|
|
|
- adev->gmc.vram_end >> 18);
|
|
|
+ max(adev->gmc.vram_end, adev->gmc.agp_end) >> 18);
|
|
|
|
|
|
/* Set default page address. */
|
|
|
value = adev->vram_scratch.gpu_addr - adev->gmc.vram_start +
|