/* * This file is part of the Advance project. * * Copyright (C) 1999, 2000, 2001, 2002, 2003 Andrea Mazzoleni * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * In addition, as a special exception, Andrea Mazzoleni * gives permission to link the code of this program with * the MAME library (or with modified versions of MAME that use the * same license as MAME), and distribute linked combinations including * the two. You must obey the GNU General Public License in all * respects for all of the code used other than MAME. If you modify * this file, you may extend this exception to your version of the * file, but you are not obligated to do so. If you do not wish to * do so, delete this exception statement from your version. */ #include "portable.h" #include "clear.h" #include "icommon.h" /***************************************************************************/ /* Clear */ /* Clear screen * in: * x, y destination pos * src data source */ static void video_8_clear(unsigned x, unsigned y, unsigned dx, unsigned dy, uint8 src) { unsigned j; unsigned pre_count; unsigned post_count; unsigned inner_count; unsigned mask; src &= 0xFF; mask = src | ((unsigned)src << 8) | ((unsigned)src << 16) | ((unsigned)src << 24); pre_count = (4 - x) & 3; if (pre_count >= dx) pre_count = dx; inner_count = (dx - pre_count) / 4; post_count = dx - pre_count - inner_count * 4; for(j=0;j= dx) pre_count = dx; inner_count = (dx - pre_count) / 2; post_count = dx - pre_count - inner_count * 2; for(j=0;j> 8; PADD(dst, 2); } for(i=inner_count;i;--i) { P32DER0(dst) = mask; PADD(dst, 4); } if (post_count) { P8DER0(dst) = mask; P8DER(dst, 1) = mask >> 8; /* dst += 2; */ } ++y; } } static void video_24_clear(unsigned x, unsigned y, unsigned dx, unsigned dy, unsigned src) { unsigned j; unsigned inner_count; uint8 mask0; uint8 mask1; uint8 mask2; mask0 = src & 0xFF; mask1 = (src >> 8) & 0xFF; mask2 = (src >> 16) & 0xFF; inner_count = dx; for(j=0;j