diff options
Diffstat (limited to 'nx-X11/programs/Xserver/hw')
| -rw-r--r-- | nx-X11/programs/Xserver/hw/nxagent/NXglxext.c | 82 | 
1 files changed, 7 insertions, 75 deletions
| diff --git a/nx-X11/programs/Xserver/hw/nxagent/NXglxext.c b/nx-X11/programs/Xserver/hw/nxagent/NXglxext.c index 5512cae1b..9d0f4f719 100644 --- a/nx-X11/programs/Xserver/hw/nxagent/NXglxext.c +++ b/nx-X11/programs/Xserver/hw/nxagent/NXglxext.c @@ -57,12 +57,11 @@  */  static int __glXDispatch(ClientPtr client)  { -    int result; -      REQUEST(xGLXSingleReq);      CARD8 opcode;      int (*proc)(__GLXclientState *cl, GLbyte *pc);      __GLXclientState *cl; +    int retval;      opcode = stuff->glxCode;      cl = __glXClients[client->index]; @@ -107,77 +106,10 @@ static int __glXDispatch(ClientPtr client)      /*      ** Use the opcode to index into the procedure table.      */ -    proc = __glXSingleTable[opcode]; - -    /* -     * Report upstream that we are -     * dispatching a GLX operation. -     */ - -    nxagentGlxTrap = 1; - -    #ifdef TEST -    fprintf(stderr, "__glXDispatch: Going to dispatch GLX operation [%d] for client [%d].\n",  -                opcode, client -> index); -    #endif -     -    result = (*proc)(cl, (GLbyte *) stuff); - -    nxagentGlxTrap = 0; - -    #ifdef TEST -    fprintf(stderr, "__glXDispatch: Dispatched GLX operation [%d] for client [%d].\n",  -                opcode, client -> index); -    #endif - -    return result; -} - -static int __glXSwapDispatch(ClientPtr client) -{ -    int result; - -    REQUEST(xGLXSingleReq); -    CARD8 opcode; -    int (*proc)(__GLXclientState *cl, GLbyte *pc); -    __GLXclientState *cl; - -    opcode = stuff->glxCode; -    cl = __glXClients[client->index]; -    if (!cl) { -	cl = (__GLXclientState *) malloc(sizeof(__GLXclientState)); -	 __glXClients[client->index] = cl; -	if (!cl) { -	    return BadAlloc; -	} -	memset(cl, 0, sizeof(__GLXclientState)); -    } -     -    if (!cl->inUse) { -	/* -	** This is first request from this client.  Associate a resource -	** with the client so we will be notified when the client dies. -	*/ -	XID xid = FakeClientID(client->index); -	if (!AddResource( xid, __glXClientRes, (void *)(long)client->index)) { -	    return BadAlloc; -	} -	ResetClientState(client->index); -	cl->inUse = GL_TRUE; -	cl->client = client; -    } - -    /* -    ** Check for valid opcode. -    */ -    if (opcode >= __GLX_SINGLE_TABLE_SIZE) { -	return BadRequest; -    } - -    /* -    ** Use the opcode to index into the procedure table. -    */ -    proc = __glXSwapSingleTable[opcode]; +    if (client->swapped) +        proc = __glXSwapSingleTable[opcode]; +    else +        proc = __glXSingleTable[opcode];      /*       * Report upstream that we are @@ -191,7 +123,7 @@ static int __glXSwapDispatch(ClientPtr client)                  opcode, client -> index);      #endif -    result = (*proc)(cl, (GLbyte *) stuff); +    retval = (*proc)(cl, (GLbyte *) stuff);      nxagentGlxTrap = 0; @@ -200,5 +132,5 @@ static int __glXSwapDispatch(ClientPtr client)                  opcode, client -> index);      #endif -    return result; +    return retval;  } | 
