[igt-dev] [i-g-t 1/5] lib/xe/xe_ioctl: Add a helper to map the buffer
Das, Nirmoy
nirmoy.das at linux.intel.com
Mon Mar 20 14:28:40 UTC 2023
On 3/20/2023 11:00 AM, Bhanuprakash Modem wrote:
> Create a new helper to map the buffer with the user PROT flags.
>
> Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
Looks good to me. The series is Acked-by: Nirmoy Das <nirmoy.das at intel.com>
> ---
> lib/xe/xe_ioctl.c | 14 ++++++++++++--
> lib/xe/xe_ioctl.h | 1 +
> 2 files changed, 13 insertions(+), 2 deletions(-)
>
> diff --git a/lib/xe/xe_ioctl.c b/lib/xe/xe_ioctl.c
> index 9d5793dff..66a8393fe 100644
> --- a/lib/xe/xe_ioctl.c
> +++ b/lib/xe/xe_ioctl.c
> @@ -334,18 +334,28 @@ uint64_t xe_bo_mmap_offset(int fd, uint32_t bo)
> return mmo.offset;
> }
>
> -void *xe_bo_map(int fd, uint32_t bo, size_t size)
> +static void *__xe_bo_map(int fd, uint16_t bo, size_t size, int prot)
> {
> uint64_t mmo;
> void *map;
>
> mmo = xe_bo_mmap_offset(fd, bo);
> - map = mmap(NULL, size, PROT_WRITE, MAP_SHARED, fd, mmo);
> + map = mmap(NULL, size, prot, MAP_SHARED, fd, mmo);
> igt_assert(map != MAP_FAILED);
>
> return map;
> }
>
> +void *xe_bo_map(int fd, uint32_t bo, size_t size)
> +{
> + return __xe_bo_map(fd, bo, size, PROT_WRITE);
> +}
> +
> +void *xe_bo_mmap_ext(int fd, uint32_t bo, size_t size, int prot)
> +{
> + return __xe_bo_map(fd, bo, size, prot);
> +}
> +
> static int __xe_exec(int fd, struct drm_xe_exec *exec)
> {
> int err = 0;
> diff --git a/lib/xe/xe_ioctl.h b/lib/xe/xe_ioctl.h
> index 5c7e773fa..d8c40eda0 100644
> --- a/lib/xe/xe_ioctl.h
> +++ b/lib/xe/xe_ioctl.h
> @@ -73,6 +73,7 @@ uint32_t xe_engine_create_class(int fd, uint32_t vm, uint16_t class);
> void xe_engine_destroy(int fd, uint32_t engine);
> uint64_t xe_bo_mmap_offset(int fd, uint32_t bo);
> void *xe_bo_map(int fd, uint32_t bo, size_t size);
> +void *xe_bo_mmap_ext(int fd, uint32_t bo, size_t size, int prot);
> void xe_exec(int fd, struct drm_xe_exec *exec);
> void xe_exec_sync(int fd, uint32_t engine, uint64_t addr,
> struct drm_xe_sync *sync, uint32_t num_syncs);
More information about the igt-dev
mailing list