2014-11-06 13:19:51 +01:00

91 lines
2.9 KiB
C

/* $XConsortium: s3bcach.c,v 1.2 94/10/12 20:07:37 kaleb Exp $ */
/* $XFree86: xc/programs/Xserver/hw/xfree86/accel/s3/s3bcach.c,v 3.7 1995/01/28 17:01:46 dawes Exp $ */
/*
* Copyright 1993 by Jon Tombs. Oxford University
*
* 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, and that the name of Jon Tombs or Oxford University shall
* not be used in advertising or publicity pertaining to distribution of the
* software without specific, written prior permission. The authors make no
* representations about the suitability of this software for any purpose. It
* is provided "as is" without express or implied warranty.
*
* JON TOMBS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
* ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
* THE AUTHORS 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.
*
*/
/*
* Id: s3bcach.c,v 2.3 1993/07/24 13:16:56 jon Exp
*/
/*
* Modified for the CyberVision 64 by Michael Teske
*/
#include "amiga.h"
#include "gcstruct.h"
#include "cfb.h"
#include "amigaCV.h"
#include "xf86bcache.h"
void
s3CacheMoveBlock(srcx, srcy, dstx, dsty, h, w, id)
int srcx, srcy, dstx, dsty, h, w;
unsigned int id;
{
fbFd *inf = amigaInfo(amigaCVsavepScreen);
volatile caddr_t vgaBase = (inf->regs);
__dolog ("Entering CacheMoveBlock()\n");
BLOCK_CURSOR;
WaitQueue(7);
PCI_HACK();
S3_OUTW(MULTIFUNC_CNTL, SCISSORS_T | 0);
S3_OUTW(MULTIFUNC_CNTL, SCISSORS_L | 0);
S3_OUTW(MULTIFUNC_CNTL, SCISSORS_R | (amigaVirtualWidth - 1));
S3_OUTW(MULTIFUNC_CNTL, SCISSORS_B | 0xfff);
S3_OUTW(MULTIFUNC_CNTL, PIX_CNTL | MIXSEL_FRGDMIX);
S3_OUTW(FRGD_MIX, FSS_BITBLT | MIX_SRC);
S3_OUTW(BKGD_MIX, BSS_BITBLT | MIX_SRC);
WaitQueue16_32(6,8); /* now shift the cache */
PCI_HACK();
S3_OUTW32(WRT_MASK, id);
S3_OUTW32(RD_MASK, id);
S3_OUTW(CUR_Y, srcy);
S3_OUTW(CUR_X, srcx);
S3_OUTW(DESTX_DIASTP, dstx);
S3_OUTW(DESTY_AXSTP, dsty);
WaitQueue(3);
PCI_HACK();
S3_OUTW(MAJ_AXIS_PCNT, w - 1);
S3_OUTW(MULTIFUNC_CNTL, MIN_AXIS_PCNT | (h - 1));
S3_OUTW(CMD, CMD_BITBLT | INC_X | INC_Y | DRAW | PLANAR | WRTDATA);
/* sanity returns */
WaitQueue16_32(4,5);
WaitIdle();
S3_OUTW32(RD_MASK, ~0);
S3_OUTW(MULTIFUNC_CNTL, PIX_CNTL | MIXSEL_FRGDMIX | COLCMPOP_F);
S3_OUTW(FRGD_MIX, FSS_FRGDCOL | MIX_SRC);
S3_OUTW(BKGD_MIX, BSS_BKGDCOL | MIX_SRC);
UNBLOCK_CURSOR;
__dolog ("Leaving s3CacheMoveBlock()\n");
}