packsingle.h revision 848b8605
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#ifndef CRAY
87848b8605Smrg#define __GLX_SINGLE_PUT_SHORT(offset,a)        \
88848b8605Smrg   *((INT16 *) (pc + offset)) = a
89848b8605Smrg
90848b8605Smrg#define __GLX_SINGLE_PUT_LONG(offset,a)         \
91848b8605Smrg   *((INT32 *) (pc + offset)) = a
92848b8605Smrg
93848b8605Smrg#define __GLX_SINGLE_PUT_FLOAT(offset,a)        \
94848b8605Smrg   *((FLOAT32 *) (pc + offset)) = a
95848b8605Smrg
96848b8605Smrg#else
97848b8605Smrg#define __GLX_SINGLE_PUT_SHORT(offset,a)        \
98848b8605Smrg   { GLubyte *cp = (pc+offset);                    \
99848b8605Smrg      int shift = (64-16) - ((int)(cp) >> (64-6));                      \
100848b8605Smrg      *(int *)cp = (*(int *)cp & ~(0xffff << shift)) | ((a & 0xffff) << shift); }
101848b8605Smrg
102848b8605Smrg#define __GLX_SINGLE_PUT_LONG(offset,a)         \
103848b8605Smrg   { GLubyte *cp = (pc+offset);                    \
104848b8605Smrg      int shift = (64-32) - ((int)(cp) >> (64-6));                      \
105848b8605Smrg      *(int *)cp = (*(int *)cp & ~(0xffffffff << shift)) | ((a & 0xffffffff) << shift); }
106848b8605Smrg
107848b8605Smrg#define __GLX_SINGLE_PUT_FLOAT(offset,a)        \
108848b8605Smrg   gl_put_float(pc + offset, a)
109848b8605Smrg#endif
110848b8605Smrg
111848b8605Smrg/* Read support macros */
112848b8605Smrg#define __GLX_SINGLE_READ_XREPLY()                    \
113848b8605Smrg   (void) _XReply(dpy, (xReply*) &reply, 0, False)
114848b8605Smrg
115848b8605Smrg#define __GLX_SINGLE_GET_RETVAL(a,cast)         \
116848b8605Smrg   a = (cast) reply.retval
117848b8605Smrg
118848b8605Smrg#define __GLX_SINGLE_GET_SIZE(a)                \
119848b8605Smrg   a = (GLint) reply.size
120848b8605Smrg
121848b8605Smrg#ifndef _CRAY
122848b8605Smrg#define __GLX_SINGLE_GET_CHAR(p)                \
123848b8605Smrg   *p = *(GLbyte *)&reply.pad3;
124848b8605Smrg
125848b8605Smrg#define __GLX_SINGLE_GET_SHORT(p)               \
126848b8605Smrg   *p = *(GLshort *)&reply.pad3;
127848b8605Smrg
128848b8605Smrg#define __GLX_SINGLE_GET_LONG(p)                \
129848b8605Smrg   *p = *(GLint *)&reply.pad3;
130848b8605Smrg
131848b8605Smrg#define __GLX_SINGLE_GET_FLOAT(p)               \
132848b8605Smrg   *p = *(GLfloat *)&reply.pad3;
133848b8605Smrg
134848b8605Smrg#else
135848b8605Smrg#define __GLX_SINGLE_GET_CHAR(p)                \
136848b8605Smrg   *p = reply.pad3 >> 24;
137848b8605Smrg
138848b8605Smrg#define __GLX_SINGLE_GET_SHORT(p)               \
139848b8605Smrg   {int t = reply.pad3 >> 16;                            \
140848b8605Smrg      *p = (t & 0x8000) ? (t | ~0xffff) : (t & 0xffff);}
141848b8605Smrg
142848b8605Smrg#define __GLX_SINGLE_GET_LONG(p)                \
143848b8605Smrg   {int t = reply.pad3;                                              \
144848b8605Smrg      *p = (t & 0x80000000) ? (t | ~0xffffffff) : (t & 0xffffffff);}
145848b8605Smrg
146848b8605Smrg#define PAD3OFFSET 16
147848b8605Smrg#define __GLX_SINGLE_GET_FLOAT(p)                        \
148848b8605Smrg   *p = gl_ntoh_float((GLubyte *)&reply + PAD3OFFSET);
149848b8605Smrg
150848b8605Smrg#define __GLX_SINGLE_GET_DOUBLE(p)                       \
151848b8605Smrg   *p = gl_ntoh_double((GLubyte *)&reply + PAD3OFFSET);
152848b8605Smrg
153848b8605Smrgextern float gl_ntoh_float(GLubyte *);
154848b8605Smrgextern float gl_ntoh_double(GLubyte *);
155848b8605Smrg#endif
156848b8605Smrg
157848b8605Smrg#ifndef _CRAY
158848b8605Smrg
159848b8605Smrg#ifdef __GLX_ALIGN64
160848b8605Smrg#define __GLX_SINGLE_GET_DOUBLE(p)              \
161848b8605Smrg   __GLX_MEM_COPY(p, &reply.pad3, 8)
162848b8605Smrg#else
163848b8605Smrg#define __GLX_SINGLE_GET_DOUBLE(p)              \
164848b8605Smrg   *p = *(GLdouble *)&reply.pad3
165848b8605Smrg#endif
166848b8605Smrg
167848b8605Smrg#endif
168848b8605Smrg
169848b8605Smrg/* Get an array of typed data */
170848b8605Smrg#define __GLX_SINGLE_GET_VOID_ARRAY(a,alen)     \
171848b8605Smrg   {                                            \
172848b8605Smrg      GLint slop = alen*__GLX_SIZE_INT8 & 3;    \
173848b8605Smrg      _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT8);  \
174848b8605Smrg      if (slop) _XEatData(dpy,4-slop);             \
175848b8605Smrg   }
176848b8605Smrg
177848b8605Smrg#define __GLX_SINGLE_GET_CHAR_ARRAY(a,alen)     \
178848b8605Smrg   {                                            \
179848b8605Smrg      GLint slop = alen*__GLX_SIZE_INT8 & 3;    \
180848b8605Smrg      _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT8);  \
181848b8605Smrg      if (slop) _XEatData(dpy,4-slop);             \
182848b8605Smrg   }
183848b8605Smrg
184848b8605Smrg
185848b8605Smrg#define __GLX_SINGLE_GET_SHORT_ARRAY(a,alen)    \
186848b8605Smrg   {                                            \
187848b8605Smrg      GLint slop = (alen*__GLX_SIZE_INT16) & 3;    \
188848b8605Smrg      _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT16); \
189848b8605Smrg      if (slop) _XEatData(dpy,4-slop);             \
190848b8605Smrg   }
191848b8605Smrg
192848b8605Smrg#define __GLX_SINGLE_GET_LONG_ARRAY(a,alen)        \
193848b8605Smrg   _XRead(dpy,(char *)a,alen*__GLX_SIZE_INT32);
194848b8605Smrg
195848b8605Smrg#ifndef _CRAY
196848b8605Smrg#define __GLX_SINGLE_GET_FLOAT_ARRAY(a,alen)       \
197848b8605Smrg   _XRead(dpy,(char *)a,alen*__GLX_SIZE_FLOAT32);
198848b8605Smrg
199848b8605Smrg#define __GLX_SINGLE_GET_DOUBLE_ARRAY(a,alen)      \
200848b8605Smrg   _XRead(dpy,(char *)a,alen*__GLX_SIZE_FLOAT64);
201848b8605Smrg
202848b8605Smrg#else
203848b8605Smrg#define __GLX_SINGLE_GET_FLOAT_ARRAY(a,alen)    \
204848b8605Smrg   gl_get_float_array(dpy,a,alen);
205848b8605Smrg
206848b8605Smrg#define __GLX_SINGLE_GET_DOUBLE_ARRAY(a,alen)   \
207848b8605Smrg   gl_get_double_array(dpy, a, alen);
208848b8605Smrg
209848b8605Smrgextern void gl_get_float_array(Display * dpy, float *a, int alen);
210848b8605Smrgextern void gl_get_double_array(Display * dpy, double *a, int alen);
211848b8605Smrg#endif
212848b8605Smrg
213848b8605Smrg#endif /* !__GLX_packsingle_h__ */
214