Better handling of bad GL drivers

git-svn-id: https://svn.eduke32.com/eduke32@1036 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
terminx 2008-08-26 19:50:34 +00:00
parent f814485606
commit b38cbec5c8
4 changed files with 45 additions and 9 deletions

View file

@ -7781,6 +7781,11 @@ int setgamemode(char davidoption, int daxdim, int daydim, int dabpp)
{ {
int i, j; int i, j;
#if defined(USE_OPENGL) && defined(POLYMOST)
extern char nogl;
if (nogl) dabpp = 8;
#endif
if ((qsetmode == 200) && (videomodereset == 0) && if ((qsetmode == 200) && (videomodereset == 0) &&
(davidoption == fullscreen) && (xdim == daxdim) && (ydim == daydim) && (bpp == dabpp)) (davidoption == fullscreen) && (xdim == daxdim) && (ydim == daydim) && (bpp == dabpp))
return(0); return(0);
@ -7792,6 +7797,7 @@ int setgamemode(char davidoption, int daxdim, int daydim, int dabpp)
//if (checkvideomode(&daxdim, &daydim, dabpp, davidoption)<0) return (-1); //if (checkvideomode(&daxdim, &daydim, dabpp, davidoption)<0) return (-1);
//bytesperline is set in this function //bytesperline is set in this function
j = bpp; j = bpp;
if (setvideomode(daxdim,daydim,dabpp,davidoption) < 0) return(-1); if (setvideomode(daxdim,daydim,dabpp,davidoption) < 0) return(-1);

View file

@ -59,7 +59,7 @@ static unsigned short sysgamma[3][256];
extern int curbrightness, gammabrightness; extern int curbrightness, gammabrightness;
#ifdef USE_OPENGL #ifdef USE_OPENGL
// OpenGL stuff // OpenGL stuff
static char nogl=0; char nogl=0;
#endif #endif
int vsync=0; int vsync=0;

View file

@ -67,7 +67,8 @@ extern int curbrightness, gammabrightness;
// OpenGL stuff // OpenGL stuff
static HGLRC hGLRC = 0; static HGLRC hGLRC = 0;
char nofog=0; char nofog=0;
static char nogl=0; char nogl=0;
char forcegl=0;
#endif #endif
static LPTSTR GetWindowsErrorMsg(DWORD code); static LPTSTR GetWindowsErrorMsg(DWORD code);
@ -382,6 +383,8 @@ int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpCmdLine, int nC
#if defined(USE_OPENGL) && defined(POLYMOST) #if defined(USE_OPENGL) && defined(POLYMOST)
if ((argp = Bgetenv("BUILD_NOFOG")) != NULL) if ((argp = Bgetenv("BUILD_NOFOG")) != NULL)
nofog = Batol(argp); nofog = Batol(argp);
if (Bgetenv("BUILD_FORCEGL") != NULL)
forcegl = 1;
#endif #endif
// install signal handlers // install signal handlers
@ -1402,7 +1405,7 @@ static void GetKeyNames(void)
tbuf[0] = 0; tbuf[0] = 0;
GetKeyNameText((i>128?(i+128):i)<<16, tbuf, sizeof(keynames[i])-1); GetKeyNameText((i>128?(i+128):i)<<16, tbuf, sizeof(keynames[i])-1);
// initprintf("%d %15s %15s\n",i,keynames[i],tbuf); // initprintf("%d %15s %15s\n",i,keynames[i],tbuf);
if(*tbuf)strncpy((char *)keynames[i], tbuf, sizeof(keynames[i])-1); if(*tbuf)strncpy(&keynames[i][0], tbuf, sizeof(keynames[i])-1);
} }
} }
@ -2248,7 +2251,8 @@ void getvalidmodes(void)
HRESULT result; HRESULT result;
#if defined(USE_OPENGL) && defined(POLYMOST) #if defined(USE_OPENGL) && defined(POLYMOST)
if (desktopbpp > 8) cdepths[1] = desktopbpp; if (desktopbpp > 8 && !nogl) cdepths[1] = desktopbpp;
else cdepths[1] = 0;
#endif #endif
if (modeschecked) return; if (modeschecked) return;
@ -3257,12 +3261,31 @@ static int SetupOpenGL(int width, int height, int bitspp)
{ {
GLubyte *p,*p2,*p3; GLubyte *p,*p2,*p3;
int err = 0;
glinfo.vendor = (char *)bglGetString(GL_VENDOR); glinfo.vendor = (char *)bglGetString(GL_VENDOR);
glinfo.renderer = (char *)bglGetString(GL_RENDERER); glinfo.renderer = (char *)bglGetString(GL_RENDERER);
glinfo.version = (char *)bglGetString(GL_VERSION); glinfo.version = (char *)bglGetString(GL_VERSION);
glinfo.extensions = (char *)bglGetString(GL_EXTENSIONS); glinfo.extensions = (char *)bglGetString(GL_EXTENSIONS);
// GL driver blacklist
if (!forcegl)
{
if (!Bstrcmp(glinfo.vendor,"Microsoft Corporation")) err = 1;
else if (!Bstrcmp(glinfo.vendor,"SiS")) err = 1;
else if (!Bstrcmp(glinfo.vendor,"3Dfx Interactive Inc.")) err = 1;
if (err)
{
OSD_Printf("Unsupported OpenGL driver. GL modes will be unavailable.\n");
ReleaseOpenGL();
nogl = 1;
modeschecked = 0;
getvalidmodes();
return TRUE;
}
}
glinfo.maxanisotropy = 1.0; glinfo.maxanisotropy = 1.0;
glinfo.bgra = 0; glinfo.bgra = 0;
glinfo.texcompr = 0; glinfo.texcompr = 0;

View file

@ -10990,19 +10990,26 @@ void app_main(int argc,const char **argv)
if (setgamemode(ud.config.ScreenMode,ud.config.ScreenWidth,ud.config.ScreenHeight,ud.config.ScreenBPP) < 0) if (setgamemode(ud.config.ScreenMode,ud.config.ScreenWidth,ud.config.ScreenHeight,ud.config.ScreenBPP) < 0)
{ {
int i = 0; int i = 0, j = 0;
int xres[] = {800,640,320}; int xres[] = {ud.config.ScreenWidth,800,640,320};
int yres[] = {600,480,240}; int yres[] = {ud.config.ScreenHeight,600,480,240};
int bpp[] = {32,16,8}; int bpp[] = {32,16,8};
initprintf("Failure setting video mode %dx%dx%d %s! Attempting safer mode...\n", initprintf("Failure setting video mode %dx%dx%d %s! Attempting safer mode...\n",
ud.config.ScreenWidth,ud.config.ScreenHeight,ud.config.ScreenBPP,ud.config.ScreenMode?"fullscreen":"windowed"); ud.config.ScreenWidth,ud.config.ScreenHeight,ud.config.ScreenBPP,ud.config.ScreenMode?"fullscreen":"windowed");
#if defined(POLYMOST) && defined(USE_OPENGL) #if defined(POLYMOST) && defined(USE_OPENGL)
while (setgamemode(0,xres[i],yres[i],bpp[i]) < 0) while (setgamemode(0,xres[i],yres[i],bpp[j]) < 0)
{ {
initprintf("Failure setting video mode %dx%dx%d windowed! Attempting safer mode...\n",xres[i],yres[i],bpp[i]); initprintf("Failure setting video mode %dx%dx%d windowed! Attempting safer mode...\n",xres[i],yres[i],bpp[i]);
i++; j++;
if (j == 3)
{
i++;
j = 0;
}
if (i == 4)
gameexit("Unable to set failsafe video mode!");
} }
#else #else
while (setgamemode(0,xres[i],yres[i],8) < 0) while (setgamemode(0,xres[i],yres[i],8) < 0)