/* Copyright (C) 2009 Red Hat, Inc. This software is licensed under the GNU General Public License, version 2 (GPLv2) (see COPYING for details), subject to the following clarification. With respect to binaries built using the Microsoft(R) Windows Driver Kit (WDK), GPLv2 does not extend to any code contained in or derived from the WDK ("WDK Code"). As to WDK Code, by using or distributing such binaries you agree to be bound by the Microsoft Software License Terms for the WDK. All WDK Code is considered by the GPLv2 licensors to qualify for the special exception stated in section 3 of GPLv2 (commonly known as the system library exception). There is NO WARRANTY for this software, express or implied, including the implied warranties of NON-INFRINGEMENT, TITLE, MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. */ #ifndef _H_QXL_DRIVER #define _H_QXL_DRIVER #include #include #if (WINVER < 0x0501) #include "wdmhelper.h" #endif enum { FIRST_AVIL_IOCTL_FUNC = 0x800, QXL_GET_INFO_FUNC = FIRST_AVIL_IOCTL_FUNC, QXL_SET_CUSTOM_DISPLAY }; #define IOCTL_QXL_GET_INFO \ CTL_CODE(FILE_DEVICE_VIDEO, QXL_GET_INFO_FUNC, METHOD_BUFFERED, FILE_ANY_ACCESS) #define IOCTL_QXL_SET_CUSTOM_DISPLAY \ CTL_CODE(FILE_DEVICE_VIDEO, QXL_SET_CUSTOM_DISPLAY, METHOD_BUFFERED, FILE_ANY_ACCESS) #define QXL_DRIVER_INFO_VERSION 3 typedef struct MemSlot { UINT8 generation; UINT64 start_phys_addr; UINT64 end_phys_addr; UINT64 start_virt_addr; UINT64 end_virt_addr; } MemSlot; typedef struct QXLDriverInfo { UINT32 version; QXLCommandRing *cmd_ring; QXLCursorRing *cursor_ring; QXLReleaseRing *release_ring; PUCHAR notify_cmd_port; PUCHAR notify_cursor_port; PUCHAR notify_oom_port; PUCHAR update_area_async_port; PUCHAR memslot_add_async_port; PUCHAR create_primary_async_port; PUCHAR destroy_primary_async_port; PUCHAR destroy_surface_async_port; PUCHAR destroy_all_surfaces_async_port; PUCHAR flush_surfaces_async_port; PUCHAR flush_release_port; PEVENT display_event; PEVENT cursor_event; PEVENT sleep_event; PEVENT io_cmd_event; UINT32 num_pages; void *io_pages_virt; UINT64 io_pages_phys; UINT8 *surface0_area; UINT32 surface0_area_size; UINT32 *update_id; UINT32 *compression_level; PUCHAR update_area_port; QXLRect *update_area; UINT32 *update_surface; UINT32 *mm_clock; PUCHAR log_port; UINT8 *log_buf; UINT32 *log_level; #if (WINVER < 0x0501) PQXLWaitForEvent WaitForEvent; #endif UINT8 num_mem_slot; UINT8 main_mem_slot_id; UINT8 slot_id_bits; UINT8 slot_gen_bits; UINT8 *slots_generation; UINT64 *ram_slot_start; UINT64 *ram_slot_end; MemSlot main_mem_slot; PUCHAR destroy_surface_wait_port; PUCHAR create_primary_port; PUCHAR destroy_primary_port; PUCHAR memslot_add_port; PUCHAR memslot_del_port; PUCHAR destroy_all_surfaces_port; UCHAR pci_revision; UINT32 dev_id; QXLSurfaceCreate *primary_surface_create; UINT32 n_surfaces; UINT64 fb_phys; UINT8 create_non_primary_surfaces; } QXLDriverInfo; #endif