2021-06-10 14:04:48 +03:00
/* SPDX-License-Identifier: MIT */
/* Copyright (c) 2012-2020 NVIDIA Corporation */
2013-03-22 18:34:09 +04:00
# ifndef _UAPI_TEGRA_DRM_H_
# define _UAPI_TEGRA_DRM_H_
2015-11-30 17:10:54 +03:00
# include "drm.h"
2013-04-26 21:49:51 +04:00
2016-04-07 21:35:50 +03:00
# if defined(__cplusplus)
extern " C " {
# endif
2021-06-10 14:04:48 +03:00
/* Tegra DRM legacy UAPI. Only enabled with STAGING */
2013-10-07 11:47:58 +04:00
# define DRM_TEGRA_GEM_CREATE_TILED (1 << 0)
# define DRM_TEGRA_GEM_CREATE_BOTTOM_UP (1 << 1)
2013-10-05 00:34:01 +04:00
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_gem_create - parameters for the GEM object creation IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_gem_create {
2018-05-16 17:43:11 +03:00
/**
* @ size :
*
* The size , in bytes , of the buffer object to be created .
*/
2013-03-22 18:34:09 +04:00
__u64 size ;
2018-05-16 17:43:11 +03:00
/**
* @ flags :
*
* A bitmask of flags that influence the creation of GEM objects :
*
* DRM_TEGRA_GEM_CREATE_TILED
* Use the 16 x16 tiling format for this buffer .
*
* DRM_TEGRA_GEM_CREATE_BOTTOM_UP
* The buffer has a bottom - up layout .
*/
2013-03-22 18:34:09 +04:00
__u32 flags ;
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* The handle of the created GEM object . Set by the kernel upon
* successful completion of the IOCTL .
*/
2013-03-22 18:34:09 +04:00
__u32 handle ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_gem_mmap - parameters for the GEM mmap IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_gem_mmap {
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* Handle of the GEM object to obtain an mmap offset for .
*/
2013-03-22 18:34:09 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ pad :
*
* Structure padding that may be used in the future . Must be 0.
*/
2015-01-30 21:57:01 +03:00
__u32 pad ;
2018-05-16 17:43:11 +03:00
/**
* @ offset :
*
* The mmap offset for the given GEM object . Set by the kernel upon
* successful completion of the IOCTL .
*/
2015-01-30 21:57:01 +03:00
__u64 offset ;
2013-03-22 18:34:09 +04:00
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_syncpt_read - parameters for the read syncpoint IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_syncpt_read {
2018-05-16 17:43:11 +03:00
/**
* @ id :
*
* ID of the syncpoint to read the current value from .
*/
2013-03-22 18:34:09 +04:00
__u32 id ;
2018-05-16 17:43:11 +03:00
/**
* @ value :
*
* The current syncpoint value . Set by the kernel upon successful
* completion of the IOCTL .
*/
2013-03-22 18:34:09 +04:00
__u32 value ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_syncpt_incr - parameters for the increment syncpoint IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_syncpt_incr {
2018-05-16 17:43:11 +03:00
/**
* @ id :
*
* ID of the syncpoint to increment .
*/
2013-03-22 18:34:09 +04:00
__u32 id ;
2018-05-16 17:43:11 +03:00
/**
* @ pad :
*
* Structure padding that may be used in the future . Must be 0.
*/
2013-03-22 18:34:09 +04:00
__u32 pad ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_syncpt_wait - parameters for the wait syncpoint IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_syncpt_wait {
2018-05-16 17:43:11 +03:00
/**
* @ id :
*
* ID of the syncpoint to wait on .
*/
2013-03-22 18:34:09 +04:00
__u32 id ;
2018-05-16 17:43:11 +03:00
/**
* @ thresh :
*
* Threshold value for which to wait .
*/
2013-03-22 18:34:09 +04:00
__u32 thresh ;
2018-05-16 17:43:11 +03:00
/**
* @ timeout :
*
* Timeout , in milliseconds , to wait .
*/
2013-03-22 18:34:09 +04:00
__u32 timeout ;
2018-05-16 17:43:11 +03:00
/**
* @ value :
*
* The new syncpoint value after the wait . Set by the kernel upon
* successful completion of the IOCTL .
*/
2013-03-22 18:34:09 +04:00
__u32 value ;
} ;
# define DRM_TEGRA_NO_TIMEOUT (0xffffffff)
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_open_channel - parameters for the open channel IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_open_channel {
2018-05-16 17:43:11 +03:00
/**
* @ client :
*
* The client ID for this channel .
*/
2013-03-22 18:34:09 +04:00
__u32 client ;
2018-05-16 17:43:11 +03:00
/**
* @ pad :
*
* Structure padding that may be used in the future . Must be 0.
*/
2013-03-22 18:34:09 +04:00
__u32 pad ;
2018-05-16 17:43:11 +03:00
/**
* @ context :
*
* The application context of this channel . Set by the kernel upon
* successful completion of the IOCTL . This context needs to be passed
* to the DRM_TEGRA_CHANNEL_CLOSE or the DRM_TEGRA_SUBMIT IOCTLs .
*/
2013-03-22 18:34:09 +04:00
__u64 context ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_close_channel - parameters for the close channel IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_close_channel {
2018-05-16 17:43:11 +03:00
/**
* @ context :
*
* The application context of this channel . This is obtained from the
* DRM_TEGRA_OPEN_CHANNEL IOCTL .
*/
2013-03-22 18:34:09 +04:00
__u64 context ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_get_syncpt - parameters for the get syncpoint IOCTL
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_get_syncpt {
2018-05-16 17:43:11 +03:00
/**
* @ context :
*
* The application context identifying the channel for which to obtain
* the syncpoint ID .
*/
2013-03-22 18:34:09 +04:00
__u64 context ;
2018-05-16 17:43:11 +03:00
/**
* @ index :
*
* Index of the client syncpoint for which to obtain the ID .
*/
2013-03-22 18:34:09 +04:00
__u32 index ;
2018-05-16 17:43:11 +03:00
/**
* @ id :
*
* The ID of the given syncpoint . Set by the kernel upon successful
* completion of the IOCTL .
*/
2013-03-22 18:34:09 +04:00
__u32 id ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_get_syncpt_base - parameters for the get wait base IOCTL
*/
2013-10-14 16:21:54 +04:00
struct drm_tegra_get_syncpt_base {
2018-05-16 17:43:11 +03:00
/**
* @ context :
*
* The application context identifying for which channel to obtain the
* wait base .
*/
2013-10-14 16:21:54 +04:00
__u64 context ;
2018-05-16 17:43:11 +03:00
/**
* @ syncpt :
*
* ID of the syncpoint for which to obtain the wait base .
*/
2013-10-14 16:21:54 +04:00
__u32 syncpt ;
2018-05-16 17:43:11 +03:00
/**
* @ id :
*
* The ID of the wait base corresponding to the client syncpoint . Set
* by the kernel upon successful completion of the IOCTL .
*/
2013-10-14 16:21:54 +04:00
__u32 id ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_syncpt - syncpoint increment operation
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_syncpt {
2018-05-16 17:43:11 +03:00
/**
* @ id :
*
* ID of the syncpoint to operate on .
*/
2013-03-22 18:34:09 +04:00
__u32 id ;
2018-05-16 17:43:11 +03:00
/**
* @ incrs :
*
* Number of increments to perform for the syncpoint .
*/
2013-03-22 18:34:09 +04:00
__u32 incrs ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_cmdbuf - structure describing a command buffer
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_cmdbuf {
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* Handle to a GEM object containing the command buffer .
*/
2013-03-22 18:34:09 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ offset :
*
* Offset , in bytes , into the GEM object identified by @ handle at
* which the command buffer starts .
*/
2013-03-22 18:34:09 +04:00
__u32 offset ;
2018-05-16 17:43:11 +03:00
/**
* @ words :
*
* Number of 32 - bit words in this command buffer .
*/
2013-03-22 18:34:09 +04:00
__u32 words ;
2018-05-16 17:43:11 +03:00
/**
* @ pad :
*
* Structure padding that may be used in the future . Must be 0.
*/
2013-03-22 18:34:09 +04:00
__u32 pad ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_reloc - GEM object relocation structure
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_reloc {
struct {
2018-05-16 17:43:11 +03:00
/**
* @ cmdbuf . handle :
*
* Handle to the GEM object containing the command buffer for
* which to perform this GEM object relocation .
*/
2013-03-22 18:34:09 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ cmdbuf . offset :
*
* Offset , in bytes , into the command buffer at which to
* insert the relocated address .
*/
2013-03-22 18:34:09 +04:00
__u32 offset ;
} cmdbuf ;
struct {
2018-05-16 17:43:11 +03:00
/**
* @ target . handle :
*
* Handle to the GEM object to be relocated .
*/
2013-03-22 18:34:09 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ target . offset :
*
* Offset , in bytes , into the target GEM object at which the
* relocated data starts .
*/
2013-03-22 18:34:09 +04:00
__u32 offset ;
} target ;
2018-05-16 17:43:11 +03:00
/**
* @ shift :
*
* The number of bits by which to shift relocated addresses .
*/
2013-03-22 18:34:09 +04:00
__u32 shift ;
2018-05-16 17:43:11 +03:00
/**
* @ pad :
*
* Structure padding that may be used in the future . Must be 0.
*/
2013-03-22 18:34:09 +04:00
__u32 pad ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_waitchk - wait check structure
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_waitchk {
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* Handle to the GEM object containing a command stream on which to
* perform the wait check .
*/
2013-03-22 18:34:09 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ offset :
*
* Offset , in bytes , of the location in the command stream to perform
* the wait check on .
*/
2013-03-22 18:34:09 +04:00
__u32 offset ;
2018-05-16 17:43:11 +03:00
/**
* @ syncpt :
*
* ID of the syncpoint to wait check .
*/
2013-03-22 18:34:09 +04:00
__u32 syncpt ;
2018-05-16 17:43:11 +03:00
/**
* @ thresh :
*
* Threshold value for which to check .
*/
2013-03-22 18:34:09 +04:00
__u32 thresh ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_submit - job submission structure
*/
2013-03-22 18:34:09 +04:00
struct drm_tegra_submit {
2018-05-16 17:43:11 +03:00
/**
* @ context :
*
* The application context identifying the channel to use for the
* execution of this job .
*/
2013-03-22 18:34:09 +04:00
__u64 context ;
2018-05-16 17:43:11 +03:00
/**
* @ num_syncpts :
*
* The number of syncpoints operated on by this job . This defines the
* length of the array pointed to by @ syncpts .
*/
2013-03-22 18:34:09 +04:00
__u32 num_syncpts ;
2018-05-16 17:43:11 +03:00
/**
* @ num_cmdbufs :
*
* The number of command buffers to execute as part of this job . This
* defines the length of the array pointed to by @ cmdbufs .
*/
2013-03-22 18:34:09 +04:00
__u32 num_cmdbufs ;
2018-05-16 17:43:11 +03:00
/**
* @ num_relocs :
*
* The number of relocations to perform before executing this job .
* This defines the length of the array pointed to by @ relocs .
*/
2013-03-22 18:34:09 +04:00
__u32 num_relocs ;
2018-05-16 17:43:11 +03:00
/**
* @ num_waitchks :
*
* The number of wait checks to perform as part of this job . This
* defines the length of the array pointed to by @ waitchks .
*/
2013-03-22 18:34:09 +04:00
__u32 num_waitchks ;
2018-05-16 17:43:11 +03:00
/**
* @ waitchk_mask :
*
* Bitmask of valid wait checks .
*/
2013-03-22 18:34:09 +04:00
__u32 waitchk_mask ;
2018-05-16 17:43:11 +03:00
/**
* @ timeout :
*
* Timeout , in milliseconds , before this job is cancelled .
*/
2013-03-22 18:34:09 +04:00
__u32 timeout ;
2018-05-16 17:43:11 +03:00
/**
* @ syncpts :
*
* A pointer to an array of & struct drm_tegra_syncpt structures that
* specify the syncpoint operations performed as part of this job .
* The number of elements in the array must be equal to the value
* given by @ num_syncpts .
*/
2013-03-22 18:34:09 +04:00
__u64 syncpts ;
2018-05-16 17:43:11 +03:00
/**
* @ cmdbufs :
*
* A pointer to an array of & struct drm_tegra_cmdbuf structures that
* define the command buffers to execute as part of this job . The
* number of elements in the array must be equal to the value given
* by @ num_syncpts .
*/
2013-03-22 18:34:09 +04:00
__u64 cmdbufs ;
2018-05-16 17:43:11 +03:00
/**
* @ relocs :
*
* A pointer to an array of & struct drm_tegra_reloc structures that
* specify the relocations that need to be performed before executing
* this job . The number of elements in the array must be equal to the
* value given by @ num_relocs .
*/
2013-03-22 18:34:09 +04:00
__u64 relocs ;
2018-05-16 17:43:11 +03:00
/**
* @ waitchks :
*
* A pointer to an array of & struct drm_tegra_waitchk structures that
* specify the wait checks to be performed while executing this job .
* The number of elements in the array must be equal to the value
* given by @ num_waitchks .
*/
2013-03-22 18:34:09 +04:00
__u64 waitchks ;
2018-05-16 17:43:11 +03:00
/**
* @ fence :
*
* The threshold of the syncpoint associated with this job after it
* has been completed . Set by the kernel upon successful completion of
* the IOCTL . This can be used with the DRM_TEGRA_SYNCPT_WAIT IOCTL to
* wait for this job to be finished .
*/
__u32 fence ;
/**
* @ reserved :
*
* This field is reserved for future use . Must be 0.
*/
__u32 reserved [ 5 ] ;
2013-03-22 18:34:09 +04:00
} ;
2014-06-03 16:56:57 +04:00
# define DRM_TEGRA_GEM_TILING_MODE_PITCH 0
# define DRM_TEGRA_GEM_TILING_MODE_TILED 1
# define DRM_TEGRA_GEM_TILING_MODE_BLOCK 2
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_gem_set_tiling - parameters for the set tiling IOCTL
*/
2014-06-03 16:56:57 +04:00
struct drm_tegra_gem_set_tiling {
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* Handle to the GEM object for which to set the tiling parameters .
*/
2014-06-03 16:56:57 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ mode :
*
* The tiling mode to set . Must be one of :
*
* DRM_TEGRA_GEM_TILING_MODE_PITCH
* pitch linear format
*
* DRM_TEGRA_GEM_TILING_MODE_TILED
* 16 x16 tiling format
*
* DRM_TEGRA_GEM_TILING_MODE_BLOCK
* 16 Bx2 tiling format
*/
2014-06-03 16:56:57 +04:00
__u32 mode ;
2018-05-16 17:43:11 +03:00
/**
* @ value :
*
* The value to set for the tiling mode parameter .
*/
2014-06-03 16:56:57 +04:00
__u32 value ;
2018-05-16 17:43:11 +03:00
/**
* @ pad :
*
* Structure padding that may be used in the future . Must be 0.
*/
2014-06-03 16:56:57 +04:00
__u32 pad ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_gem_get_tiling - parameters for the get tiling IOCTL
*/
2014-06-03 16:56:57 +04:00
struct drm_tegra_gem_get_tiling {
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* Handle to the GEM object for which to query the tiling parameters .
*/
2014-06-03 16:56:57 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ mode :
*
* The tiling mode currently associated with the GEM object . Set by
* the kernel upon successful completion of the IOCTL .
*/
2014-06-03 16:56:57 +04:00
__u32 mode ;
2018-05-16 17:43:11 +03:00
/**
* @ value :
*
* The tiling mode parameter currently associated with the GEM object .
* Set by the kernel upon successful completion of the IOCTL .
*/
2014-06-03 16:56:57 +04:00
__u32 value ;
2018-05-16 17:43:11 +03:00
/**
* @ pad :
*
* Structure padding that may be used in the future . Must be 0.
*/
2014-06-03 16:56:57 +04:00
__u32 pad ;
} ;
2014-06-10 14:04:03 +04:00
# define DRM_TEGRA_GEM_BOTTOM_UP (1 << 0)
# define DRM_TEGRA_GEM_FLAGS (DRM_TEGRA_GEM_BOTTOM_UP)
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_gem_set_flags - parameters for the set flags IOCTL
*/
2014-06-10 14:04:03 +04:00
struct drm_tegra_gem_set_flags {
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* Handle to the GEM object for which to set the flags .
*/
2014-06-10 14:04:03 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ flags :
*
* The flags to set for the GEM object .
*/
2014-06-10 14:04:03 +04:00
__u32 flags ;
} ;
2018-05-16 17:43:11 +03:00
/**
* struct drm_tegra_gem_get_flags - parameters for the get flags IOCTL
*/
2014-06-10 14:04:03 +04:00
struct drm_tegra_gem_get_flags {
2018-05-16 17:43:11 +03:00
/**
* @ handle :
*
* Handle to the GEM object for which to query the flags .
*/
2014-06-10 14:04:03 +04:00
__u32 handle ;
2018-05-16 17:43:11 +03:00
/**
* @ flags :
*
* The flags currently associated with the GEM object . Set by the
* kernel upon successful completion of the IOCTL .
*/
2014-06-10 14:04:03 +04:00
__u32 flags ;
} ;
2013-10-14 16:21:54 +04:00
# define DRM_TEGRA_GEM_CREATE 0x00
# define DRM_TEGRA_GEM_MMAP 0x01
# define DRM_TEGRA_SYNCPT_READ 0x02
# define DRM_TEGRA_SYNCPT_INCR 0x03
# define DRM_TEGRA_SYNCPT_WAIT 0x04
2021-06-10 14:04:48 +03:00
# define DRM_TEGRA_OPEN_CHANNEL 0x05
# define DRM_TEGRA_CLOSE_CHANNEL 0x06
2013-10-14 16:21:54 +04:00
# define DRM_TEGRA_GET_SYNCPT 0x07
# define DRM_TEGRA_SUBMIT 0x08
# define DRM_TEGRA_GET_SYNCPT_BASE 0x09
2014-06-03 16:56:57 +04:00
# define DRM_TEGRA_GEM_SET_TILING 0x0a
# define DRM_TEGRA_GEM_GET_TILING 0x0b
2014-06-10 14:04:03 +04:00
# define DRM_TEGRA_GEM_SET_FLAGS 0x0c
# define DRM_TEGRA_GEM_GET_FLAGS 0x0d
2013-03-22 18:34:09 +04:00
# define DRM_IOCTL_TEGRA_GEM_CREATE DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GEM_CREATE, struct drm_tegra_gem_create)
# define DRM_IOCTL_TEGRA_GEM_MMAP DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GEM_MMAP, struct drm_tegra_gem_mmap)
# define DRM_IOCTL_TEGRA_SYNCPT_READ DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_SYNCPT_READ, struct drm_tegra_syncpt_read)
# define DRM_IOCTL_TEGRA_SYNCPT_INCR DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_SYNCPT_INCR, struct drm_tegra_syncpt_incr)
# define DRM_IOCTL_TEGRA_SYNCPT_WAIT DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_SYNCPT_WAIT, struct drm_tegra_syncpt_wait)
# define DRM_IOCTL_TEGRA_OPEN_CHANNEL DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_OPEN_CHANNEL, struct drm_tegra_open_channel)
2018-05-05 09:12:53 +03:00
# define DRM_IOCTL_TEGRA_CLOSE_CHANNEL DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_CLOSE_CHANNEL, struct drm_tegra_close_channel)
2013-03-22 18:34:09 +04:00
# define DRM_IOCTL_TEGRA_GET_SYNCPT DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GET_SYNCPT, struct drm_tegra_get_syncpt)
# define DRM_IOCTL_TEGRA_SUBMIT DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_SUBMIT, struct drm_tegra_submit)
2013-10-14 16:21:54 +04:00
# define DRM_IOCTL_TEGRA_GET_SYNCPT_BASE DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GET_SYNCPT_BASE, struct drm_tegra_get_syncpt_base)
2014-06-03 16:56:57 +04:00
# define DRM_IOCTL_TEGRA_GEM_SET_TILING DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GEM_SET_TILING, struct drm_tegra_gem_set_tiling)
# define DRM_IOCTL_TEGRA_GEM_GET_TILING DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GEM_GET_TILING, struct drm_tegra_gem_get_tiling)
2014-06-10 14:04:03 +04:00
# define DRM_IOCTL_TEGRA_GEM_SET_FLAGS DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GEM_SET_FLAGS, struct drm_tegra_gem_set_flags)
# define DRM_IOCTL_TEGRA_GEM_GET_FLAGS DRM_IOWR(DRM_COMMAND_BASE + DRM_TEGRA_GEM_GET_FLAGS, struct drm_tegra_gem_get_flags)
2013-03-22 18:34:09 +04:00
2021-06-10 14:04:48 +03:00
/* New Tegra DRM UAPI */
/*
* Reported by the driver in the ` capabilities ` field .
*
* DRM_TEGRA_CHANNEL_CAP_CACHE_COHERENT : If set , the engine is cache coherent
* with regard to the system memory .
*/
# define DRM_TEGRA_CHANNEL_CAP_CACHE_COHERENT (1 << 0)
struct drm_tegra_channel_open {
/**
* @ host1x_class : [ in ]
*
* Host1x class of the engine that will be programmed using this
* channel .
*/
__u32 host1x_class ;
/**
* @ flags : [ in ]
*
* Flags .
*/
__u32 flags ;
/**
* @ context : [ out ]
*
* Opaque identifier corresponding to the opened channel .
*/
__u32 context ;
/**
* @ version : [ out ]
*
* Version of the engine hardware . This can be used by userspace
* to determine how the engine needs to be programmed .
*/
__u32 version ;
/**
* @ capabilities : [ out ]
*
* Flags describing the hardware capabilities .
*/
__u32 capabilities ;
__u32 padding ;
} ;
struct drm_tegra_channel_close {
/**
* @ context : [ in ]
*
* Identifier of the channel to close .
*/
__u32 context ;
__u32 padding ;
} ;
/*
* Mapping flags that can be used to influence how the mapping is created .
*
* DRM_TEGRA_CHANNEL_MAP_READ : create mapping that allows HW read access
* DRM_TEGRA_CHANNEL_MAP_WRITE : create mapping that allows HW write access
*/
# define DRM_TEGRA_CHANNEL_MAP_READ (1 << 0)
# define DRM_TEGRA_CHANNEL_MAP_WRITE (1 << 1)
# define DRM_TEGRA_CHANNEL_MAP_READ_WRITE (DRM_TEGRA_CHANNEL_MAP_READ | \
DRM_TEGRA_CHANNEL_MAP_WRITE )
struct drm_tegra_channel_map {
/**
* @ context : [ in ]
*
* Identifier of the channel to which make memory available for .
*/
__u32 context ;
/**
* @ handle : [ in ]
*
* GEM handle of the memory to map .
*/
__u32 handle ;
/**
* @ flags : [ in ]
*
* Flags .
*/
__u32 flags ;
/**
* @ mapping : [ out ]
*
* Identifier corresponding to the mapping , to be used for
* relocations or unmapping later .
*/
__u32 mapping ;
} ;
struct drm_tegra_channel_unmap {
/**
* @ context : [ in ]
*
* Channel identifier of the channel to unmap memory from .
*/
__u32 context ;
/**
* @ mapping : [ in ]
*
* Mapping identifier of the memory mapping to unmap .
*/
__u32 mapping ;
} ;
/* Submission */
/**
* Specify that bit 39 of the patched - in address should be set to switch
* swizzling between Tegra and non - Tegra sector layout on systems that store
* surfaces in system memory in non - Tegra sector layout .
*/
# define DRM_TEGRA_SUBMIT_RELOC_SECTOR_LAYOUT (1 << 0)
struct drm_tegra_submit_buf {
/**
* @ mapping : [ in ]
*
* Identifier of the mapping to use in the submission .
*/
__u32 mapping ;
/**
* @ flags : [ in ]
*
* Flags .
*/
__u32 flags ;
/**
* Information for relocation patching .
*/
struct {
/**
* @ target_offset : [ in ]
*
* Offset from the start of the mapping of the data whose
* address is to be patched into the gather .
*/
__u64 target_offset ;
/**
* @ gather_offset_words : [ in ]
*
* Offset in words from the start of the gather data to
* where the address should be patched into .
*/
__u32 gather_offset_words ;
/**
* @ shift : [ in ]
*
* Number of bits the address should be shifted right before
* patching in .
*/
__u32 shift ;
} reloc ;
} ;
/**
* Execute ` words ` words of Host1x opcodes specified in the ` gather_data_ptr `
* buffer . Each GATHER_UPTR command uses successive words from the buffer .
*/
# define DRM_TEGRA_SUBMIT_CMD_GATHER_UPTR 0
/**
* Wait for a syncpoint to reach a value before continuing with further
* commands .
*/
# define DRM_TEGRA_SUBMIT_CMD_WAIT_SYNCPT 1
/**
* Wait for a syncpoint to reach a value before continuing with further
* commands . The threshold is calculated relative to the start of the job .
*/
# define DRM_TEGRA_SUBMIT_CMD_WAIT_SYNCPT_RELATIVE 2
struct drm_tegra_submit_cmd_gather_uptr {
__u32 words ;
__u32 reserved [ 3 ] ;
} ;
struct drm_tegra_submit_cmd_wait_syncpt {
__u32 id ;
__u32 value ;
__u32 reserved [ 2 ] ;
} ;
struct drm_tegra_submit_cmd {
/**
* @ type : [ in ]
*
* Command type to execute . One of the DRM_TEGRA_SUBMIT_CMD *
* defines .
*/
__u32 type ;
/**
* @ flags : [ in ]
*
* Flags .
*/
__u32 flags ;
union {
struct drm_tegra_submit_cmd_gather_uptr gather_uptr ;
struct drm_tegra_submit_cmd_wait_syncpt wait_syncpt ;
__u32 reserved [ 4 ] ;
} ;
} ;
struct drm_tegra_submit_syncpt {
/**
* @ id : [ in ]
*
* ID of the syncpoint that the job will increment .
*/
__u32 id ;
/**
* @ flags : [ in ]
*
* Flags .
*/
__u32 flags ;
/**
* @ increments : [ in ]
*
* Number of times the job will increment this syncpoint .
*/
__u32 increments ;
/**
* @ value : [ out ]
*
* Value the syncpoint will have once the job has completed all
* its specified syncpoint increments .
*
* Note that the kernel may increment the syncpoint before or after
* the job . These increments are not reflected in this field .
*
* If the job hangs or times out , not all of the increments may
* get executed .
*/
__u32 value ;
} ;
struct drm_tegra_channel_submit {
/**
* @ context : [ in ]
*
* Identifier of the channel to submit this job to .
*/
__u32 context ;
/**
* @ num_bufs : [ in ]
*
* Number of elements in the ` bufs_ptr ` array .
*/
__u32 num_bufs ;
/**
* @ num_cmds : [ in ]
*
* Number of elements in the ` cmds_ptr ` array .
*/
__u32 num_cmds ;
/**
* @ gather_data_words : [ in ]
*
* Number of 32 - bit words in the ` gather_data_ptr ` array .
*/
__u32 gather_data_words ;
/**
* @ bufs_ptr : [ in ]
*
* Pointer to an array of drm_tegra_submit_buf structures .
*/
__u64 bufs_ptr ;
/**
* @ cmds_ptr : [ in ]
*
* Pointer to an array of drm_tegra_submit_cmd structures .
*/
__u64 cmds_ptr ;
/**
* @ gather_data_ptr : [ in ]
*
* Pointer to an array of Host1x opcodes to be used by GATHER_UPTR
* commands .
*/
__u64 gather_data_ptr ;
/**
* @ syncobj_in : [ in ]
*
* Handle for DRM syncobj that will be waited before submission .
* Ignored if zero .
*/
__u32 syncobj_in ;
/**
* @ syncobj_out : [ in ]
*
* Handle for DRM syncobj that will have its fence replaced with
* the job ' s completion fence . Ignored if zero .
*/
__u32 syncobj_out ;
/**
* @ syncpt_incr : [ in , out ]
*
* Information about the syncpoint the job will increment .
*/
struct drm_tegra_submit_syncpt syncpt ;
} ;
struct drm_tegra_syncpoint_allocate {
/**
* @ id : [ out ]
*
* ID of allocated syncpoint .
*/
__u32 id ;
__u32 padding ;
} ;
struct drm_tegra_syncpoint_free {
/**
* @ id : [ in ]
*
* ID of syncpoint to free .
*/
__u32 id ;
__u32 padding ;
} ;
struct drm_tegra_syncpoint_wait {
/**
* @ timeout : [ in ]
*
* Absolute timestamp at which the wait will time out .
*/
__s64 timeout_ns ;
/**
* @ id : [ in ]
*
* ID of syncpoint to wait on .
*/
__u32 id ;
/**
* @ threshold : [ in ]
*
* Threshold to wait for .
*/
__u32 threshold ;
/**
* @ value : [ out ]
*
* Value of the syncpoint upon wait completion .
*/
__u32 value ;
__u32 padding ;
} ;
# define DRM_IOCTL_TEGRA_CHANNEL_OPEN DRM_IOWR(DRM_COMMAND_BASE + 0x10, struct drm_tegra_channel_open)
# define DRM_IOCTL_TEGRA_CHANNEL_CLOSE DRM_IOWR(DRM_COMMAND_BASE + 0x11, struct drm_tegra_channel_close)
# define DRM_IOCTL_TEGRA_CHANNEL_MAP DRM_IOWR(DRM_COMMAND_BASE + 0x12, struct drm_tegra_channel_map)
# define DRM_IOCTL_TEGRA_CHANNEL_UNMAP DRM_IOWR(DRM_COMMAND_BASE + 0x13, struct drm_tegra_channel_unmap)
# define DRM_IOCTL_TEGRA_CHANNEL_SUBMIT DRM_IOWR(DRM_COMMAND_BASE + 0x14, struct drm_tegra_channel_submit)
# define DRM_IOCTL_TEGRA_SYNCPOINT_ALLOCATE DRM_IOWR(DRM_COMMAND_BASE + 0x20, struct drm_tegra_syncpoint_allocate)
# define DRM_IOCTL_TEGRA_SYNCPOINT_FREE DRM_IOWR(DRM_COMMAND_BASE + 0x21, struct drm_tegra_syncpoint_free)
# define DRM_IOCTL_TEGRA_SYNCPOINT_WAIT DRM_IOWR(DRM_COMMAND_BASE + 0x22, struct drm_tegra_syncpoint_wait)
2016-04-07 21:35:50 +03:00
# if defined(__cplusplus)
}
# endif
2013-03-22 18:34:09 +04:00
# endif