Hmm, looks like we're still not ready for the 2.6.1 release.

Removed scanline autodetection from the Console startup code.  It makes
more sense to just assume the Console is either NTSC or PAL, and let the
TIA auto-adjust the framerate if necessary.


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1530 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2008-05-21 21:36:18 +00:00
parent 832fab1ee8
commit 8d4d5b4563
1 changed files with 8 additions and 23 deletions

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: Console.cxx,v 1.146 2008-05-21 21:01:40 stephena Exp $ // $Id: Console.cxx,v 1.147 2008-05-21 21:36:18 stephena Exp $
//============================================================================ //============================================================================
#include <cassert> #include <cassert>
@ -126,7 +126,6 @@ Console::Console(OSystem* osystem, Cartridge* cart, const Properties& props)
// Auto-detect NTSC/PAL mode if it's requested // Auto-detect NTSC/PAL mode if it's requested
myDisplayFormat = myProperties.get(Display_Format); myDisplayFormat = myProperties.get(Display_Format);
float avgScanlineCount = 0.0;
vidinfo << " Display Format: " << myDisplayFormat; vidinfo << " Display Format: " << myDisplayFormat;
if(myDisplayFormat == "AUTO-DETECT" || if(myDisplayFormat == "AUTO-DETECT" ||
myOSystem->settings().getBool("rominfo")) myOSystem->settings().getBool("rominfo"))
@ -137,18 +136,13 @@ Console::Console(OSystem* osystem, Cartridge* cart, const Properties& props)
// Unfortunately, this means we have to always enable 'fastscbios', // Unfortunately, this means we have to always enable 'fastscbios',
// since otherwise the BIOS loading will take over 250 frames! // since otherwise the BIOS loading will take over 250 frames!
mySystem->reset(); mySystem->reset();
int palCount = 0, scanlineCount = 0; int palCount = 0;
for(int i = 0; i < 60; ++i) for(int i = 0; i < 60; ++i)
{ {
myMediaSource->update(); myMediaSource->update();
if(i >= 30) if(i >= 30 && myMediaSource->scanlines() > 285)
{ ++palCount;
if(myMediaSource->scanlines() > 285)
++palCount;
scanlineCount += myMediaSource->scanlines();
}
} }
avgScanlineCount = scanlineCount / 30.0;
myDisplayFormat = (palCount >= 15) ? "PAL" : "NTSC"; myDisplayFormat = (palCount >= 15) ? "PAL" : "NTSC";
if(myProperties.get(Display_Format) == "AUTO-DETECT") if(myProperties.get(Display_Format) == "AUTO-DETECT")
vidinfo << " ==> " << myDisplayFormat; vidinfo << " ==> " << myDisplayFormat;
@ -158,26 +152,17 @@ Console::Console(OSystem* osystem, Cartridge* cart, const Properties& props)
// Note that this can be overridden if a format is forced // Note that this can be overridden if a format is forced
// For example, if a PAL ROM is forced to be NTSC, it will use NTSC-like // For example, if a PAL ROM is forced to be NTSC, it will use NTSC-like
// properties (60Hz, 262 scanlines, etc) and cycle between NTSC-like modes // properties (60Hz, 262 scanlines, etc) and cycle between NTSC-like modes
// The TIA will self-adjust the framerate if necessary
if(myDisplayFormat == "NTSC" || myDisplayFormat == "PAL60" || if(myDisplayFormat == "NTSC" || myDisplayFormat == "PAL60" ||
myDisplayFormat == "SECAM60") myDisplayFormat == "SECAM60")
{ {
// Try to be as accurate as possible with the framerate // Assume we've got ~262 scanlines (NTSC-like format)
// Use the scanline count if available, otherwise assume we've got
// ~262 scanlines (NTSC-like format)
if(avgScanlineCount > 0.0)
myFramerate = 15720.0 / avgScanlineCount;
else
myFramerate = 60.0; myFramerate = 60.0;
} }
else else
{ {
// Try to be as accurate as possible with the framerate // Assume we've got ~312 scanlines (PAL-like format)
// Use the scanline count if available, otherwise assume we've got myFramerate = 50.0;
// ~312 scanlines (PAL-like format)
if(avgScanlineCount > 0.0)
myFramerate = 15600.0 / avgScanlineCount;
else
myFramerate = 50.0;
if(myProperties.get(Display_Height) == "210") if(myProperties.get(Display_Height) == "210")
myProperties.set(Display_Height, "250"); myProperties.set(Display_Height, "250");