/*
* include/uapi/linux/nvhost_nvdla_ioctl.h
*
* Tegra NvDLA Driver
*
* Copyright (c) 2016-2020, NVIDIA CORPORATION. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, see .
*/
#ifndef __UAPI_LINUX_NVHOST_NVDLA_IOCTL_H
#define __UAPI_LINUX_NVHOST_NVDLA_IOCTL_H
#include
#include
#if !defined(__KERNEL__)
#define __user
#endif
/**
* struct nvdla_queue_stat_args strcture
*
* @status queue status flags
*
*/
struct nvdla_queue_status_args {
#define NVDLA_QUEUE_FLAGS_SUSPEND (1 << 0)
#define NVDLA_QUEUE_FLAGS_RESUME (1 << 1)
__u64 status;
};
/**
* struct nvdla_ping_args structure for ping data
*
* @in_challenge challenge data to be sent
* @out_response response/CRC on challenge data from engine
*
*/
struct nvdla_ping_args {
__u32 in_challenge;
__u32 out_response;
};
/**
* struct nvdla_pin_unpin_args strcture args for buffer pin/unpin
*
* @buffers list of buffers to pin/unpin'ed
* @num_buffers number of buffers count
* @reserved reserved for future use
*
*/
struct nvdla_pin_unpin_args {
__u64 buffers;
__u32 num_buffers;
__u32 reserved;
};
/**
* struct nvdla_submit_args structure for task submit
*
* @tasks pointer to task list
* @num_tasks number of tasks count
* @flags flags for task submit, like atomic
* @version version of task structure
*
*/
struct nvdla_submit_args {
__u64 tasks;
__u16 num_tasks;
#define MAX_TASKS_PER_SUBMIT 16
#define NVDLA_SUBMIT_FLAGS_ATOMIC (1 << 0)
__u16 flags;
__u32 version;
};
/**
* struct nvdla_get_fw_ver_args strcture
*
* @version Firmware version
*
*/
struct nvdla_get_fw_ver_args {
__u32 version;
};
/**
* struct nvdla_get_q_status_args strcture
*
* @id queue id
* @fence fence assigned to queue
*
*/
struct nvdla_get_q_status_args {
__u32 id;
__u64 fence;
};
/**
* struct nvdla_mem_handle structure for memory handles
*
* @handle handle to buffer allocated in userspace
* @offset offset in buffer
*
*/
struct nvdla_mem_handle {
__u32 handle;
__u32 offset;
};
/**
* struct nvdla_ioctl_submit_task structure for single task information
*
* @num_prefences number of pre-fences in task
* @num_postfences number of post-fences in task
* @num_input_task_status number of input task status
* @num_sof_task_status number of sof task status
* @num_eof_task_status number of eof task status
* @num_sof_timestamps number of sof timestamp
* @num_eof_timestamps number of eof timestamp
* @flags flags for bitwise task info embeddeing
* @reserved reserved for future use
* @prefences pointer to pre-fence struct table
* @postfences pointer to post-fence struct table
* @input_task_status pointer to input task status struct table
* @sof_task_status pointer to sof task status struct table
* @eof_task_status pointer to eof task status struct table
* @sof_timestamps pointer to sof timestamp handle list
* @eof_timestamps pointer to eof timestamp handle list
* @num_addresses total number of addressed passed in structure
* @address_list pointer to address list
* @timeout task timeout
*
*/
struct nvdla_ioctl_submit_task {
__u8 num_prefences;
__u8 num_postfences;
__u8 num_input_task_status;
__u8 num_sof_task_status;
__u8 num_eof_task_status;
__u8 num_sof_timestamps;
__u8 num_eof_timestamps;
__u8 reserved0[1];
#define NVDLA_MAX_BUFFERS_PER_TASK (6144)
__u32 num_addresses;
__u16 flags;
__u16 reserved1;
__u64 prefences;
__u64 postfences;
__u64 input_task_status;
__u64 sof_task_status;
__u64 eof_task_status;
__u64 sof_timestamps;
__u64 eof_timestamps;
__u64 address_list;
__u64 timeout;
};
/**
* struct nvdla_ioctl_emu_submit_task structure for single emulator task
* information
*
* @num_prefences number of pre-fences in task
* @num_postfences number of post-fences in task
* @prefences pointer to pre-fence struct table
* @postfences pointer to post-fence struct table
*
*/
struct nvdla_ioctl_emu_submit_task {
__u32 num_prefences;
__u32 num_postfences;
__u64 prefences;
__u64 postfences;
};
/**
* struct nvdla_fence structure for passing fence information
*
* NOTE: this will be removed soon, please use generic fence type
* from nvdev_fence.h
*/
struct nvdla_fence {
__u32 type;
#define NVDLA_FENCE_TYPE_SYNCPT 0
#define NVDLA_FENCE_TYPE_SYNC_FD 1
#define NVDLA_FENCE_TYPE_SEMAPHORE 2
#define NVDLA_FENCE_TYPE_TS_SEMAPHORE 3
__u32 syncpoint_index;
__u32 syncpoint_value;
__u32 sync_fd;
__u32 sem_handle;
__u32 sem_offset;
__u32 sem_val;
};
/**
* struct nvdla_status_notify structure for passing status notify information
*
* @handle handle to buffer allocated in userspace
* @offset offset in buffer
* @status status
*
*/
struct nvdla_status_notify {
__u32 handle;
__u32 offset;
__u32 status;
};
#define NVHOST_NVDLA_IOCTL_MAGIC 'D'
#define NVDLA_IOCTL_PING \
_IOWR(NVHOST_NVDLA_IOCTL_MAGIC, 1, struct nvdla_ping_args)
#define NVDLA_IOCTL_PIN \
_IOW(NVHOST_NVDLA_IOCTL_MAGIC, 2, struct nvdla_pin_unpin_args)
#define NVDLA_IOCTL_UNPIN \
_IOW(NVHOST_NVDLA_IOCTL_MAGIC, 3, struct nvdla_pin_unpin_args)
#define NVDLA_IOCTL_SUBMIT \
_IOW(NVHOST_NVDLA_IOCTL_MAGIC, 4, struct nvdla_submit_args)
#define NVDLA_IOCTL_SET_QUEUE_STATUS \
_IOW(NVHOST_NVDLA_IOCTL_MAGIC, 5, struct nvdla_queue_status_args)
#define NVDLA_IOCTL_GET_FIRMWARE_VERSION \
_IOWR(NVHOST_NVDLA_IOCTL_MAGIC, 6, struct nvdla_get_fw_ver_args)
#define NVDLA_IOCTL_GET_QUEUE_STATUS \
_IOWR(NVHOST_NVDLA_IOCTL_MAGIC, 7, struct nvdla_get_q_status_args)
#define NVDLA_IOCTL_EMU_TASK_SUBMIT \
_IOWR(NVHOST_NVDLA_IOCTL_MAGIC, 8, struct nvdla_submit_args)
#define NVDLA_IOCTL_LAST \
_IOC_NR(NVDLA_IOCTL_EMU_TASK_SUBMIT)
#define NVDLA_IOCTL_MAX_ARG_SIZE \
sizeof(struct nvdla_pin_unpin_args)
#endif /* __UAPI_LINUX_NVHOST_NVDLA_IOCTL_H */