b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/*
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * $Xorg: mergerop.h,v 1.4 2001/02/09 02:05:18 xorgcvs Exp $
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 in
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncall copies or substantial portions of the Software.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncTHE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncOPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncAN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncCONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncExcept as contained in this notice, the name of The Open Group shall not be
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncused in advertising or otherwise to promote the sale, use or other dealings
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncin this Software without prior written authorization from The Open Group.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync * Author: Keith Packard, MIT X Consortium
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* $XFree86: xc/programs/Xserver/mfb/mergerop.h,v 3.13 2001/10/28 03:34:13 tsi Exp $ */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifdef HAVE_DIX_CONFIG_H
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#include <dix-config.h>
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifndef _MERGEROP_H_
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define _MERGEROP_H_
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifndef GXcopy
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#include <X11/X.h>
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynctypedef struct _mergeRopBits {
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits ca1, cx1, ca2, cx2;
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync} mergeRopRec, *mergeRopPtr;
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncextern mergeRopRec mergeRopBits[16];
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncextern mergeRopPtr mergeGetRopBits(int i);
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if defined(PPW) && defined(PGSZ) && (PPW != PGSZ) /* cfb */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DeclareMergeRop() MfbBits _ca1 = 0, _cx1 = 0, _ca2 = 0, _cx2 = 0;
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DeclarePrebuiltMergeRop() MfbBits _cca, _ccx;
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if PSZ == 24 /* both for PGSZ == 32 and 64 */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DeclareMergeRop24() \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _ca1u[4], _cx1u[4], _ca2u[4], _cx2u[4];
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /* int _unrollidx[3]={0,0,1,2};*/
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DeclarePrebuiltMergeRop24() MfbBits _ccau[4], _ccxu[4];
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif /* PSZ == 24 */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#else /* mfb */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DeclareMergeRop() MfbBits _ca1 = 0, _cx1 = 0, _ca2 = 0, _cx2 = 0;
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DeclarePrebuiltMergeRop() MfbBits _cca, _ccx;
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if defined(PPW) && defined(PGSZ) && (PPW != PGSZ) /* cfb */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define InitializeMergeRop(alu,pm) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync mergeRopPtr _bits; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _pm = PFILL(pm); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _bits = mergeGetRopBits(alu); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca1 = _bits->ca1 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx1 = _bits->cx1 | ~_pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca2 = _bits->ca2 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx2 = _bits->cx2 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync}
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if PSZ == 24
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if (BITMAP_BIT_ORDER == MSBFirst)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define InitializeMergeRop24(alu,pm) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int i; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register MfbBits _pm = (pm) & 0xFFFFFF; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync mergeRopPtr _bits = mergeGetRopBits(alu); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_ca1 = _bits->ca1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_cx1 = _bits->cx1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_ca2 = _bits->ca2; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_cx2 = _bits->cx2; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _pm = (_pm << 8) | (_pm >> 16); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync for(i = 0; i < 4; i++){ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca1u[i] = _bits_ca1 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx1u[i] = _bits_cx1 | ~_pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca2u[i] = _bits_ca2 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx2u[i] = _bits_cx2 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _pm = (_pm << 16)|(_pm >> 8); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync } \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync}
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#else /*(BITMAP_BIT_ORDER == LSBFirst)*/
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define InitializeMergeRop24(alu,pm) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int i; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register MfbBits _pm = (pm) & cfbmask[0]; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync mergeRopPtr _bits = mergeGetRopBits(alu); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_ca1 = _bits->ca1 & cfbmask[0]; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_cx1 = _bits->cx1 & cfbmask[0]; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_ca2 = _bits->ca2 & cfbmask[0]; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _bits_cx2 = _bits->cx2 & cfbmask[0]; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _pm |= (_pm << 24); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _bits_ca1 |= (_bits->ca1 << 24); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _bits_cx1 |= (_bits->cx1 << 24); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _bits_ca2 |= (_bits->ca2 << 24); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _bits_cx2 |= (_bits->cx2 << 24); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync for(i = 0; i < 4; i++){ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca1u[i] = _bits_ca1 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx1u[i] = _bits_cx1 | ~_pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca2u[i] = _bits_ca2 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx2u[i] = _bits_cx2 & _pm; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _pm = (_pm << 16)|(_pm >> 8); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync } \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync}
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif /*(BITMAP_BIT_ORDER == MSBFirst)*/
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif /* PSZ == 24 */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#else /* mfb */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define InitializeMergeRop(alu,pm) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync mergeRopPtr _bits; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _bits = mergeGetRopBits(alu); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca1 = _bits->ca1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx1 = _bits->cx1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca2 = _bits->ca2; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx2 = _bits->cx2; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync}
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync/* AND has higher precedence than XOR */
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoMergeRop(src, dst) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((dst) & (((src) & _ca1) ^ _cx1)) ^ (((src) & _ca2) ^ _cx2))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoMergeRop24u(src, dst, i) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync(((dst) & (((src) & _ca1u[i]) ^ _cx1u[i])) ^ (((src) & _ca2u[i]) ^ _cx2u[i]))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoMaskMergeRop24(src, dst, mask, index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src0 = (src);\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src1 = (_src0 & _ca1) ^ _cx1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src2 = (_src0 & _ca2) ^ _cx2; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (((*(dst)) & cfbrmask[idx]) | (((*(dst)) & cfbmask[idx]) & \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((( _src1 |(~mask))<<cfb24Shift[idx])&cfbmask[idx]) ^ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((( _src2&(mask))<<cfb24Shift[idx])&cfbmask[idx])))); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (((*(dst)) & cfbrmask[idx]) | (((*(dst)) & cfbmask[idx]) & \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((((_src1 |(~mask))>>cfb24Shift[idx])&cfbmask[idx]) ^ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((_src2 &(mask))>>cfb24Shift[idx])&cfbmask[idx])))); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoMaskMergeRop(src, dst, mask) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((dst) & ((((src) & _ca1) ^ _cx1) | ~(mask))) ^ ((((src) & _ca2) ^ _cx2) & (mask)))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoMaskMergeRop24u(src, dst, mask, i) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync(((dst) & ((((src) & _ca1u[(i)]) ^ _cx1u[(i)]) | ~(mask))) ^ ((((src) & _ca2u[(i)]) ^ _cx2u[(i)]) & (mask)))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoMergeRop24(src,dst,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src0 = (src);\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src1 = (_src0 & _ca1) ^ _cx1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src2 = (_src0 & _ca2) ^ _cx2; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (((*(dst)) & cfbrmask[idx]) | ((((*(dst)) & cfbmask[idx]) & \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((_src1 << cfb24Shift[idx])&cfbmask[idx])) ^ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((_src2 << cfb24Shift[idx])&cfbmask[idx]))); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (((*(dst)) & cfbrmask[idx]) | ((((*(dst)) & cfbmask[idx]) & \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((_src1 >> cfb24Shift[idx])&cfbmask[idx])) ^ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((_src2 >> cfb24Shift[idx])&cfbmask[idx]))); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoPrebuiltMergeRop(dst) (((dst) & _cca) ^ _ccx)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoPrebuiltMergeRop24(dst,index) { \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (((*(dst)) & cfbrmask[idx]) | ((((*(dst)) & cfbmask[idx]) &\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (( _cca <<cfb24Shift[idx])&cfbmask[idx])) ^ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (( _ccx <<cfb24Shift[idx])&cfbmask[idx]))); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (((*(dst)) & cfbrmask[idx]) | ((((*(dst)) & cfbmask[idx]) &\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (( _cca >>cfb24Shift[idx])&cfbmask[idx])) ^ \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (( _ccx >>cfb24Shift[idx])&cfbmask[idx]))); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define DoMaskPrebuiltMergeRop(dst,mask) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((dst) & (_cca | ~(mask))) ^ (_ccx & (mask)))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define PrebuildMergeRop(src) ((_cca = ((src) & _ca1) ^ _cx1), \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (_ccx = ((src) & _ca2) ^ _cx2))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifndef MROP
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP 0
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mclear (1<<GXclear)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mand (1<<GXand)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MandReverse (1<<GXandReverse)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mcopy (1<<GXcopy)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MandInverted (1<<GXandInverted)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mnoop (1<<GXnoop)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mxor (1<<GXxor)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mor (1<<GXor)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mnor (1<<GXnor)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mequiv (1<<GXequiv)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Minvert (1<<GXinvert)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MorReverse (1<<GXorReverse)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define McopyInverted (1<<GXcopyInverted)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MorInverted (1<<GXorInverted)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mnand (1<<GXnand)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define Mset (1<<GXset)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PIXEL24(pix, idx) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((*(pix) & cfbmask[(idx)<<1]) >> cfb24Shift[(idx)<<1])| \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((*((pix)+1) & cfbmask[((idx)<<1)+1]) << cfb24Shift[((idx)<<1)+1]))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID24P(src,dst,sindex, index) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MROP_SOLID24(MROP_PIXEL24(src,sindex),dst,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK24P(src,dst,mask,sindex,index) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MROP_MASK24(MROP_PIXEL24(src,sindex),dst,mask,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if (MROP) == Mcopy
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE_REG()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_INITIALIZE(alu,pm)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID(src,dst) (src)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID24(src,dst,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src = (src); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (*(dst) & cfbrmask[idx])|((_src<<cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *((dst)+1) = (*((dst)+1) & cfbrmask[idx])|((_src>>cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK(src,dst,mask) (((dst) & ~(mask)) | ((src) & (mask)))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK24(src,dst,mask,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src = (src); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (*(dst) & cfbrmask[idx] &(~(((mask)<< cfb24Shift[idx])&cfbmask[idx])) | \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((_src &(mask))<<cfb24Shift[idx])&cfbmask[idx])); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *((dst)+1) = (*((dst)+1) & cfbrmask[idx] &(~(((mask)>>cfb24Shift[idx])&cfbmask[idx])) | \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((_src&(mask))>>cfb24Shift[idx])&cfbmask[idx])); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME(prefix) MROP_NAME_CAT(prefix,Copy)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if (MROP) == McopyInverted
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE_REG()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_INITIALIZE(alu,pm)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID(src,dst) (~(src))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID24(src,dst,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src = ~(src); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (*(dst) & cfbrmask[idx])|((_src << cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (*(dst) & cfbrmask[idx])|((_src >>cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK(src,dst,mask) (((dst) & ~(mask)) | ((~(src)) & (mask)))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK24(src,dst,mask,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src = ~(src); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (*(dst) & cfbrmask[idx] &(~(((mask)<< cfb24Shift[idx])&cfbmask[idx])) | \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((_src &(mask))<<cfb24Shift[idx])&cfbmask[idx])); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) = (*(dst) & cfbrmask[idx] &(~(((mask)>>cfb24Shift[idx])&cfbmask[idx])) | \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ((((_src & (mask))>>cfb24Shift[idx])&cfbmask[idx])); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME(prefix) MROP_NAME_CAT(prefix,CopyInverted)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if (MROP) == Mxor
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE_REG()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_INITIALIZE(alu,pm)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID(src,dst) ((src) ^ (dst))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID24(src,dst,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src = (src); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) ^= ((_src << cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) ^= ((_src >>cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK(src,dst,mask) (((src) & (mask)) ^ (dst))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK24(src,dst,mask,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) ^= ((((src)&(mask))<<cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) ^= ((((src)&(mask))>>cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME(prefix) MROP_NAME_CAT(prefix,Xor)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if (MROP) == Mor
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE_REG()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_INITIALIZE(alu,pm)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID(src,dst) ((src) | (dst))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID24(src,dst,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) |= (((src)<<cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) |= (((src)>>cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK(src,dst,mask) (((src) & (mask)) | (dst))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK24(src,dst,mask,index) {\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register int idx = ((index) & 3)<< 1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync MfbBits _src = (src); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) |= (((_src &(mask))<<cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync idx++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)++; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync *(dst) |= (((_src &(mask))>>cfb24Shift[idx])&cfbmask[idx]); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (dst)--; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync }
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME(prefix) MROP_NAME_CAT(prefix,Or)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if (MROP) == (Mcopy|Mxor|MandReverse|Mor)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE() MfbBits _ca1 = 0, _cx1 = 0;
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE_REG() register MROP_DECLARE()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_INITIALIZE(alu,pm) { \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync mergeRopPtr _bits; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _bits = mergeGetRopBits(alu); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _ca1 = _bits->ca1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync _cx1 = _bits->cx1; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync}
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID(src,dst) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((dst) & (((src) & _ca1) ^ _cx1)) ^ (src))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK(src,dst,mask) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (((dst) & ((((src) & _ca1) ^ _cx1)) | (~(mask)) ^ ((src) & (mask))))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME(prefix) MROP_NAME_CAT(prefix,CopyXorAndReverseOr)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILD(src) PrebuildMergeRop(src)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_DECLARE() DeclarePrebuiltMergeRop()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_SOLID(src,dst) DoPrebuiltMergeRop(dst)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_SOLID24(src,dst,index) DoPrebuiltMergeRop24(dst,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_MASK(src,dst,mask) DoMaskPrebuiltMergeRop(dst,mask)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_MASK24(src,dst,mask,index) DoMaskPrebuiltMergeRop24(dst,mask,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if (MROP) == 0
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if !defined(PSZ) || (PSZ != 24)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE() DeclareMergeRop()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE_REG() register DeclareMergeRop()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_INITIALIZE(alu,pm) InitializeMergeRop(alu,pm)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID(src,dst) DoMergeRop(src,dst)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK(src,dst,mask) DoMaskMergeRop(src, dst, mask)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#else
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE() \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync DeclareMergeRop() \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync DeclareMergeRop24()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_DECLARE_REG() \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync register DeclareMergeRop()\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync DeclareMergeRop24()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_INITIALIZE(alu,pm) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync InitializeMergeRop(alu,pm)\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync InitializeMergeRop24(alu,pm)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID(src,dst) DoMergeRop24u(src,dst,((int)(&(dst)-pdstBase) % 3))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK(src,dst,mask) DoMaskMergeRop24u(src, dst, mask,((int)(&(dst) - pdstBase)%3))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_SOLID24(src,dst,index) DoMergeRop24(src,dst,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_MASK24(src,dst,mask,index) DoMaskMergeRop24(src, dst, mask,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME(prefix) MROP_NAME_CAT(prefix,General)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILD(src) PrebuildMergeRop(src)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_DECLARE() DeclarePrebuiltMergeRop()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_SOLID(src,dst) DoPrebuiltMergeRop(dst)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_SOLID24(src,dst,index) DoPrebuiltMergeRop24(dst,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_MASK(src,dst,mask) DoMaskPrebuiltMergeRop(dst,mask)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_MASK24(src,dst,mask,index) \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync DoMaskPrebuiltMergeRop24(dst,mask,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#ifndef MROP_PREBUILD
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILD(src)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_DECLARE()
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_SOLID(src,dst) MROP_SOLID(src,dst)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_SOLID24(src,dst,index) MROP_SOLID24(src,dst,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_MASK(src,dst,mask) MROP_MASK(src,dst,mask)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_PREBUILT_MASK24(src,dst,mask,index) MROP_MASK24(src,dst,mask,index)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#if !defined(UNIXCPP) || defined(ANSICPP)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME_CAT(prefix,suffix) prefix##suffix
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#else
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#define MROP_NAME_CAT(prefix,suffix) prefix/**/suffix
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#endif