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