+ if(vid_forcerefreshrate.integer)
+ {
+ foundmode = true;
+ gdevmode.dmFields = DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT;
+ gdevmode.dmBitsPerPel = bpp;
+ gdevmode.dmPelsWidth = width;
+ gdevmode.dmPelsHeight = height;
+ gdevmode.dmSize = sizeof (gdevmode);
+ if(refreshrate)
+ {
+ gdevmode.dmFields |= DM_DISPLAYFREQUENCY;
+ gdevmode.dmDisplayFrequency = refreshrate;
+ }
+ }
+ else
+ {
+ if(refreshrate == 0)
+ refreshrate = initialdevmode.dmDisplayFrequency; // default vid_refreshrate to the rate of the desktop
+
+ foundmode = false;
+ foundgoodmode = false;
+
+ thismode.dmSize = sizeof(thismode);
+ thismode.dmDriverExtra = 0;
+ for(i = 0; EnumDisplaySettings(NULL, i, &thismode); ++i)
+ {
+ if(~thismode.dmFields & (DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT | DM_DISPLAYFREQUENCY))
+ {
+ Con_DPrintf("enumerating modes yielded a bogus item... please debug this\n");
+ continue;
+ }
+ if(developer.integer >= 100)
+ Con_Printf("Found mode %dx%dx%dbpp %dHz... ", (int)thismode.dmPelsWidth, (int)thismode.dmPelsHeight, (int)thismode.dmBitsPerPel, (int)thismode.dmDisplayFrequency);
+ if(thismode.dmBitsPerPel != (DWORD)bpp)
+ {
+ if(developer.integer >= 100)
+ Con_Printf("wrong bpp\n");
+ continue;
+ }
+ if(thismode.dmPelsWidth != (DWORD)width)
+ {
+ if(developer.integer >= 100)
+ Con_Printf("wrong width\n");
+ continue;
+ }
+ if(thismode.dmPelsHeight != (DWORD)height)
+ {
+ if(developer.integer >= 100)
+ Con_Printf("wrong height\n");
+ continue;
+ }
+
+ if(foundgoodmode)
+ {
+ // if we have a good mode, make sure this mode is better than the previous one, and allowed by the refreshrate
+ if(thismode.dmDisplayFrequency > (DWORD)refreshrate)
+ {
+ if(developer.integer >= 100)
+ Con_Printf("too high refresh rate\n");
+ continue;
+ }
+ else if(thismode.dmDisplayFrequency <= gdevmode.dmDisplayFrequency)
+ {
+ if(developer.integer >= 100)
+ Con_Printf("doesn't beat previous best match (too low)\n");
+ continue;
+ }
+ }
+ else if(foundmode)
+ {
+ // we do have one, but it isn't good... make sure it has a lower frequency than the previous one
+ if(thismode.dmDisplayFrequency >= gdevmode.dmDisplayFrequency)
+ {
+ if(developer.integer >= 100)
+ Con_Printf("doesn't beat previous best match (too high)\n");
+ continue;
+ }
+ }
+ // otherwise, take anything
+
+ memcpy(&gdevmode, &thismode, sizeof(gdevmode));
+ if(thismode.dmDisplayFrequency <= (DWORD)refreshrate)
+ foundgoodmode = true;
+ else
+ {
+ if(developer.integer >= 100)
+ Con_Printf("(out of range)\n");
+ }
+ foundmode = true;
+ if(developer.integer >= 100)
+ Con_Printf("accepted\n");
+ }
+ }
+
+ if (!foundmode)
+ {
+ VID_Shutdown();
+ Con_Printf("Unable to find the requested mode %dx%dx%dbpp\n", width, height, bpp);
+ return false;
+ }
+ else if(ChangeDisplaySettings (&gdevmode, CDS_FULLSCREEN) != DISP_CHANGE_SUCCESSFUL)