[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [XEN PATCH v10 09/24] xen/arm: ffa: add support for FFA_ID_GET


  • To: Jens Wiklander <jens.wiklander@xxxxxxxxxx>
  • From: Bertrand Marquis <Bertrand.Marquis@xxxxxxx>
  • Date: Tue, 18 Jul 2023 09:34:35 +0000
  • Accept-language: en-GB, en-US
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=i/g4k9D9SvR5mKHxvJhhHBkmqMlgOSwvcoxhNKuGuP4=; b=BdteZDbx6vBGZ20KQM2cYSzFwTSIX2e8NHvYeNBOs34p2D13kj1+yf0nogZWo+CnKs59viFL0ySA3k4cz0s9qfE+X8OCIu2zf74qfK60/Y32gCm7N4gZ5BK8IGBrVAdqQar61uEpCFLKSDAz9k/s6ldQPAAZEYinfrO3owQbocK9oPmzeRRHNOvo2MUCPH8iFWTOFiLPFkmHaUQ7xUdAGrN0mv8O0gm5mYtObT31JlhGW5pkbS23HAenACDAKtb01tXvVwJXySzo8O/Lt/waJ94wTUqhpi8qtCJYh4Z9eaISm97ccLGgdFGnljZFIcDUSz5b7sG1pF+67XM6zZSxGg==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=axxv49FL0jpi2XNei41+FW2eUaR6UnH74tsSRhIWz+HdRruK0TIREEVlUkgAly4La63O4H7KU9CF6n+ZmnXk73Ctgv/YSeX5NjyH6d/pIwXNZ3WurjqeMmnZNOc8/uXPkCV8KedngSDMjfGGSHAJ12UJw1YOou2SjinsXpAHHHw7n5+z9Pncjj56JuZJlq3W3TGuYwxkI7XUGkz3w0Xyltq2E+rPAVvtUBjj1q41U41UvXwfFk4SH2gPmNdpgg1FXbYStrUdjDhxI2+QCqtP2M5kJEuuXTzZxSbEL3hJBRfFd7NPGef9uPu5eu9L/gpEE28UDdS9RnfaV5bPTl2O+A==
  • Authentication-results-original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com;
  • Cc: Xen-devel <xen-devel@xxxxxxxxxxxxxxxxxxxx>, Stefano Stabellini <sstabellini@xxxxxxxxxx>, Julien Grall <julien@xxxxxxx>, Volodymyr Babchuk <Volodymyr_Babchuk@xxxxxxxx>, Anthony PERARD <anthony.perard@xxxxxxxxxx>, Juergen Gross <jgross@xxxxxxxx>, Wei Liu <wl@xxxxxxx>, Marc Bonnici <Marc.Bonnici@xxxxxxx>, Achin Gupta <Achin.Gupta@xxxxxxx>
  • Delivery-date: Tue, 18 Jul 2023 09:35:15 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>
  • Nodisclaimer: true
  • Original-authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com;
  • Thread-index: AQHZuH9UE3hx62s6skKCeGk62Jh6i6+/RRWA
  • Thread-topic: [XEN PATCH v10 09/24] xen/arm: ffa: add support for FFA_ID_GET

Hi Jens,

> On 17 Jul 2023, at 09:20, Jens Wiklander <jens.wiklander@xxxxxxxxxx> wrote:
> 
> Adds support for the FF-A function FFA_ID_GET to return the ID of the
> calling client.
> 
> Signed-off-by: Jens Wiklander <jens.wiklander@xxxxxxxxxx>

Reviewed-by: Bertrand Marquis <bertrand.marquis@xxxxxxx>

Cheers
Bertrand

> ---
> xen/arch/arm/tee/ffa.c | 21 +++++++++++++++++++++
> 1 file changed, 21 insertions(+)
> 
> diff --git a/xen/arch/arm/tee/ffa.c b/xen/arch/arm/tee/ffa.c
> index f0a2715d4bbf..e157ed20ad8b 100644
> --- a/xen/arch/arm/tee/ffa.c
> +++ b/xen/arch/arm/tee/ffa.c
> @@ -181,6 +181,12 @@ static bool ffa_get_version(uint32_t *vers)
>     return true;
> }
> 
> +static uint16_t get_vm_id(const struct domain *d)
> +{
> +    /* +1 since 0 is reserved for the hypervisor in FF-A */
> +    return d->domain_id + 1;
> +}
> +
> static void set_regs(struct cpu_user_regs *regs, register_t v0, register_t v1,
>                      register_t v2, register_t v3, register_t v4, register_t 
> v5,
>                      register_t v6, register_t v7)
> @@ -195,6 +201,12 @@ static void set_regs(struct cpu_user_regs *regs, 
> register_t v0, register_t v1,
>         set_user_reg(regs, 7, v7);
> }
> 
> +static void set_regs_success(struct cpu_user_regs *regs, uint32_t w2,
> +                             uint32_t w3)
> +{
> +    set_regs(regs, FFA_SUCCESS_32, 0, w2, w3, 0, 0, 0, 0);
> +}
> +
> static void handle_version(struct cpu_user_regs *regs)
> {
>     struct domain *d = current->domain;
> @@ -224,6 +236,9 @@ static bool ffa_handle_call(struct cpu_user_regs *regs)
>     case FFA_VERSION:
>         handle_version(regs);
>         return true;
> +    case FFA_ID_GET:
> +        set_regs_success(regs, get_vm_id(d), 0);
> +        return true;
> 
>     default:
>         gprintk(XENLOG_ERR, "ffa: unhandled fid 0x%x\n", fid);
> @@ -237,6 +252,12 @@ static int ffa_domain_init(struct domain *d)
> 
>     if ( !ffa_version )
>         return -ENODEV;
> +     /*
> +      * We can't use that last possible domain ID or get_vm_id() would cause
> +      * an overflow.
> +      */
> +    if ( d->domain_id >= UINT16_MAX)
> +        return -ERANGE;
> 
>     ctx = xzalloc(struct ffa_ctx);
>     if ( !ctx )
> -- 
> 2.34.1
> 




 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.