From: Lang Yu <Lang.Yu@amd.com>
To: "Christian König" <christian.koenig@amd.com>
Cc: Alex Deucher <alexander.deucher@amd.com>,
Felix Kuehling <Felix.Kuehling@amd.com>,
Huang Rui <ray.huang@amd.com>,
amd-gfx@lists.freedesktop.org
Subject: Re: [PATCH v2] drm/amdkfd: simplify vm_validate_pt_pd_bos
Date: Mon, 13 Jun 2022 16:26:16 +0800 [thread overview]
Message-ID: <Yqb0qO2mym1X9ha4@lang-desktop> (raw)
In-Reply-To: <55d98218-7032-5d29-fea7-afa7ff1e5ea6@amd.com>
On 06/13/ , Christian König wrote:
> Am 13.06.22 um 09:59 schrieb Lang Yu:
> > We don't need to validate and map root PD specially here,
> > it would be validated and mapped by amdgpu_vm_validate_pt_bos
> > if it is evicted.
>
> I'm not sure if that's correct. Traditionally we have handled the root PD
> differently to the rest in the VM.
>
> It doesn't make much sense any more today, but I need to double check if
> that isn't still the case.
From my observations, if root PD is evicted. amdgpu_vm_validate_pt_bos
will validate and map it.
And amdgpu_cs_list_validate always validates root PD after
amdgpu_vm_validate_pt_bos has done that, it is actually unnecessary.
Do you think it's worth skiping root PD validation in
amdgpu_cs_list_validate? Thanks!
Regards,
Lang
> Christian.
>
> >
> > The special case is when turning a GFX VM to a compute VM,
> > if vm_update_mode changed, we need to map the root PD again.
> > So just move root PD mapping to amdgpu_vm_make_compute.
> >
> > v2:
> > - Don't rename vm_validate_pt_pd_bos and make it public.
> >
> > Signed-off-by: Lang Yu <Lang.Yu@amd.com>
> > ---
> > drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c | 14 --------------
> > drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c | 5 +++++
> > 2 files changed, 5 insertions(+), 14 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c
> > index 6a3bd8b9a08f..3805eef9ab69 100644
> > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c
> > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd_gpuvm.c
> > @@ -425,22 +425,8 @@ static int vm_validate_pt_pd_bos(struct amdgpu_vm *vm)
> > return ret;
> > }
> > - ret = amdgpu_amdkfd_validate_vm_bo(NULL, pd);
> > - if (ret) {
> > - pr_err("failed to validate PD\n");
> > - return ret;
> > - }
> > -
> > vm->pd_phys_addr = amdgpu_gmc_pd_addr(vm->root.bo);
> > - if (vm->use_cpu_for_update) {
> > - ret = amdgpu_bo_kmap(pd, NULL);
> > - if (ret) {
> > - pr_err("failed to kmap PD, ret=%d\n", ret);
> > - return ret;
> > - }
> > - }
> > -
> > return 0;
> > }
> > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> > index 703552f9a6d7..08fda57f5aa2 100644
> > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
> > @@ -2225,6 +2225,11 @@ int amdgpu_vm_make_compute(struct amdgpu_device *adev, struct amdgpu_vm *vm)
> > } else {
> > vm->update_funcs = &amdgpu_vm_sdma_funcs;
> > }
> > +
> > + r = vm->update_funcs->map_table(to_amdgpu_bo_vm(vm->root.bo));
> > + if (r)
> > + goto unreserve_bo;
> > +
> > dma_fence_put(vm->last_update);
> > vm->last_update = NULL;
> > vm->is_compute_context = true;
>
next prev parent reply other threads:[~2022-06-13 8:26 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-13 7:59 [PATCH v2] drm/amdkfd: simplify vm_validate_pt_pd_bos Lang Yu
2022-06-13 8:03 ` Christian König
2022-06-13 8:26 ` Lang Yu [this message]
2022-06-13 8:30 ` Christian König
2022-06-13 8:41 ` Lang Yu
2022-06-13 8:50 ` Christian König
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Yqb0qO2mym1X9ha4@lang-desktop \
--to=lang.yu@amd.com \
--cc=Felix.Kuehling@amd.com \
--cc=alexander.deucher@amd.com \
--cc=amd-gfx@lists.freedesktop.org \
--cc=christian.koenig@amd.com \
--cc=ray.huang@amd.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.