Edit

IABSD.fr/xenocara/xserver/dix/swapreq.c

Branch :

  • Show log

    Commit

  • Author : matthieu
    Date : 2017-07-07 06:22:19
    Hash : 1862f548
    Message : Merge upstream fixes to the X event swapping code. (CVE-2017-10971 and CVE-2017-10972).

  • xserver/dix/swapreq.c
  • /************************************************************
    
    Copyright 1987, 1998  The Open Group
    
    Permission to use, copy, modify, distribute, and sell this software and its
    documentation for any purpose is hereby granted without fee, provided that
    the above copyright notice appear in all copies and that both that
    copyright notice and this permission notice appear in supporting
    documentation.
    
    The above copyright notice and this permission notice shall be included in
    all copies or substantial portions of the Software.
    
    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
    OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
    AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
    CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
    
    Except as contained in this notice, the name of The Open Group shall not be
    used in advertising or otherwise to promote the sale, use or other dealings
    in this Software without prior written authorization from The Open Group.
    
    Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.
    
                            All Rights Reserved
    
    Permission to use, copy, modify, and distribute this software and its
    documentation for any purpose and without fee is hereby granted,
    provided that the above copyright notice appear in all copies and that
    both that copyright notice and this permission notice appear in
    supporting documentation, and that the name of Digital not be
    used in advertising or publicity pertaining to distribution of the
    software without specific, written prior permission.
    
    DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
    ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
    DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
    ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
    WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
    ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
    SOFTWARE.
    
    ********************************************************/
    
    #ifdef HAVE_DIX_CONFIG_H
    #include <dix-config.h>
    #endif
    
    #include <X11/X.h>
    #include <X11/Xproto.h>
    #include <X11/Xprotostr.h>
    #include "misc.h"
    #include "dixstruct.h"
    #include "extnsionst.h"         /* for SendEvent */
    #include "swapreq.h"
    
    /* Thanks to Jack Palevich for testing and subsequently rewriting all this */
    
    /* Byte swap a list of longs */
    void
    SwapLongs(CARD32 *list, unsigned long count)
    {
        while (count >= 8) {
            swapl(list + 0);
            swapl(list + 1);
            swapl(list + 2);
            swapl(list + 3);
            swapl(list + 4);
            swapl(list + 5);
            swapl(list + 6);
            swapl(list + 7);
            list += 8;
            count -= 8;
        }
        if (count != 0) {
            do {
                swapl(list);
                list++;
            } while (--count != 0);
        }
    }
    
    /* Byte swap a list of shorts */
    void
    SwapShorts(short *list, unsigned long count)
    {
        while (count >= 16) {
            swaps(list + 0);
            swaps(list + 1);
            swaps(list + 2);
            swaps(list + 3);
            swaps(list + 4);
            swaps(list + 5);
            swaps(list + 6);
            swaps(list + 7);
            swaps(list + 8);
            swaps(list + 9);
            swaps(list + 10);
            swaps(list + 11);
            swaps(list + 12);
            swaps(list + 13);
            swaps(list + 14);
            swaps(list + 15);
            list += 16;
            count -= 16;
        }
        if (count != 0) {
            do {
                swaps(list);
                list++;
            } while (--count != 0);
        }
    }
    
    /* The following is used for all requests that have
       no fields to be swapped (except "length") */
    int
    SProcSimpleReq(ClientPtr client)
    {
        REQUEST(xReq);
        swaps(&stuff->length);
        return (*ProcVector[stuff->reqType]) (client);
    }
    
    /* The following is used for all requests that have
       only a single 32-bit field to be swapped, coming
       right after the "length" field */
    int
    SProcResourceReq(ClientPtr client)
    {
        REQUEST(xResourceReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xResourceReq);        /* not EXACT */
        swapl(&stuff->id);
        return (*ProcVector[stuff->reqType]) (client);
    }
    
    int
    SProcCreateWindow(ClientPtr client)
    {
        REQUEST(xCreateWindowReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xCreateWindowReq);
        swapl(&stuff->wid);
        swapl(&stuff->parent);
        swaps(&stuff->x);
        swaps(&stuff->y);
        swaps(&stuff->width);
        swaps(&stuff->height);
        swaps(&stuff->borderWidth);
        swaps(&stuff->class);
        swapl(&stuff->visual);
        swapl(&stuff->mask);
        SwapRestL(stuff);
        return ((*ProcVector[X_CreateWindow]) (client));
    }
    
    int
    SProcChangeWindowAttributes(ClientPtr client)
    {
        REQUEST(xChangeWindowAttributesReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xChangeWindowAttributesReq);
        swapl(&stuff->window);
        swapl(&stuff->valueMask);
        SwapRestL(stuff);
        return ((*ProcVector[X_ChangeWindowAttributes]) (client));
    }
    
    int
    SProcReparentWindow(ClientPtr client)
    {
        REQUEST(xReparentWindowReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xReparentWindowReq);
        swapl(&stuff->window);
        swapl(&stuff->parent);
        swaps(&stuff->x);
        swaps(&stuff->y);
        return ((*ProcVector[X_ReparentWindow]) (client));
    }
    
    int
    SProcConfigureWindow(ClientPtr client)
    {
        REQUEST(xConfigureWindowReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xConfigureWindowReq);
        swapl(&stuff->window);
        swaps(&stuff->mask);
        SwapRestL(stuff);
        return ((*ProcVector[X_ConfigureWindow]) (client));
    
    }
    
    int
    SProcInternAtom(ClientPtr client)
    {
        REQUEST(xInternAtomReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xInternAtomReq);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_InternAtom]) (client));
    }
    
    int
    SProcChangeProperty(ClientPtr client)
    {
        REQUEST(xChangePropertyReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xChangePropertyReq);
        swapl(&stuff->window);
        swapl(&stuff->property);
        swapl(&stuff->type);
        swapl(&stuff->nUnits);
        switch (stuff->format) {
        case 8:
            break;
        case 16:
            SwapRestS(stuff);
            break;
        case 32:
            SwapRestL(stuff);
            break;
        }
        return ((*ProcVector[X_ChangeProperty]) (client));
    }
    
    int
    SProcDeleteProperty(ClientPtr client)
    {
        REQUEST(xDeletePropertyReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xDeletePropertyReq);
        swapl(&stuff->window);
        swapl(&stuff->property);
        return ((*ProcVector[X_DeleteProperty]) (client));
    
    }
    
    int
    SProcGetProperty(ClientPtr client)
    {
        REQUEST(xGetPropertyReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xGetPropertyReq);
        swapl(&stuff->window);
        swapl(&stuff->property);
        swapl(&stuff->type);
        swapl(&stuff->longOffset);
        swapl(&stuff->longLength);
        return ((*ProcVector[X_GetProperty]) (client));
    }
    
    int
    SProcSetSelectionOwner(ClientPtr client)
    {
        REQUEST(xSetSelectionOwnerReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xSetSelectionOwnerReq);
        swapl(&stuff->window);
        swapl(&stuff->selection);
        swapl(&stuff->time);
        return ((*ProcVector[X_SetSelectionOwner]) (client));
    }
    
    int
    SProcConvertSelection(ClientPtr client)
    {
        REQUEST(xConvertSelectionReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xConvertSelectionReq);
        swapl(&stuff->requestor);
        swapl(&stuff->selection);
        swapl(&stuff->target);
        swapl(&stuff->property);
        swapl(&stuff->time);
        return ((*ProcVector[X_ConvertSelection]) (client));
    }
    
    int
    SProcSendEvent(ClientPtr client)
    {
        xEvent eventT = { .u.u.type = 0 };
        EventSwapPtr proc;
    
        REQUEST(xSendEventReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xSendEventReq);
        swapl(&stuff->destination);
        swapl(&stuff->eventMask);
    
        /* Generic events can have variable size, but SendEvent request holds
           exactly 32B of event data. */
        if (stuff->event.u.u.type == GenericEvent) {
            client->errorValue = stuff->event.u.u.type;
            return BadValue;
        }
    
        /* Swap event */
        proc = EventSwapVector[stuff->event.u.u.type & 0177];
        if (!proc || proc == NotImplemented)        /* no swapping proc; invalid event type? */
            return BadValue;
        (*proc) (&stuff->event, &eventT);
        stuff->event = eventT;
    
        return ((*ProcVector[X_SendEvent]) (client));
    }
    
    int
    SProcGrabPointer(ClientPtr client)
    {
        REQUEST(xGrabPointerReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xGrabPointerReq);
        swapl(&stuff->grabWindow);
        swaps(&stuff->eventMask);
        swapl(&stuff->confineTo);
        swapl(&stuff->cursor);
        swapl(&stuff->time);
        return ((*ProcVector[X_GrabPointer]) (client));
    }
    
    int
    SProcGrabButton(ClientPtr client)
    {
        REQUEST(xGrabButtonReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xGrabButtonReq);
        swapl(&stuff->grabWindow);
        swaps(&stuff->eventMask);
        swapl(&stuff->confineTo);
        swapl(&stuff->cursor);
        swaps(&stuff->modifiers);
        return ((*ProcVector[X_GrabButton]) (client));
    }
    
    int
    SProcUngrabButton(ClientPtr client)
    {
        REQUEST(xUngrabButtonReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xUngrabButtonReq);
        swapl(&stuff->grabWindow);
        swaps(&stuff->modifiers);
        return ((*ProcVector[X_UngrabButton]) (client));
    }
    
    int
    SProcChangeActivePointerGrab(ClientPtr client)
    {
        REQUEST(xChangeActivePointerGrabReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xChangeActivePointerGrabReq);
        swapl(&stuff->cursor);
        swapl(&stuff->time);
        swaps(&stuff->eventMask);
        return ((*ProcVector[X_ChangeActivePointerGrab]) (client));
    }
    
    int
    SProcGrabKeyboard(ClientPtr client)
    {
        REQUEST(xGrabKeyboardReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xGrabKeyboardReq);
        swapl(&stuff->grabWindow);
        swapl(&stuff->time);
        return ((*ProcVector[X_GrabKeyboard]) (client));
    }
    
    int
    SProcGrabKey(ClientPtr client)
    {
        REQUEST(xGrabKeyReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xGrabKeyReq);
        swapl(&stuff->grabWindow);
        swaps(&stuff->modifiers);
        return ((*ProcVector[X_GrabKey]) (client));
    }
    
    int
    SProcUngrabKey(ClientPtr client)
    {
        REQUEST(xUngrabKeyReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xUngrabKeyReq);
        swapl(&stuff->grabWindow);
        swaps(&stuff->modifiers);
        return ((*ProcVector[X_UngrabKey]) (client));
    }
    
    int
    SProcGetMotionEvents(ClientPtr client)
    {
        REQUEST(xGetMotionEventsReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xGetMotionEventsReq);
        swapl(&stuff->window);
        swapl(&stuff->start);
        swapl(&stuff->stop);
        return ((*ProcVector[X_GetMotionEvents]) (client));
    }
    
    int
    SProcTranslateCoords(ClientPtr client)
    {
        REQUEST(xTranslateCoordsReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xTranslateCoordsReq);
        swapl(&stuff->srcWid);
        swapl(&stuff->dstWid);
        swaps(&stuff->srcX);
        swaps(&stuff->srcY);
        return ((*ProcVector[X_TranslateCoords]) (client));
    }
    
    int
    SProcWarpPointer(ClientPtr client)
    {
        REQUEST(xWarpPointerReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xWarpPointerReq);
        swapl(&stuff->srcWid);
        swapl(&stuff->dstWid);
        swaps(&stuff->srcX);
        swaps(&stuff->srcY);
        swaps(&stuff->srcWidth);
        swaps(&stuff->srcHeight);
        swaps(&stuff->dstX);
        swaps(&stuff->dstY);
        return ((*ProcVector[X_WarpPointer]) (client));
    }
    
    int
    SProcSetInputFocus(ClientPtr client)
    {
        REQUEST(xSetInputFocusReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xSetInputFocusReq);
        swapl(&stuff->focus);
        swapl(&stuff->time);
        return ((*ProcVector[X_SetInputFocus]) (client));
    }
    
    int
    SProcOpenFont(ClientPtr client)
    {
        REQUEST(xOpenFontReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xOpenFontReq);
        swapl(&stuff->fid);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_OpenFont]) (client));
    }
    
    int
    SProcListFonts(ClientPtr client)
    {
        REQUEST(xListFontsReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xListFontsReq);
        swaps(&stuff->maxNames);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_ListFonts]) (client));
    }
    
    int
    SProcListFontsWithInfo(ClientPtr client)
    {
        REQUEST(xListFontsWithInfoReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xListFontsWithInfoReq);
        swaps(&stuff->maxNames);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_ListFontsWithInfo]) (client));
    }
    
    int
    SProcSetFontPath(ClientPtr client)
    {
        REQUEST(xSetFontPathReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xSetFontPathReq);
        swaps(&stuff->nFonts);
        return ((*ProcVector[X_SetFontPath]) (client));
    }
    
    int
    SProcCreatePixmap(ClientPtr client)
    {
        REQUEST(xCreatePixmapReq);
    
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCreatePixmapReq);
        swapl(&stuff->pid);
        swapl(&stuff->drawable);
        swaps(&stuff->width);
        swaps(&stuff->height);
        return ((*ProcVector[X_CreatePixmap]) (client));
    }
    
    int
    SProcCreateGC(ClientPtr client)
    {
        REQUEST(xCreateGCReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xCreateGCReq);
        swapl(&stuff->gc);
        swapl(&stuff->drawable);
        swapl(&stuff->mask);
        SwapRestL(stuff);
        return ((*ProcVector[X_CreateGC]) (client));
    }
    
    int
    SProcChangeGC(ClientPtr client)
    {
        REQUEST(xChangeGCReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xChangeGCReq);
        swapl(&stuff->gc);
        swapl(&stuff->mask);
        SwapRestL(stuff);
        return ((*ProcVector[X_ChangeGC]) (client));
    }
    
    int
    SProcCopyGC(ClientPtr client)
    {
        REQUEST(xCopyGCReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCopyGCReq);
        swapl(&stuff->srcGC);
        swapl(&stuff->dstGC);
        swapl(&stuff->mask);
        return ((*ProcVector[X_CopyGC]) (client));
    }
    
    int
    SProcSetDashes(ClientPtr client)
    {
        REQUEST(xSetDashesReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xSetDashesReq);
        swapl(&stuff->gc);
        swaps(&stuff->dashOffset);
        swaps(&stuff->nDashes);
        return ((*ProcVector[X_SetDashes]) (client));
    
    }
    
    int
    SProcSetClipRectangles(ClientPtr client)
    {
        REQUEST(xSetClipRectanglesReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xSetClipRectanglesReq);
        swapl(&stuff->gc);
        swaps(&stuff->xOrigin);
        swaps(&stuff->yOrigin);
        SwapRestS(stuff);
        return ((*ProcVector[X_SetClipRectangles]) (client));
    }
    
    int
    SProcClearToBackground(ClientPtr client)
    {
        REQUEST(xClearAreaReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xClearAreaReq);
        swapl(&stuff->window);
        swaps(&stuff->x);
        swaps(&stuff->y);
        swaps(&stuff->width);
        swaps(&stuff->height);
        return ((*ProcVector[X_ClearArea]) (client));
    }
    
    int
    SProcCopyArea(ClientPtr client)
    {
        REQUEST(xCopyAreaReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCopyAreaReq);
        swapl(&stuff->srcDrawable);
        swapl(&stuff->dstDrawable);
        swapl(&stuff->gc);
        swaps(&stuff->srcX);
        swaps(&stuff->srcY);
        swaps(&stuff->dstX);
        swaps(&stuff->dstY);
        swaps(&stuff->width);
        swaps(&stuff->height);
        return ((*ProcVector[X_CopyArea]) (client));
    }
    
    int
    SProcCopyPlane(ClientPtr client)
    {
        REQUEST(xCopyPlaneReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCopyPlaneReq);
        swapl(&stuff->srcDrawable);
        swapl(&stuff->dstDrawable);
        swapl(&stuff->gc);
        swaps(&stuff->srcX);
        swaps(&stuff->srcY);
        swaps(&stuff->dstX);
        swaps(&stuff->dstY);
        swaps(&stuff->width);
        swaps(&stuff->height);
        swapl(&stuff->bitPlane);
        return ((*ProcVector[X_CopyPlane]) (client));
    }
    
    /* The following routine is used for all Poly drawing requests
       (except FillPoly, which uses a different request format) */
    int
    SProcPoly(ClientPtr client)
    {
        REQUEST(xPolyPointReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xPolyPointReq);
        swapl(&stuff->drawable);
        swapl(&stuff->gc);
        SwapRestS(stuff);
        return ((*ProcVector[stuff->reqType]) (client));
    }
    
    /* cannot use SProcPoly for this one, because xFillPolyReq
       is longer than xPolyPointReq, and we don't want to swap
       the difference as shorts! */
    int
    SProcFillPoly(ClientPtr client)
    {
        REQUEST(xFillPolyReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xFillPolyReq);
        swapl(&stuff->drawable);
        swapl(&stuff->gc);
        SwapRestS(stuff);
        return ((*ProcVector[X_FillPoly]) (client));
    }
    
    int
    SProcPutImage(ClientPtr client)
    {
        REQUEST(xPutImageReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xPutImageReq);
        swapl(&stuff->drawable);
        swapl(&stuff->gc);
        swaps(&stuff->width);
        swaps(&stuff->height);
        swaps(&stuff->dstX);
        swaps(&stuff->dstY);
        /* Image should already be swapped */
        return ((*ProcVector[X_PutImage]) (client));
    
    }
    
    int
    SProcGetImage(ClientPtr client)
    {
        REQUEST(xGetImageReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xGetImageReq);
        swapl(&stuff->drawable);
        swaps(&stuff->x);
        swaps(&stuff->y);
        swaps(&stuff->width);
        swaps(&stuff->height);
        swapl(&stuff->planeMask);
        return ((*ProcVector[X_GetImage]) (client));
    }
    
    /* ProcPolyText used for both PolyText8 and PolyText16 */
    
    int
    SProcPolyText(ClientPtr client)
    {
        REQUEST(xPolyTextReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xPolyTextReq);
        swapl(&stuff->drawable);
        swapl(&stuff->gc);
        swaps(&stuff->x);
        swaps(&stuff->y);
        return ((*ProcVector[stuff->reqType]) (client));
    }
    
    /* ProcImageText used for both ImageText8 and ImageText16 */
    
    int
    SProcImageText(ClientPtr client)
    {
        REQUEST(xImageTextReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xImageTextReq);
        swapl(&stuff->drawable);
        swapl(&stuff->gc);
        swaps(&stuff->x);
        swaps(&stuff->y);
        return ((*ProcVector[stuff->reqType]) (client));
    }
    
    int
    SProcCreateColormap(ClientPtr client)
    {
        REQUEST(xCreateColormapReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCreateColormapReq);
        swapl(&stuff->mid);
        swapl(&stuff->window);
        swapl(&stuff->visual);
        return ((*ProcVector[X_CreateColormap]) (client));
    }
    
    int
    SProcCopyColormapAndFree(ClientPtr client)
    {
        REQUEST(xCopyColormapAndFreeReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCopyColormapAndFreeReq);
        swapl(&stuff->mid);
        swapl(&stuff->srcCmap);
        return ((*ProcVector[X_CopyColormapAndFree]) (client));
    
    }
    
    int
    SProcAllocColor(ClientPtr client)
    {
        REQUEST(xAllocColorReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xAllocColorReq);
        swapl(&stuff->cmap);
        swaps(&stuff->red);
        swaps(&stuff->green);
        swaps(&stuff->blue);
        return ((*ProcVector[X_AllocColor]) (client));
    }
    
    int
    SProcAllocNamedColor(ClientPtr client)
    {
        REQUEST(xAllocNamedColorReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xAllocNamedColorReq);
        swapl(&stuff->cmap);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_AllocNamedColor]) (client));
    }
    
    int
    SProcAllocColorCells(ClientPtr client)
    {
        REQUEST(xAllocColorCellsReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xAllocColorCellsReq);
        swapl(&stuff->cmap);
        swaps(&stuff->colors);
        swaps(&stuff->planes);
        return ((*ProcVector[X_AllocColorCells]) (client));
    }
    
    int
    SProcAllocColorPlanes(ClientPtr client)
    {
        REQUEST(xAllocColorPlanesReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xAllocColorPlanesReq);
        swapl(&stuff->cmap);
        swaps(&stuff->colors);
        swaps(&stuff->red);
        swaps(&stuff->green);
        swaps(&stuff->blue);
        return ((*ProcVector[X_AllocColorPlanes]) (client));
    }
    
    int
    SProcFreeColors(ClientPtr client)
    {
        REQUEST(xFreeColorsReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xFreeColorsReq);
        swapl(&stuff->cmap);
        swapl(&stuff->planeMask);
        SwapRestL(stuff);
        return ((*ProcVector[X_FreeColors]) (client));
    
    }
    
    void
    SwapColorItem(xColorItem * pItem)
    {
        swapl(&pItem->pixel);
        swaps(&pItem->red);
        swaps(&pItem->green);
        swaps(&pItem->blue);
    }
    
    int
    SProcStoreColors(ClientPtr client)
    {
        long count;
        xColorItem *pItem;
    
        REQUEST(xStoreColorsReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xStoreColorsReq);
        swapl(&stuff->cmap);
        pItem = (xColorItem *) &stuff[1];
        for (count = LengthRestB(stuff) / sizeof(xColorItem); --count >= 0;)
            SwapColorItem(pItem++);
        return ((*ProcVector[X_StoreColors]) (client));
    }
    
    int
    SProcStoreNamedColor(ClientPtr client)
    {
        REQUEST(xStoreNamedColorReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xStoreNamedColorReq);
        swapl(&stuff->cmap);
        swapl(&stuff->pixel);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_StoreNamedColor]) (client));
    }
    
    int
    SProcQueryColors(ClientPtr client)
    {
        REQUEST(xQueryColorsReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xQueryColorsReq);
        swapl(&stuff->cmap);
        SwapRestL(stuff);
        return ((*ProcVector[X_QueryColors]) (client));
    }
    
    int
    SProcLookupColor(ClientPtr client)
    {
        REQUEST(xLookupColorReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xLookupColorReq);
        swapl(&stuff->cmap);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_LookupColor]) (client));
    }
    
    int
    SProcCreateCursor(ClientPtr client)
    {
        REQUEST(xCreateCursorReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCreateCursorReq);
        swapl(&stuff->cid);
        swapl(&stuff->source);
        swapl(&stuff->mask);
        swaps(&stuff->foreRed);
        swaps(&stuff->foreGreen);
        swaps(&stuff->foreBlue);
        swaps(&stuff->backRed);
        swaps(&stuff->backGreen);
        swaps(&stuff->backBlue);
        swaps(&stuff->x);
        swaps(&stuff->y);
        return ((*ProcVector[X_CreateCursor]) (client));
    }
    
    int
    SProcCreateGlyphCursor(ClientPtr client)
    {
        REQUEST(xCreateGlyphCursorReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xCreateGlyphCursorReq);
        swapl(&stuff->cid);
        swapl(&stuff->source);
        swapl(&stuff->mask);
        swaps(&stuff->sourceChar);
        swaps(&stuff->maskChar);
        swaps(&stuff->foreRed);
        swaps(&stuff->foreGreen);
        swaps(&stuff->foreBlue);
        swaps(&stuff->backRed);
        swaps(&stuff->backGreen);
        swaps(&stuff->backBlue);
        return ((*ProcVector[X_CreateGlyphCursor]) (client));
    }
    
    int
    SProcRecolorCursor(ClientPtr client)
    {
        REQUEST(xRecolorCursorReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xRecolorCursorReq);
        swapl(&stuff->cursor);
        swaps(&stuff->foreRed);
        swaps(&stuff->foreGreen);
        swaps(&stuff->foreBlue);
        swaps(&stuff->backRed);
        swaps(&stuff->backGreen);
        swaps(&stuff->backBlue);
        return ((*ProcVector[X_RecolorCursor]) (client));
    }
    
    int
    SProcQueryBestSize(ClientPtr client)
    {
        REQUEST(xQueryBestSizeReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xQueryBestSizeReq);
        swapl(&stuff->drawable);
        swaps(&stuff->width);
        swaps(&stuff->height);
        return ((*ProcVector[X_QueryBestSize]) (client));
    
    }
    
    int
    SProcQueryExtension(ClientPtr client)
    {
        REQUEST(xQueryExtensionReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xQueryExtensionReq);
        swaps(&stuff->nbytes);
        return ((*ProcVector[X_QueryExtension]) (client));
    }
    
    int
    SProcChangeKeyboardMapping(ClientPtr client)
    {
        REQUEST(xChangeKeyboardMappingReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xChangeKeyboardMappingReq);
        SwapRestL(stuff);
        return ((*ProcVector[X_ChangeKeyboardMapping]) (client));
    }
    
    int
    SProcChangeKeyboardControl(ClientPtr client)
    {
        REQUEST(xChangeKeyboardControlReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xChangeKeyboardControlReq);
        swapl(&stuff->mask);
        SwapRestL(stuff);
        return ((*ProcVector[X_ChangeKeyboardControl]) (client));
    }
    
    int
    SProcChangePointerControl(ClientPtr client)
    {
        REQUEST(xChangePointerControlReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xChangePointerControlReq);
        swaps(&stuff->accelNum);
        swaps(&stuff->accelDenum);
        swaps(&stuff->threshold);
        return ((*ProcVector[X_ChangePointerControl]) (client));
    }
    
    int
    SProcSetScreenSaver(ClientPtr client)
    {
        REQUEST(xSetScreenSaverReq);
        swaps(&stuff->length);
        REQUEST_SIZE_MATCH(xSetScreenSaverReq);
        swaps(&stuff->timeout);
        swaps(&stuff->interval);
        return ((*ProcVector[X_SetScreenSaver]) (client));
    }
    
    int
    SProcChangeHosts(ClientPtr client)
    {
        REQUEST(xChangeHostsReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xChangeHostsReq);
        swaps(&stuff->hostLength);
        return ((*ProcVector[X_ChangeHosts]) (client));
    
    }
    
    int
    SProcRotateProperties(ClientPtr client)
    {
        REQUEST(xRotatePropertiesReq);
        swaps(&stuff->length);
        REQUEST_AT_LEAST_SIZE(xRotatePropertiesReq);
        swapl(&stuff->window);
        swaps(&stuff->nAtoms);
        swaps(&stuff->nPositions);
        SwapRestL(stuff);
        return ((*ProcVector[X_RotateProperties]) (client));
    }
    
    int
    SProcNoOperation(ClientPtr client)
    {
        REQUEST(xReq);
        swaps(&stuff->length);
        return ((*ProcVector[X_NoOperation]) (client));
    }
    
    void
    SwapConnClientPrefix(xConnClientPrefix * pCCP)
    {
        swaps(&pCCP->majorVersion);
        swaps(&pCCP->minorVersion);
        swaps(&pCCP->nbytesAuthProto);
        swaps(&pCCP->nbytesAuthString);
    }