From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.5 required=3.0 tests=DKIM_INVALID,DKIM_SIGNED, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY, SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 4CA6CC4724C for ; Fri, 8 May 2020 06:41:00 +0000 (UTC) Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 2245221655 for ; Fri, 8 May 2020 06:41:00 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=fail reason="signature verification failed" (1024-bit key) header.d=ffwll.ch header.i=@ffwll.ch header.b="ZoZ4o1LU" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 2245221655 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=ffwll.ch Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=dri-devel-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id B253B6EA7E; Fri, 8 May 2020 06:40:58 +0000 (UTC) Received: from mail-wr1-x444.google.com (mail-wr1-x444.google.com [IPv6:2a00:1450:4864:20::444]) by gabe.freedesktop.org (Postfix) with ESMTPS id ED9096EA7E for ; Fri, 8 May 2020 06:40:56 +0000 (UTC) Received: by mail-wr1-x444.google.com with SMTP id i15so504970wrx.10 for ; Thu, 07 May 2020 23:40:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=LlZNWr2ULsnWPtOzZvKbfMrvgkMK27lymoNxsFAY3Ak=; b=ZoZ4o1LUJyhJMqRJ6NICXQ6hbkCkr/nA7wjrLgb8O5vxM6S01j3VMocbpGDNUeT9ga WE1bQ/OSC2FUqeqafuC8ISS5LZ0v2yXYS4eGqxZhKFSAZxKA7BFnCq48nau7HOm6eLhA Y8Z8jAoc0AZiIrradD+Q4EpVfchsf3ekXIDNY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=LlZNWr2ULsnWPtOzZvKbfMrvgkMK27lymoNxsFAY3Ak=; b=E9qE0vABqmIXdwQ2nt7mOMPD8vEXqB5Qo1DKX1MfUC24Nz7QGumRXbKbM9/Rs14KsL 8PbbPDUGl3KU7AW0l2+A27hpgR8HiJHPwfIfrqZT/UXhPqUi8gEJ4wnOFPOwu1oJRUhf BQon9AKac0toEjxyWlCniFeTXh+V3Oer8kOs1m0UK1uzV2Ph06ni3DGsQGNu/yt2FORH 3jZ9HcpF6NGuDN6MoPpHCJkwPn5dEQzypwjvsSJhp3iiOxRph1NDcbmG5WrQYe4E8B9P KWddei5mp5hF4OcDqtBNu462Gr/pD1NWNTthCYJHTzSzepgApTnsjl82ImtbQmtka+1E CPiw== X-Gm-Message-State: AGi0PuZGtHRzZwo7ubQ+IEiDGpvR5ZpeJrwf6VxgzZ7h4/12fYYRJgNU IhoOAtn2YRqpV70P7zOhcRboXw== X-Google-Smtp-Source: APiQypIjN/LcNlF7XH3aw+beA8fvsw20zR+5C5ks412vv4cp/Ldh8533l18oKxJ5ISxNc9mw0AM64g== X-Received: by 2002:a5d:6691:: with SMTP id l17mr1056221wru.127.1588920055565; Thu, 07 May 2020 23:40:55 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id p23sm6642894wmj.37.2020.05.07.23.40.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 May 2020 23:40:54 -0700 (PDT) Date: Fri, 8 May 2020 08:40:53 +0200 From: Daniel Vetter To: Emil Velikov Subject: Re: [PATCH 10/36] drm/gem: add _locked suffix to drm_object_put Message-ID: <20200508064053.GB1383626@phenom.ffwll.local> References: <20200507150822.114464-1-emil.l.velikov@gmail.com> <20200507150822.114464-11-emil.l.velikov@gmail.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20200507150822.114464-11-emil.l.velikov@gmail.com> X-Operating-System: Linux phenom 5.4.0-4-amd64 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-arm-msm@vger.kernel.org, Sean Paul , dri-devel@lists.freedesktop.org Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" On Thu, May 07, 2020 at 04:07:56PM +0100, Emil Velikov wrote: > From: Emil Velikov > > Vast majority of DRM (core and drivers) are struct_mutex free. > > As such we have only a handful of cases where the locked helper should > be used. Make that stand out a little bit better. > > Done via the following script: > > __from=drm_gem_object_put > __to=drm_gem_object_put_locked > > for __file in $(git grep --name-only --word-regexp $__from); do > sed -i "s/\<$__from\>/$__to/g" $__file; > done > > Cc: Rob Clark > Cc: Sean Paul > Cc: linux-arm-msm@vger.kernel.org > Signed-off-by: Emil Velikov Since commit 48e7f18392c66f9b69ebac11c54f1a2e033ced54 Author: Kristian H. Kristensen Date: Wed Mar 20 10:09:08 2019 -0700 drm/msm: Implement .gem_free_object_unlocked msm doesn't need the struct_mutex in the bo_put anymore, the only reason we had to use the _locked version here is historical accidents I think. I think you could convert these all to the _unlocked variant and then entirely drop the _locked version. Once we have that we could move struct_mutex into each driver (at least for msm and i915) since it's purely internal, and then wrap it in an #ifdef CONFIG_DRM_LEGACY to gloriously sunset it all :-) Cheers, Daniel > --- > drivers/gpu/drm/drm_gem.c | 6 +++--- > drivers/gpu/drm/msm/adreno/a5xx_debugfs.c | 4 ++-- > drivers/gpu/drm/msm/msm_drv.c | 2 +- > drivers/gpu/drm/msm/msm_gem.c | 6 +++--- > drivers/gpu/drm/msm/msm_gem_submit.c | 2 +- > drivers/gpu/drm/msm/msm_gpu.c | 2 +- > include/drm/drm_gem.h | 4 ++-- > 7 files changed, 13 insertions(+), 13 deletions(-) > > diff --git a/drivers/gpu/drm/drm_gem.c b/drivers/gpu/drm/drm_gem.c > index 599d5ff53b73..f21327ebc562 100644 > --- a/drivers/gpu/drm/drm_gem.c > +++ b/drivers/gpu/drm/drm_gem.c > @@ -983,7 +983,7 @@ drm_gem_object_free(struct kref *kref) > EXPORT_SYMBOL(drm_gem_object_free); > > /** > - * drm_gem_object_put - release a GEM buffer object reference > + * drm_gem_object_put_locked - release a GEM buffer object reference > * @obj: GEM buffer object > * > * This releases a reference to @obj. Callers must hold the > @@ -994,7 +994,7 @@ EXPORT_SYMBOL(drm_gem_object_free); > * drm_gem_object_put_unlocked() instead. > */ > void > -drm_gem_object_put(struct drm_gem_object *obj) > +drm_gem_object_put_locked(struct drm_gem_object *obj) > { > if (obj) { > WARN_ON(!mutex_is_locked(&obj->dev->struct_mutex)); > @@ -1002,7 +1002,7 @@ drm_gem_object_put(struct drm_gem_object *obj) > kref_put(&obj->refcount, drm_gem_object_free); > } > } > -EXPORT_SYMBOL(drm_gem_object_put); > +EXPORT_SYMBOL(drm_gem_object_put_locked); > > /** > * drm_gem_vm_open - vma->ops->open implementation for GEM > diff --git a/drivers/gpu/drm/msm/adreno/a5xx_debugfs.c b/drivers/gpu/drm/msm/adreno/a5xx_debugfs.c > index 8cae2ca4af6b..68eddac7771c 100644 > --- a/drivers/gpu/drm/msm/adreno/a5xx_debugfs.c > +++ b/drivers/gpu/drm/msm/adreno/a5xx_debugfs.c > @@ -124,13 +124,13 @@ reset_set(void *data, u64 val) > > if (a5xx_gpu->pm4_bo) { > msm_gem_unpin_iova(a5xx_gpu->pm4_bo, gpu->aspace); > - drm_gem_object_put(a5xx_gpu->pm4_bo); > + drm_gem_object_put_locked(a5xx_gpu->pm4_bo); > a5xx_gpu->pm4_bo = NULL; > } > > if (a5xx_gpu->pfp_bo) { > msm_gem_unpin_iova(a5xx_gpu->pfp_bo, gpu->aspace); > - drm_gem_object_put(a5xx_gpu->pfp_bo); > + drm_gem_object_put_locked(a5xx_gpu->pfp_bo); > a5xx_gpu->pfp_bo = NULL; > } > > diff --git a/drivers/gpu/drm/msm/msm_drv.c b/drivers/gpu/drm/msm/msm_drv.c > index 29295dee2a2e..6baed5b43ea3 100644 > --- a/drivers/gpu/drm/msm/msm_drv.c > +++ b/drivers/gpu/drm/msm/msm_drv.c > @@ -932,7 +932,7 @@ static int msm_ioctl_gem_madvise(struct drm_device *dev, void *data, > ret = 0; > } > > - drm_gem_object_put(obj); > + drm_gem_object_put_locked(obj); > > unlock: > mutex_unlock(&dev->struct_mutex); > diff --git a/drivers/gpu/drm/msm/msm_gem.c b/drivers/gpu/drm/msm/msm_gem.c > index 5a6a79fbc9d6..8696c405f709 100644 > --- a/drivers/gpu/drm/msm/msm_gem.c > +++ b/drivers/gpu/drm/msm/msm_gem.c > @@ -879,7 +879,7 @@ void msm_gem_describe_objects(struct list_head *list, struct seq_file *m) > } > #endif > > -/* don't call directly! Use drm_gem_object_put() and friends */ > +/* don't call directly! Use drm_gem_object_put_locked() and friends */ > void msm_gem_free_object(struct drm_gem_object *obj) > { > struct msm_gem_object *msm_obj = to_msm_bo(obj); > @@ -1183,7 +1183,7 @@ static void *_msm_gem_kernel_new(struct drm_device *dev, uint32_t size, > return vaddr; > err: > if (locked) > - drm_gem_object_put(obj); > + drm_gem_object_put_locked(obj); > else > drm_gem_object_put_unlocked(obj); > > @@ -1215,7 +1215,7 @@ void msm_gem_kernel_put(struct drm_gem_object *bo, > msm_gem_unpin_iova(bo, aspace); > > if (locked) > - drm_gem_object_put(bo); > + drm_gem_object_put_locked(bo); > else > drm_gem_object_put_unlocked(bo); > } > diff --git a/drivers/gpu/drm/msm/msm_gem_submit.c b/drivers/gpu/drm/msm/msm_gem_submit.c > index 385d4965a8d0..8f450a245cfb 100644 > --- a/drivers/gpu/drm/msm/msm_gem_submit.c > +++ b/drivers/gpu/drm/msm/msm_gem_submit.c > @@ -387,7 +387,7 @@ static void submit_cleanup(struct msm_gem_submit *submit) > struct msm_gem_object *msm_obj = submit->bos[i].obj; > submit_unlock_unpin_bo(submit, i, false); > list_del_init(&msm_obj->submit_entry); > - drm_gem_object_put(&msm_obj->base); > + drm_gem_object_put_locked(&msm_obj->base); > } > } > > diff --git a/drivers/gpu/drm/msm/msm_gpu.c b/drivers/gpu/drm/msm/msm_gpu.c > index 615c5cda5389..86a68f96c48d 100644 > --- a/drivers/gpu/drm/msm/msm_gpu.c > +++ b/drivers/gpu/drm/msm/msm_gpu.c > @@ -694,7 +694,7 @@ static void retire_submit(struct msm_gpu *gpu, struct msm_ringbuffer *ring, > /* move to inactive: */ > msm_gem_move_to_inactive(&msm_obj->base); > msm_gem_unpin_iova(&msm_obj->base, submit->aspace); > - drm_gem_object_put(&msm_obj->base); > + drm_gem_object_put_locked(&msm_obj->base); > } > > pm_runtime_mark_last_busy(&gpu->pdev->dev); > diff --git a/include/drm/drm_gem.h b/include/drm/drm_gem.h > index 7c877bea7b3a..0f22f3320dcb 100644 > --- a/include/drm/drm_gem.h > +++ b/include/drm/drm_gem.h > @@ -187,7 +187,7 @@ struct drm_gem_object { > * > * Reference count of this object > * > - * Please use drm_gem_object_get() to acquire and drm_gem_object_put() > + * Please use drm_gem_object_get() to acquire and drm_gem_object_put_locked() > * or drm_gem_object_put_unlocked() to release a reference to a GEM > * buffer object. > */ > @@ -376,7 +376,7 @@ drm_gem_object_put_unlocked(struct drm_gem_object *obj) > kref_put(&obj->refcount, drm_gem_object_free); > } > > -void drm_gem_object_put(struct drm_gem_object *obj); > +void drm_gem_object_put_locked(struct drm_gem_object *obj); > > int drm_gem_handle_create(struct drm_file *file_priv, > struct drm_gem_object *obj, > -- > 2.25.1 > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch _______________________________________________ dri-devel mailing list dri-devel@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/dri-devel