Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1275107pxb; Fri, 21 Jan 2022 14:05:25 -0800 (PST) X-Google-Smtp-Source: ABdhPJxVXnXlQmoFnFqFA3TgWWm78yq4vE0Ntm1UC7FGwT9uGj+ashE/+008pYOpd+7P/KF4lkbI X-Received: by 2002:a63:b247:: with SMTP id t7mr4282326pgo.164.1642802725476; Fri, 21 Jan 2022 14:05:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642802725; cv=none; d=google.com; s=arc-20160816; b=X76a6LxuKtsUbCT7sDU0L4k6TwMDbky/JAV9aU5yppcHm/gWwrJ/7xUVMo1nizAU35 P0kaw0y3iGyVQtOsv+w8GkJl0EwVGygWHkdDhzLzMOiWfi3emI0c4k7nu+BAtrgYYOYU ZsAneyePs4DFx9WDTPcbTXvAQpBb/rgZbK/LlRMBNbHzzCxf6bCkUTK1alJYAi/ma5Tg je28V559ffCb/gtaeRCHMqlIXVMU+7s5v8wd/CKDd3F2/IEB723VfN00PwgTEIN7mnmC RwnAl0lLoyv9s59eFFSFqy3oqo7Es09Ml/G4KkUcASM/Hu9GtoxYA539wHOMgSkNdbxV Ucig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=uLZAF7sCDnz30XuUh5h5/yfPyILI1cE9mpPTMxW3ZDk=; b=kbQ4ogTfz0+4t6JV+4AlRULGDSl7H0JpQzgzY+80s7CMD8k1T/wxWc7OqIip8GBU5q J6g/7MZdzPA8RucKVM0t+lUsYC4CxIfZW0b+HDl8dt6F414xZag0C9pLwOksbDSBYgms syYbp68Y4l9XzQFWqROIkmlbGHoQEsh0NsNnQnGggUUQp6i5usgoX/eZMJtKsN2IxByQ Asip7s/c80E2J+LVrcfrukeWk3u4fvgCoFOynzoKfn/zaHWdIl+vCui1sfATc86/axWk brkL1EcJoA848A7X1ylQqtTksXwSR5nG7ARWtCqrp8a5s3VU3En7l0kFYoTnne9aUEnH LpMw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=KW6eikTA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r11si4041613plr.178.2022.01.21.14.05.13; Fri, 21 Jan 2022 14:05:25 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=KW6eikTA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239567AbiATNEI (ORCPT + 99 others); Thu, 20 Jan 2022 08:04:08 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40726 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231776AbiATNEH (ORCPT ); Thu, 20 Jan 2022 08:04:07 -0500 Received: from mail-lf1-x12d.google.com (mail-lf1-x12d.google.com [IPv6:2a00:1450:4864:20::12d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 51F50C061574 for ; Thu, 20 Jan 2022 05:04:07 -0800 (PST) Received: by mail-lf1-x12d.google.com with SMTP id x22so21288440lfd.10 for ; Thu, 20 Jan 2022 05:04:07 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=uLZAF7sCDnz30XuUh5h5/yfPyILI1cE9mpPTMxW3ZDk=; b=KW6eikTA+14POfY2Iu1JBOhJxv/oHBC+5SOLilBGaL6J912JGlCsbraZquqKfpb3L1 yGoEPtdNxgkrTGeQwz78dJflB05qp4WBGXCjA0lbimCWCnVirEuekEqSlUEDvZfFH2Uu 1SK4e86agfg5j7byzzLzOhApeWnBiBLfdn+8E55i7/f12xOVOdokKxbJzJF+nOeThIIF ExBIGLFFONVifOpYAEKpZVHul7rLmM2WtTGonEZ8nW7MFRd2/cspjbeJ9Xq53SrgS60R /FPOsXzrh9JNnK7YSsxFNjRHe4utt8rfk4H1D349siCIu+HV+Kq3p++z06b675ro4jFQ 78Ig== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=uLZAF7sCDnz30XuUh5h5/yfPyILI1cE9mpPTMxW3ZDk=; b=DGPmWqiWzhYY+zjyPMx4DCHnqgIG7r1LCmygm5rISPq7trUFpyz4RhlI2Z2RQ3vr4U 5kOgDcfdCn45Qo2ml3UQmaVZoP/5wXiFGWximKTAqo5dDWSHms/E+cLDodGVc9a6bnlN AnXmZEe+dl3i5vrh+8yT9Vz7tU1I6QVtq/R618obFwAO6t0N+MVnpSfIgFMv/1WqhI1Q jtJr6+QgK+cIfmdjs7bmhmMZfX4qUIaxPBlZ55qg1j53mb2jVSbLQVkKnMD/Bna7/VIU f2ducSR2fkbnPVqiI+dXwMc+NuvzbIEeqAsdnqTg/DgoFVbRYnTSUtuv8DVqC/RdPXm9 RaUw== X-Gm-Message-State: AOAM532BG0eLo+R/K6yY2ifcL9zpBWnzxVKYsQ2faPFIo/ZdRX1CKrdi Pz9GiDOJ8ZF6nEpl5Xg66LXflKjRXdc7byoQT4u0DDAGofQZwzxZ X-Received: by 2002:a2e:bd81:: with SMTP id o1mr30465233ljq.271.1642683845607; Thu, 20 Jan 2022 05:04:05 -0800 (PST) MIME-Version: 1.0 References: <20220114150824.3578829-1-jens.wiklander@linaro.org> <20220114150824.3578829-13-jens.wiklander@linaro.org> In-Reply-To: <20220114150824.3578829-13-jens.wiklander@linaro.org> From: Sumit Garg Date: Thu, 20 Jan 2022 18:33:54 +0530 Message-ID: Subject: Re: [PATCH v2 12/12] tee: refactor TEE_SHM_* flags To: Jens Wiklander Cc: linux-kernel@vger.kernel.org, op-tee@lists.trustedfirmware.org, Herbert Xu , Devaraj Rangasamy , Rijo Thomas , David Howells , Tyler Hicks Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 14 Jan 2022 at 20:38, Jens Wiklander wrote: > > Removes the redundant TEE_SHM_DMA_BUF, TEE_SHM_EXT_DMA_BUF, > TEE_SHM_MAPPED and TEE_SHM_KERNEL_MAPPED flags. > > Assigns new values to the remaining flags to void gaps. > > Signed-off-by: Jens Wiklander > --- > drivers/tee/tee_shm.c | 21 ++++++++++----------- > include/linux/tee_drv.h | 12 ++++-------- > 2 files changed, 14 insertions(+), 19 deletions(-) > > diff --git a/drivers/tee/tee_shm.c b/drivers/tee/tee_shm.c > index fe3e5977dd7c..9945bdec086b 100644 > --- a/drivers/tee/tee_shm.c > +++ b/drivers/tee/tee_shm.c > @@ -139,8 +139,7 @@ static struct tee_shm *shm_alloc_helper(struct tee_context *ctx, size_t size, > */ > struct tee_shm *tee_shm_alloc_user_buf(struct tee_context *ctx, size_t size) > { > - u32 flags = TEE_SHM_MAPPED | TEE_SHM_DMA_BUF | TEE_SHM_REGISTER | > - TEE_SHM_POOL; > + u32 flags = TEE_SHM_REGISTER | TEE_SHM_POOL; > struct tee_device *teedev = ctx->teedev; > struct tee_shm *shm; > void *ret; > @@ -186,7 +185,7 @@ EXPORT_SYMBOL_GPL(tee_shm_alloc_user_buf); > */ > struct tee_shm *tee_shm_alloc_kernel_buf(struct tee_context *ctx, size_t size) > { > - u32 flags = TEE_SHM_MAPPED | TEE_SHM_REGISTER | TEE_SHM_POOL; > + u32 flags = TEE_SHM_REGISTER | TEE_SHM_POOL; > > return shm_alloc_helper(ctx, size, PAGE_SIZE, flags, -1); > } > @@ -211,7 +210,7 @@ EXPORT_SYMBOL_GPL(tee_shm_alloc_kernel_buf); > struct tee_shm *tee_shm_alloc_priv_kernel_buf(struct tee_context *ctx, > size_t size) > { > - u32 flags = TEE_SHM_MAPPED | TEE_SHM_PRIV | TEE_SHM_POOL; > + u32 flags = TEE_SHM_PRIV | TEE_SHM_POOL; > > return shm_alloc_helper(ctx, size, sizeof(long) * 2, flags, -1); > } > @@ -308,7 +307,7 @@ register_shm_helper(struct tee_context *ctx, unsigned long addr, > struct tee_shm *tee_shm_register_user_buf(struct tee_context *ctx, > unsigned long addr, size_t length) > { > - u32 f = TEE_SHM_DMA_BUF | TEE_SHM_USER_MAPPED | TEE_SHM_REGISTER; > + u32 f = TEE_SHM_USER_MAPPED | TEE_SHM_REGISTER; > struct tee_device *teedev = ctx->teedev; > struct tee_shm *shm; > void *ret; > @@ -354,7 +353,7 @@ EXPORT_SYMBOL_GPL(tee_shm_register_user_buf); > struct tee_shm *tee_shm_register_kernel_buf(struct tee_context *ctx, > void *addr, size_t length) > { > - u32 f = TEE_SHM_REGISTER | TEE_SHM_KERNEL_MAPPED; > + u32 f = TEE_SHM_REGISTER; > > return register_shm_helper(ctx, (unsigned long)addr, length, f, -1); > } > @@ -398,7 +397,7 @@ int tee_shm_get_fd(struct tee_shm *shm) > { > int fd; > > - if (!(shm->flags & TEE_SHM_DMA_BUF)) > + if (shm->id < 0) > return -EINVAL; > > /* matched by tee_shm_put() in tee_shm_op_release() */ > @@ -428,7 +427,7 @@ EXPORT_SYMBOL_GPL(tee_shm_free); > */ > int tee_shm_va2pa(struct tee_shm *shm, void *va, phys_addr_t *pa) > { > - if (!(shm->flags & TEE_SHM_MAPPED)) > + if (!shm->kaddr) > return -EINVAL; > /* Check that we're in the range of the shm */ > if ((char *)va < (char *)shm->kaddr) > @@ -450,7 +449,7 @@ EXPORT_SYMBOL_GPL(tee_shm_va2pa); > */ > int tee_shm_pa2va(struct tee_shm *shm, phys_addr_t pa, void **va) > { > - if (!(shm->flags & TEE_SHM_MAPPED)) > + if (!shm->kaddr) > return -EINVAL; > /* Check that we're in the range of the shm */ > if (pa < shm->paddr) > @@ -478,7 +477,7 @@ EXPORT_SYMBOL_GPL(tee_shm_pa2va); > */ > void *tee_shm_get_va(struct tee_shm *shm, size_t offs) > { > - if (!(shm->flags & TEE_SHM_MAPPED)) > + if (!shm->kaddr) > return ERR_PTR(-EINVAL); > if (offs >= shm->size) > return ERR_PTR(-EINVAL); > @@ -553,7 +552,7 @@ void tee_shm_put(struct tee_shm *shm) > * the refcount_inc() in tee_shm_get_from_id() never starts > * from 0. > */ > - if (shm->flags & TEE_SHM_DMA_BUF) > + if (shm->id >= 0) > idr_remove(&teedev->idr, shm->id); > do_release = true; > } > diff --git a/include/linux/tee_drv.h b/include/linux/tee_drv.h > index e4f32885e273..dcc7a55e1128 100644 > --- a/include/linux/tee_drv.h > +++ b/include/linux/tee_drv.h > @@ -20,14 +20,10 @@ > * specific TEE driver. > */ > > -#define TEE_SHM_MAPPED BIT(0) /* Memory mapped by the kernel */ > -#define TEE_SHM_DMA_BUF BIT(1) /* Memory with dma-buf handle */ > -#define TEE_SHM_EXT_DMA_BUF BIT(2) /* Memory with dma-buf handle */ > -#define TEE_SHM_REGISTER BIT(3) /* Memory registered in secure world */ > -#define TEE_SHM_USER_MAPPED BIT(4) /* Memory mapped in user space */ > -#define TEE_SHM_POOL BIT(5) /* Memory allocated from pool */ > -#define TEE_SHM_KERNEL_MAPPED BIT(6) /* Memory mapped in kernel space */ > -#define TEE_SHM_PRIV BIT(7) /* Memory private to TEE driver */ > +#define TEE_SHM_REGISTER BIT(0) /* Memory registered in secure world */ TEE_SHM_REGISTER as a flag name seems ambiguous to me when it is being used by both types of APIs tee_shm_alloc_* and tee_shm_register_*. Can we rename it to TEE_SHM_DYNAMIC instead? -Sumit > +#define TEE_SHM_USER_MAPPED BIT(1) /* Memory mapped in user space */ > +#define TEE_SHM_POOL BIT(2) /* Memory allocated from pool */ > +#define TEE_SHM_PRIV BIT(3) /* Memory private to TEE driver */ > > struct device; > struct tee_device; > -- > 2.31.1 >