b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* $Xorg: fastblt.h,v 1.4 2001/02/09 02:05:17 xorgcvs Exp $ */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/*
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncCopyright 1989, 1998 The Open Group
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncPermission to use, copy, modify, distribute, and sell this software and its
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncdocumentation for any purpose is hereby granted without fee, provided that
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncthe above copyright notice appear in all copies and that both that
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynccopyright notice and this permission notice appear in supporting
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncdocumentation.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncThe above copyright notice and this permission notice shall be included
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncin all copies or substantial portions of the Software.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncIN NO EVENT SHALL THE OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncOTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncOTHER DEALINGS IN THE SOFTWARE.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncExcept as contained in this notice, the name of The Open Group shall
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncnot be used in advertising or otherwise to promote the sale, use or
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncother dealings in this Software without prior written authorization
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncfrom The Open Group.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync*/
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* $XFree86: xc/programs/Xserver/mfb/fastblt.h,v 1.4 2001/01/17 22:37:01 dawes Exp $ */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/*
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * Fast bitblt macros for certain hardware. If your machine has an addressing
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * mode of small constant + register, you'll probably want this magic specific
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * code. It's 25% faster for the R2000. I haven't studied the Sparc
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * instruction set, but I suspect it also has this addressing mode. Also,
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * unrolling the loop by 32 is possibly excessive for mfb. The number of times
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * the loop is actually looped through is pretty small.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/*
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * WARNING: These macros make *a lot* of assumptions about
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * the environment they are invoked in. Plenty of implicit
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * arguments, lots of side effects. Don't use them casually.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define SwitchOdd(n) case n: BodyOdd(n)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define SwitchEven(n) case n: BodyEven(n)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* to allow mfb and cfb to share code... */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifdef HAVE_DIX_CONFIG_H
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#include <dix-config.h>
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifndef BitRight
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define BitRight(a,b) SCRRIGHT(a,b)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define BitLeft(a,b) SCRLEFT(a,b)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifdef LARGE_INSTRUCTION_CACHE
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define UNROLL 8
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define PackedLoop \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync switch (nl & (UNROLL-1)) { \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync SwitchOdd( 7) SwitchEven( 6) SwitchOdd( 5) SwitchEven( 4) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync SwitchOdd( 3) SwitchEven( 2) SwitchOdd( 1) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync } \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync while ((nl -= UNROLL) >= 0) { \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync LoopReset \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync BodyEven( 8) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync BodyOdd( 7) BodyEven( 6) BodyOdd( 5) BodyEven( 4) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync BodyOdd( 3) BodyEven( 2) BodyOdd( 1) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#else
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define UNROLL 4
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define PackedLoop \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync switch (nl & (UNROLL-1)) { \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync SwitchOdd( 3) SwitchEven( 2) SwitchOdd( 1) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync } \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync while ((nl -= UNROLL) >= 0) { \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync LoopReset \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync BodyEven( 4) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync BodyOdd( 3) BodyEven( 2) BodyOdd( 1) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DuffL(counter,label,body) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync switch (counter & 3) { \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync label: \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync body \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync case 3: \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync body \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync case 2: \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync body \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync case 1: \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync body \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync case 0: \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync if ((counter -= 4) >= 0) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync goto label; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }