diff src/video/photon/SDL_ph_video.c @ 886:05c551e5bc64

Date: Sat, 24 Apr 2004 15:13:32 +0300 From: "Mike Gorchak" Subject: SDL updates for the QNX6 1. Updated the README.QNX 2. Updated libtool scripts, which are shipped with SDL for QNX6 support. 3. Added some code to support the new QNX 6.3.0, which is in beta now. 4. Added code to detect the hw features, which driver supports. 5. Added hw alpha blits code. 6. Fixed bug when application switches to fullscreen more the 2 times. (afte\ r that window becames always stay on top). 7. Updated a bit README for the tests. 8. Added information about acceleration show in the testalpha.c test. 9. Added small fixes to the testoverlay2.c test. 10. Added alpha and cc+alpha blits benchmarks to the testvidinfo.c test.
author Sam Lantinga <slouken@libsdl.org>
date Thu, 06 May 2004 15:55:06 +0000
parents 4bc7e16a13ed
children 4ab6d1fd028f
line wrap: on
line diff
--- a/src/video/photon/SDL_ph_video.c	Fri Apr 30 18:33:30 2004 +0000
+++ b/src/video/photon/SDL_ph_video.c	Thu May 06 15:55:06 2004 +0000
@@ -83,27 +83,28 @@
     return 1;
 }
 
-static SDL_VideoDevice *ph_CreateDevice(int devindex)
+static SDL_VideoDevice* ph_CreateDevice(int devindex)
 {
-    SDL_VideoDevice *device;
+    SDL_VideoDevice* device;
 
     /* Initialize all variables that we clean on shutdown */
     device = (SDL_VideoDevice *)malloc(sizeof(SDL_VideoDevice));
-    if (device) {
+    if (device)
+    {
         memset(device, 0, (sizeof *device));
-        device->hidden = (struct SDL_PrivateVideoData *)
-                malloc((sizeof *device->hidden));
+        device->hidden = (struct SDL_PrivateVideoData*)malloc((sizeof *device->hidden));
         device->gl_data = NULL;
     }
-    if ((device == NULL) || (device->hidden == NULL)) {
+    if ((device == NULL) || (device->hidden == NULL))
+    {
         SDL_OutOfMemory();
         ph_DeleteDevice(device);
-        return(0);
+        return NULL;
     }
     memset(device->hidden, 0, (sizeof *device->hidden));
 
     /* Set the driver flags */
-    device->handles_any_size = 1; /* JB not true for fullscreen */
+    device->handles_any_size = 1;
 
     /* Set the function pointers */
     device->CreateYUVOverlay = ph_CreateYUVOverlay;
@@ -113,7 +114,7 @@
     device->ToggleFullScreen = ph_ToggleFullScreen;
     device->UpdateMouse = ph_UpdateMouse;
     device->SetColors = ph_SetColors;
-    device->UpdateRects = NULL;         /* set up in ph_SetupUpdateFunction */
+    device->UpdateRects = NULL;                        /* set up in ph_SetupUpdateFunction */
     device->VideoQuit = ph_VideoQuit;
     device->AllocHWSurface = ph_AllocHWSurface;
     device->CheckHWBlit = ph_CheckHWBlit;
@@ -254,6 +255,10 @@
     }
     else
     {
+        PtSetArg(&args[nargs++], Pt_ARG_WINDOW_MANAGED_FLAGS, Pt_FALSE, Ph_WM_FFRONT | Ph_WM_CONSWITCH);
+        PtSetArg(&args[nargs++], Pt_ARG_WINDOW_STATE, Pt_FALSE, Ph_WM_STATE_ISFRONT);
+        PtSetArg(&args[nargs++], Pt_ARG_WINDOW_STATE, Pt_TRUE, Ph_WM_STATE_ISALTKEY);
+
         if ((flags & SDL_HWSURFACE) == SDL_HWSURFACE)
         {
             PtSetArg(&args[nargs++], Pt_ARG_BASIC_FLAGS, Pt_TRUE, Pt_BASIC_PREVENT_FILL);
@@ -450,20 +455,15 @@
     OCImage.FrameData1 = NULL;
     videomode_emulatemode = 0;
     
-    this->info.video_mem=hwcaps.currently_available_video_ram/1024;
     this->info.wm_available = 1;
-    this->info.hw_available = 1;
-    this->info.blit_fill = 1;
-    this->info.blit_hw = 1;
-    this->info.blit_hw_A = 0;
-    this->info.blit_hw_CC = 1;
+
+    ph_UpdateHWInfo(this);
     
     return 0;
 }
 
 static SDL_Surface* ph_SetVideoMode(_THIS, SDL_Surface *current, int width, int height, int bpp, Uint32 flags)
 {
-    PgHWCaps_t hwcaps;
     const struct ColourMasks* mask;
 
     /* Lock the event thread, in multi-threading environments */
@@ -558,6 +558,7 @@
     /* Must call at least once for setup image planes */
     if (ph_SetupUpdateFunction(this, current, current->flags)==-1)
     {
+        /* Error string was filled in the ph_SetupUpdateFunction() */
         return NULL;
     }
 
@@ -573,12 +574,7 @@
 
     visualbpp=bpp;
 
-    if (PgGetGraphicsHWCaps(&hwcaps) < 0)
-    {
-        SDL_SetError("ph_SetVideoMode(): GetGraphicsHWCaps function failed !\n");
-        return NULL;
-    }
-    this->info.video_mem=hwcaps.currently_available_video_ram/1024;
+    ph_UpdateHWInfo(this);
 
     SDL_Unlock_EventThread();