[PATCH 9/9] firmware: arm_ffa: Setup in-kernel users of FFA partitions
Jonathan Cameron
Jonathan.Cameron at Huawei.com
Tue Sep 1 12:38:02 EDT 2020
On Sat, 29 Aug 2020 18:09:23 +0100
Sudeep Holla <sudeep.holla at arm.com> wrote:
> In order to also enable in-kernel users of FFA interface along with
> the access to user-space applications, let us add simple set of operations
> for such devices.
>
> The in-kernel users are registered without the character device interface.
>
> Signed-off-by: Sudeep Holla <sudeep.holla at arm.com>
> ---
> drivers/firmware/arm_ffa/driver.c | 119 ++++++++++++++++++++++++++----
> include/linux/arm_ffa.h | 12 +++
> 2 files changed, 117 insertions(+), 14 deletions(-)
>
> diff --git a/drivers/firmware/arm_ffa/driver.c b/drivers/firmware/arm_ffa/driver.c
> index 96113e594db6..811558ef2a1d 100644
> --- a/drivers/firmware/arm_ffa/driver.c
> +++ b/drivers/firmware/arm_ffa/driver.c
> @@ -372,6 +372,97 @@ static void ffa_device_put(struct ffa_device *ffa_dev)
> mutex_unlock(&ffa_dev->mutex);
> }
...
> +
> +static long
> +ffa_dev_ioctl(struct ffa_device *ffa_dev, unsigned int ioctl, void *arg)
> +{
> + long r = -EINVAL;
> +
> + switch (ioctl) {
> + case FFA_GET_API_VERSION:
> + r = drv_info->version;
Early returns would make this a tiny bit shorter and more readable.
return drv_info->version;
etc
> + break;
> + case FFA_GET_PARTITION_ID:
> + r = ffa_dev->vm_id;
> + break;
> + case FFA_GET_PARTITION_INFO: {
> + struct ffa_part_info *pinfo = arg;
> +
> + if (ffa_partition_probe(pinfo->uuid_str, &pinfo->info) != 1)
> + r = -E2BIG;
> + break;
> + }
> + case FFA_SEND_RECEIVE_SYNC: {
> + struct ffa_send_recv_sync *kdata = arg;
> +
> + r = ffa_msg_send_direct_req(ffa_dev->vm_id, kdata->endpoint_id,
> + &kdata->data);
> + break;
> + }
> + case FFA_SEND_RECEIVE_ASYNC: {
> + struct ffa_send_recv_async *kdata = arg;
> +
> + if (kdata->length < 0 || kdata->length > RXTX_BUFFER_SIZE) {
> + r = -EINVAL;
> + break;
> + }
> +
> + r = ffa_msg_send(ffa_dev->vm_id, kdata->endpoint_id,
> + kdata->buffer, kdata->length);
> + break;
> + }
> + default:
> + r = -EINVAL;
> + }
> +
> + return r;
> +}
> +
...
Thanks,
Jonathan
More information about the linux-arm-kernel
mailing list