1655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/****************************************************************************
2655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ****************************************************************************
3655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***
4655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   This header was automatically generated from a Linux kernel header
5655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   of the same name, to make information necessary for userspace to
6655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   call into the kernel available to libc.  It contains only constants,
7655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   structures, and macros generated from the original header, and thus,
8655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   contains no copyrightable information.
9655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***
10655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   To edit the content of this header, modify the corresponding
11655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   source file (e.g. under external/kernel-headers/original/) then
12655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   run bionic/libc/kernel/tools/update_all.py
13655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***
14655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   Any manual change here will be lost the next time this script will
15655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***   be run. You've been warned!
16655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ***
17655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ****************************************************************************
18655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng ****************************************************************************/
19655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#ifndef QXL_DRM_H
20655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_DRM_H
21655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#include <stddef.h>
22655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#include "drm/drm.h"
23655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
24655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_GEM_DOMAIN_CPU 0
25655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_GEM_DOMAIN_VRAM 1
26655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_GEM_DOMAIN_SURFACE 2
27655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_QXL_ALLOC 0x00
28655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
29655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_QXL_MAP 0x01
30655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_QXL_EXECBUFFER 0x02
31655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_QXL_UPDATE_AREA 0x03
32655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_QXL_GETPARAM 0x04
33655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
34655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_QXL_CLIENTCAP 0x05
35655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_QXL_ALLOC_SURF 0x06
36655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_alloc {
37655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t size;
38655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
39655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t handle;
40655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
41655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_map {
42655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t offset;
43655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
44655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t handle;
45655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t pad;
46655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
47655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_RELOC_TYPE_BO 1
48655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
49655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_RELOC_TYPE_SURF 2
50655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_reloc {
51655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t src_offset;
52655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t dst_offset;
53655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
54655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t src_handle;
55655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t dst_handle;
56655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t reloc_type;
57655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t pad;
58655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
59655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
60655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_command {
61655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t __user command;
62655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t __user relocs;
63655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
64655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t type;
65655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t command_size;
66655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t relocs_num;
67655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t pad;
68655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
69655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
70655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_execbuffer {
71655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t flags;
72655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t commands_num;
73655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
74655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t __user commands;
75655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
76655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_update_area {
77655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t handle;
78655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
79655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t top;
80655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t left;
81655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t bottom;
82655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t right;
83655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
84655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t pad;
85655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
86655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_PARAM_NUM_SURFACES 1
87655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define QXL_PARAM_MAX_RELOCS 2
88655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
89655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_getparam {
90655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t param;
91655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint64_t value;
92655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
93655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
94655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_clientcap {
95655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t index;
96655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t pad;
97655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
98655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
99655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Chengstruct drm_qxl_alloc_surf {
100655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t format;
101655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t width;
102655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t height;
103655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
104655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng int32_t stride;
105655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t handle;
106655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng uint32_t pad;
107655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng};
108655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
109655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_IOCTL_QXL_ALLOC   DRM_IOWR(DRM_COMMAND_BASE + DRM_QXL_ALLOC, struct drm_qxl_alloc)
110655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_IOCTL_QXL_MAP   DRM_IOWR(DRM_COMMAND_BASE + DRM_QXL_MAP, struct drm_qxl_map)
111655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_IOCTL_QXL_EXECBUFFER   DRM_IOW(DRM_COMMAND_BASE + DRM_QXL_EXECBUFFER,  struct drm_qxl_execbuffer)
112655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_IOCTL_QXL_UPDATE_AREA   DRM_IOW(DRM_COMMAND_BASE + DRM_QXL_UPDATE_AREA,  struct drm_qxl_update_area)
113655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
114655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_IOCTL_QXL_GETPARAM   DRM_IOWR(DRM_COMMAND_BASE + DRM_QXL_GETPARAM,  struct drm_qxl_getparam)
115655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_IOCTL_QXL_CLIENTCAP   DRM_IOW(DRM_COMMAND_BASE + DRM_QXL_CLIENTCAP,  struct drm_qxl_clientcap)
116655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#define DRM_IOCTL_QXL_ALLOC_SURF   DRM_IOWR(DRM_COMMAND_BASE + DRM_QXL_ALLOC_SURF,  struct drm_qxl_alloc_surf)
117655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng#endif
118655a7c081f83b8351ed5f11a6c6accd9458293a8Ben Cheng/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */
119