1848b8605Smrg#ifndef __GLX_packsingle_h__ 2848b8605Smrg#define __GLX_packsingle_h__ 3848b8605Smrg 4848b8605Smrg/* 5848b8605Smrg * SGI FREE SOFTWARE LICENSE B (Version 2.0, Sept. 18, 2008) 6848b8605Smrg * Copyright (C) 1991-2000 Silicon Graphics, Inc. All Rights Reserved. 7848b8605Smrg * 8848b8605Smrg * Permission is hereby granted, free of charge, to any person obtaining a 9848b8605Smrg * copy of this software and associated documentation files (the "Software"), 10848b8605Smrg * to deal in the Software without restriction, including without limitation 11848b8605Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 12848b8605Smrg * and/or sell copies of the Software, and to permit persons to whom the 13848b8605Smrg * Software is furnished to do so, subject to the following conditions: 14848b8605Smrg * 15848b8605Smrg * The above copyright notice including the dates of first publication and 16848b8605Smrg * either this permission notice or a reference to 17848b8605Smrg * http://oss.sgi.com/projects/FreeB/ 18848b8605Smrg * shall be included in all copies or substantial portions of the Software. 19848b8605Smrg * 20848b8605Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 21848b8605Smrg * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 22848b8605Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 23848b8605Smrg * SILICON GRAPHICS, INC. BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 24848b8605Smrg * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF 25848b8605Smrg * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 26848b8605Smrg * SOFTWARE. 27848b8605Smrg * 28848b8605Smrg * Except as contained in this notice, the name of Silicon Graphics, Inc. 29848b8605Smrg * shall not be used in advertising or otherwise to promote the sale, use or 30848b8605Smrg * other dealings in this Software without prior written authorization from 31848b8605Smrg * Silicon Graphics, Inc. 32848b8605Smrg */ 33848b8605Smrg 34848b8605Smrg#include "packrender.h" 35848b8605Smrg 36848b8605Smrg/* 37848b8605Smrg** The macros in this header convert wire protocol data types to the client 38848b8605Smrg** machine's native data types. The header is part of the porting layer of 39848b8605Smrg** the client library, and it is intended that hardware vendors will rewrite 40848b8605Smrg** this header to suit their own machines. 41848b8605Smrg*/ 42848b8605Smrg 43848b8605Smrg/* 44848b8605Smrg** Dummy define to make the GetReqExtra macro happy. The value is not 45848b8605Smrg** used, but instead the code in __GLX_SINGLE_BEGIN issues its own store 46848b8605Smrg** to req->reqType with the proper code (our extension code). 47848b8605Smrg*/ 48848b8605Smrg#define X_GLXSingle 0 49848b8605Smrg 50848b8605Smrg/* Declare common variables used during a single command */ 51848b8605Smrg#define __GLX_SINGLE_DECLARE_VARIABLES() \ 52848b8605Smrg struct glx_context *gc = __glXGetCurrentContext(); \ 53848b8605Smrg GLubyte *pc, *pixelHeaderPC; \ 54848b8605Smrg GLuint compsize, cmdlen; \ 55848b8605Smrg Display *dpy = gc->currentDpy; \ 56848b8605Smrg xGLXSingleReq *req 57848b8605Smrg 58848b8605Smrg#define __GLX_SINGLE_LOAD_VARIABLES() \ 59848b8605Smrg pc = gc->pc; \ 60848b8605Smrg /* Muffle compilers */ \ 61848b8605Smrg pixelHeaderPC = 0; (void)pixelHeaderPC; \ 62848b8605Smrg compsize = 0; (void)compsize; \ 63848b8605Smrg cmdlen = 0; (void)cmdlen 64848b8605Smrg 65848b8605Smrg/* Start a single command */ 66848b8605Smrg#define __GLX_SINGLE_BEGIN(opcode,bytes) \ 67848b8605Smrg if (dpy) { \ 68848b8605Smrg (void) __glXFlushRenderBuffer(gc, pc); \ 69848b8605Smrg LockDisplay(dpy); \ 70848b8605Smrg GetReqExtra(GLXSingle,bytes,req); \ 71848b8605Smrg req->reqType = gc->majorOpcode; \ 72848b8605Smrg req->glxCode = opcode; \ 73848b8605Smrg req->contextTag = gc->currentContextTag; \ 74848b8605Smrg pc = ((GLubyte *)(req) + sz_xGLXSingleReq) 75848b8605Smrg 76848b8605Smrg/* End a single command */ 77848b8605Smrg#define __GLX_SINGLE_END() \ 78848b8605Smrg UnlockDisplay(dpy); \ 79848b8605Smrg SyncHandle(); \ 80848b8605Smrg } 81848b8605Smrg 82848b8605Smrg/* Store data to sending for a single command */ 83848b8605Smrg#define __GLX_SINGLE_PUT_CHAR(offset,a) \ 84848b8605Smrg *((INT8 *) (pc + offset)) = a 85848b8605Smrg 86848b8605Smrg#define __GLX_SINGLE_PUT_SHORT(offset,a) \ 87848b8605Smrg *((INT16 *) (pc + offset)) = a 88848b8605Smrg 89848b8605Smrg#define __GLX_SINGLE_PUT_LONG(offset,a) \ 90848b8605Smrg *((INT32 *) (pc + offset)) = a 91848b8605Smrg 92848b8605Smrg#define __GLX_SINGLE_PUT_FLOAT(offset,a) \ 93848b8605Smrg *((FLOAT32 *) (pc + offset)) = a 94848b8605Smrg 95848b8605Smrg/* Read support macros */ 96848b8605Smrg#define __GLX_SINGLE_READ_XREPLY() \ 97848b8605Smrg (void) _XReply(dpy, (xReply*) &reply, 0, False) 98848b8605Smrg 99848b8605Smrg#define __GLX_SINGLE_GET_RETVAL(a,cast) \ 100848b8605Smrg a = (cast) reply.retval 101848b8605Smrg 102848b8605Smrg#define __GLX_SINGLE_GET_SIZE(a) \ 103848b8605Smrg a = (GLint) reply.size 104848b8605Smrg 105848b8605Smrg#define __GLX_SINGLE_GET_CHAR(p) \ 106b8e80941Smrg memcpy((p), &reply.pad3, 1); 107848b8605Smrg 108848b8605Smrg#define __GLX_SINGLE_GET_SHORT(p) \ 109b8e80941Smrg memcpy((p), &reply.pad3, 2); 110848b8605Smrg 111848b8605Smrg#define __GLX_SINGLE_GET_LONG(p) \ 112b8e80941Smrg memcpy((p), &reply.pad3, 4); 113848b8605Smrg 114848b8605Smrg#define __GLX_SINGLE_GET_FLOAT(p) \ 115b8e80941Smrg memcpy((p), &reply.pad3, 4); 116848b8605Smrg 117848b8605Smrg#define __GLX_SINGLE_GET_DOUBLE(p) \ 118b8e80941Smrg memcpy((p), &reply.pad3, 8); 119848b8605Smrg 120848b8605Smrg/* Get an array of typed data */ 121848b8605Smrg#define __GLX_SINGLE_GET_VOID_ARRAY(a,alen) \ 122848b8605Smrg { \ 123848b8605Smrg GLint slop = alen*__GLX_SIZE_INT8 & 3; \ 124848b8605Smrg _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT8); \ 125848b8605Smrg if (slop) _XEatData(dpy,4-slop); \ 126848b8605Smrg } 127848b8605Smrg 128848b8605Smrg#define __GLX_SINGLE_GET_CHAR_ARRAY(a,alen) \ 129848b8605Smrg { \ 130848b8605Smrg GLint slop = alen*__GLX_SIZE_INT8 & 3; \ 131848b8605Smrg _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT8); \ 132848b8605Smrg if (slop) _XEatData(dpy,4-slop); \ 133848b8605Smrg } 134848b8605Smrg 135848b8605Smrg 136848b8605Smrg#define __GLX_SINGLE_GET_SHORT_ARRAY(a,alen) \ 137848b8605Smrg { \ 138848b8605Smrg GLint slop = (alen*__GLX_SIZE_INT16) & 3; \ 139848b8605Smrg _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT16); \ 140848b8605Smrg if (slop) _XEatData(dpy,4-slop); \ 141848b8605Smrg } 142848b8605Smrg 143848b8605Smrg#define __GLX_SINGLE_GET_LONG_ARRAY(a,alen) \ 144848b8605Smrg _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT32); 145848b8605Smrg 146848b8605Smrg#define __GLX_SINGLE_GET_FLOAT_ARRAY(a,alen) \ 147848b8605Smrg _XRead(dpy,(char *)a,alen*__GLX_SIZE_FLOAT32); 148848b8605Smrg 149848b8605Smrg#define __GLX_SINGLE_GET_DOUBLE_ARRAY(a,alen) \ 150848b8605Smrg _XRead(dpy,(char *)a,alen*__GLX_SIZE_FLOAT64); 151848b8605Smrg 152848b8605Smrg#endif /* !__GLX_packsingle_h__ */ 153