1/*
2 * This header was generated from the Linux kernel headers by update_headers.py,
3 * to provide necessary information from kernel to userspace, such as constants,
4 * structures, and macros, and thus, contains no copyrightable information.
5 */
6#ifndef __MSM_DRM_H__
7#define __MSM_DRM_H__
8#include "drm.h"
9#if defined(__cplusplus)
10extern "C" {
11#endif
12#define MSM_PIPE_NONE        0x00
13#define MSM_PIPE_2D0         0x01
14#define MSM_PIPE_2D1         0x02
15#define MSM_PIPE_3D0         0x10
16#define MSM_PIPE_ID_MASK     0xffff
17#define MSM_PIPE_ID(x)       ((x) & MSM_PIPE_ID_MASK)
18#define MSM_PIPE_FLAGS(x)    ((x) & ~MSM_PIPE_ID_MASK)
19struct drm_msm_timespec {
20	__s64 tv_sec;
21	__s64 tv_nsec;
22};
23#define MSM_PARAM_GPU_ID     0x01
24#define MSM_PARAM_GMEM_SIZE  0x02
25#define MSM_PARAM_CHIP_ID    0x03
26#define MSM_PARAM_MAX_FREQ   0x04
27#define MSM_PARAM_TIMESTAMP  0x05
28#define MSM_PARAM_GMEM_BASE  0x06
29#define MSM_PARAM_NR_RINGS   0x07
30struct drm_msm_param {
31	__u32 pipe;
32	__u32 param;
33	__u64 value;
34};
35#define MSM_BO_SCANOUT       0x00000001
36#define MSM_BO_GPU_READONLY  0x00000002
37#define MSM_BO_CACHE_MASK    0x000f0000
38#define MSM_BO_CACHED        0x00010000
39#define MSM_BO_WC            0x00020000
40#define MSM_BO_UNCACHED      0x00040000
41#define MSM_BO_FLAGS         (MSM_BO_SCANOUT | \
42                              MSM_BO_GPU_READONLY | \
43                              MSM_BO_CACHED | \
44                              MSM_BO_WC | \
45                              MSM_BO_UNCACHED)
46struct drm_msm_gem_new {
47	__u64 size;
48	__u32 flags;
49	__u32 handle;
50};
51#define MSM_INFO_IOVA	0x01
52#define MSM_INFO_FLAGS (MSM_INFO_IOVA)
53struct drm_msm_gem_info {
54	__u32 handle;
55	__u32 flags;
56	__u64 offset;
57};
58#define MSM_PREP_READ        0x01
59#define MSM_PREP_WRITE       0x02
60#define MSM_PREP_NOSYNC      0x04
61#define MSM_PREP_FLAGS       (MSM_PREP_READ | MSM_PREP_WRITE | MSM_PREP_NOSYNC)
62struct drm_msm_gem_cpu_prep {
63	__u32 handle;
64	__u32 op;
65	struct drm_msm_timespec timeout;
66};
67struct drm_msm_gem_cpu_fini {
68	__u32 handle;
69};
70struct drm_msm_gem_submit_reloc {
71	__u32 submit_offset;
72	__u32 or;
73	__s32 shift;
74	__u32 reloc_idx;
75	__u64 reloc_offset;
76};
77#define MSM_SUBMIT_CMD_BUF             0x0001
78#define MSM_SUBMIT_CMD_IB_TARGET_BUF   0x0002
79#define MSM_SUBMIT_CMD_CTX_RESTORE_BUF 0x0003
80struct drm_msm_gem_submit_cmd {
81	__u32 type;
82	__u32 submit_idx;
83	__u32 submit_offset;
84	__u32 size;
85	__u32 pad;
86	__u32 nr_relocs;
87	__u64 relocs;
88};
89#define MSM_SUBMIT_BO_READ             0x0001
90#define MSM_SUBMIT_BO_WRITE            0x0002
91#define MSM_SUBMIT_BO_FLAGS            (MSM_SUBMIT_BO_READ | MSM_SUBMIT_BO_WRITE)
92struct drm_msm_gem_submit_bo {
93	__u32 flags;
94	__u32 handle;
95	__u64 presumed;
96};
97#define MSM_SUBMIT_NO_IMPLICIT   0x80000000
98#define MSM_SUBMIT_FENCE_FD_IN   0x40000000
99#define MSM_SUBMIT_FENCE_FD_OUT  0x20000000
100#define MSM_SUBMIT_SUDO          0x10000000
101#define MSM_SUBMIT_FLAGS                ( \
102		MSM_SUBMIT_NO_IMPLICIT   | \
103		MSM_SUBMIT_FENCE_FD_IN   | \
104		MSM_SUBMIT_FENCE_FD_OUT  | \
105		MSM_SUBMIT_SUDO          | \
106		0)
107struct drm_msm_gem_submit {
108	__u32 flags;
109	__u32 fence;
110	__u32 nr_bos;
111	__u32 nr_cmds;
112	__u64 bos;
113	__u64 cmds;
114	__s32 fence_fd;
115	__u32 queueid;
116};
117struct drm_msm_wait_fence {
118	__u32 fence;
119	__u32 pad;
120	struct drm_msm_timespec timeout;
121	__u32 queueid;
122};
123#define MSM_MADV_WILLNEED 0
124#define MSM_MADV_DONTNEED 1
125#define __MSM_MADV_PURGED 2
126struct drm_msm_gem_madvise {
127	__u32 handle;
128	__u32 madv;
129	__u32 retained;
130};
131#define MSM_SUBMITQUEUE_FLAGS (0)
132struct drm_msm_submitqueue {
133	__u32 flags;
134	__u32 prio;
135	__u32 id;
136};
137#define DRM_MSM_GET_PARAM              0x00
138#define DRM_MSM_GEM_NEW                0x02
139#define DRM_MSM_GEM_INFO               0x03
140#define DRM_MSM_GEM_CPU_PREP           0x04
141#define DRM_MSM_GEM_CPU_FINI           0x05
142#define DRM_MSM_GEM_SUBMIT             0x06
143#define DRM_MSM_WAIT_FENCE             0x07
144#define DRM_MSM_GEM_MADVISE            0x08
145#define DRM_MSM_SUBMITQUEUE_NEW        0x0A
146#define DRM_MSM_SUBMITQUEUE_CLOSE      0x0B
147#define DRM_IOCTL_MSM_GET_PARAM        DRM_IOWR(DRM_COMMAND_BASE + DRM_MSM_GET_PARAM, struct drm_msm_param)
148#define DRM_IOCTL_MSM_GEM_NEW          DRM_IOWR(DRM_COMMAND_BASE + DRM_MSM_GEM_NEW, struct drm_msm_gem_new)
149#define DRM_IOCTL_MSM_GEM_INFO         DRM_IOWR(DRM_COMMAND_BASE + DRM_MSM_GEM_INFO, struct drm_msm_gem_info)
150#define DRM_IOCTL_MSM_GEM_CPU_PREP     DRM_IOW (DRM_COMMAND_BASE + DRM_MSM_GEM_CPU_PREP, struct drm_msm_gem_cpu_prep)
151#define DRM_IOCTL_MSM_GEM_CPU_FINI     DRM_IOW (DRM_COMMAND_BASE + DRM_MSM_GEM_CPU_FINI, struct drm_msm_gem_cpu_fini)
152#define DRM_IOCTL_MSM_GEM_SUBMIT       DRM_IOWR(DRM_COMMAND_BASE + DRM_MSM_GEM_SUBMIT, struct drm_msm_gem_submit)
153#define DRM_IOCTL_MSM_WAIT_FENCE       DRM_IOW (DRM_COMMAND_BASE + DRM_MSM_WAIT_FENCE, struct drm_msm_wait_fence)
154#define DRM_IOCTL_MSM_GEM_MADVISE      DRM_IOWR(DRM_COMMAND_BASE + DRM_MSM_GEM_MADVISE, struct drm_msm_gem_madvise)
155#define DRM_IOCTL_MSM_SUBMITQUEUE_NEW    DRM_IOWR(DRM_COMMAND_BASE + DRM_MSM_SUBMITQUEUE_NEW, struct drm_msm_submitqueue)
156#define DRM_IOCTL_MSM_SUBMITQUEUE_CLOSE  DRM_IOW (DRM_COMMAND_BASE + DRM_MSM_SUBMITQUEUE_CLOSE, __u32)
157#if defined(__cplusplus)
158}
159#endif
160#endif
161