1401 lines
38 KiB
C
1401 lines
38 KiB
C
/************************************************************
|
|
Copyright 1987 by Sun Microsystems, Inc. Mountain View, CA.
|
|
|
|
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 no-
|
|
tice appear in all copies and that both that copyright no-
|
|
tice and this permission notice appear in supporting docu-
|
|
mentation, and that the names of Sun or The Open Group
|
|
not be used in advertising or publicity pertaining to
|
|
distribution of the software without specific prior
|
|
written permission. Sun and The Open Group make no
|
|
representations about the suitability of this software for
|
|
any purpose. It is provided "as is" without any express or
|
|
implied warranty.
|
|
|
|
SUN DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
|
INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FIT-
|
|
NESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SUN BE LI-
|
|
ABLE 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.
|
|
|
|
********************************************************/
|
|
|
|
|
|
/*
|
|
* ==========================================================================
|
|
* Converted to Color Frame Buffer by smarks@sun, April-May 1987. The "bit
|
|
* numbering" in the doc below really means "byte numbering" now.
|
|
* ==========================================================================
|
|
*/
|
|
|
|
/*
|
|
these tables are used by several macros in the cfb code.
|
|
|
|
the vax numbers everything left to right, so bit indices on the
|
|
screen match bit indices in longwords. the pc-rt and Sun number
|
|
bits on the screen the way they would be written on paper,
|
|
(i.e. msb to the left), and so a bit index n on the screen is
|
|
bit index 32-n in a longword
|
|
|
|
see also cfbmskbits.h
|
|
*/
|
|
#ifdef HAVE_DIX_CONFIG_H
|
|
#include <dix-config.h>
|
|
#endif
|
|
|
|
#include <X11/X.h>
|
|
#include <X11/Xmd.h>
|
|
#include <servermd.h>
|
|
#include "cfb.h"
|
|
#include "cfbmskbits.h"
|
|
|
|
#define _cfbBits(a) (PixelGroup)(a)
|
|
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
#define cfbBits(v) _cfbBits(v)
|
|
#else /* BITMAP_BIT_ORDER == LSBFirst */
|
|
#define cfbFlip2(a) ((((a) & 0x1) << 1) | (((a) & 0x2) >> 1))
|
|
#define cfbFlip4(a) ((cfbFlip2(a) << 2) | cfbFlip2(a >> 2))
|
|
#define cfbFlip8(a) ((cfbFlip4(a) << 4) | cfbFlip4(a >> 4))
|
|
#define cfbFlip16(a) ((cfbFlip8(a) << 8) | cfbFlip8(a >> 8))
|
|
#define cfbFlip32(a) ((cfbFlip16(a) << 16) | cfbFlip16(a >> 16))
|
|
#if PGSZ == 32
|
|
#define cfbBits(a) cfbFlip32(_cfbBits(a))
|
|
#else /* PGSZ == 64 */
|
|
#define cfbFlip64(a) ((cfbFlip32(a) << 32) | cfbFlip32(a >> 32))
|
|
#define cfbBits(a) cfbFlip64(_cfbBits(a))
|
|
#endif /* PGSZ */
|
|
#endif /* BITMAP_BIT_ORDER */
|
|
|
|
/* NOTE:
|
|
the first element in starttab could be 0xffffffff. making it 0
|
|
lets us deal with a full first word in the middle loop, rather
|
|
than having to do the multiple reads and masks that we'd
|
|
have to do if we thought it was partial.
|
|
*/
|
|
#if PSZ == 4
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0x0FFFFFFF),
|
|
cfbBits(0x00FFFFFF),
|
|
cfbBits(0x000FFFFF),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0x00000FFF),
|
|
cfbBits(0x000000FF),
|
|
cfbBits(0x0000000F)
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0xF0000000),
|
|
cfbBits(0xFF000000),
|
|
cfbBits(0xFFF00000),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0xFFFFF000),
|
|
cfbBits(0xFFFFFF00),
|
|
cfbBits(0xFFFFFFF0)
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x0FFFFFFFFFFFFFFF),
|
|
cfbBits(0x00FFFFFFFFFFFFFF),
|
|
cfbBits(0x000FFFFFFFFFFFFF),
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0x00000FFFFFFFFFFF),
|
|
cfbBits(0x000000FFFFFFFFFF),
|
|
cfbBits(0x0000000FFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0x000000000FFFFFFF),
|
|
cfbBits(0x0000000000FFFFFF),
|
|
cfbBits(0x00000000000FFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
cfbBits(0x0000000000000FFF),
|
|
cfbBits(0x00000000000000FF),
|
|
cfbBits(0x000000000000000F),
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0xF000000000000000),
|
|
cfbBits(0xFF00000000000000),
|
|
cfbBits(0xFFF0000000000000),
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0xFFFFF00000000000),
|
|
cfbBits(0xFFFFFF0000000000),
|
|
cfbBits(0xFFFFFFF000000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0xFFFFFFFFF0000000),
|
|
cfbBits(0xFFFFFFFFFF000000),
|
|
cfbBits(0xFFFFFFFFFFF00000),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
cfbBits(0xFFFFFFFFFFFFF000),
|
|
cfbBits(0xFFFFFFFFFFFFFF00),
|
|
cfbBits(0xFFFFFFFFFFFFFFF0),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 4 */
|
|
|
|
#if PSZ == 8
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0x00FFFFFF),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0x000000FF)
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0xFF000000),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0xFFFFFF00)
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x00FFFFFFFFFFFFFF),
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0x000000FFFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0x0000000000FFFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
cfbBits(0x00000000000000FF)
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0xFF00000000000000),
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0xFFFFFF0000000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0xFFFFFFFFFF000000),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
cfbBits(0xFFFFFFFFFFFFFF00)
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 8 */
|
|
|
|
#if PSZ == 16
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0x0000FFFF),
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0xFFFF0000),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif
|
|
|
|
#if PSZ == 24
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0x000000FF),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0x00FFFFFF),
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
cfbBits(0xFFFFFF00),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0xFF000000),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x000000FFFFFFFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0xFFFFFFFFFF000000),
|
|
cfbBits(0xFFFF000000000000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 24 */
|
|
|
|
#if PSZ == 32
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x00000000),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstarttab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
};
|
|
PixelGroup cfbendtab[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 32 */
|
|
|
|
/* a hack, for now, since the entries for 0 need to be all
|
|
1 bits, not all zeros.
|
|
this means the code DOES NOT WORK for segments of length
|
|
0 (which is only a problem in the horizontal line code.)
|
|
*/
|
|
#if PSZ == 4
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0x0FFFFFFF),
|
|
cfbBits(0x00FFFFFF),
|
|
cfbBits(0x000FFFFF),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0x00000FFF),
|
|
cfbBits(0x000000FF),
|
|
cfbBits(0x0000000F)
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0xF0000000),
|
|
cfbBits(0xFF000000),
|
|
cfbBits(0xFFF00000),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0xFFFFF000),
|
|
cfbBits(0xFFFFFF00),
|
|
cfbBits(0xFFFFFFF0)
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0x0FFFFFFFFFFFFFFF),
|
|
cfbBits(0x00FFFFFFFFFFFFFF),
|
|
cfbBits(0x000FFFFFFFFFFFFF),
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0x00000FFFFFFFFFFF),
|
|
cfbBits(0x000000FFFFFFFFFF),
|
|
cfbBits(0x0000000FFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0x000000000FFFFFFF),
|
|
cfbBits(0x0000000000FFFFFF),
|
|
cfbBits(0x00000000000FFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
cfbBits(0x0000000000000FFF),
|
|
cfbBits(0x00000000000000FF),
|
|
cfbBits(0x000000000000000F),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0xF000000000000000),
|
|
cfbBits(0xFF00000000000000),
|
|
cfbBits(0xFFF0000000000000),
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0xFFFFF00000000000),
|
|
cfbBits(0xFFFFFF0000000000),
|
|
cfbBits(0xFFFFFFF000000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0xFFFFFFFFF0000000),
|
|
cfbBits(0xFFFFFFFFFF000000),
|
|
cfbBits(0xFFFFFFFFFFF00000),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
cfbBits(0xFFFFFFFFFFFFF000),
|
|
cfbBits(0xFFFFFFFFFFFFFF00),
|
|
cfbBits(0xFFFFFFFFFFFFFFF0),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 4 */
|
|
|
|
#if PSZ == 8
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0x00FFFFFF),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0x000000FF)
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0xFF000000),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0xFFFFFF00)
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0x00FFFFFFFFFFFFFF),
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0x000000FFFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0x0000000000FFFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
cfbBits(0x00000000000000FF),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0xFF00000000000000),
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0xFFFFFF0000000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0xFFFFFFFFFF000000),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
cfbBits(0xFFFFFFFFFFFFFF00),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 8 */
|
|
|
|
#if PSZ == 16
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0x0000FFFF),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0xFFFF0000),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 16 */
|
|
|
|
#if PSZ == 24
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0x000000FF),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0x00FFFFFF),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0xFFFFFF00),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0xFF000000),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0x000000FFFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0x0000000000FFFFFF),
|
|
cfbBits(0x000000000000FFFF),
|
|
cfbBits(0x00000000000000FF),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
cfbBits(0xFFFFFFFFFF000000),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0xFFFFFF0000000000),
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0xFF00000000000000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 24 */
|
|
|
|
#if PSZ == 32
|
|
#if PGSZ == 32
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbstartpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
};
|
|
|
|
PixelGroup cfbendpartial[] =
|
|
{
|
|
cfbBits(0xFFFFFFFFFFFFFFFF),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 32 */
|
|
|
|
/* used for masking bits in bresenham lines
|
|
mask[n] is used to mask out all but bit n in a longword (n is a
|
|
screen position).
|
|
rmask[n] is used to mask out the single bit at position n (n
|
|
is a screen posiotion.)
|
|
*/
|
|
|
|
#if PSZ == 4
|
|
#if PGSZ == 32
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xF0000000),
|
|
cfbBits(0x0F000000),
|
|
cfbBits(0x00F00000),
|
|
cfbBits(0x000F0000),
|
|
cfbBits(0x0000F000),
|
|
cfbBits(0x00000F00),
|
|
cfbBits(0x000000F0),
|
|
cfbBits(0x0000000F)
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x0FFFFFFF),
|
|
cfbBits(0xF0FFFFFF),
|
|
cfbBits(0xFF0FFFFF),
|
|
cfbBits(0xFFF0FFFF),
|
|
cfbBits(0xFFFF0FFF),
|
|
cfbBits(0xFFFFF0FF),
|
|
cfbBits(0xFFFFFF0F),
|
|
cfbBits(0xFFFFFFF0)
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xF000000000000000),
|
|
cfbBits(0x0F00000000000000),
|
|
cfbBits(0x00F0000000000000),
|
|
cfbBits(0x000F000000000000),
|
|
cfbBits(0x0000F00000000000),
|
|
cfbBits(0x00000F0000000000),
|
|
cfbBits(0x000000F000000000),
|
|
cfbBits(0x0000000F00000000),
|
|
cfbBits(0x00000000F0000000),
|
|
cfbBits(0x000000000F000000),
|
|
cfbBits(0x0000000000F00000),
|
|
cfbBits(0x00000000000F0000),
|
|
cfbBits(0x000000000000F000),
|
|
cfbBits(0x0000000000000F00),
|
|
cfbBits(0x00000000000000F0),
|
|
cfbBits(0x000000000000000F),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x0FFFFFFFFFFFFFFF),
|
|
cfbBits(0xF0FFFFFFFFFFFFFF),
|
|
cfbBits(0xFF0FFFFFFFFFFFFF),
|
|
cfbBits(0xFFF0FFFFFFFFFFFF),
|
|
cfbBits(0xFFFF0FFFFFFFFFFF),
|
|
cfbBits(0xFFFFF0FFFFFFFFFF),
|
|
cfbBits(0xFFFFFF0FFFFFFFFF),
|
|
cfbBits(0xFFFFFFF0FFFFFFFF),
|
|
cfbBits(0xFFFFFFFF0FFFFFFF),
|
|
cfbBits(0xFFFFFFFFF0FFFFFF),
|
|
cfbBits(0xFFFFFFFFFF0FFFFF),
|
|
cfbBits(0xFFFFFFFFFFF0FFFF),
|
|
cfbBits(0xFFFFFFFFFFFF0FFF),
|
|
cfbBits(0xFFFFFFFFFFFFF0FF),
|
|
cfbBits(0xFFFFFFFFFFFFFF0F),
|
|
cfbBits(0xFFFFFFFFFFFFFFF0),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 4 */
|
|
|
|
#if PSZ == 8
|
|
#if PGSZ == 32
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFF000000),
|
|
cfbBits(0x00FF0000),
|
|
cfbBits(0x0000FF00),
|
|
cfbBits(0x000000FF)
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x00FFFFFF),
|
|
cfbBits(0xFF00FFFF),
|
|
cfbBits(0xFFFF00FF),
|
|
cfbBits(0xFFFFFF00)
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFF00000000000000),
|
|
cfbBits(0x00FF000000000000),
|
|
cfbBits(0x0000FF0000000000),
|
|
cfbBits(0x000000FF00000000),
|
|
cfbBits(0x00000000FF000000),
|
|
cfbBits(0x0000000000FF0000),
|
|
cfbBits(0x000000000000FF00),
|
|
cfbBits(0x00000000000000FF),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x00FFFFFFFFFFFFFF),
|
|
cfbBits(0xFF00FFFFFFFFFFFF),
|
|
cfbBits(0xFFFF00FFFFFFFFFF),
|
|
cfbBits(0xFFFFFF00FFFFFFFF),
|
|
cfbBits(0xFFFFFFFF00FFFFFF),
|
|
cfbBits(0xFFFFFFFFFF00FFFF),
|
|
cfbBits(0xFFFFFFFFFFFF00FF),
|
|
cfbBits(0xFFFFFFFFFFFFFF00),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 8 */
|
|
|
|
#if PSZ == 16
|
|
#if PGSZ == 32
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0x0000FFFF),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0xFFFF0000),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFFFF000000000000),
|
|
cfbBits(0x0000FFFF00000000),
|
|
cfbBits(0x00000000FFFF0000),
|
|
cfbBits(0x000000000000FFFF),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x0000FFFFFFFFFFFF),
|
|
cfbBits(0xFFFF0000FFFFFFFF),
|
|
cfbBits(0xFFFFFFFF0000FFFF),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 16 */
|
|
|
|
#if PSZ == 24
|
|
#if PGSZ == 32
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFFFFFF00),
|
|
cfbBits(0x00000000),
|
|
cfbBits(0x000000FF),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0xFF000000),
|
|
cfbBits(0x00FFFFFF),
|
|
cfbBits(0x00000000),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x000000FF),
|
|
cfbBits(0xFFFFFFFF),
|
|
cfbBits(0xFFFFFF00),
|
|
cfbBits(0x0000FFFF),
|
|
cfbBits(0xFFFF0000),
|
|
cfbBits(0x00FFFFFF),
|
|
cfbBits(0xFF000000),
|
|
cfbBits(0xFFFFFFFF),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFFFFFF0000000000),
|
|
cfbBits(0x000000FFFFFF0000),
|
|
cfbBits(0x000000000000FFFF),
|
|
};
|
|
PixelGroup cfbmask2[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0xFF00000000000000),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x000000FFFFFFFFFF),
|
|
cfbBits(0xFFFFFF000000FFFF),
|
|
cfbBits(0xFFFFFFFFFFFF0000),
|
|
};
|
|
PixelGroup cfbrmask2[] =
|
|
{
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x0000000000000000),
|
|
cfbBits(0x00FFFFFFFFFFFFFF),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 24 */
|
|
|
|
#if PSZ == 32
|
|
#if PGSZ == 32
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF),
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
PixelGroup cfbmask[] =
|
|
{
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
};
|
|
PixelGroup cfbrmask[] =
|
|
{
|
|
cfbBits(0x00000000FFFFFFFF),
|
|
cfbBits(0xFFFFFFFF00000000),
|
|
};
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 32 */
|
|
|
|
/*
|
|
* QuartetBitsTable contains PPW+1 masks whose binary values are masks in the
|
|
* low order quartet that contain the number of bits specified in the
|
|
* index. This table is used by getstipplepixels.
|
|
*/
|
|
#if PSZ == 4
|
|
PixelGroup QuartetBitsTable[] = {
|
|
#if PGSZ == 32
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 00000000 */
|
|
0x00000080, /* 1 - 10000000 */
|
|
0x000000C0, /* 2 - 11000000 */
|
|
0x000000E0, /* 3 - 11100000 */
|
|
0x000000F0, /* 4 - 11110000 */
|
|
0x000000F8, /* 5 - 11111000 */
|
|
0x000000FC, /* 6 - 11111100 */
|
|
0x000000FE, /* 7 - 11111110 */
|
|
0x000000FF /* 8 - 11111111 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 00000000 */
|
|
0x00000001, /* 1 - 00000001 */
|
|
0x00000003, /* 2 - 00000011 */
|
|
0x00000007, /* 3 - 00000111 */
|
|
0x0000000F, /* 4 - 00001111 */
|
|
0x0000001F, /* 5 - 00011111 */
|
|
0x0000003F, /* 6 - 00111111 */
|
|
0x0000007F, /* 7 - 01111111 */
|
|
0x000000FF /* 8 - 11111111 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#else /* PGSZ == 64 */
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 0000000000000000 */
|
|
0x00008000, /* 1 - 1000000000000000 */
|
|
0x0000C000, /* 2 - 1100000000000000 */
|
|
0x0000E000, /* 3 - 1110000000000000 */
|
|
0x0000F000, /* 4 - 1111000000000000 */
|
|
0x0000F800, /* 5 - 1111100000000000 */
|
|
0x0000FC00, /* 6 - 1111110000000000 */
|
|
0x0000FE00, /* 7 - 1111111000000000 */
|
|
0x0000FF00, /* 8 - 1111111100000000 */
|
|
0x0000FF80, /* 9 - 1111111110000000 */
|
|
0x0000FFC0, /* 10- 1111111111000000 */
|
|
0x0000FFE0, /* 11- 1111111111100000 */
|
|
0x0000FFF0, /* 12- 1111111111110000 */
|
|
0x0000FFF8, /* 13- 1111111111111000 */
|
|
0x0000FFFC, /* 14- 1111111111111100 */
|
|
0x0000FFFE, /* 15- 1111111111111110 */
|
|
0x0000FFFF, /* 16- 1111111111111111 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 0000000000000000 */
|
|
0x00000001, /* 1 - 0000000000000001 */
|
|
0x00000003, /* 2 - 0000000000000011 */
|
|
0x00000007, /* 3 - 0000000000000111 */
|
|
0x0000000F, /* 4 - 0000000000001111 */
|
|
0x0000001F, /* 5 - 0000000000011111 */
|
|
0x0000003F, /* 6 - 0000000000111111 */
|
|
0x0000007F, /* 7 - 0000000001111111 */
|
|
0x000000FF, /* 8 - 0000000011111111 */
|
|
0x000001FF, /* 9 - 0000000111111111 */
|
|
0x000003FF, /* 10- 0000001111111111 */
|
|
0x000007FF, /* 11- 0000011111111111 */
|
|
0x00000FFF, /* 12- 0000111111111111 */
|
|
0x00001FFF, /* 13- 0001111111111111 */
|
|
0x00003FFF, /* 14- 0011111111111111 */
|
|
0x00007FFF, /* 15- 0111111111111111 */
|
|
0x0000FFFF, /* 16- 1111111111111111 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 4 */
|
|
|
|
#if PSZ == 8
|
|
PixelGroup QuartetBitsTable[] = {
|
|
#if PGSZ == 32
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 0000 */
|
|
0x00000008, /* 1 - 1000 */
|
|
0x0000000C, /* 2 - 1100 */
|
|
0x0000000E, /* 3 - 1110 */
|
|
0x0000000F /* 4 - 1111 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 0000 */
|
|
0x00000001, /* 1 - 0001 */
|
|
0x00000003, /* 2 - 0011 */
|
|
0x00000007, /* 3 - 0111 */
|
|
0x0000000F /* 4 - 1111 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#else /* PGSZ == 64 */
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 00000000 */
|
|
0x00000080, /* 1 - 10000000 */
|
|
0x000000C0, /* 2 - 11000000 */
|
|
0x000000E0, /* 3 - 11100000 */
|
|
0x000000F0, /* 4 - 11110000 */
|
|
0x000000F8, /* 5 - 11111000 */
|
|
0x000000FC, /* 6 - 11111100 */
|
|
0x000000FE, /* 7 - 11111110 */
|
|
0x000000FF /* 8 - 11111111 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 00000000 */
|
|
0x00000001, /* 1 - 00000001 */
|
|
0x00000003, /* 2 - 00000011 */
|
|
0x00000007, /* 3 - 00000111 */
|
|
0x0000000F, /* 4 - 10000111 */
|
|
0x0000001F, /* 5 - 00011111 */
|
|
0x0000003F, /* 6 - 00111111 */
|
|
0x0000007F, /* 7 - 01111111 */
|
|
0x000000FF /* 8 - 11111111 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 8 */
|
|
|
|
#if PSZ == 16
|
|
PixelGroup QuartetBitsTable[] = {
|
|
#if PGSZ == 32
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 00 */
|
|
0x00000002, /* 1 - 10 */
|
|
0x00000003, /* 2 - 11 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 00 */
|
|
0x00000001, /* 1 - 01 */
|
|
0x00000003, /* 2 - 11 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#else /* PGSZ == 64 */
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 0000 */
|
|
0x00000008, /* 1 - 1000 */
|
|
0x0000000C, /* 2 - 1100 */
|
|
0x0000000E, /* 3 - 1110 */
|
|
0x0000000F, /* 4 - 1111 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 0000 */
|
|
0x00000001, /* 1 - 0001 */
|
|
0x00000003, /* 2 - 0011 */
|
|
0x00000007, /* 3 - 0111 */
|
|
0x0000000F, /* 4 - 1111 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 16 */
|
|
|
|
#if PSZ == 24
|
|
PixelGroup QuartetBitsTable[] = {
|
|
#if PGSZ == 32
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 0 */
|
|
0x00000001, /* 1 - 1 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 0 */
|
|
0x00000001, /* 1 - 1 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#else /* PGSZ == 64 */
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 00 */
|
|
0x00000002, /* 1 - 10 */
|
|
0x00000003, /* 2 - 11*/
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 00 */
|
|
0x00000001, /* 1 - 01 */
|
|
0x00000003, /* 2 - 11 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 24 */
|
|
|
|
#if PSZ == 32
|
|
PixelGroup QuartetBitsTable[] = {
|
|
#if PGSZ == 32
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 0 */
|
|
0x00000001, /* 1 - 1 */
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 0 */
|
|
0x00000001, /* 1 - 1 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#else /* PGSZ == 64 */
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
0x00000000, /* 0 - 00 */
|
|
0x00000002, /* 1 - 10 */
|
|
0x00000003, /* 2 - 11*/
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst */
|
|
0x00000000, /* 0 - 00 */
|
|
0x00000001, /* 1 - 01 */
|
|
0x00000003, /* 2 - 11 */
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 32 */
|
|
|
|
/*
|
|
* QuartetPixelMaskTable is used by getstipplepixels to get a pixel mask
|
|
* corresponding to a quartet of bits. Note: the bit/byte order dependency
|
|
* is handled by QuartetBitsTable above.
|
|
*/
|
|
#if PSZ == 4
|
|
#if PGSZ == 32
|
|
PixelGroup QuartetPixelMaskTable[] = {
|
|
0x00000000,
|
|
0x0000000F,
|
|
0x000000F0,
|
|
0x000000FF,
|
|
0x00000F00,
|
|
0x00000F0F,
|
|
0x00000FF0,
|
|
0x00000FFF,
|
|
0x0000F000,
|
|
0x0000F00F,
|
|
0x0000F0F0,
|
|
0x0000F0FF,
|
|
0x0000FF00,
|
|
0x0000FF0F,
|
|
0x0000FFF0,
|
|
0x0000FFFF,
|
|
0x000F0000,
|
|
0x000F000F,
|
|
0x000F00F0,
|
|
0x000F00FF,
|
|
0x000F0F00,
|
|
0x000F0F0F,
|
|
0x000F0FF0,
|
|
0x000F0FFF,
|
|
0x000FF000,
|
|
0x000FF00F,
|
|
0x000FF0F0,
|
|
0x000FF0FF,
|
|
0x000FFF00,
|
|
0x000FFF0F,
|
|
0x000FFFF0,
|
|
0x000FFFFF,
|
|
0x00F00000,
|
|
0x00F0000F,
|
|
0x00F000F0,
|
|
0x00F000FF,
|
|
0x00F00F00,
|
|
0x00F00F0F,
|
|
0x00F00FF0,
|
|
0x00F00FFF,
|
|
0x00F0F000,
|
|
0x00F0F00F,
|
|
0x00F0F0F0,
|
|
0x00F0F0FF,
|
|
0x00F0FF00,
|
|
0x00F0FF0F,
|
|
0x00F0FFF0,
|
|
0x00F0FFFF,
|
|
0x00FF0000,
|
|
0x00FF000F,
|
|
0x00FF00F0,
|
|
0x00FF00FF,
|
|
0x00FF0F00,
|
|
0x00FF0F0F,
|
|
0x00FF0FF0,
|
|
0x00FF0FFF,
|
|
0x00FFF000,
|
|
0x00FFF00F,
|
|
0x00FFF0F0,
|
|
0x00FFF0FF,
|
|
0x00FFFF00,
|
|
0x00FFFF0F,
|
|
0x00FFFFF0,
|
|
0x00FFFFFF,
|
|
0x0F000000,
|
|
0x0F00000F,
|
|
0x0F0000F0,
|
|
0x0F0000FF,
|
|
0x0F000F00,
|
|
0x0F000F0F,
|
|
0x0F000FF0,
|
|
0x0F000FFF,
|
|
0x0F00F000,
|
|
0x0F00F00F,
|
|
0x0F00F0F0,
|
|
0x0F00F0FF,
|
|
0x0F00FF00,
|
|
0x0F00FF0F,
|
|
0x0F00FFF0,
|
|
0x0F00FFFF,
|
|
0x0F0F0000,
|
|
0x0F0F000F,
|
|
0x0F0F00F0,
|
|
0x0F0F00FF,
|
|
0x0F0F0F00,
|
|
0x0F0F0F0F,
|
|
0x0F0F0FF0,
|
|
0x0F0F0FFF,
|
|
0x0F0FF000,
|
|
0x0F0FF00F,
|
|
0x0F0FF0F0,
|
|
0x0F0FF0FF,
|
|
0x0F0FFF00,
|
|
0x0F0FFF0F,
|
|
0x0F0FFFF0,
|
|
0x0F0FFFFF,
|
|
0x0FF00000,
|
|
0x0FF0000F,
|
|
0x0FF000F0,
|
|
0x0FF000FF,
|
|
0x0FF00F00,
|
|
0x0FF00F0F,
|
|
0x0FF00FF0,
|
|
0x0FF00FFF,
|
|
0x0FF0F000,
|
|
0x0FF0F00F,
|
|
0x0FF0F0F0,
|
|
0x0FF0F0FF,
|
|
0x0FF0FF00,
|
|
0x0FF0FF0F,
|
|
0x0FF0FFF0,
|
|
0x0FF0FFFF,
|
|
0x0FFF0000,
|
|
0x0FFF000F,
|
|
0x0FFF00F0,
|
|
0x0FFF00FF,
|
|
0x0FFF0F00,
|
|
0x0FFF0F0F,
|
|
0x0FFF0FF0,
|
|
0x0FFF0FFF,
|
|
0x0FFFF000,
|
|
0x0FFFF00F,
|
|
0x0FFFF0F0,
|
|
0x0FFFF0FF,
|
|
0x0FFFFF00,
|
|
0x0FFFFF0F,
|
|
0x0FFFFFF0,
|
|
0x0FFFFFFF,
|
|
0xF0000000,
|
|
0xF000000F,
|
|
0xF00000F0,
|
|
0xF00000FF,
|
|
0xF0000F00,
|
|
0xF0000F0F,
|
|
0xF0000FF0,
|
|
0xF0000FFF,
|
|
0xF000F000,
|
|
0xF000F00F,
|
|
0xF000F0F0,
|
|
0xF000F0FF,
|
|
0xF000FF00,
|
|
0xF000FF0F,
|
|
0xF000FFF0,
|
|
0xF000FFFF,
|
|
0xF00F0000,
|
|
0xF00F000F,
|
|
0xF00F00F0,
|
|
0xF00F00FF,
|
|
0xF00F0F00,
|
|
0xF00F0F0F,
|
|
0xF00F0FF0,
|
|
0xF00F0FFF,
|
|
0xF00FF000,
|
|
0xF00FF00F,
|
|
0xF00FF0F0,
|
|
0xF00FF0FF,
|
|
0xF00FFF00,
|
|
0xF00FFF0F,
|
|
0xF00FFFF0,
|
|
0xF00FFFFF,
|
|
0xF0F00000,
|
|
0xF0F0000F,
|
|
0xF0F000F0,
|
|
0xF0F000FF,
|
|
0xF0F00F00,
|
|
0xF0F00F0F,
|
|
0xF0F00FF0,
|
|
0xF0F00FFF,
|
|
0xF0F0F000,
|
|
0xF0F0F00F,
|
|
0xF0F0F0F0,
|
|
0xF0F0F0FF,
|
|
0xF0F0FF00,
|
|
0xF0F0FF0F,
|
|
0xF0F0FFF0,
|
|
0xF0F0FFFF,
|
|
0xF0FF0000,
|
|
0xF0FF000F,
|
|
0xF0FF00F0,
|
|
0xF0FF00FF,
|
|
0xF0FF0F00,
|
|
0xF0FF0F0F,
|
|
0xF0FF0FF0,
|
|
0xF0FF0FFF,
|
|
0xF0FFF000,
|
|
0xF0FFF00F,
|
|
0xF0FFF0F0,
|
|
0xF0FFF0FF,
|
|
0xF0FFFF00,
|
|
0xF0FFFF0F,
|
|
0xF0FFFFF0,
|
|
0xF0FFFFFF,
|
|
0xFF000000,
|
|
0xFF00000F,
|
|
0xFF0000F0,
|
|
0xFF0000FF,
|
|
0xFF000F00,
|
|
0xFF000F0F,
|
|
0xFF000FF0,
|
|
0xFF000FFF,
|
|
0xFF00F000,
|
|
0xFF00F00F,
|
|
0xFF00F0F0,
|
|
0xFF00F0FF,
|
|
0xFF00FF00,
|
|
0xFF00FF0F,
|
|
0xFF00FFF0,
|
|
0xFF00FFFF,
|
|
0xFF0F0000,
|
|
0xFF0F000F,
|
|
0xFF0F00F0,
|
|
0xFF0F00FF,
|
|
0xFF0F0F00,
|
|
0xFF0F0F0F,
|
|
0xFF0F0FF0,
|
|
0xFF0F0FFF,
|
|
0xFF0FF000,
|
|
0xFF0FF00F,
|
|
0xFF0FF0F0,
|
|
0xFF0FF0FF,
|
|
0xFF0FFF00,
|
|
0xFF0FFF0F,
|
|
0xFF0FFFF0,
|
|
0xFF0FFFFF,
|
|
0xFFF00000,
|
|
0xFFF0000F,
|
|
0xFFF000F0,
|
|
0xFFF000FF,
|
|
0xFFF00F00,
|
|
0xFFF00F0F,
|
|
0xFFF00FF0,
|
|
0xFFF00FFF,
|
|
0xFFF0F000,
|
|
0xFFF0F00F,
|
|
0xFFF0F0F0,
|
|
0xFFF0F0FF,
|
|
0xFFF0FF00,
|
|
0xFFF0FF0F,
|
|
0xFFF0FFF0,
|
|
0xFFF0FFFF,
|
|
0xFFFF0000,
|
|
0xFFFF000F,
|
|
0xFFFF00F0,
|
|
0xFFFF00FF,
|
|
0xFFFF0F00,
|
|
0xFFFF0F0F,
|
|
0xFFFF0FF0,
|
|
0xFFFF0FFF,
|
|
0xFFFFF000,
|
|
0xFFFFF00F,
|
|
0xFFFFF0F0,
|
|
0xFFFFF0FF,
|
|
0xFFFFFF00,
|
|
0xFFFFFF0F,
|
|
0xFFFFFFF0,
|
|
0xFFFFFFFF,
|
|
};
|
|
#else /* PGSZ == 64 */
|
|
No QuartetPixelMaskTable for psz=PSZ
|
|
this would be a 64K entry table, a bit much I think.
|
|
Try breaking things in two:
|
|
mask = table[index&0xff00]<<32 | table[index&0xff]
|
|
#endif /* PGSZ */
|
|
#endif /* PSZ == 4 */
|
|
|
|
#if PSZ == 8
|
|
PixelGroup QuartetPixelMaskTable[] = {
|
|
#if PGSZ == 32
|
|
0x00000000,
|
|
0x000000FF,
|
|
0x0000FF00,
|
|
0x0000FFFF,
|
|
0x00FF0000,
|
|
0x00FF00FF,
|
|
0x00FFFF00,
|
|
0x00FFFFFF,
|
|
0xFF000000,
|
|
0xFF0000FF,
|
|
0xFF00FF00,
|
|
0xFF00FFFF,
|
|
0xFFFF0000,
|
|
0xFFFF00FF,
|
|
0xFFFFFF00,
|
|
0xFFFFFFFF
|
|
#else /* PGSZ == 64 */
|
|
0x0000000000000000, 0x00000000000000FF,
|
|
0x000000000000FF00, 0x000000000000FFFF,
|
|
0x0000000000FF0000, 0x0000000000FF00FF,
|
|
0x0000000000FFFF00, 0x0000000000FFFFFF,
|
|
0x00000000FF000000, 0x00000000FF0000FF,
|
|
0x00000000FF00FF00, 0x00000000FF00FFFF,
|
|
0x00000000FFFF0000, 0x00000000FFFF00FF,
|
|
0x00000000FFFFFF00, 0x00000000FFFFFFFF,
|
|
0x000000FF00000000, 0x000000FF000000FF,
|
|
0x000000FF0000FF00, 0x000000FF0000FFFF,
|
|
0x000000FF00FF0000, 0x000000FF00FF00FF,
|
|
0x000000FF00FFFF00, 0x000000FF00FFFFFF,
|
|
0x000000FFFF000000, 0x000000FFFF0000FF,
|
|
0x000000FFFF00FF00, 0x000000FFFF00FFFF,
|
|
0x000000FFFFFF0000, 0x000000FFFFFF00FF,
|
|
0x000000FFFFFFFF00, 0x000000FFFFFFFFFF,
|
|
0x0000FF0000000000, 0x0000FF00000000FF,
|
|
0x0000FF000000FF00, 0x0000FF000000FFFF,
|
|
0x0000FF0000FF0000, 0x0000FF0000FF00FF,
|
|
0x0000FF0000FFFF00, 0x0000FF0000FFFFFF,
|
|
0x0000FF00FF000000, 0x0000FF00FF0000FF,
|
|
0x0000FF00FF00FF00, 0x0000FF00FF00FFFF,
|
|
0x0000FF00FFFF0000, 0x0000FF00FFFF00FF,
|
|
0x0000FF00FFFFFF00, 0x0000FF00FFFFFFFF,
|
|
0x0000FFFF00000000, 0x0000FFFF000000FF,
|
|
0x0000FFFF0000FF00, 0x0000FFFF0000FFFF,
|
|
0x0000FFFF00FF0000, 0x0000FFFF00FF00FF,
|
|
0x0000FFFF00FFFF00, 0x0000FFFF00FFFFFF,
|
|
0x0000FFFFFF000000, 0x0000FFFFFF0000FF,
|
|
0x0000FFFFFF00FF00, 0x0000FFFFFF00FFFF,
|
|
0x0000FFFFFFFF0000, 0x0000FFFFFFFF00FF,
|
|
0x0000FFFFFFFFFF00, 0x0000FFFFFFFFFFFF,
|
|
0x00FF000000000000, 0x00FF0000000000FF,
|
|
0x00FF00000000FF00, 0x00FF00000000FFFF,
|
|
0x00FF000000FF0000, 0x00FF000000FF00FF,
|
|
0x00FF000000FFFF00, 0x00FF000000FFFFFF,
|
|
0x00FF0000FF000000, 0x00FF0000FF0000FF,
|
|
0x00FF0000FF00FF00, 0x00FF0000FF00FFFF,
|
|
0x00FF0000FFFF0000, 0x00FF0000FFFF00FF,
|
|
0x00FF0000FFFFFF00, 0x00FF0000FFFFFFFF,
|
|
0x00FF00FF00000000, 0x00FF00FF000000FF,
|
|
0x00FF00FF0000FF00, 0x00FF00FF0000FFFF,
|
|
0x00FF00FF00FF0000, 0x00FF00FF00FF00FF,
|
|
0x00FF00FF00FFFF00, 0x00FF00FF00FFFFFF,
|
|
0x00FF00FFFF000000, 0x00FF00FFFF0000FF,
|
|
0x00FF00FFFF00FF00, 0x00FF00FFFF00FFFF,
|
|
0x00FF00FFFFFF0000, 0x00FF00FFFFFF00FF,
|
|
0x00FF00FFFFFFFF00, 0x00FF00FFFFFFFFFF,
|
|
0x00FFFF0000000000, 0x00FFFF00000000FF,
|
|
0x00FFFF000000FF00, 0x00FFFF000000FFFF,
|
|
0x00FFFF0000FF0000, 0x00FFFF0000FF00FF,
|
|
0x00FFFF0000FFFF00, 0x00FFFF0000FFFFFF,
|
|
0x00FFFF00FF000000, 0x00FFFF00FF0000FF,
|
|
0x00FFFF00FF00FF00, 0x00FFFF00FF00FFFF,
|
|
0x00FFFF00FFFF0000, 0x00FFFF00FFFF00FF,
|
|
0x00FFFF00FFFFFF00, 0x00FFFF00FFFFFFFF,
|
|
0x00FFFFFF00000000, 0x00FFFFFF000000FF,
|
|
0x00FFFFFF0000FF00, 0x00FFFFFF0000FFFF,
|
|
0x00FFFFFF00FF0000, 0x00FFFFFF00FF00FF,
|
|
0x00FFFFFF00FFFF00, 0x00FFFFFF00FFFFFF,
|
|
0x00FFFFFFFF000000, 0x00FFFFFFFF0000FF,
|
|
0x00FFFFFFFF00FF00, 0x00FFFFFFFF00FFFF,
|
|
0x00FFFFFFFFFF0000, 0x00FFFFFFFFFF00FF,
|
|
0x00FFFFFFFFFFFF00, 0x00FFFFFFFFFFFFFF,
|
|
0xFF00000000000000, 0xFF000000000000FF,
|
|
0xFF0000000000FF00, 0xFF0000000000FFFF,
|
|
0xFF00000000FF0000, 0xFF00000000FF00FF,
|
|
0xFF00000000FFFF00, 0xFF00000000FFFFFF,
|
|
0xFF000000FF000000, 0xFF000000FF0000FF,
|
|
0xFF000000FF00FF00, 0xFF000000FF00FFFF,
|
|
0xFF000000FFFF0000, 0xFF000000FFFF00FF,
|
|
0xFF000000FFFFFF00, 0xFF000000FFFFFFFF,
|
|
0xFF0000FF00000000, 0xFF0000FF000000FF,
|
|
0xFF0000FF0000FF00, 0xFF0000FF0000FFFF,
|
|
0xFF0000FF00FF0000, 0xFF0000FF00FF00FF,
|
|
0xFF0000FF00FFFF00, 0xFF0000FF00FFFFFF,
|
|
0xFF0000FFFF000000, 0xFF0000FFFF0000FF,
|
|
0xFF0000FFFF00FF00, 0xFF0000FFFF00FFFF,
|
|
0xFF0000FFFFFF0000, 0xFF0000FFFFFF00FF,
|
|
0xFF0000FFFFFFFF00, 0xFF0000FFFFFFFFFF,
|
|
0xFF00FF0000000000, 0xFF00FF00000000FF,
|
|
0xFF00FF000000FF00, 0xFF00FF000000FFFF,
|
|
0xFF00FF0000FF0000, 0xFF00FF0000FF00FF,
|
|
0xFF00FF0000FFFF00, 0xFF00FF0000FFFFFF,
|
|
0xFF00FF00FF000000, 0xFF00FF00FF0000FF,
|
|
0xFF00FF00FF00FF00, 0xFF00FF00FF00FFFF,
|
|
0xFF00FF00FFFF0000, 0xFF00FF00FFFF00FF,
|
|
0xFF00FF00FFFFFF00, 0xFF00FF00FFFFFFFF,
|
|
0xFF00FFFF00000000, 0xFF00FFFF000000FF,
|
|
0xFF00FFFF0000FF00, 0xFF00FFFF0000FFFF,
|
|
0xFF00FFFF00FF0000, 0xFF00FFFF00FF00FF,
|
|
0xFF00FFFF00FFFF00, 0xFF00FFFF00FFFFFF,
|
|
0xFF00FFFFFF000000, 0xFF00FFFFFF0000FF,
|
|
0xFF00FFFFFF00FF00, 0xFF00FFFFFF00FFFF,
|
|
0xFF00FFFFFFFF0000, 0xFF00FFFFFFFF00FF,
|
|
0xFF00FFFFFFFFFF00, 0xFF00FFFFFFFFFFFF,
|
|
0xFFFF000000000000, 0xFFFF0000000000FF,
|
|
0xFFFF00000000FF00, 0xFFFF00000000FFFF,
|
|
0xFFFF000000FF0000, 0xFFFF000000FF00FF,
|
|
0xFFFF000000FFFF00, 0xFFFF000000FFFFFF,
|
|
0xFFFF0000FF000000, 0xFFFF0000FF0000FF,
|
|
0xFFFF0000FF00FF00, 0xFFFF0000FF00FFFF,
|
|
0xFFFF0000FFFF0000, 0xFFFF0000FFFF00FF,
|
|
0xFFFF0000FFFFFF00, 0xFFFF0000FFFFFFFF,
|
|
0xFFFF00FF00000000, 0xFFFF00FF000000FF,
|
|
0xFFFF00FF0000FF00, 0xFFFF00FF0000FFFF,
|
|
0xFFFF00FF00FF0000, 0xFFFF00FF00FF00FF,
|
|
0xFFFF00FF00FFFF00, 0xFFFF00FF00FFFFFF,
|
|
0xFFFF00FFFF000000, 0xFFFF00FFFF0000FF,
|
|
0xFFFF00FFFF00FF00, 0xFFFF00FFFF00FFFF,
|
|
0xFFFF00FFFFFF0000, 0xFFFF00FFFFFF00FF,
|
|
0xFFFF00FFFFFFFF00, 0xFFFF00FFFFFFFFFF,
|
|
0xFFFFFF0000000000, 0xFFFFFF00000000FF,
|
|
0xFFFFFF000000FF00, 0xFFFFFF000000FFFF,
|
|
0xFFFFFF0000FF0000, 0xFFFFFF0000FF00FF,
|
|
0xFFFFFF0000FFFF00, 0xFFFFFF0000FFFFFF,
|
|
0xFFFFFF00FF000000, 0xFFFFFF00FF0000FF,
|
|
0xFFFFFF00FF00FF00, 0xFFFFFF00FF00FFFF,
|
|
0xFFFFFF00FFFF0000, 0xFFFFFF00FFFF00FF,
|
|
0xFFFFFF00FFFFFF00, 0xFFFFFF00FFFFFFFF,
|
|
0xFFFFFFFF00000000, 0xFFFFFFFF000000FF,
|
|
0xFFFFFFFF0000FF00, 0xFFFFFFFF0000FFFF,
|
|
0xFFFFFFFF00FF0000, 0xFFFFFFFF00FF00FF,
|
|
0xFFFFFFFF00FFFF00, 0xFFFFFFFF00FFFFFF,
|
|
0xFFFFFFFFFF000000, 0xFFFFFFFFFF0000FF,
|
|
0xFFFFFFFFFF00FF00, 0xFFFFFFFFFF00FFFF,
|
|
0xFFFFFFFFFFFF0000, 0xFFFFFFFFFFFF00FF,
|
|
0xFFFFFFFFFFFFFF00, 0xFFFFFFFFFFFFFFFF,
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 8 */
|
|
|
|
#if PSZ == 16
|
|
PixelGroup QuartetPixelMaskTable[] = {
|
|
#if PGSZ == 32
|
|
0x00000000,
|
|
0x0000FFFF,
|
|
0xFFFF0000,
|
|
0xFFFFFFFF,
|
|
#else /* PGSZ == 64 */
|
|
0x0000000000000000, 0x000000000000FFFF,
|
|
0x00000000FFFF0000, 0x00000000FFFFFFFF,
|
|
0x0000FFFF00000000, 0x0000FFFF0000FFFF,
|
|
0x0000FFFFFFFF0000, 0x0000FFFFFFFFFFFF,
|
|
0xFFFF000000000000, 0xFFFF00000000FFFF,
|
|
0xFFFF0000FFFF0000, 0xFFFF0000FFFFFFFF,
|
|
0xFFFFFFFF00000000, 0xFFFFFFFF0000FFFF,
|
|
0xFFFFFFFFFFFF0000, 0xFFFFFFFFFFFFFFFF,
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 16 */
|
|
|
|
#if PSZ == 24
|
|
PixelGroup QuartetPixelMaskTable[] = {
|
|
#if PGSZ == 32
|
|
/* Four pixels consist three pixel groups....*/
|
|
0x00000000, 0x00FFFFFF, /*0x00000000, *//*0*/
|
|
/* 0x00000000, 0x00000000, 0x00000000,*/ /*0*/
|
|
/* 0x00FFFFFF, 0x00000000, 0x00000000,*/ /*1*/
|
|
/* 0xFF000000, 0x0000FFFF, 0x00000000,*/ /*2*/
|
|
/* 0xFFFFFFFF, 0x0000FFFF, 0x00000000,*/ /*3*/
|
|
/* 0x00000000, 0xFFFF0000, 0x000000FF,*/ /*4*/
|
|
/* 0x00FFFFFF, 0xFFFF0000, 0x000000FF,*/ /*5*/
|
|
/* 0xFF000000, 0xFFFFFFFF, 0x000000FF,*/ /*6*/
|
|
/* 0xFFFFFFFF, 0xFFFFFFFF, 0x000000FF,*/ /*7*/
|
|
/* 0x00000000, 0x00000000, 0xFFFFFF00,*/ /*8*/
|
|
/* 0x00FFFFFF, 0x00000000, 0xFFFFFF00,*/ /*9*/
|
|
/* 0xFF000000, 0x0000FFFF, 0xFFFFFF00,*/ /*10*/
|
|
/* 0xFFFFFFFF, 0x0000FFFF, 0xFFFFFF00,*/ /*11*/
|
|
/* 0x00000000, 0xFFFF0000, 0xFFFFFFFF,*/ /*12*/
|
|
/* 0x00FFFFFF, 0xFFFF0000, 0xFFFFFFFF,*/ /*13*/
|
|
/* 0xFF000000, 0xFFFFFFFF, 0xFFFFFFFF,*/ /*14*/
|
|
/* 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,*/ /*15*/
|
|
#else /* PGSZ == 64 */
|
|
0x0000000000000000, 0x0000000000FFFFFF,
|
|
0x0000FFFFFF000000, 0xFFFFFFFFFFFFFFFF
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 24 */
|
|
|
|
#if PSZ == 32
|
|
PixelGroup QuartetPixelMaskTable[] = {
|
|
#if PGSZ == 32
|
|
0x00000000,
|
|
0xFFFFFFFF,
|
|
#else /* PGSZ == 64 */
|
|
0x0000000000000000,
|
|
0x00000000FFFFFFFF,
|
|
0xFFFFFFFF00000000,
|
|
0xFFFFFFFFFFFFFFFF
|
|
#endif /* PGSZ */
|
|
};
|
|
#endif /* PSZ == 32 */
|
|
|
|
#if PSZ == 24
|
|
int cfb24Shift[] =
|
|
#if (BITMAP_BIT_ORDER == MSBFirst)
|
|
{8,0,16,16,8,24,0,0};
|
|
#else /* (BITMAP_BIT_ORDER == LSBFirst) */
|
|
{0,0,24,8,16,16,8,0};
|
|
#endif /* (BITMAP_BIT_ORDER == MSBFirst) */
|
|
#endif
|