1 #ifndef __GLX_packsingle_h__ 2 #define __GLX_packsingle_h__ 3 4 /* 5 * SGI FREE SOFTWARE LICENSE B (Version 2.0, Sept. 18, 2008) 6 * Copyright (C) 1991-2000 Silicon Graphics, Inc. All Rights Reserved. 7 * 8 * Permission is hereby granted, free of charge, to any person obtaining a 9 * copy of this software and associated documentation files (the "Software"), 10 * to deal in the Software without restriction, including without limitation 11 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 12 * and/or sell copies of the Software, and to permit persons to whom the 13 * Software is furnished to do so, subject to the following conditions: 14 * 15 * The above copyright notice including the dates of first publication and 16 * either this permission notice or a reference to 17 * http://oss.sgi.com/projects/FreeB/ 18 * shall be included in all copies or substantial portions of the Software. 19 * 20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 21 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 22 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 23 * SILICON GRAPHICS, INC. BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 24 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF 25 * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 26 * SOFTWARE. 27 * 28 * Except as contained in this notice, the name of Silicon Graphics, Inc. 29 * shall not be used in advertising or otherwise to promote the sale, use or 30 * other dealings in this Software without prior written authorization from 31 * Silicon Graphics, Inc. 32 */ 33 34 #include "packrender.h" 35 36 /* 37 ** The macros in this header convert wire protocol data types to the client 38 ** machine's native data types. The header is part of the porting layer of 39 ** the client library, and it is intended that hardware vendors will rewrite 40 ** this header to suit their own machines. 41 */ 42 43 /* 44 ** Dummy define to make the GetReqExtra macro happy. The value is not 45 ** used, but instead the code in __GLX_SINGLE_BEGIN issues its own store 46 ** to req->reqType with the proper code (our extension code). 47 */ 48 #define X_GLXSingle 0 49 50 /* Declare common variables used during a single command */ 51 #define __GLX_SINGLE_DECLARE_VARIABLES() \ 52 struct glx_context *gc = __glXGetCurrentContext(); \ 53 GLubyte *pc, *pixelHeaderPC; \ 54 GLuint compsize, cmdlen; \ 55 Display *dpy = gc->currentDpy; \ 56 xGLXSingleReq *req 57 58 #define __GLX_SINGLE_LOAD_VARIABLES() \ 59 pc = gc->pc; \ 60 /* Muffle compilers */ \ 61 pixelHeaderPC = 0; (void)pixelHeaderPC; \ 62 compsize = 0; (void)compsize; \ 63 cmdlen = 0; (void)cmdlen 64 65 /* Start a single command */ 66 #define __GLX_SINGLE_BEGIN(opcode,bytes) \ 67 if (dpy) { \ 68 (void) __glXFlushRenderBuffer(gc, pc); \ 69 LockDisplay(dpy); \ 70 GetReqExtra(GLXSingle,bytes,req); \ 71 req->reqType = gc->majorOpcode; \ 72 req->glxCode = opcode; \ 73 req->contextTag = gc->currentContextTag; \ 74 pc = ((GLubyte *)(req) + sz_xGLXSingleReq) 75 76 /* End a single command */ 77 #define __GLX_SINGLE_END() \ 78 UnlockDisplay(dpy); \ 79 SyncHandle(); \ 80 } 81 82 /* Store data to sending for a single command */ 83 #define __GLX_SINGLE_PUT_CHAR(offset,a) \ 84 *((INT8 *) (pc + offset)) = a 85 86 #ifndef CRAY 87 #define __GLX_SINGLE_PUT_SHORT(offset,a) \ 88 *((INT16 *) (pc + offset)) = a 89 90 #define __GLX_SINGLE_PUT_LONG(offset,a) \ 91 *((INT32 *) (pc + offset)) = a 92 93 #define __GLX_SINGLE_PUT_FLOAT(offset,a) \ 94 *((FLOAT32 *) (pc + offset)) = a 95 96 #else 97 #define __GLX_SINGLE_PUT_SHORT(offset,a) \ 98 { GLubyte *cp = (pc+offset); \ 99 int shift = (64-16) - ((int)(cp) >> (64-6)); \ 100 *(int *)cp = (*(int *)cp & ~(0xffff << shift)) | ((a & 0xffff) << shift); } 101 102 #define __GLX_SINGLE_PUT_LONG(offset,a) \ 103 { GLubyte *cp = (pc+offset); \ 104 int shift = (64-32) - ((int)(cp) >> (64-6)); \ 105 *(int *)cp = (*(int *)cp & ~(0xffffffff << shift)) | ((a & 0xffffffff) << shift); } 106 107 #define __GLX_SINGLE_PUT_FLOAT(offset,a) \ 108 gl_put_float(pc + offset, a) 109 #endif 110 111 /* Read support macros */ 112 #define __GLX_SINGLE_READ_XREPLY() \ 113 (void) _XReply(dpy, (xReply*) &reply, 0, False) 114 115 #define __GLX_SINGLE_GET_RETVAL(a,cast) \ 116 a = (cast) reply.retval 117 118 #define __GLX_SINGLE_GET_SIZE(a) \ 119 a = (GLint) reply.size 120 121 #ifndef _CRAY 122 #define __GLX_SINGLE_GET_CHAR(p) \ 123 *p = *(GLbyte *)&reply.pad3; 124 125 #define __GLX_SINGLE_GET_SHORT(p) \ 126 *p = *(GLshort *)&reply.pad3; 127 128 #define __GLX_SINGLE_GET_LONG(p) \ 129 *p = *(GLint *)&reply.pad3; 130 131 #define __GLX_SINGLE_GET_FLOAT(p) \ 132 *p = *(GLfloat *)&reply.pad3; 133 134 #else 135 #define __GLX_SINGLE_GET_CHAR(p) \ 136 *p = reply.pad3 >> 24; 137 138 #define __GLX_SINGLE_GET_SHORT(p) \ 139 {int t = reply.pad3 >> 16; \ 140 *p = (t & 0x8000) ? (t | ~0xffff) : (t & 0xffff);} 141 142 #define __GLX_SINGLE_GET_LONG(p) \ 143 {int t = reply.pad3; \ 144 *p = (t & 0x80000000) ? (t | ~0xffffffff) : (t & 0xffffffff);} 145 146 #define PAD3OFFSET 16 147 #define __GLX_SINGLE_GET_FLOAT(p) \ 148 *p = gl_ntoh_float((GLubyte *)&reply + PAD3OFFSET); 149 150 #define __GLX_SINGLE_GET_DOUBLE(p) \ 151 *p = gl_ntoh_double((GLubyte *)&reply + PAD3OFFSET); 152 153 extern float gl_ntoh_float(GLubyte *); 154 extern float gl_ntoh_double(GLubyte *); 155 #endif 156 157 #ifndef _CRAY 158 159 #ifdef __GLX_ALIGN64 160 #define __GLX_SINGLE_GET_DOUBLE(p) \ 161 __GLX_MEM_COPY(p, &reply.pad3, 8) 162 #else 163 #define __GLX_SINGLE_GET_DOUBLE(p) \ 164 *p = *(GLdouble *)&reply.pad3 165 #endif 166 167 #endif 168 169 /* Get an array of typed data */ 170 #define __GLX_SINGLE_GET_VOID_ARRAY(a,alen) \ 171 { \ 172 GLint slop = alen*__GLX_SIZE_INT8 & 3; \ 173 _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT8); \ 174 if (slop) _XEatData(dpy,4-slop); \ 175 } 176 177 #define __GLX_SINGLE_GET_CHAR_ARRAY(a,alen) \ 178 { \ 179 GLint slop = alen*__GLX_SIZE_INT8 & 3; \ 180 _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT8); \ 181 if (slop) _XEatData(dpy,4-slop); \ 182 } 183 184 185 #define __GLX_SINGLE_GET_SHORT_ARRAY(a,alen) \ 186 { \ 187 GLint slop = (alen*__GLX_SIZE_INT16) & 3; \ 188 _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT16); \ 189 if (slop) _XEatData(dpy,4-slop); \ 190 } 191 192 #define __GLX_SINGLE_GET_LONG_ARRAY(a,alen) \ 193 _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT32); 194 195 #ifndef _CRAY 196 #define __GLX_SINGLE_GET_FLOAT_ARRAY(a,alen) \ 197 _XRead(dpy,(char *)a,alen*__GLX_SIZE_FLOAT32); 198 199 #define __GLX_SINGLE_GET_DOUBLE_ARRAY(a,alen) \ 200 _XRead(dpy,(char *)a,alen*__GLX_SIZE_FLOAT64); 201 202 #else 203 #define __GLX_SINGLE_GET_FLOAT_ARRAY(a,alen) \ 204 gl_get_float_array(dpy,a,alen); 205 206 #define __GLX_SINGLE_GET_DOUBLE_ARRAY(a,alen) \ 207 gl_get_double_array(dpy, a, alen); 208 209 extern void gl_get_float_array(Display * dpy, float *a, int alen); 210 extern void gl_get_double_array(Display * dpy, double *a, int alen); 211 #endif 212 213 #endif /* !__GLX_packsingle_h__ */ 214