[PATCH v1 07/14] tee: optee: add shared buffer registration functions

Mark Rutland mark.rutland at arm.com
Fri Sep 29 06:06:43 PDT 2017


On Thu, Sep 28, 2017 at 09:04:04PM +0300, Volodymyr Babchuk wrote:
> From: Volodymyr Babchuk <vlad.babchuk at gmail.com>
> 
> This change adds ops for shm_(un)register functions in tee interface.
> Client application can use these functions to (un)register an own shared
> buffer in OP-TEE address space. This allows zero copy data sharing between
> Normal and Secure Worlds.
> 
> Please note that while those functions were added to optee code,
> it does not report to userspace that those functions are available.
> OP-TEE code does not set TEE_GEN_CAP_REG_MEM flag. This flag will be
> enabled only after all other features of dynamic shared memory will be
> implemented in subsequent patches.

While it's not adveritsed to the user, AFAICT the user could still
invoke these via ioctls, right?

Is there a problem if the user were to do so, or is it simply not useful
without the other features?

[...]

> +int optee_shm_register(struct tee_context *ctx, struct tee_shm *shm,
> +		       struct page **pages, size_t num_pages)
> +{

> +	pages_array = optee_allocate_pages_array(num_pages);
> +	if (!pages_array)
> +		return -ENOMEM;

> +	msg_arg->params->u.tmem.buf_ptr = virt_to_phys(pages_array) |
> +					  tee_shm_get_page_offset(shm);

This doesn't look right. Why is the shm page offset being orred-in to
the pages_array physical address? They're completely separate objects.

Thanks,
Mark.



More information about the linux-arm-kernel mailing list