changeset 1061:5023cde12cbd

Add Falcon Centscreen extension support
author Patrice Mandin <patmandin@gmail.com>
date Wed, 18 May 2005 17:02:17 +0000
parents 86885b40a53b
children 3e637850c02b
files README.MiNT src/video/xbios/Makefile.am src/video/xbios/SDL_xbios.c src/video/xbios/SDL_xbios_centscreen.c src/video/xbios/SDL_xbios_centscreen.h
diffstat 5 files changed, 176 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/README.MiNT	Mon May 16 08:23:34 2005 +0000
+++ b/README.MiNT	Wed May 18 17:02:17 2005 +0000
@@ -156,7 +156,8 @@
 		320x480x8 and 320x240x8 (software double-lined mode).
 	Falcon:
 		All modes supported by the current monitor (RVB or VGA).
-		BlowUp extended modes, ScreenBlaster 3 current mode.
+		BlowUp extended modes, ScreenBlaster 3 current mode, Centscreen current
+		mode.
 	Clones and any machine with monochrome monitor:
 		Not supported.
 
--- a/src/video/xbios/Makefile.am	Mon May 16 08:23:34 2005 +0000
+++ b/src/video/xbios/Makefile.am	Wed May 18 17:02:17 2005 +0000
@@ -10,5 +10,7 @@
 	SDL_xbios.h	\
 	SDL_xbios_blowup.c	\
 	SDL_xbios_blowup.h	\
+	SDL_xbios_centscreen.c	\
+	SDL_xbios_centscreen.h	\
 	SDL_xbios_sb3.c	\
 	SDL_xbios_sb3.h
--- a/src/video/xbios/SDL_xbios.c	Mon May 16 08:23:34 2005 +0000
+++ b/src/video/xbios/SDL_xbios.c	Wed May 18 17:02:17 2005 +0000
@@ -56,6 +56,7 @@
 #include "SDL_atarigl_c.h"
 #include "SDL_xbios.h"
 #include "SDL_xbios_blowup.h"
+#include "SDL_xbios_centscreen.h"
 #include "SDL_xbios_sb3.h"
 
 #define XBIOS_VID_DRIVER_NAME "xbios"
@@ -261,7 +262,7 @@
 {
 	int i,j8,j16;
 	xbiosmode_t *current_mode;
-	unsigned long cookie_blow, cookie_scpn;
+	unsigned long cookie_blow, cookie_scpn, cookie_cnts;
 
 	/* Initialize all variables that we clean on shutdown */
 	memset (SDL_modelist, 0, sizeof(SDL_modelist));
@@ -415,8 +416,9 @@
 				SDL_XBIOS_BlowupInit(this, (blow_cookie_t *)cookie_blow);
 			} else if (Getcookie(C_SCPN, &cookie_scpn) == C_FOUND) {
 				SDL_XBIOS_SB3Init(this, (scpn_cookie_t *)cookie_scpn);
+			} else if (Getcookie(C_CNTS, &cookie_cnts) == C_FOUND) {
+				SDL_XBIOS_CentscreenInit(this);
 			}
-
 			break;
 	}
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/video/xbios/SDL_xbios_centscreen.c	Wed May 18 17:02:17 2005 +0000
@@ -0,0 +1,53 @@
+/*
+    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
+*/
+
+/*
+	Centscreen extension definitions
+
+	Patrice Mandin
+*/
+
+#include <stdlib.h>
+
+#include <mint/falcon.h>
+
+#include "SDL_xbios.h"
+#include "SDL_xbios_centscreen.h"
+
+void SDL_XBIOS_CentscreenInit(_THIS)
+{
+	centscreen_mode_t	curmode;
+
+	/* Reset current mode list */
+	if (XBIOS_modelist) {
+		free(XBIOS_modelist);
+		XBIOS_nummodes = 0;
+		XBIOS_modelist = NULL;
+	}
+
+	/* Add current active mode */
+	Vread(&curmode);
+
+	SDL_XBIOS_AddMode(this, -1, curmode.physx, curmode.physy, curmode.plan,
+		SDL_FALSE
+	);
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/video/xbios/SDL_xbios_centscreen.h	Wed May 18 17:02:17 2005 +0000
@@ -0,0 +1,115 @@
+/*
+    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
+*/
+
+/*
+	Centscreen extension definitions
+
+	Patrice Mandin
+*/
+
+#ifndef _SDL_xbios_centscreen_h
+#define _SDL_xbios_centscreen_h
+
+#include <mint/falcon.h>	/* for trap_14_xxx macros */
+
+#include "SDL_xbios.h"
+
+/*--- Defines ---*/
+
+#ifndef C_CNTS
+#define C_CNTS 0x434e5453L
+#endif
+
+#define CSCREEN_ENERGYSTAR		(1<<9)
+#define CSCREEN_SAVER			(1<<10)
+#define CSCREEN_VIRTUAL			(1<<11)
+#define CSCREEN_EXTCLOCK_CT2	(1<<12)
+#define CSCREEN_EXTCLOCK		(1<<13)
+#define CSCREEN_STANDARD		(1<<14)
+#define CSCREEN_DEFAULT			(1<<15)
+
+/*--- Structures ---*/
+
+typedef struct {
+	unsigned short	handle;	/* videomode handle */
+	unsigned short	mode;	/* Falcon videomode code */
+	unsigned short	physx;	/* visible width */
+	unsigned short	physy;	/* visible height */
+	unsigned short	plan;	/* bitplanes */
+	unsigned short	logx;	/* virtual width */
+	unsigned short	logy;	/* virtual height */
+	unsigned short	eco;	/* screen saver delay */
+	unsigned short	eco2;	/* energy star screen saver delay */
+	unsigned short	wsize;	/* screen width (mm) */
+	unsigned short	hsize;	/* screen height (mm) */
+	unsigned short	dummy[21];
+	unsigned char	name[32];	/* videomode name */
+} __attribute__((packed)) centscreen_mode_t;
+
+/*--- Functions prototypes ---*/
+
+#define Vread(current_mode)	\
+	(void)trap_14_wl((short)0x41,(long)(current_mode))
+#define Vwrite(init_vdi, inparam, outparam)	\
+	(long)trap_14_wwll((short)0x42,(short)(init_vdi),(long)(inparam),(long)(outparam))
+#define Vattrib(inparam, outparam)	\
+	(void)trap_14_wll((short)0x43,(long)(inparam),(long)(outparam))
+#define Vcreate(inparam, outparam)	\
+	(void)trap_14_wll((short)0x44,(long)(inparam),(long)(outparam))
+#define Vdelete(handle)	\
+	(long)trap_14_ww((short)0x45,(short)(handle))
+#define Vfirst(mask,mode)	\
+	(long)trap_14_wll((short)0x46,(long)(mask),(long)(mode))
+#define Vnext(mask,mode)	\
+	(long)trap_14_wll((short)0x47,(long)(mask),(long)(mode))
+#define Vvalid(handle)	\
+	(long)trap_14_ww((short)0x48,(short)(handle))
+#define Vload()	\
+	(long)trap_14_w((short)0x49)
+#define Vsave()	\
+	(long)trap_14_w((short)0x4a)
+#define Vopen()	\
+	(long)trap_14_w((short)0x4b)
+#define Vclose()	\
+	(long)trap_14_w((short)0x4c)
+#define Vscroll(scrollmode)	\
+	(long)trap_14_ww((short)0x4d,(short)(scrollmode))
+#define Voffset()	\
+	(long)trap_14_w((short)0x4e)
+#define Vseek()	\
+	(long)trap_14_w((short)0x4f)
+#define Vlock(cmd)	\
+	(long)trap_14_ww((short)0x50,(short)(cmd))
+#define SetMon(montype)	\
+	(long)trap_14_ww((short)0x51,(short)(montype))
+#define MultiMon(cmd)	\
+	(long)trap_14_ww((short)0x52,(short)(cmd))
+#define VSizeComp()	\
+	(long)trap_14_w((short)0x53)
+#define Vsize(mode)	\
+	(long)trap_14_wl((short)0x54,(long)(mode))
+
+/*--- Functions prototypes ---*/
+
+void SDL_XBIOS_CentscreenInit(_THIS);
+
+#endif /* _SDL_xbios_centscreen_h */