[PATCH] staging: android: ion: add buffer flag update ioctl
Laura Abbott
labbott at redhat.com
Wed Dec 19 18:09:30 UTC 2018
On 12/19/18 9:19 AM, Zeng Tao wrote:
> In some usecases, the buffer cached attribute is not determined at
> allocation time, it's determined just before the real cpu mapping.
> And from the memory view of point, a buffer should not have the cached
> attribute util is really mapped by the cpu. So in this patch, we
> introduced the new ioctl command to target the requirement.
>
This is racy and error prone. Can you explain more what
problem you are trying to solve?
> Signed-off-by: Zeng Tao <prime.zeng at hisilicon.com>
> ---
> drivers/staging/android/ion/ion-ioctl.c | 4 ++++
> drivers/staging/android/ion/ion.c | 17 +++++++++++++++++
> drivers/staging/android/ion/ion.h | 1 +
> drivers/staging/android/uapi/ion.h | 22 ++++++++++++++++++++++
> 4 files changed, 44 insertions(+)
>
> diff --git a/drivers/staging/android/ion/ion-ioctl.c b/drivers/staging/android/ion/ion-ioctl.c
> index a8d3cc4..60bb702 100644
> --- a/drivers/staging/android/ion/ion-ioctl.c
> +++ b/drivers/staging/android/ion/ion-ioctl.c
> @@ -12,6 +12,7 @@
>
> union ion_ioctl_arg {
> struct ion_allocation_data allocation;
> + struct ion_buffer_flag_data update;
> struct ion_heap_query query;
> };
>
> @@ -83,6 +84,9 @@ long ion_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
>
> break;
> }
> + case ION_IOC_BUFFER_UPDATE:
> + ret = ion_buffer_update(data.update.fd, data.update.flags);
> + break;
> case ION_IOC_HEAP_QUERY:
> ret = ion_query_heaps(&data.query);
> break;
> diff --git a/drivers/staging/android/ion/ion.c b/drivers/staging/android/ion/ion.c
> index 9907332..f1404dc 100644
> --- a/drivers/staging/android/ion/ion.c
> +++ b/drivers/staging/android/ion/ion.c
> @@ -436,6 +436,23 @@ int ion_alloc(size_t len, unsigned int heap_id_mask, unsigned int flags)
> return fd;
> }
>
> +int ion_buffer_update(unsigned int fd, unsigned int flags)
> +{
> + struct dma_buf *dmabuf;
> + struct ion_buffer *buffer;
> +
> + dmabuf = dma_buf_get(fd);
> +
> + if (!dmabuf)
> + return -EINVAL;
> +
> + buffer = dmabuf->priv;
> + buffer->flags = flags;
> + dma_buf_put(dmabuf);
> +
> + return 0;
> +}
> +
> int ion_query_heaps(struct ion_heap_query *query)
> {
> struct ion_device *dev = internal_dev;
> diff --git a/drivers/staging/android/ion/ion.h b/drivers/staging/android/ion/ion.h
> index c006fc1..99bf9ab 100644
> --- a/drivers/staging/android/ion/ion.h
> +++ b/drivers/staging/android/ion/ion.h
> @@ -199,6 +199,7 @@ int ion_heap_pages_zero(struct page *page, size_t size, pgprot_t pgprot);
> int ion_alloc(size_t len,
> unsigned int heap_id_mask,
> unsigned int flags);
> +int ion_buffer_update(unsigned int fd, unsigned int flags);
>
> /**
> * ion_heap_init_shrinker
> diff --git a/drivers/staging/android/uapi/ion.h b/drivers/staging/android/uapi/ion.h
> index 5d70098..99753fc 100644
> --- a/drivers/staging/android/uapi/ion.h
> +++ b/drivers/staging/android/uapi/ion.h
> @@ -74,6 +74,20 @@ struct ion_allocation_data {
> __u32 unused;
> };
>
> +/**
> + * struct ion_buffer_flag_data - metadata passed from userspace for update
> + * buffer flags
> + * @fd: file descriptor of the buffer
> + * @flags: flags passed to the buffer
> + *
> + * Provided by userspace as an argument to the ioctl
> + */
> +
> +struct ion_buffer_flag_data {
> + __u32 fd;
> + __u32 flags;
> +}
> +
> #define MAX_HEAP_NAME 32
>
> /**
> @@ -116,6 +130,14 @@ struct ion_heap_query {
> struct ion_allocation_data)
>
> /**
> + * DOC: ION_IOC_BUFFER_UPDATE - update the specified ion buffer flags
> + *
> + * Takes an ion_buffer_flag_data structure and returns the result of the
> + * buffer flag update operation.
> + */
> +#define ION_IOC_BUFFER_UPDATE _IOWR(ION_IOC_MAGIC, 1, \
> + struct ion_buffer_flag_data)
> +/**
> * DOC: ION_IOC_HEAP_QUERY - information about available heaps
> *
> * Takes an ion_heap_query structure and populates information about
>
More information about the dri-devel
mailing list