œ_#ÁÕ§TE NAŒ“KeÉ:”(åŽÖJÞùY’‚ñùž7; «]Û ý`8g“¯B© jdÖÖ¸ðzœ¸¦4Ç3Kó^(ÍÖ¼ Õ€pvìwšõB4df$Èü^0˜…åÌC$#2FŽÑ§±¦ÛZ/÷š&m£ñzÒÖ ’.Î]!Î;ƒ(Õ–¢d/—#Kª+tZyuÏB>NÛÖ†(¸ŒSà'³„Y˜´-_•¦¼´˜OlNK§¶ÒàŠˆTHµƒeTPå·fïM’…þuÏÍüp6دªE£åü‡ZØ'CKF#â«;‹eyO Qp„†l"ö1èíÙP ÏŒúl! BÝ2ñª•_VÁÉ÷3eu`–F¸ìI--ö<¿žë¯4õ캿¢)34Å{wMÉ2ÆÖFŸ¥`e9Ú¶¸P‡.”FÔï rY ‚²ÈTB,{ÛœéJ}«àQ4¹0Rû4D‚B§S‘ dO•v¾„™Sן¯3FeŸ™«+ÓâwH dÕÛÌì·P4ë&¥#rÜÉ Ù¦ê†ý·xòqk¯2,¹§™E\ék‚×Sá”ÚºÙ⺷ö£6…à ʾ qSá³Å|;àû}4Ÿ($â¹VY~óÍ!èÜÒŒËX½Ù1j‚VíÍŸš³+œ]«½g{_{/vµ½\¢¶vÉWKÿ:ñám½ ¥ S²x‘t ŽšÝÙÿÀÇ^ný PK IW™k‚½÷ á _rels/.relsUT dìd dìd dìd’ÏNÃ0‡ï{ŠÈ÷ÕÝ@¡¥» ¤Ý*`%îÑ&QâÁöö‚J£ì°cœŸ¿|¶²ÙÆA½rL½wVE Šñ¶w†çúay * 9Kƒw¬áÈ ¶ÕbóÄIîI]’Ê—4t"á1™ŽGJ…ìòMããH’±Å@æ…ZÆuYÞ`üÍ€jÂT;«!îì T}|Û7MoøÞ›ýÈNN<|v–í2ÄÜ¥ÏèšbË¢Ázó˜Ë )„"£OÏ7ú{ZYÈ’yÞç#1'tuÉM?6o>Z´_å9›ëKÚ˜}?þ³žÏÌ·N>fµx PK IWª½e ¢ U € word/document.xmlUT dìdPK IWþË3” z €J¢ word/settings.xmlUT dìdPK IWC‡{š' ƒ €¤ docProps/custom.xmlUT dìdPK IW츱=Œ €‡¥ [Content_Types].xmlUT dìdPK IWV%ë±" €U§ docProps/app.xmlUT dìdPK IW€RŒ 3 €¶¨ docProps/core.xmlUT dìdPK IWkòDn ô €ª word/_rels/document.xml.relsUT dìdPK IW;$î €Î« word/fontTable.xmlUT dìdPK IW+åäz] ÷. €ý¬ word/numbering.xmlUT dìdPK IW¤2×r- ¿ €›° word/styles.xmlUT dìdPK IWMFÒ ø €´ word/header1.xmlUT dìdPK IWF— T e €· word/media/image1.jpegUT dìdPK IW!Yéáå €°Ë word/media/image2.pngUT dìdPK IW°Àºë ú €ÙÌ word/media/image3.pngUT dìdPK IW$“†ª L €Î word/footer1.xmlUT dìdPK IWzaGôM €ñÑ word/footer2.xmlUT dìdPK IW–µâº P €}Õ word/theme/theme1.xmlUT dìdPK IW™k‚½÷ á €{Û _rels/.relsUT PK ! bîh^ [Content_Types].xml ¢( ¬”ËNÃ0E÷HüCä-Jܲ@5í‚Ç*Q>Àēƪc[žiiÿž‰ûB¡j7±ÏÜ{2ñÍh²nm¶‚ˆÆ»R‹ÈÀU^7/ÅÇì%¿’rZYï @1__f› ˜q·ÃR4DáAJ¬h>€ãÚÇV߯¹ªZ¨9ÈÛÁàNVÞ8Ê©ÓãÑÔji){^óã-I‹"{Üv^¥P!XS)bR¹rú—K¾s(¸3Õ`cÞ0†½ÝÎß»¾7M4²©ŠôªZÆk+¿|\|z¿(Ž‹ôPúº6h_-[ž@!‚ÒØ Pk‹´2nÏ}Ä?£LËð Ýû%áÄßdºždN"m,à¥ÇžDO97*‚~§Èɸ8ÀOíc|n¦Ñ äEøÿöéºóÀBÉÀ!$}‡íàÈé;{ìÐå[ƒîñ–é2þ ÿÿ PK ! µU0#ô L _rels/.rels ¢( ¬’MOÃ0†ïHü‡È÷ÕÝBKwAH»!T~€Iܵ£$Ý¿'TƒG½~üÊÛÝ<êÈ!öâ4¬‹;#¶w†—úqu *&r–Fq¬áÄvÕõÕö™GJy(v½*«¸¨¡KÉß#FÓñD±Ï.W ¥†=™ZÆMYÞbø®ÕBS톰·7 ê“Ï›×–¦é ?ˆ9LìÒ™ÈsbgÙ®|Èl!õùUSh9i°bžr:"y_dlÀóD›¿ý|-NœÈR"4ø2ÏGÇ% õZ´4ñËyÄ7 ëÈðÉ‚‹¨Þ ÿÿ PK ! Q48wÛ — xl/workbook.xml¤UÙnâ0}iþ!cñ‡ *–¢AšVU×$dC¬&vÆv UÕŸë@XÊK§/¹p|Žï¹N÷b“¥Ö •Š ÞC¸î"‹òHÄŒ¯zèá~b·‘¥4á1I§=ôJºèÿüÑ] ù¼âÙ ®z(Ñ:GE ͈ª‹œrˆ,…̈†©\9*—”Ä*¡Tg©ã¹nàd„q´Eåg0ÄrÉ":Q‘Q®· ’¦D}•°\UhYô¸ŒÈç"·#‘å ±`)Ó¯%(²²(œ®¸d‘‚ì nZ w v¡ñª• t¶TÆ")”Xê:@;[Ògú±ë`|²›ó=ø’ïHúÂL÷¬dðEVÁ+8€a÷Ûh¬Uz%„Íû"ZsÏÍCýî’¥ôqk]‹äù5ÉL¦Rd¥Dé˘i÷P ¦bM/|dÉ",…¨çãFNoçiûéë>aêiçsó#ðÄ ÕTr¢éHp ÜIú®ÝJìQ"ÀÜÖ-ý[0I¡¦ÀZ Z…d¡nˆN¬B¦=4 g %PDF-1.4 %âãÏÓ 3 0 obj << /Linearized 1 /L 422775 ÿØÿà JFIF ÿÛ C ÿÛ C ÿÀ X" ÿÄ ÿÄ H !1A"Qaq2‘¡#±ÁBRÑ3Cbrá$S‚¢²ð4ñ%6DTc’ÂsÿÄ ÿÄ = !1AQ"aq‘Á2R¡±BÑð#3br’²4á$‚¢ÂñÿÚ ? áHBßÝ`„! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! ! stream
/*
* This file generated automatically from dri2.xml by c_client.py.
* Edit at your peril.
*/
/**
* @defgroup XCB_DRI2_API XCB DRI2 API
* @brief DRI2 XCB Protocol Implementation.
* @{
**/
#ifndef __DRI2_H
#define __DRI2_H
#include "xcb.h"
#include "xproto.h"
#ifdef __cplusplus
extern "C" {
#endif
#define XCB_DRI2_MAJOR_VERSION 1
#define XCB_DRI2_MINOR_VERSION 4
extern xcb_extension_t xcb_dri2_id;
typedef enum xcb_dri2_attachment_t {
XCB_DRI2_ATTACHMENT_BUFFER_FRONT_LEFT = 0,
XCB_DRI2_ATTACHMENT_BUFFER_BACK_LEFT = 1,
XCB_DRI2_ATTACHMENT_BUFFER_FRONT_RIGHT = 2,
XCB_DRI2_ATTACHMENT_BUFFER_BACK_RIGHT = 3,
XCB_DRI2_ATTACHMENT_BUFFER_DEPTH = 4,
XCB_DRI2_ATTACHMENT_BUFFER_STENCIL = 5,
XCB_DRI2_ATTACHMENT_BUFFER_ACCUM = 6,
XCB_DRI2_ATTACHMENT_BUFFER_FAKE_FRONT_LEFT = 7,
XCB_DRI2_ATTACHMENT_BUFFER_FAKE_FRONT_RIGHT = 8,
XCB_DRI2_ATTACHMENT_BUFFER_DEPTH_STENCIL = 9,
XCB_DRI2_ATTACHMENT_BUFFER_HIZ = 10
} xcb_dri2_attachment_t;
typedef enum xcb_dri2_driver_type_t {
XCB_DRI2_DRIVER_TYPE_DRI = 0,
XCB_DRI2_DRIVER_TYPE_VDPAU = 1
} xcb_dri2_driver_type_t;
typedef enum xcb_dri2_event_type_t {
XCB_DRI2_EVENT_TYPE_EXCHANGE_COMPLETE = 1,
XCB_DRI2_EVENT_TYPE_BLIT_COMPLETE = 2,
XCB_DRI2_EVENT_TYPE_FLIP_COMPLETE = 3
} xcb_dri2_event_type_t;
/**
* @brief xcb_dri2_dri2_buffer_t
**/
typedef struct xcb_dri2_dri2_buffer_t {
uint32_t attachment;
uint32_t name;
uint32_t pitch;
uint32_t cpp;
uint32_t flags;
} xcb_dri2_dri2_buffer_t;
/**
* @brief xcb_dri2_dri2_buffer_iterator_t
**/
typedef struct xcb_dri2_dri2_buffer_iterator_t {
xcb_dri2_dri2_buffer_t *data;
int rem;
int index;
} xcb_dri2_dri2_buffer_iterator_t;
/**
* @brief xcb_dri2_attach_format_t
**/
typedef struct xcb_dri2_attach_format_t {
uint32_t attachment;
uint32_t format;
} xcb_dri2_attach_format_t;
/**
* @brief xcb_dri2_attach_format_iterator_t
**/
typedef struct xcb_dri2_attach_format_iterator_t {
xcb_dri2_attach_format_t *data;
int rem;
int index;
} xcb_dri2_attach_format_iterator_t;
/**
* @brief xcb_dri2_query_version_cookie_t
**/
typedef struct xcb_dri2_query_version_cookie_t {
unsigned int sequence;
} xcb_dri2_query_version_cookie_t;
/** Opcode for xcb_dri2_query_version. */
#define XCB_DRI2_QUERY_VERSION 0
/**
* @brief xcb_dri2_query_version_request_t
**/
typedef struct xcb_dri2_query_version_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
uint32_t major_version;
uint32_t minor_version;
} xcb_dri2_query_version_request_t;
/**
* @brief xcb_dri2_query_version_reply_t
**/
typedef struct xcb_dri2_query_version_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t major_version;
uint32_t minor_version;
} xcb_dri2_query_version_reply_t;
/**
* @brief xcb_dri2_connect_cookie_t
**/
typedef struct xcb_dri2_connect_cookie_t {
unsigned int sequence;
} xcb_dri2_connect_cookie_t;
/** Opcode for xcb_dri2_connect. */
#define XCB_DRI2_CONNECT 1
/**
* @brief xcb_dri2_connect_request_t
**/
typedef struct xcb_dri2_connect_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_window_t window;
uint32_t driver_type;
} xcb_dri2_connect_request_t;
/**
* @brief xcb_dri2_connect_reply_t
**/
typedef struct xcb_dri2_connect_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t driver_name_length;
uint32_t device_name_length;
uint8_t pad1[16];
} xcb_dri2_connect_reply_t;
/**
* @brief xcb_dri2_authenticate_cookie_t
**/
typedef struct xcb_dri2_authenticate_cookie_t {
unsigned int sequence;
} xcb_dri2_authenticate_cookie_t;
/** Opcode for xcb_dri2_authenticate. */
#define XCB_DRI2_AUTHENTICATE 2
/**
* @brief xcb_dri2_authenticate_request_t
**/
typedef struct xcb_dri2_authenticate_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_window_t window;
uint32_t magic;
} xcb_dri2_authenticate_request_t;
/**
* @brief xcb_dri2_authenticate_reply_t
**/
typedef struct xcb_dri2_authenticate_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t authenticated;
} xcb_dri2_authenticate_reply_t;
/** Opcode for xcb_dri2_create_drawable. */
#define XCB_DRI2_CREATE_DRAWABLE 3
/**
* @brief xcb_dri2_create_drawable_request_t
**/
typedef struct xcb_dri2_create_drawable_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
} xcb_dri2_create_drawable_request_t;
/** Opcode for xcb_dri2_destroy_drawable. */
#define XCB_DRI2_DESTROY_DRAWABLE 4
/**
* @brief xcb_dri2_destroy_drawable_request_t
**/
typedef struct xcb_dri2_destroy_drawable_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
} xcb_dri2_destroy_drawable_request_t;
/**
* @brief xcb_dri2_get_buffers_cookie_t
**/
typedef struct xcb_dri2_get_buffers_cookie_t {
unsigned int sequence;
} xcb_dri2_get_buffers_cookie_t;
/** Opcode for xcb_dri2_get_buffers. */
#define XCB_DRI2_GET_BUFFERS 5
/**
* @brief xcb_dri2_get_buffers_request_t
**/
typedef struct xcb_dri2_get_buffers_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t count;
} xcb_dri2_get_buffers_request_t;
/**
* @brief xcb_dri2_get_buffers_reply_t
**/
typedef struct xcb_dri2_get_buffers_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t width;
uint32_t height;
uint32_t count;
uint8_t pad1[12];
} xcb_dri2_get_buffers_reply_t;
/**
* @brief xcb_dri2_copy_region_cookie_t
**/
typedef struct xcb_dri2_copy_region_cookie_t {
unsigned int sequence;
} xcb_dri2_copy_region_cookie_t;
/** Opcode for xcb_dri2_copy_region. */
#define XCB_DRI2_COPY_REGION 6
/**
* @brief xcb_dri2_copy_region_request_t
**/
typedef struct xcb_dri2_copy_region_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t region;
uint32_t dest;
uint32_t src;
} xcb_dri2_copy_region_request_t;
/**
* @brief xcb_dri2_copy_region_reply_t
**/
typedef struct xcb_dri2_copy_region_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
} xcb_dri2_copy_region_reply_t;
/**
* @brief xcb_dri2_get_buffers_with_format_cookie_t
**/
typedef struct xcb_dri2_get_buffers_with_format_cookie_t {
unsigned int sequence;
} xcb_dri2_get_buffers_with_format_cookie_t;
/** Opcode for xcb_dri2_get_buffers_with_format. */
#define XCB_DRI2_GET_BUFFERS_WITH_FORMAT 7
/**
* @brief xcb_dri2_get_buffers_with_format_request_t
**/
typedef struct xcb_dri2_get_buffers_with_format_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t count;
} xcb_dri2_get_buffers_with_format_request_t;
/**
* @brief xcb_dri2_get_buffers_with_format_reply_t
**/
typedef struct xcb_dri2_get_buffers_with_format_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t width;
uint32_t height;
uint32_t count;
uint8_t pad1[12];
} xcb_dri2_get_buffers_with_format_reply_t;
/**
* @brief xcb_dri2_swap_buffers_cookie_t
**/
typedef struct xcb_dri2_swap_buffers_cookie_t {
unsigned int sequence;
} xcb_dri2_swap_buffers_cookie_t;
/** Opcode for xcb_dri2_swap_buffers. */
#define XCB_DRI2_SWAP_BUFFERS 8
/**
* @brief xcb_dri2_swap_buffers_request_t
**/
typedef struct xcb_dri2_swap_buffers_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t target_msc_hi;
uint32_t target_msc_lo;
uint32_t divisor_hi;
uint32_t divisor_lo;
uint32_t remainder_hi;
uint32_t remainder_lo;
} xcb_dri2_swap_buffers_request_t;
/**
* @brief xcb_dri2_swap_buffers_reply_t
**/
typedef struct xcb_dri2_swap_buffers_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t swap_hi;
uint32_t swap_lo;
} xcb_dri2_swap_buffers_reply_t;
/**
* @brief xcb_dri2_get_msc_cookie_t
**/
typedef struct xcb_dri2_get_msc_cookie_t {
unsigned int sequence;
} xcb_dri2_get_msc_cookie_t;
/** Opcode for xcb_dri2_get_msc. */
#define XCB_DRI2_GET_MSC 9
/**
* @brief xcb_dri2_get_msc_request_t
**/
typedef struct xcb_dri2_get_msc_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
} xcb_dri2_get_msc_request_t;
/**
* @brief xcb_dri2_get_msc_reply_t
**/
typedef struct xcb_dri2_get_msc_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t ust_hi;
uint32_t ust_lo;
uint32_t msc_hi;
uint32_t msc_lo;
uint32_t sbc_hi;
uint32_t sbc_lo;
} xcb_dri2_get_msc_reply_t;
/**
* @brief xcb_dri2_wait_msc_cookie_t
**/
typedef struct xcb_dri2_wait_msc_cookie_t {
unsigned int sequence;
} xcb_dri2_wait_msc_cookie_t;
/** Opcode for xcb_dri2_wait_msc. */
#define XCB_DRI2_WAIT_MSC 10
/**
* @brief xcb_dri2_wait_msc_request_t
**/
typedef struct xcb_dri2_wait_msc_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t target_msc_hi;
uint32_t target_msc_lo;
uint32_t divisor_hi;
uint32_t divisor_lo;
uint32_t remainder_hi;
uint32_t remainder_lo;
} xcb_dri2_wait_msc_request_t;
/**
* @brief xcb_dri2_wait_msc_reply_t
**/
typedef struct xcb_dri2_wait_msc_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t ust_hi;
uint32_t ust_lo;
uint32_t msc_hi;
uint32_t msc_lo;
uint32_t sbc_hi;
uint32_t sbc_lo;
} xcb_dri2_wait_msc_reply_t;
/**
* @brief xcb_dri2_wait_sbc_cookie_t
**/
typedef struct xcb_dri2_wait_sbc_cookie_t {
unsigned int sequence;
} xcb_dri2_wait_sbc_cookie_t;
/** Opcode for xcb_dri2_wait_sbc. */
#define XCB_DRI2_WAIT_SBC 11
/**
* @brief xcb_dri2_wait_sbc_request_t
**/
typedef struct xcb_dri2_wait_sbc_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t target_sbc_hi;
uint32_t target_sbc_lo;
} xcb_dri2_wait_sbc_request_t;
/**
* @brief xcb_dri2_wait_sbc_reply_t
**/
typedef struct xcb_dri2_wait_sbc_reply_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint32_t length;
uint32_t ust_hi;
uint32_t ust_lo;
uint32_t msc_hi;
uint32_t msc_lo;
uint32_t sbc_hi;
uint32_t sbc_lo;
} xcb_dri2_wait_sbc_reply_t;
/** Opcode for xcb_dri2_swap_interval. */
#define XCB_DRI2_SWAP_INTERVAL 12
/**
* @brief xcb_dri2_swap_interval_request_t
**/
typedef struct xcb_dri2_swap_interval_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t interval;
} xcb_dri2_swap_interval_request_t;
/**
* @brief xcb_dri2_get_param_cookie_t
**/
typedef struct xcb_dri2_get_param_cookie_t {
unsigned int sequence;
} xcb_dri2_get_param_cookie_t;
/** Opcode for xcb_dri2_get_param. */
#define XCB_DRI2_GET_PARAM 13
/**
* @brief xcb_dri2_get_param_request_t
**/
typedef struct xcb_dri2_get_param_request_t {
uint8_t major_opcode;
uint8_t minor_opcode;
uint16_t length;
xcb_drawable_t drawable;
uint32_t param;
} xcb_dri2_get_param_request_t;
/**
* @brief xcb_dri2_get_param_reply_t
**/
typedef struct xcb_dri2_get_param_reply_t {
uint8_t response_type;
uint8_t is_param_recognized;
uint16_t sequence;
uint32_t length;
uint32_t value_hi;
uint32_t value_lo;
} xcb_dri2_get_param_reply_t;
/** Opcode for xcb_dri2_buffer_swap_complete. */
#define XCB_DRI2_BUFFER_SWAP_COMPLETE 0
/**
* @brief xcb_dri2_buffer_swap_complete_event_t
**/
typedef struct xcb_dri2_buffer_swap_complete_event_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
uint16_t event_type;
uint8_t pad1[2];
xcb_drawable_t drawable;
uint32_t ust_hi;
uint32_t ust_lo;
uint32_t msc_hi;
uint32_t msc_lo;
uint32_t sbc;
} xcb_dri2_buffer_swap_complete_event_t;
/** Opcode for xcb_dri2_invalidate_buffers. */
#define XCB_DRI2_INVALIDATE_BUFFERS 1
/**
* @brief xcb_dri2_invalidate_buffers_event_t
**/
typedef struct xcb_dri2_invalidate_buffers_event_t {
uint8_t response_type;
uint8_t pad0;
uint16_t sequence;
xcb_drawable_t drawable;
} xcb_dri2_invalidate_buffers_event_t;
/**
* Get the next element of the iterator
* @param i Pointer to a xcb_dri2_dri2_buffer_iterator_t
*
* Get the next element in the iterator. The member rem is
* decreased by one. The member data points to the next
* element. The member index is increased by sizeof(xcb_dri2_dri2_buffer_t)
*/
void
xcb_dri2_dri2_buffer_next (xcb_dri2_dri2_buffer_iterator_t *i);
/**
* Return the iterator pointing to the last element
* @param i An xcb_dri2_dri2_buffer_iterator_t
* @return The iterator pointing to the last element
*
* Set the current element in the iterator to the last element.
* The member rem is set to 0. The member data points to the
* last element.
*/
xcb_generic_iterator_t
xcb_dri2_dri2_buffer_end (xcb_dri2_dri2_buffer_iterator_t i);
/**
* Get the next element of the iterator
* @param i Pointer to a xcb_dri2_attach_format_iterator_t
*
* Get the next element in the iterator. The member rem is
* decreased by one. The member data points to the next
* element. The member index is increased by sizeof(xcb_dri2_attach_format_t)
*/
void
xcb_dri2_attach_format_next (xcb_dri2_attach_format_iterator_t *i);
/**
* Return the iterator pointing to the last element
* @param i An xcb_dri2_attach_format_iterator_t
* @return The iterator pointing to the last element
*
* Set the current element in the iterator to the last element.
* The member rem is set to 0. The member data points to the
* last element.
*/
xcb_generic_iterator_t
xcb_dri2_attach_format_end (xcb_dri2_attach_format_iterator_t i);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_query_version_cookie_t
xcb_dri2_query_version (xcb_connection_t *c,
uint32_t major_version,
uint32_t minor_version);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_query_version_cookie_t
xcb_dri2_query_version_unchecked (xcb_connection_t *c,
uint32_t major_version,
uint32_t minor_version);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_query_version_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_query_version_reply_t *
xcb_dri2_query_version_reply (xcb_connection_t *c,
xcb_dri2_query_version_cookie_t cookie /**< */,
xcb_generic_error_t **e);
int
xcb_dri2_connect_sizeof (const void *_buffer);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_connect_cookie_t
xcb_dri2_connect (xcb_connection_t *c,
xcb_window_t window,
uint32_t driver_type);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_connect_cookie_t
xcb_dri2_connect_unchecked (xcb_connection_t *c,
xcb_window_t window,
uint32_t driver_type);
char *
xcb_dri2_connect_driver_name (const xcb_dri2_connect_reply_t *R);
int
xcb_dri2_connect_driver_name_length (const xcb_dri2_connect_reply_t *R);
xcb_generic_iterator_t
xcb_dri2_connect_driver_name_end (const xcb_dri2_connect_reply_t *R);
void *
xcb_dri2_connect_alignment_pad (const xcb_dri2_connect_reply_t *R);
int
xcb_dri2_connect_alignment_pad_length (const xcb_dri2_connect_reply_t *R);
xcb_generic_iterator_t
xcb_dri2_connect_alignment_pad_end (const xcb_dri2_connect_reply_t *R);
char *
xcb_dri2_connect_device_name (const xcb_dri2_connect_reply_t *R);
int
xcb_dri2_connect_device_name_length (const xcb_dri2_connect_reply_t *R);
xcb_generic_iterator_t
xcb_dri2_connect_device_name_end (const xcb_dri2_connect_reply_t *R);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_connect_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_connect_reply_t *
xcb_dri2_connect_reply (xcb_connection_t *c,
xcb_dri2_connect_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_authenticate_cookie_t
xcb_dri2_authenticate (xcb_connection_t *c,
xcb_window_t window,
uint32_t magic);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_authenticate_cookie_t
xcb_dri2_authenticate_unchecked (xcb_connection_t *c,
xcb_window_t window,
uint32_t magic);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_authenticate_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_authenticate_reply_t *
xcb_dri2_authenticate_reply (xcb_connection_t *c,
xcb_dri2_authenticate_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will not cause
* a reply to be generated. Any returned error will be
* saved for handling by xcb_request_check().
*/
xcb_void_cookie_t
xcb_dri2_create_drawable_checked (xcb_connection_t *c,
xcb_drawable_t drawable);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_void_cookie_t
xcb_dri2_create_drawable (xcb_connection_t *c,
xcb_drawable_t drawable);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will not cause
* a reply to be generated. Any returned error will be
* saved for handling by xcb_request_check().
*/
xcb_void_cookie_t
xcb_dri2_destroy_drawable_checked (xcb_connection_t *c,
xcb_drawable_t drawable);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_void_cookie_t
xcb_dri2_destroy_drawable (xcb_connection_t *c,
xcb_drawable_t drawable);
int
xcb_dri2_get_buffers_sizeof (const void *_buffer,
uint32_t attachments_len);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_get_buffers_cookie_t
xcb_dri2_get_buffers (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t count,
uint32_t attachments_len,
const uint32_t *attachments);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_get_buffers_cookie_t
xcb_dri2_get_buffers_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t count,
uint32_t attachments_len,
const uint32_t *attachments);
xcb_dri2_dri2_buffer_t *
xcb_dri2_get_buffers_buffers (const xcb_dri2_get_buffers_reply_t *R);
int
xcb_dri2_get_buffers_buffers_length (const xcb_dri2_get_buffers_reply_t *R);
xcb_dri2_dri2_buffer_iterator_t
xcb_dri2_get_buffers_buffers_iterator (const xcb_dri2_get_buffers_reply_t *R);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_get_buffers_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_get_buffers_reply_t *
xcb_dri2_get_buffers_reply (xcb_connection_t *c,
xcb_dri2_get_buffers_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_copy_region_cookie_t
xcb_dri2_copy_region (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t region,
uint32_t dest,
uint32_t src);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_copy_region_cookie_t
xcb_dri2_copy_region_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t region,
uint32_t dest,
uint32_t src);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_copy_region_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_copy_region_reply_t *
xcb_dri2_copy_region_reply (xcb_connection_t *c,
xcb_dri2_copy_region_cookie_t cookie /**< */,
xcb_generic_error_t **e);
int
xcb_dri2_get_buffers_with_format_sizeof (const void *_buffer,
uint32_t attachments_len);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_get_buffers_with_format_cookie_t
xcb_dri2_get_buffers_with_format (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t count,
uint32_t attachments_len,
const xcb_dri2_attach_format_t *attachments);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_get_buffers_with_format_cookie_t
xcb_dri2_get_buffers_with_format_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t count,
uint32_t attachments_len,
const xcb_dri2_attach_format_t *attachments);
xcb_dri2_dri2_buffer_t *
xcb_dri2_get_buffers_with_format_buffers (const xcb_dri2_get_buffers_with_format_reply_t *R);
int
xcb_dri2_get_buffers_with_format_buffers_length (const xcb_dri2_get_buffers_with_format_reply_t *R);
xcb_dri2_dri2_buffer_iterator_t
xcb_dri2_get_buffers_with_format_buffers_iterator (const xcb_dri2_get_buffers_with_format_reply_t *R);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_get_buffers_with_format_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_get_buffers_with_format_reply_t *
xcb_dri2_get_buffers_with_format_reply (xcb_connection_t *c,
xcb_dri2_get_buffers_with_format_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_swap_buffers_cookie_t
xcb_dri2_swap_buffers (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t target_msc_hi,
uint32_t target_msc_lo,
uint32_t divisor_hi,
uint32_t divisor_lo,
uint32_t remainder_hi,
uint32_t remainder_lo);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_swap_buffers_cookie_t
xcb_dri2_swap_buffers_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t target_msc_hi,
uint32_t target_msc_lo,
uint32_t divisor_hi,
uint32_t divisor_lo,
uint32_t remainder_hi,
uint32_t remainder_lo);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_swap_buffers_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_swap_buffers_reply_t *
xcb_dri2_swap_buffers_reply (xcb_connection_t *c,
xcb_dri2_swap_buffers_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_get_msc_cookie_t
xcb_dri2_get_msc (xcb_connection_t *c,
xcb_drawable_t drawable);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_get_msc_cookie_t
xcb_dri2_get_msc_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_get_msc_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_get_msc_reply_t *
xcb_dri2_get_msc_reply (xcb_connection_t *c,
xcb_dri2_get_msc_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_wait_msc_cookie_t
xcb_dri2_wait_msc (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t target_msc_hi,
uint32_t target_msc_lo,
uint32_t divisor_hi,
uint32_t divisor_lo,
uint32_t remainder_hi,
uint32_t remainder_lo);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_wait_msc_cookie_t
xcb_dri2_wait_msc_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t target_msc_hi,
uint32_t target_msc_lo,
uint32_t divisor_hi,
uint32_t divisor_lo,
uint32_t remainder_hi,
uint32_t remainder_lo);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_wait_msc_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_wait_msc_reply_t *
xcb_dri2_wait_msc_reply (xcb_connection_t *c,
xcb_dri2_wait_msc_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_wait_sbc_cookie_t
xcb_dri2_wait_sbc (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t target_sbc_hi,
uint32_t target_sbc_lo);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_wait_sbc_cookie_t
xcb_dri2_wait_sbc_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t target_sbc_hi,
uint32_t target_sbc_lo);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_wait_sbc_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_wait_sbc_reply_t *
xcb_dri2_wait_sbc_reply (xcb_connection_t *c,
xcb_dri2_wait_sbc_cookie_t cookie /**< */,
xcb_generic_error_t **e);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will not cause
* a reply to be generated. Any returned error will be
* saved for handling by xcb_request_check().
*/
xcb_void_cookie_t
xcb_dri2_swap_interval_checked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t interval);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_void_cookie_t
xcb_dri2_swap_interval (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t interval);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
*/
xcb_dri2_get_param_cookie_t
xcb_dri2_get_param (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t param);
/**
*
* @param c The connection
* @return A cookie
*
* Delivers a request to the X server.
*
* This form can be used only if the request will cause
* a reply to be generated. Any returned error will be
* placed in the event queue.
*/
xcb_dri2_get_param_cookie_t
xcb_dri2_get_param_unchecked (xcb_connection_t *c,
xcb_drawable_t drawable,
uint32_t param);
/**
* Return the reply
* @param c The connection
* @param cookie The cookie
* @param e The xcb_generic_error_t supplied
*
* Returns the reply of the request asked by
*
* The parameter @p e supplied to this function must be NULL if
* xcb_dri2_get_param_unchecked(). is used.
* Otherwise, it stores the error if any.
*
* The returned value must be freed by the caller using free().
*/
xcb_dri2_get_param_reply_t *
xcb_dri2_get_param_reply (xcb_connection_t *c,
xcb_dri2_get_param_cookie_t cookie /**< */,
xcb_generic_error_t **e);
#ifdef __cplusplus
}
#endif
#endif
/**
* @}
*/