19682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall/* 29682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall SDL - Simple DirectMedia Layer 39682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall Copyright (C) 1997-2012 Sam Lantinga 49682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 59682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall This library is free software; you can redistribute it and/or 69682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall modify it under the terms of the GNU Lesser General Public 79682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall License as published by the Free Software Foundation; either 89682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall version 2.1 of the License, or (at your option) any later version. 99682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 109682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall This library is distributed in the hope that it will be useful, 119682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall but WITHOUT ANY WARRANTY; without even the implied warranty of 129682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 139682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall Lesser General Public License for more details. 149682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 159682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall You should have received a copy of the GNU Lesser General Public 169682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall License along with this library; if not, write to the Free Software 179682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 189682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 199682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall Sam Lantinga 209682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall slouken@libsdl.org 219682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall*/ 229682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#include "SDL_config.h" 239682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 249682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall/* MGA register definitions */ 259682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 269682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#include "matrox_regs.h" 279682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 289682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall/* MGA control macros */ 299682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 309682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#define mga_in8(reg) *(volatile Uint8 *)(mapped_io + (reg)) 319682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#define mga_in32(reg) *(volatile Uint32 *)(mapped_io + (reg)) 329682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 339682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#define mga_out8(reg,v) *(volatile Uint8 *)(mapped_io + (reg)) = v; 349682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#define mga_out32(reg,v) *(volatile Uint32 *)(mapped_io + (reg)) = v; 359682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 369682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 379682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall/* Wait for fifo space */ 389682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#define mga_wait(space) \ 399682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall{ \ 409682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall while ( mga_in8(MGAREG_FIFOSTATUS) < space ) \ 419682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall ; \ 429682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall} 439682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 449682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 459682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall/* Wait for idle accelerator */ 469682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall#define mga_waitidle() \ 479682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall{ \ 489682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall while ( mga_in32(MGAREG_STATUS) & 0x10000 ) \ 499682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall ; \ 509682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall} 519682c8870b8ff5e4ac2e4c70b759f791c6f38c1fJesse Hall 52