Received: by 10.223.185.116 with SMTP id b49csp3893342wrg; Mon, 19 Feb 2018 07:42:52 -0800 (PST) X-Google-Smtp-Source: AH8x226o50LiXX4eHLq48fPtLYnnyd4EBZ7ZHRBJ2fuhdTuYkMAlxRH9J2oUWY9cK8IwAf5dH9nV X-Received: by 10.101.98.85 with SMTP id q21mr12352225pgv.182.1519054972243; Mon, 19 Feb 2018 07:42:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519054972; cv=none; d=google.com; s=arc-20160816; b=JNVvwobR4BMuLusdc92gngmjkKP2uUkpqCrUi37Y6owC0DDYACLj4sKqNDmnBgpaah A9MfIdt0r775P+cio4rRup1Y68a+mcZN+5ovq45XMqjQwKoL2CTdh6mxXDbCjyEhftMI L0nrSH77FDhAF+RjhJ6qsolD/UTeDAmXmXC6g7ZuPa4ZPEbVbGHTYLtxAXjgtTf9pgid 8bZ/BcyipWXVAWarAdHw5L6pVzdst9q9Bnv5zmtsoWMXbFpTQK55fowX3a4yx+VGLFhj TlCXoxrwXcb6YLcZ05L5c3lYNS2GB2YREx4gEretfAKcEHWhpaQkJJJgdZepUGhiSKFw eZzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:to:subject:reply-to:dkim-signature :arc-authentication-results; bh=oVc5yT256tzoNuv5a30eQ/L+c5Cz+yGkl+7SO8cMco8=; b=YdWPncWBW+uBorAXXUqJK1PxH34eydIFQuXeQ8s+BJ+uENLpfRjYsz9lD+GdUqfhx9 FDKVtoa9ZShSAtMnioRlYb6IDA87er3Rl8a2nEFU01vQe2xZCfr3Uw/c+cl/MfpG9Rc2 HK4EOY2s7V639gR1NJEW8gaewPLVLivuNqPukHTg3WsK106ScLxDLbYwCLHgRDKzmK0J msD8nEP4SSqX6cRc5swuNWr/+p/wjd+vO8v5fB9OR+DMUK8KhhKbQy93puJgHT9/B8/h eMWibI0MkKPEG0TPenzJLftJQkdQgUYVyfEXNenqnbOStq7oIFV05jj4ngKcD7oyzb9n 03lA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=IMU+Xkvk; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i64-v6si5807256pli.142.2018.02.19.07.42.37; Mon, 19 Feb 2018 07:42:52 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=IMU+Xkvk; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752667AbeBSPl7 (ORCPT + 99 others); Mon, 19 Feb 2018 10:41:59 -0500 Received: from mail-wr0-f193.google.com ([209.85.128.193]:40029 "EHLO mail-wr0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752048AbeBSPl6 (ORCPT ); Mon, 19 Feb 2018 10:41:58 -0500 Received: by mail-wr0-f193.google.com with SMTP id o76so10073550wrb.7 for ; Mon, 19 Feb 2018 07:41:57 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=reply-to:subject:to:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=oVc5yT256tzoNuv5a30eQ/L+c5Cz+yGkl+7SO8cMco8=; b=IMU+XkvkV4dzsmwwwlmwfpeHcuau6yZpPqMZ58YsjEJLMwoInZhWrdRURNYRIJG1nJ 4eMvj05CxIFjWgse1C7ZjojdPN1ZjmcugdOPSLo99arAtK1UqAWvMkcofsRnAXWIJPDT /Fu3x08xFaNsHtiNsXcNlxy2FvdbDpexYWkMU3G3omWx6zyO8xgamIExSi9IP2f3DQ1W i33JD6mwDs5SxlsLRb/ke0kucJSCtNNqK2ImkInUoM5XtMDcAWFPqBy2tm1sY5ZgVx1F l9OX1/bIJvBkWJnr0yjEYm1GmI8Ki0c7+kJOzwFpxoyAKOBjRVdkObPaf88xpKLWVvOe lcLA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:reply-to:subject:to:references:from:message-id :date:user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=oVc5yT256tzoNuv5a30eQ/L+c5Cz+yGkl+7SO8cMco8=; b=cvDAbp85ijCdUox/DU5wlZoyGCJbedQ611dDs8H+UBpggWaxRO8gR90PY0OFrevhZg 5+qUNzWxomWhnu3aLjdc7AtA+xQ2u8XwkLmQ0rNT5DjlbIBa4VgW++id9+sM++sLbDkV h5vfTMhrjauYONQ05LCK4OFyc/ZbY2Br4+9oIeMgY72w+vwTAxC/gN7vSVCLHtRcFAM8 GpOkbmZhMXjCsEGe6hm7D6dXOGF1J/UVV+7/XJQLlfsYSkn+FTQSS2fLnHbILF/lAqdR wU8zgM4yYHsKnZ21LdH8n1CbRlzYO27LLO7hsnq5+Z+QmD4CO2Uvz15tmWNCvu9YenhK ZrdA== X-Gm-Message-State: APf1xPDoj0DlPQ0X9eB0+uhi8LYOyxIQWN8eyB32Qj8KzL+KD1k0rfJB ep9KKuwintA2woG+I4z5bxyEaO0s X-Received: by 10.223.133.70 with SMTP id 64mr12493348wrh.219.1519054916987; Mon, 19 Feb 2018 07:41:56 -0800 (PST) Received: from ?IPv6:2a02:908:1251:8fc0:4c6d:7233:b7e1:3b88? ([2a02:908:1251:8fc0:4c6d:7233:b7e1:3b88]) by smtp.gmail.com with ESMTPSA id n20sm9592025wrg.84.2018.02.19.07.41.56 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 19 Feb 2018 07:41:56 -0800 (PST) Reply-To: christian.koenig@amd.com Subject: Re: [PATCH 1/3] locking/ww_mutex: cleanup lock->ctx usage in amdgpu To: dri-devel@lists.freedesktop.org, amd-gfx@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20180215141944.4332-1-christian.koenig@amd.com> <20180219152421.GQ22199@phenom.ffwll.local> From: =?UTF-8?Q?Christian_K=c3=b6nig?= Message-ID: Date: Mon, 19 Feb 2018 16:41:55 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <20180219152421.GQ22199@phenom.ffwll.local> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am 19.02.2018 um 16:24 schrieb Daniel Vetter: > On Thu, Feb 15, 2018 at 03:19:42PM +0100, Christian König wrote: >> amdgpu needs to verify if userspace sends us valid addresses and the simplest >> way of doing this is to check if the buffer object is locked with the ticket >> of the current submission. >> >> Clean up the access to the ww_mutex internals by providing a function >> for this and extend the check to the thread owning the underlying mutex. >> >> Signed-off-by: Christian König >> --- >> drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c | 3 ++- >> include/linux/ww_mutex.h | 17 +++++++++++++++++ >> 2 files changed, 19 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c >> index eaa3cb0c3ad1..4c04b560e358 100644 >> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c >> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c >> @@ -1594,7 +1594,8 @@ int amdgpu_cs_find_mapping(struct amdgpu_cs_parser *parser, >> *map = mapping; >> >> /* Double check that the BO is reserved by this CS */ >> - if (READ_ONCE((*bo)->tbo.resv->lock.ctx) != &parser->ticket) >> + if (!ww_mutex_is_owned_by(&(*bo)->tbo.resv->lock, current, >> + &parser->ticket)) >> return -EINVAL; >> >> if (!((*bo)->flags & AMDGPU_GEM_CREATE_VRAM_CONTIGUOUS)) { >> diff --git a/include/linux/ww_mutex.h b/include/linux/ww_mutex.h >> index 39fda195bf78..dd580db289e8 100644 >> --- a/include/linux/ww_mutex.h >> +++ b/include/linux/ww_mutex.h >> @@ -358,4 +358,21 @@ static inline bool ww_mutex_is_locked(struct ww_mutex *lock) >> return mutex_is_locked(&lock->base); >> } >> >> +/** >> + * ww_mutex_is_owned_by - is the w/w mutex locked by this task in that context >> + * @lock: the mutex to be queried >> + * @task: the task structure to check >> + * @ctx: the w/w acquire context to test >> + * >> + * Returns true if the mutex is locked in the context by the given task, false >> + * otherwise. >> + */ >> +static inline bool ww_mutex_is_owned_by(struct ww_mutex *lock, >> + struct task_struct *task, >> + struct ww_acquire_ctx *ctx) >> +{ >> + return likely(__mutex_owner(&lock->base) == task) && >> + READ_ONCE(lock->ctx) == ctx; > Just comparing the context should be good enough. If you ever pass a > ww_acquire_ctx which does not belong to your own thread your seriously > wreaking things much worse already (and if we do catch that, should > probably lock the ctx to a given task when ww-mutex debugging is enabled). > > That also simplifies the function signature. > > Of course that means if you don't have a ctx, you can't test ownership of > a ww_mute, but I think that's not a really valid use-case. Well exactly that is the use case in TTM, see patch #3 in this series. In TTM the evicted BOs are trylocked and so we need a way of testing for ownership without a context. Christian. > And not needed > for cmd submission, where you need the ctx anyway. > > Besides this interface nit looks all good. With the task check¶meter > removed: > > Reviewed-by: Daniel Vetter > > -Daniel > >> +} >> + >> #endif >> -- >> 2.14.1 >> >> _______________________________________________ >> dri-devel mailing list >> dri-devel@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/dri-devel