Hi Yong, That has been submitted.
MC address is the address sent to memory controller bus to address the physical memory. In many places it is also called physical address. Logical address is the address before it is translated to physical address. The translation can be either linear or through page table. Under VMID0, logical address of some apertures (AGP, FB) are linearly mapped to MC address. (I think in our driver implementation, logical address == MC address). But Gart aperture is mapped through gpuvm (gart) page table - the mapped address can also be called virtual address. Under VMID1~15, it is user space virtual address (can also be called logical address), mapped through gpuvm page tables. So virtual address is one type of logical address. Virtual address is usually mapped through page table/vm. Just my understanding. Regards, Oak From: Zhao, Yong <yong.z...@amd.com> Sent: Thursday, November 7, 2019 12:16 PM To: Alex Deucher <alexdeuc...@gmail.com>; Zeng, Oak <oak.z...@amd.com> Cc: Kuehling, Felix <felix.kuehl...@amd.com>; Koenig, Christian <christian.koe...@amd.com>; amd-gfx@lists.freedesktop.org Subject: Re: [PATCH] drm/amdgpu: Add comments to gmc structure If this is not submitted, I would like to see some comments regarding the explanation of MC address and logical address, which I prefer to mention as GPU physical/virtual address. Regards, Yong ________________________________ From: amd-gfx <amd-gfx-boun...@lists.freedesktop.org<mailto:amd-gfx-boun...@lists.freedesktop.org>> on behalf of Alex Deucher <alexdeuc...@gmail.com<mailto:alexdeuc...@gmail.com>> Sent: Thursday, November 7, 2019 9:02 AM To: Zeng, Oak <oak.z...@amd.com<mailto:oak.z...@amd.com>> Cc: Kuehling, Felix <felix.kuehl...@amd.com<mailto:felix.kuehl...@amd.com>>; Koenig, Christian <christian.koe...@amd.com<mailto:christian.koe...@amd.com>>; amd-gfx@lists.freedesktop.org<mailto:amd-gfx@lists.freedesktop.org> <amd-gfx@lists.freedesktop.org<mailto:amd-gfx@lists.freedesktop.org>> Subject: Re: [PATCH] drm/amdgpu: Add comments to gmc structure On Wed, Nov 6, 2019 at 12:27 PM Zeng, Oak <oak.z...@amd.com<mailto:oak.z...@amd.com>> wrote: > > Explain fields like aper_base, agp_start etc. The definition > of those fields are confusing as they are from different view > (CPU or GPU). Add comments for easier understand. > > Change-Id: I02c2a27cd0dbc205498eb86aafa722f2e0c25fe6 > Signed-off-by: Oak Zeng <oak.z...@amd.com<mailto:oak.z...@amd.com>> Same comments as the previous version. With those addressed, Reviewed-by: Alex Deucher <alexander.deuc...@amd.com<mailto:alexander.deuc...@amd.com>> > --- > drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h | 26 ++++++++++++++++++++++++++ > 1 file changed, 26 insertions(+) > > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h > b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h > index 555d8e5..1356ff9 100644 > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h > @@ -127,18 +127,44 @@ struct amdgpu_xgmi { > }; > > struct amdgpu_gmc { > + /* FB's physical address in MMIO space (for CPU to > + * map FB). This is different compared to the apg/ > + * gart/vram_start/end field as the later is from > + * GPU's view and aper_base is from CPU's view. > + */ > resource_size_t aper_size; > resource_size_t aper_base; > /* for some chips with <= 32MB we need to lie > * about vram size near mc fb location */ > u64 mc_vram_size; > u64 visible_vram_size; > + /* APG aperture start and end in MC address space > + * Driver find a hole in the MC address space > + * to place AGP by setting MC_VM_AGP_BOT/TOP registers > + * Under VMID0, logical address == MC address > + * AGP aperture is used to simulate FB in ZFB case > + */ > u64 agp_size; > u64 agp_start; > u64 agp_end; > + /* GART aperture start and end in MC address space > + * Driver find a hole in the MC address space > + * to place GART by setting VM_CONTEXT0_PAGE_TABLE_START/END_ADDR > + * registers > + * Under VMID0, logical address inside GART aperture will > + * be translated through gpuvm gart page table to access > + * paged system memory > + */ > u64 gart_size; > u64 gart_start; > u64 gart_end; > + /* Frame buffer aperture of this GPU device. Different from > + * fb_start (see below), this only covers the local GPU device. > + * Driver get fb_start from MC_VM_FB_LOCATION_BASE (set by vbios) > + * and calculate vram_start of this local device by adding an > + * offset inside the XGMI hive. > + * Under VMID0, logical address == MC address > + */ > u64 vram_start; > u64 vram_end; > /* FB region , it's same as local vram region in single GPU, in XGMI > -- > 2.7.4 > > _______________________________________________ > amd-gfx mailing list > amd-gfx@lists.freedesktop.org<mailto:amd-gfx@lists.freedesktop.org> > https://lists.freedesktop.org/mailman/listinfo/amd-gfx _______________________________________________ amd-gfx mailing list amd-gfx@lists.freedesktop.org<mailto:amd-gfx@lists.freedesktop.org> https://lists.freedesktop.org/mailman/listinfo/amd-gfx
_______________________________________________ amd-gfx mailing list amd-gfx@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/amd-gfx