lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <5ca2b6f4912946e7a7415dd35679704c@honor.com>
Date: Tue, 13 May 2025 12:27:31 +0000
From: wangtao <tao.wangtao@...or.com>
To: Christian König <christian.koenig@....com>,
	"sumit.semwal@...aro.org" <sumit.semwal@...aro.org>,
	"benjamin.gaignard@...labora.com" <benjamin.gaignard@...labora.com>,
	"Brian.Starkey@....com" <Brian.Starkey@....com>, "jstultz@...gle.com"
	<jstultz@...gle.com>, "tjmercier@...gle.com" <tjmercier@...gle.com>
CC: "linux-media@...r.kernel.org" <linux-media@...r.kernel.org>,
	"dri-devel@...ts.freedesktop.org" <dri-devel@...ts.freedesktop.org>,
	"linaro-mm-sig@...ts.linaro.org" <linaro-mm-sig@...ts.linaro.org>,
	"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
	"wangbintian(BintianWang)" <bintian.wang@...or.com>, yipengxiang
	<yipengxiang@...or.com>, liulu 00013167 <liulu.liu@...or.com>, "hanfeng
 00012985" <feng.han@...or.com>
Subject: RE: [PATCH 1/2] dmabuf: add DMA_BUF_IOCTL_RW_FILE



> -----Original Message-----
> From: Christian König <christian.koenig@....com>
> Sent: Tuesday, May 13, 2025 7:31 PM
> To: wangtao <tao.wangtao@...or.com>; sumit.semwal@...aro.org;
> benjamin.gaignard@...labora.com; Brian.Starkey@....com;
> jstultz@...gle.com; tjmercier@...gle.com
> Cc: linux-media@...r.kernel.org; dri-devel@...ts.freedesktop.org; linaro-
> mm-sig@...ts.linaro.org; linux-kernel@...r.kernel.org;
> wangbintian(BintianWang) <bintian.wang@...or.com>; yipengxiang
> <yipengxiang@...or.com>; liulu 00013167 <liulu.liu@...or.com>; hanfeng
> 00012985 <feng.han@...or.com>
> Subject: Re: [PATCH 1/2] dmabuf: add DMA_BUF_IOCTL_RW_FILE
> 
> On 5/13/25 11:27, wangtao wrote:
> > Add DMA_BUF_IOCTL_RW_FILE to save/restore data from/to a dma-buf.
> 
> Similar approach where rejected before in favor of using udmabuf.
> 
> Is there any reason you can't use that approach as well?
[wangtao] For performance optimization, we can achieves 3776 MB/s (UFS 4.0 device @ 4GB/s).
Apologies, my three previous emails were not consolidated into the same thread.
> 
> Regards,
> Christian.
> 
> >
> > Signed-off-by: wangtao <tao.wangtao@...or.com>
> > ---
> >  drivers/dma-buf/dma-buf.c    |  8 ++++++++
> >  include/linux/dma-buf.h      |  3 +++
> >  include/uapi/linux/dma-buf.h | 29 +++++++++++++++++++++++++++++
> >  3 files changed, 40 insertions(+)
> >
> > diff --git a/drivers/dma-buf/dma-buf.c b/drivers/dma-buf/dma-buf.c
> > index 5baa83b85515..95d8b0158ffd 100644
> > --- a/drivers/dma-buf/dma-buf.c
> > +++ b/drivers/dma-buf/dma-buf.c
> > @@ -460,6 +460,7 @@ static long dma_buf_ioctl(struct file *file,
> >  	struct dma_buf *dmabuf;
> >  	struct dma_buf_sync sync;
> >  	enum dma_data_direction direction;
> > +	struct dma_buf_rw_file kfile;
> >  	int ret;
> >
> >  	dmabuf = file->private_data;
> > @@ -504,6 +505,13 @@ static long dma_buf_ioctl(struct file *file,
> >  		return dma_buf_import_sync_file(dmabuf, (const void
> __user *)arg);
> > #endif
> >
> > +	case DMA_BUF_IOCTL_RW_FILE:
> > +		if (copy_from_user(&kfile, (void __user *) arg, sizeof(kfile)))
> > +			return -EFAULT;
> > +		if (!dmabuf->ops->rw_file)
> > +			return -EINVAL;
> > +		return dmabuf->ops->rw_file(dmabuf, &kfile);
> > +
> >  	default:
> >  		return -ENOTTY;
> >  	}
> > diff --git a/include/linux/dma-buf.h b/include/linux/dma-buf.h index
> > 36216d28d8bd..de236ba2094b 100644
> > --- a/include/linux/dma-buf.h
> > +++ b/include/linux/dma-buf.h
> > @@ -22,6 +22,7 @@
> >  #include <linux/fs.h>
> >  #include <linux/dma-fence.h>
> >  #include <linux/wait.h>
> > +#include <uapi/linux/dma-buf.h>
> >
> >  struct device;
> >  struct dma_buf;
> > @@ -285,6 +286,8 @@ struct dma_buf_ops {
> >
> >  	int (*vmap)(struct dma_buf *dmabuf, struct iosys_map *map);
> >  	void (*vunmap)(struct dma_buf *dmabuf, struct iosys_map *map);
> > +
> > +	int (*rw_file)(struct dma_buf *dmabuf, struct dma_buf_rw_file
> > +*file);
> >  };
> >
> >  /**
> > diff --git a/include/uapi/linux/dma-buf.h
> > b/include/uapi/linux/dma-buf.h index 5a6fda66d9ad..ec9164b7b753
> 100644
> > --- a/include/uapi/linux/dma-buf.h
> > +++ b/include/uapi/linux/dma-buf.h
> > @@ -167,6 +167,29 @@ struct dma_buf_import_sync_file {
> >  	__s32 fd;
> >  };
> >
> > +/**
> > + * struct dma_buf_rw_file - read/write file associated with a dma-buf
> > + *
> > + * Userspace can performs a DMA_BUF_IOCTL_BACK to save data from a
> > +dma-buf or
> > + * restore data to a dma-buf.
> > + */
> > +struct dma_buf_rw_file {
> > +
> > +	/** @flags: Flags indicating read/write for this dma-buf. */
> > +	__u32 flags;
> > +	/** @fd: File descriptor of the file associated with this dma-buf. */
> > +	__s32 fd;
> > +	/** @file_offset: Offset within the file where this dma-buf starts.
> > +	 *
> > +	 *  Offset and Length must be page-aligned for direct I/O.
> > +	 */
> > +	__u64 file_offset;
> > +	/** @buf_offset: Offset within this dma-buf where the read/write
> starts. */
> > +	__u64 buf_offset;
> > +	/** @buf_len: Length of this dma-buf read/write. */
> > +	__u64 buf_len;
> > +};
> > +
> >  #define DMA_BUF_BASE		'b'
> >  #define DMA_BUF_IOCTL_SYNC	_IOW(DMA_BUF_BASE, 0, struct
> dma_buf_sync)
> >
> > @@ -179,4 +202,10 @@ struct dma_buf_import_sync_file {
> >  #define DMA_BUF_IOCTL_EXPORT_SYNC_FILE
> 	_IOWR(DMA_BUF_BASE, 2, struct dma_buf_export_sync_file)
> >  #define DMA_BUF_IOCTL_IMPORT_SYNC_FILE
> 	_IOW(DMA_BUF_BASE, 3, struct dma_buf_import_sync_file)
> >
> > +#define DMA_BUF_RW_FLAGS_OP_MASK (0xFF << 0) #define
> > +DMA_BUF_RW_FLAGS_READ (1 << 0) /* Restore dma-buf data */
> #define
> > +DMA_BUF_RW_FLAGS_WRITE (2 << 0) /* Save dma-buf data */ #define
> > +DMA_BUF_RW_FLAGS_DIRECT (1u << 31) /* Direct read/write file */
> > +#define DMA_BUF_IOCTL_RW_FILE	_IOW(DMA_BUF_BASE, 4, struct
> dma_buf_rw_file)
> > +
> >  #endif

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ