f8db7ee747
New in This Version (2.4) As I now have five (!) different emulators to maintain in addition to my academic studies, I expect you, people, to look for bugs and fix them if possible. Please, submit your fixes and bug reports! * Small fix to the DI instruction. * Small fix to the HALT instruction. * Added -sync option to fMSX-MSDOS on public request. * Fixed PHYDIO DiskROM call (4010h) to return the number of remaining sectors in register B (thanks, Maarten!). * Fixed ASCII mappers to prevent memory corruption when switching ROM pages in disconnected slots. * Fixed palette to span to true white. * Added SetWave() call to the sound API. * SCC emulation now makes use of waveforms via SetWave(). * SCC gets silenced when 0 frequency is written (thanks, Maarten!). * Fixed SCC+ emulation. * Vertical screen adjustment is only computed once, when refresh starts. * Moved picture 10 pixels down when the screen is 192 pixels high. * Removed unused SprCol variable. * Added wave synthesis sound to fMSX-Windows. * Fixed fMSX-MSDOS to restore palette when exiting the debugger. New in fMSX 2.3 * Now, when you buy fMSX-Windows, you also fMSX-MSDOS. * Added modular FMPAC (aka YM2413 aka OPLL) emulation. * FMPAC soundtrack can be logged into a MIDI file. * Sound and MIDI logging APIs have been integrated and rewritten to accomodate MIDI instruments, dynamic instrument changes, drum usage, etc. * Added PAL/NTSC switch on a bit in VDP[9] (thanks, Alex!). * Added support for the overscan (Mantra demos and games run now). * Added sprite support to SCREEN3 (no idea why it was not there). * Added support for YJK (SCREEN12) and YAE (SCREEN10/11) screens. * Added separate handling for IE0 and IE1 IRQs (Xevious, etc.). * Added masking of Character Table address (SourceOfPower demo runs now). * Fixed Z80 interrupt handling after EI (thanks, Maarten!). * IE0 and IE1 IRQs are now reset when disabled. * IE0 IRQ is now set when enabled. * Palette sequencer now resets when writing to VDP[16]. * Fixed mapper #1 to support generic 16kB-paged MegaROMs (HoleInOneSpecial). * Fixed cartridge loader to correctly load MegaROMs with "AB" signature in the last 16kB page (R-Type). * Mappers #0 and #1 are now renamed to Generic/8kB and Generic/16kB. * Fixed mapper #3 to have hardwired ROM at addresses 4000h-5FFFh (thanks, Sean!). * Added mapper #6 that corresponds to the Konami GameMaster2 cartridge with SRAM (thanks again, Sean!). * Added key click and motor relay click emulation via Drum() call. * Major rewrite of the sound drivers and sound logging system. * Added mouse emulation to fMSX-MSDOS. * Added border emulation via VGA border to fMSX-MSDOS. * Added built-in debugger to fMSX-MSDOS (F11). * Fixed static palette in fMSX-MSDOS. * Fixed fMSX-Unix to work in 24BPP and 32BPP modes. * Added static palette to fMSX-Unix. * Minor fixes to fMSX-Unix makefile. * fMSX-Windows now runs in 16BPP HiColor mode. * Changed Setup Panel in fMSX-Windows. * HPeriod and VPeriod scrollbars are gone from fMSX-Windows as timing control is done automatically. * PAL and NTSC buttons are gone from fMSX-Windows as PAL/NTSC switch is done automatically. - minor inprovements or modifies. It is now selectable if use sun-compatible sound or ossaudio by defining USE_SUN_AUDIO to YES or NO in /etc/mk.conf (default YES) XXX Though it can be build in both conditions, sound still doesn't work properly. On my macppc box, if USE_SUN_AUDIO to YES, it generates continuous hum and nothing changes by play command in BASIC interpreter within the emulator. if set it to NO, it keeps quiet. cleanup package Makefile some.
180 lines
5 KiB
Text
180 lines
5 KiB
Text
$NetBSD: patch-ad,v 1.3 2001/06/03 17:34:58 kei Exp $
|
|
|
|
--- MSX.c.orig Mon May 14 07:35:08 2001
|
|
+++ MSX.c Sun Jun 3 04:36:49 2001
|
|
@@ -287,6 +287,7 @@
|
|
byte *P;
|
|
word A;
|
|
FILE *F;
|
|
+ char string[FILENAME_MAX];
|
|
|
|
/*** STARTUP CODE starts here: ***/
|
|
|
|
@@ -380,7 +381,7 @@
|
|
|
|
/* Save current directory and cd to wherever system ROMs are */
|
|
if(ProgDir)
|
|
- if(WorkDir=getcwd(NULL,0))
|
|
+ if((WorkDir=getcwd(NULL,0)))
|
|
{
|
|
Chunks[CCount++]=WorkDir;
|
|
chdir(ProgDir);
|
|
@@ -391,7 +392,10 @@
|
|
{
|
|
case 0:
|
|
if(Verbose) printf(" Opening MSX.ROM...");
|
|
- P=LoadROM("MSX.ROM",0x8000,0);
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "MSX.ROM");
|
|
+ P=LoadROM(string,0x8000,0);
|
|
PRINTRESULT(P);
|
|
if(!P) return(0);
|
|
MemMap[0][0][0]=P;
|
|
@@ -402,7 +406,10 @@
|
|
|
|
case 1:
|
|
if(Verbose) printf(" Opening MSX2.ROM...");
|
|
- P=LoadROM("MSX2.ROM",0x8000,0);
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "MSX2.ROM");
|
|
+ P=LoadROM(string,0x8000,0);
|
|
PRINTRESULT(P);
|
|
if(!P) return(0);
|
|
MemMap[0][0][0]=P;
|
|
@@ -410,7 +417,10 @@
|
|
MemMap[0][0][2]=P+0x4000;
|
|
MemMap[0][0][3]=P+0x6000;
|
|
if(Verbose) printf(" Opening MSX2EXT.ROM...");
|
|
- P=LoadROM("MSX2EXT.ROM",0x4000,0);
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "MSX2EXT.ROM");
|
|
+ P=LoadROM(string,0x4000,0);
|
|
PRINTRESULT(P);
|
|
if(!P) return(0);
|
|
MemMap[3][1][0]=P;
|
|
@@ -419,7 +429,10 @@
|
|
|
|
case 2:
|
|
if(Verbose) printf(" Opening MSX2P.ROM...");
|
|
- P=LoadROM("MSX2P.ROM",0x8000,0);
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "MSX2P.ROM");
|
|
+ P=LoadROM(string,0x8000,0);
|
|
PRINTRESULT(P);
|
|
if(!P) return(0);
|
|
MemMap[0][0][0]=P;
|
|
@@ -427,7 +440,10 @@
|
|
MemMap[0][0][2]=P+0x4000;
|
|
MemMap[0][0][3]=P+0x6000;
|
|
if(Verbose) printf(" Opening MSX2PEXT.ROM...");
|
|
- P=LoadROM("MSX2PEXT.ROM",0x4000,0);
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "MSX2PEXT.ROM");
|
|
+ P=LoadROM(string,0x4000,0);
|
|
PRINTRESULT(P);
|
|
if(!P) return(0);
|
|
MemMap[3][1][0]=P;
|
|
@@ -436,7 +452,10 @@
|
|
}
|
|
|
|
/* Try loading DiskROM */
|
|
- if(P=LoadROM("DISK.ROM",0x4000,0))
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "DISK.ROM");
|
|
+ if((P=LoadROM(string,0x4000,0)))
|
|
{
|
|
if(Verbose) puts(" Opening DISK.ROM...OK");
|
|
MemMap[3][1][2]=P;
|
|
@@ -469,16 +488,25 @@
|
|
if(Verbose) printf("Loading other ROMs: ");
|
|
|
|
/* Try loading CMOS memory contents */
|
|
- if(LoadROM("CMOS.ROM",sizeof(RTC),(byte *)RTC))
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "CMOS.ROM");
|
|
+ if(LoadROM(string,sizeof(RTC),(byte *)RTC))
|
|
{ if(Verbose) printf("CMOS.ROM.."); }
|
|
else memcpy(RTC,RTCInit,sizeof(RTC));
|
|
|
|
/* Try loading Kanji alphabet ROM */
|
|
- if(Kanji=LoadROM("KANJI.ROM",0x20000,0))
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "KANJI.ROM");
|
|
+ if((Kanji=LoadROM(string,0x20000,0)))
|
|
{ if(Verbose) printf("KANJI.ROM.."); }
|
|
|
|
/* Try loading RS232 support ROM */
|
|
- if(P=LoadROM("RS232.ROM..",0x4000,0))
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "RS232.ROM");
|
|
+ if((P=LoadROM(string,0x4000,0)))
|
|
{
|
|
if(Verbose) printf("RS232.ROM..");
|
|
MemMap[3][0][2]=P;
|
|
@@ -486,7 +514,10 @@
|
|
}
|
|
|
|
/* Try loading FM-PAC support ROM */
|
|
- if(P=LoadROM("FMPAC.ROM",0x4000,0))
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "FMPAC.ROM");
|
|
+ if((P=LoadROM(string,0x4000,0)))
|
|
{
|
|
if(Verbose) printf("FMPAC.ROM..");
|
|
MemMap[3][3][2]=P;
|
|
@@ -574,7 +605,10 @@
|
|
if(J&&(MemMap[3][1][2]!=EmptyRAM))
|
|
{
|
|
if(J==2) ROMTypeB=1; else ROMTypeA=1;
|
|
- if(LoadCart("MSXDOS2.ROM",J-1))
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "MSXDOS2.ROM");
|
|
+ if(LoadCart(string,J-1))
|
|
SetMegaROM(J-1,0,1,ROMMask[J-1]-1,ROMMask[J-1]);
|
|
}
|
|
|
|
@@ -584,15 +618,21 @@
|
|
else J=0;
|
|
|
|
/* Try loading PAINTER ROM if slot found */
|
|
- if(J) LoadCart("PAINTER.ROM",J-1);
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, "PAINTER.ROM");
|
|
+ if(J) LoadCart(string,J-1);
|
|
}
|
|
|
|
/* We are now back to working directory */
|
|
if(WorkDir) chdir(WorkDir);
|
|
|
|
/* Try loading font */
|
|
- if(Verbose) printf("Loading %s font...",FontName);
|
|
- FontBuf=LoadROM(FontName,0x800,0);
|
|
+ bzero(string, sizeof(string));
|
|
+ strcpy(string, RomDir);
|
|
+ strcat(string, FontName);
|
|
+ if(Verbose) printf("Loading %s font...",string);
|
|
+ FontBuf=LoadROM(string,0x800,0);
|
|
PRINTRESULT(FontBuf);
|
|
|
|
/* Open stream for a printer */
|
|
@@ -624,7 +664,7 @@
|
|
|
|
/* Open casette image */
|
|
if(CasName)
|
|
- if(CasStream=fopen(CasName,"r+b"))
|
|
+ if((CasStream=fopen(CasName,"r+b")))
|
|
if(Verbose) printf("Using %s as a tape\n",CasName);
|
|
|
|
if(Verbose)
|