Reviewed-by: Christian König <christian.koenig at amd.com> for both as well. Christian. Am 26.05.2018 um 15:23 schrieb Deucher, Alexander: > > Both patches are: > > Reviewed-by: Alex Deucher <alexander.deucher at amd.com> > > ------------------------------------------------------------------------ > *From:* Sharma, Deepak > *Sent:* Friday, May 25, 2018 8:19:26 PM > *To:* amd-gfx at lists.freedesktop.org; Deucher, Alexander; > michel at daenzer.net; Koenig, Christian > *Subject:* Re: drm/amdgpu: Add helper function to get buffer domain > If look fine , please give rb for this and > https://patchwork.freedesktop.org/patch/224850/ > > Thanks, > Deepak > > On 05/25/2018 05:12 PM, Deepak Sharma wrote: > > Move logic of getting supported domain to a helper > > function > > > > Signed-off-by: Deepak Sharma <Deepak.Sharma at amd.com> > > --- > >  drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c   | 10 +++------- > >  drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 17 ++++++++++++----- > >  drivers/gpu/drm/amd/amdgpu/amdgpu_object.h | 3 ++- > >  3 files changed, 17 insertions(+), 13 deletions(-) > > > > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c > b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c > > index 63758db5e2ea..556406a44da3 100644 > > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c > > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c > > @@ -750,19 +750,15 @@ int amdgpu_mode_dumb_create(struct drm_file > *file_priv, > >       struct amdgpu_device *adev = dev->dev_private; > >       struct drm_gem_object *gobj; > >       uint32_t handle; > > -    u32 domain = amdgpu_display_supported_domains(adev); > > +    u32 domain; > >       int r; > > > >       args->pitch = amdgpu_align_pitch(adev, args->width, > > DIV_ROUND_UP(args->bpp, 8), 0); > >       args->size = (u64)args->pitch * args->height; > >       args->size = ALIGN(args->size, PAGE_SIZE); > > -    if (domain == (AMDGPU_GEM_DOMAIN_VRAM | AMDGPU_GEM_DOMAIN_GTT)) { > > -            domain = AMDGPU_GEM_DOMAIN_VRAM; > > -            if (adev->gmc.real_vram_size <= AMDGPU_SG_THRESHOLD) > > -                    domain = AMDGPU_GEM_DOMAIN_GTT; > > -    } > > - > > +    domain = amdgpu_bo_get_preferred_pin_domain(adev, > > + amdgpu_display_supported_domains(adev)); > >       r = amdgpu_gem_object_create(adev, args->size, 0, domain, > > AMDGPU_GEM_CREATE_CPU_ACCESS_REQUIRED, > >                                    false, NULL, &gobj); > > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c > b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c > > index 6a9e46ae7f0a..5e4e1bd90383 100644 > > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c > > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c > > @@ -703,11 +703,7 @@ int amdgpu_bo_pin_restricted(struct amdgpu_bo > *bo, u32 domain, > >       /* This assumes only APU display buffers are pinned with > (VRAM|GTT). > >        * See function amdgpu_display_supported_domains() > >        */ > > -    if (domain == (AMDGPU_GEM_DOMAIN_VRAM | AMDGPU_GEM_DOMAIN_GTT)) { > > -            domain = AMDGPU_GEM_DOMAIN_VRAM; > > -            if (adev->gmc.real_vram_size <= AMDGPU_SG_THRESHOLD) > > -                    domain = AMDGPU_GEM_DOMAIN_GTT; > > -    } > > +    domain = amdgpu_bo_get_preferred_pin_domain(adev, domain); > > > >       if (bo->pin_count) { > >               uint32_t mem_type = bo->tbo.mem.mem_type; > > @@ -1066,3 +1062,14 @@ u64 amdgpu_bo_gpu_offset(struct amdgpu_bo *bo) > > > >       return bo->tbo.offset; > >  } > > + > > +uint32_t amdgpu_bo_get_preferred_pin_domain(struct amdgpu_device *adev, > > +                                        uint32_t domain) > > +{ > > +    if (domain == (AMDGPU_GEM_DOMAIN_VRAM | AMDGPU_GEM_DOMAIN_GTT)) { > > +            domain = AMDGPU_GEM_DOMAIN_VRAM; > > +            if (adev->gmc.real_vram_size <= AMDGPU_SG_THRESHOLD) > > +                    domain = AMDGPU_GEM_DOMAIN_GTT; > > +    } > > +    return domain; > > +} > > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h > b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h > > index 540e03fa159f..731748033878 100644 > > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h > > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.h > > @@ -289,7 +289,8 @@ int amdgpu_bo_restore_from_shadow(struct > amdgpu_device *adev, > >                                 struct reservation_object *resv, > >                                 struct dma_fence **fence, > >                                 bool direct); > > - > > +uint32_t amdgpu_bo_get_preferred_pin_domain(struct amdgpu_device *adev, > > +                                        uint32_t domain); > > > >  /* > >   * sub allocation > > > > > _______________________________________________ > amd-gfx mailing list > amd-gfx at lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/amd-gfx -------------- next part -------------- An HTML attachment was scrubbed... URL: <https://lists.freedesktop.org/archives/amd-gfx/attachments/20180528/c792a074/attachment.html>