Mercurial > sdl-ios-xcode
diff src/video/xbios/SDL_xbios_blowup.c @ 1040:c6ed27c7d47d
Preliminary support for Blowup and Screen Blaster 3 extensions on Atari Falcon 030
author | Patrice Mandin <patmandin@gmail.com> |
---|---|
date | Tue, 22 Feb 2005 17:57:40 +0000 |
parents | |
children | 0e7218843cfb |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/video/xbios/SDL_xbios_blowup.c Tue Feb 22 17:57:40 2005 +0000 @@ -0,0 +1,93 @@ +/* + SDL - Simple DirectMedia Layer + Copyright (C) 1997-2004 Sam Lantinga + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library 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 + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public + License along with this library; if not, write to the Free + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + + Sam Lantinga + slouken@libsdl.org +*/ + +/* + Blowup extension definitions + + Patrice Mandin +*/ + +#include "SDL_xbios.h" +#include "SDL_xbios_blowup.h" + +void SDL_XBIOS_BlowupInit(_THIS, blow_cookie_t *cookie_blow) +{ + int i, num_mode, bank, keep_old; + xbiosmode_t *current_mode; + blow_mode_t *blow_mode; + + current_mode = XBIOS_modelist; + for (i=0;i<XBIOS_nummodes;i++) { + keep_old=1; /* use default mode */ + blow_mode = NULL; + switch (current_mode->depth) { + case 1: + num_mode=0; + break; + case 2: + num_mode=1; + break; + case 4: + num_mode=2; + break; + case 8: + num_mode=3; + break; + case 16: + num_mode=4; + break; + default: + num_mode=-1; + break; + } + + /* Check which bank of modes to use */ + if (num_mode>=0) { + bank = cookie_blow->num_mode[num_mode]; + blow_mode = &(cookie_blow->blowup_modes[num_mode+(bank*5)]); + + /* Check extended mode enabled */ + if (blow_mode->enabled == 0) { + /* Check monitor needed for this mode */ + if ((blow_mode->monitor == cookie_blow->montype) + || ((blow_mode->monitor == MONITOR_TV) + && (cookie_blow->montype == MONITOR_RGB)) + || ((blow_mode->monitor == MONITOR_RGB) + && (cookie_blow->montype == MONITOR_TV))) + { + keep_old = 0; /* we can use this extended mode */ + } + } + } + + if (keep_old) { + /* disable blowup for this mode */ + current_mode->number |= (1<<15); + } else { + /* Update mode size */ + current_mode->width = blow_mode->width +1; + current_mode->height = blow_mode->height +1; + } + + current_mode++; + } +}