Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1395521pxb; Fri, 21 Jan 2022 17:34:14 -0800 (PST) X-Google-Smtp-Source: ABdhPJzHb0rouETlENJPDuhK3BJsI9MJzO/MoHcDJFvb7C2gIruEy1piYSCe1C1XCnZ92RztIsq3 X-Received: by 2002:a17:90b:4c11:: with SMTP id na17mr3258313pjb.206.1642815254002; Fri, 21 Jan 2022 17:34:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642815253; cv=none; d=google.com; s=arc-20160816; b=Udp55dx0CIXVor7oMpY9hnozUHP6+Rxeu+1Mi2bdilvS5/Ap+lJ5WVQ3vz1VfxaJvC tdoMe3KWYukbfy04SERnPbXphjvkCzljSZXz5B5c2GzGdVUSrbGTrmNk4ElBnG2ABjrY YKeOmu+pATJIiSGQOYivj/tcLY72qjM8kBKdEFqiDhjv2fzjxrQgMsKC06RpYzyQngFD mqSBgp4xCSYtCaBSSARVOltZMSpElIEEixqfSnly4/+7+ZKJLOzcLh2hu4WN62FhEf9h t9VTuwknAr8PGJ8tWTdLIFWvHVz1ee8ZhFbw+SxsZfZRlSx+Qh0ugVpiMR3Elz/AARRv ILDw== 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=mBhkS/ZeBxLH+0BxP3Hcg+id4TNzZIL//WN86Dn8RYs=; b=nzDZ7tXprOpmiKSNO33xix4bTXhYTsrjOeb59LJfiwoOJ4q9K9lj46kIDn8A6c0RpF XdJe4UbdB3vF2NC/Lw9D/QQY60Kw97CPQRVCS3zQvnAzc5Ywzk7i1VpgWvFv166JOmAE E3aJujMq2bBT/9AloKWC+45R6Z5nlWjdccT8bddwSLLcUh9MeXSKssIjIbagV7VQAtbH gkQMm19xOdLtvmbUoS4aRmQr6nTkIS+bTEwCUwcDWr8sLQp2054v3uXXhxCXpsN8PGhX PrS/T9Ak2GshKNq+Vq8IGKHS7akKD5a+NMmvadjRn3yiP6xQUJ5BGzOtI1RX+FtYs0w6 DGEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=x9Ir7LHo; 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 n22si7808429pfu.0.2022.01.21.17.34.02; Fri, 21 Jan 2022 17:34:13 -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=x9Ir7LHo; 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 S1350602AbiAUNhP (ORCPT + 99 others); Fri, 21 Jan 2022 08:37:15 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60460 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235175AbiAUNhO (ORCPT ); Fri, 21 Jan 2022 08:37:14 -0500 Received: from mail-lf1-x12e.google.com (mail-lf1-x12e.google.com [IPv6:2a00:1450:4864:20::12e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5A71EC061574 for ; Fri, 21 Jan 2022 05:37:13 -0800 (PST) Received: by mail-lf1-x12e.google.com with SMTP id x7so33914436lfu.8 for ; Fri, 21 Jan 2022 05:37:13 -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=mBhkS/ZeBxLH+0BxP3Hcg+id4TNzZIL//WN86Dn8RYs=; b=x9Ir7LHom4o+ADME8JtW07SVKmDNsIXNlPz1iDMp+KM0QPMCYb2SEDruDrsXNqTClF dTqpFp4THjkOSNT91XRsmm4I4ZAbhLviNHqvlfMyHNxzPfhZJYmlv0R6hX5YGkZEbK4g Y8XmdLwhhJ2LzPRsZs2oxcIaf7wmzXAhqL8fdBVLnQ3pRD8M6UAUldaBEjbUzE+ZvWWu 3NETef2qgXY07Thoqj3C+RozJlVeKzweu5O1M8c3Oy6cfoJFqSx7dOX4VPicGGiZafFi ZcsZrgzfzYgbqPkZYV/E4Asg6Y+nxuDhoPI5XqEWccVeDFhvac1d36+JtYja+EFeq3ot pUAw== 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=mBhkS/ZeBxLH+0BxP3Hcg+id4TNzZIL//WN86Dn8RYs=; b=00qPLw1+yiQE52tsOhQTLj9FkNYKqXzc8iHd2Hpw3rHQlJ2EwGmkRpvJAUVecY5+sx PbHlEEYStrmExfXFvZWhKKfdYc3yMyHOrh/9XfoFEevjq8W6oAybNJV6r6uJ+XdryizZ xvpznceXhj6C3m1e+ET2OUXyTZzFooICg2rlpJK46in6IWVpYgX9/aMkZAIlbqitfF0b MgvRgN/csqkc5o+WcqksHjJc2nHKLicz8BKu+6fO3zW/q1u/lbBZkpo+0hDrUidjdpi8 GiosuSZvgvfprG41he2hjNg8o5NQtZzXEXl48Zkd88yeSTr7hMZdULiCO5GtsxVF+X1q cbTg== X-Gm-Message-State: AOAM530ttk9cAp1ewHMRri9u5aZpnn2ChddcNi1Bgp4fCkJUA5SBZAzQ UMEGm1pM/0YLBandg6Ooc4O7rD3mHPljeJ8CNeHZKQ== X-Received: by 2002:a05:6512:34d3:: with SMTP id w19mr3690841lfr.253.1642772231555; Fri, 21 Jan 2022 05:37:11 -0800 (PST) MIME-Version: 1.0 References: <20220114150824.3578829-1-jens.wiklander@linaro.org> <20220114150824.3578829-8-jens.wiklander@linaro.org> In-Reply-To: From: Sumit Garg Date: Fri, 21 Jan 2022 19:07:00 +0530 Message-ID: Subject: Re: [PATCH v2 07/12] optee: use driver internal tee_contex for some rpc To: Jerome Forissier Cc: Jens Wiklander , linux-kernel@vger.kernel.org, op-tee@lists.trustedfirmware.org, Herbert Xu , Devaraj Rangasamy , Rijo Thomas , David Howells , Tyler Hicks , Etienne Carriere Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 21 Jan 2022 at 18:58, Jerome Forissier wrote: > > On 1/21/22 13:54, Sumit Garg wrote: > > + Jerome, Etienne > > > > On Fri, 14 Jan 2022 at 20:38, Jens Wiklander wrote: > >> > >> Uses the new driver internal tee_context when allocating driver private > >> shared memory. This decouples the shared memory object from its original > >> tee_context. This is needed when the life time of such a memory > >> allocation outlives the client tee_context. > >> > >> Signed-off-by: Jens Wiklander > >> --- > >> drivers/tee/optee/ffa_abi.c | 16 ++++++++-------- > >> drivers/tee/optee/smc_abi.c | 7 ++++--- > >> 2 files changed, 12 insertions(+), 11 deletions(-) > >> > > > > I guess with this patch we should no longer see issues [1] reported earlier. > > Correct. I have tested [1] again in QEMU with this whole series applied > and the issue is gone. > Thanks for the confirmation. Jens, Can we have a Fixes tag for this and CC stable? I know it won't be directly applicable to stable kernels but we can help with a backport. -Sumit > -- > Jerome > > > > > FWIW, > > > > Reviewed-by: Sumit Garg > > > > [1] https://github.com/OP-TEE/optee_os/issues/1918 > > > > -Sumit > > > >> diff --git a/drivers/tee/optee/ffa_abi.c b/drivers/tee/optee/ffa_abi.c > >> index 88a028d4fb7b..5ec484b42432 100644 > >> --- a/drivers/tee/optee/ffa_abi.c > >> +++ b/drivers/tee/optee/ffa_abi.c > >> @@ -424,6 +424,7 @@ static struct tee_shm_pool *optee_ffa_shm_pool_alloc_pages(void) > >> */ > >> > >> static void handle_ffa_rpc_func_cmd_shm_alloc(struct tee_context *ctx, > >> + struct optee *optee, > >> struct optee_msg_arg *arg) > >> { > >> struct tee_shm *shm; > >> @@ -439,7 +440,7 @@ static void handle_ffa_rpc_func_cmd_shm_alloc(struct tee_context *ctx, > >> shm = optee_rpc_cmd_alloc_suppl(ctx, arg->params[0].u.value.b); > >> break; > >> case OPTEE_RPC_SHM_TYPE_KERNEL: > >> - shm = tee_shm_alloc_priv_kernel_buf(ctx, > >> + shm = tee_shm_alloc_priv_kernel_buf(optee->ctx, > >> arg->params[0].u.value.b); > >> break; > >> default: > >> @@ -493,14 +494,13 @@ static void handle_ffa_rpc_func_cmd_shm_free(struct tee_context *ctx, > >> } > >> > >> static void handle_ffa_rpc_func_cmd(struct tee_context *ctx, > >> + struct optee *optee, > >> struct optee_msg_arg *arg) > >> { > >> - struct optee *optee = tee_get_drvdata(ctx->teedev); > >> - > >> arg->ret_origin = TEEC_ORIGIN_COMMS; > >> switch (arg->cmd) { > >> case OPTEE_RPC_CMD_SHM_ALLOC: > >> - handle_ffa_rpc_func_cmd_shm_alloc(ctx, arg); > >> + handle_ffa_rpc_func_cmd_shm_alloc(ctx, optee, arg); > >> break; > >> case OPTEE_RPC_CMD_SHM_FREE: > >> handle_ffa_rpc_func_cmd_shm_free(ctx, optee, arg); > >> @@ -510,12 +510,12 @@ static void handle_ffa_rpc_func_cmd(struct tee_context *ctx, > >> } > >> } > >> > >> -static void optee_handle_ffa_rpc(struct tee_context *ctx, u32 cmd, > >> - struct optee_msg_arg *arg) > >> +static void optee_handle_ffa_rpc(struct tee_context *ctx, struct optee *optee, > >> + u32 cmd, struct optee_msg_arg *arg) > >> { > >> switch (cmd) { > >> case OPTEE_FFA_YIELDING_CALL_RETURN_RPC_CMD: > >> - handle_ffa_rpc_func_cmd(ctx, arg); > >> + handle_ffa_rpc_func_cmd(ctx, optee, arg); > >> break; > >> case OPTEE_FFA_YIELDING_CALL_RETURN_INTERRUPT: > >> /* Interrupt delivered by now */ > >> @@ -582,7 +582,7 @@ static int optee_ffa_yielding_call(struct tee_context *ctx, > >> * above. > >> */ > >> cond_resched(); > >> - optee_handle_ffa_rpc(ctx, data->data1, rpc_arg); > >> + optee_handle_ffa_rpc(ctx, optee, data->data1, rpc_arg); > >> cmd = OPTEE_FFA_YIELDING_CALL_RESUME; > >> data->data0 = cmd; > >> data->data1 = 0; > >> diff --git a/drivers/tee/optee/smc_abi.c b/drivers/tee/optee/smc_abi.c > >> index 1dbb13b08381..f2ef76451443 100644 > >> --- a/drivers/tee/optee/smc_abi.c > >> +++ b/drivers/tee/optee/smc_abi.c > >> @@ -621,6 +621,7 @@ static void handle_rpc_func_cmd_shm_free(struct tee_context *ctx, > >> } > >> > >> static void handle_rpc_func_cmd_shm_alloc(struct tee_context *ctx, > >> + struct optee *optee, > >> struct optee_msg_arg *arg, > >> struct optee_call_ctx *call_ctx) > >> { > >> @@ -650,7 +651,7 @@ static void handle_rpc_func_cmd_shm_alloc(struct tee_context *ctx, > >> shm = optee_rpc_cmd_alloc_suppl(ctx, sz); > >> break; > >> case OPTEE_RPC_SHM_TYPE_KERNEL: > >> - shm = tee_shm_alloc_priv_kernel_buf(ctx, sz); > >> + shm = tee_shm_alloc_priv_kernel_buf(optee->ctx, sz); > >> break; > >> default: > >> arg->ret = TEEC_ERROR_BAD_PARAMETERS; > >> @@ -746,7 +747,7 @@ static void handle_rpc_func_cmd(struct tee_context *ctx, struct optee *optee, > >> switch (arg->cmd) { > >> case OPTEE_RPC_CMD_SHM_ALLOC: > >> free_pages_list(call_ctx); > >> - handle_rpc_func_cmd_shm_alloc(ctx, arg, call_ctx); > >> + handle_rpc_func_cmd_shm_alloc(ctx, optee, arg, call_ctx); > >> break; > >> case OPTEE_RPC_CMD_SHM_FREE: > >> handle_rpc_func_cmd_shm_free(ctx, arg); > >> @@ -775,7 +776,7 @@ static void optee_handle_rpc(struct tee_context *ctx, > >> > >> switch (OPTEE_SMC_RETURN_GET_RPC_FUNC(param->a0)) { > >> case OPTEE_SMC_RPC_FUNC_ALLOC: > >> - shm = tee_shm_alloc_priv_kernel_buf(ctx, param->a1); > >> + shm = tee_shm_alloc_priv_kernel_buf(optee->ctx, param->a1); > >> if (!IS_ERR(shm) && !tee_shm_get_pa(shm, 0, &pa)) { > >> reg_pair_from_64(¶m->a1, ¶m->a2, pa); > >> reg_pair_from_64(¶m->a4, ¶m->a5, > >> -- > >> 2.31.1 > >>