mirror of
https://github.com/dborth/fceugx.git
synced 2025-01-23 05:51:10 +01:00
sync with FCEUX
This commit is contained in:
parent
d394fbce17
commit
bc0ec15568
@ -787,7 +787,7 @@ int FDSLoad(const char *name, FCEUFILE *fp)
|
|||||||
|
|
||||||
if(!(zp=FCEUD_UTF8fopen(fn,"rb")))
|
if(!(zp=FCEUD_UTF8fopen(fn,"rb")))
|
||||||
{
|
{
|
||||||
FCEU_PrintError("FDS BIOS ROM image missing!");
|
FCEU_PrintError("FDS BIOS ROM image missing: %s", FCEU_MakeFName(FCEUMKF_FDSROM,0,0).c_str());
|
||||||
FreeFDSMemory();
|
FreeFDSMemory();
|
||||||
free(fn);
|
free(fn);
|
||||||
return 0;
|
return 0;
|
||||||
@ -834,6 +834,10 @@ if (!disableBatteryLoading)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef GEKKO
|
||||||
|
extern char LoadedRomFName[2048];
|
||||||
|
strcpy(LoadedRomFName,name); //For the debugger list
|
||||||
|
#endif
|
||||||
GameInfo->type=GIT_FDS;
|
GameInfo->type=GIT_FDS;
|
||||||
GameInterface=FDSGI;
|
GameInterface=FDSGI;
|
||||||
|
|
||||||
|
@ -266,6 +266,7 @@ struct PPUREGS {
|
|||||||
}
|
}
|
||||||
} ppur;
|
} ppur;
|
||||||
|
|
||||||
|
|
||||||
static void makeppulut(void)
|
static void makeppulut(void)
|
||||||
{
|
{
|
||||||
int x;
|
int x;
|
||||||
@ -471,6 +472,22 @@ void (*FFCEUX_PPUWrite)(uint32 A, uint8 V) = 0;
|
|||||||
|
|
||||||
//whether to use the new ppu (new PPU doesn't handle MMC5 extra nametables at all
|
//whether to use the new ppu (new PPU doesn't handle MMC5 extra nametables at all
|
||||||
int newppu = 0;
|
int newppu = 0;
|
||||||
|
|
||||||
|
void ppu_getScroll(int &xpos, int &ypos)
|
||||||
|
{
|
||||||
|
if(newppu)
|
||||||
|
{
|
||||||
|
ypos = ppur._vt*8 + ppur._fv + ppur._v*256;
|
||||||
|
xpos = ppur._ht*8 + ppur.fh + ppur._h*256;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xpos = ((RefreshAddr & 0x400) >> 2) | ((RefreshAddr & 0x1F) << 3) | XOffset;
|
||||||
|
|
||||||
|
ypos = ((RefreshAddr & 0x3E0) >> 2) | ((RefreshAddr & 0x7000) >> 12);
|
||||||
|
if(RefreshAddr & 0x800) ypos += 240;
|
||||||
|
}
|
||||||
|
}
|
||||||
//---------------
|
//---------------
|
||||||
|
|
||||||
static DECLFR(A2002)
|
static DECLFR(A2002)
|
||||||
@ -1074,7 +1091,8 @@ static void CheckSpriteHit(int p)
|
|||||||
|
|
||||||
for(x=sphitx;x<(sphitx+8) && x<l;x++)
|
for(x=sphitx;x<(sphitx+8) && x<l;x++)
|
||||||
{
|
{
|
||||||
if((sphitdata&(0x80>>(x-sphitx))) && !(Plinef[x]&64))
|
|
||||||
|
if((sphitdata&(0x80>>(x-sphitx))) && !(Plinef[x]&64) && x < 255)
|
||||||
{
|
{
|
||||||
PPU_status|=0x40;
|
PPU_status|=0x40;
|
||||||
//printf("Ha: %d, %d, Hita: %d, %d, %d, %d, %d\n",p,p&~7,scanline,GETLASTPIXEL-16,&Plinef[x],Pline,Pline-Plinef);
|
//printf("Ha: %d, %d, Hita: %d, %d, %d, %d, %d\n",p,p&~7,scanline,GETLASTPIXEL-16,&Plinef[x],Pline,Pline-Plinef);
|
||||||
@ -2284,9 +2302,10 @@ int FCEUX_PPU_Loop(int skip) {
|
|||||||
//1. is it sprite#0?
|
//1. is it sprite#0?
|
||||||
//2. is the bg pixel nonzero?
|
//2. is the bg pixel nonzero?
|
||||||
//then, it is spritehit.
|
//then, it is spritehit.
|
||||||
if(oam[6] == 0 && pixel != 0)
|
if(oam[6] == 0 && (pixel & 3) != 0 &&
|
||||||
|
rasterpos < 255)
|
||||||
{
|
{
|
||||||
PPU_status |= 0x40;
|
PPU_status |= 0x40;
|
||||||
}
|
}
|
||||||
havepixel = true;
|
havepixel = true;
|
||||||
|
|
||||||
|
@ -17,6 +17,8 @@ extern uint8 PPUCHRRAM;
|
|||||||
void FCEUPPU_SaveState(void);
|
void FCEUPPU_SaveState(void);
|
||||||
void FCEUPPU_LoadState(int version);
|
void FCEUPPU_LoadState(int version);
|
||||||
uint8* FCEUPPU_GetCHR(uint32 vadr, uint32 refreshaddr);
|
uint8* FCEUPPU_GetCHR(uint32 vadr, uint32 refreshaddr);
|
||||||
|
void ppu_getScroll(int &xpos, int &ypos);
|
||||||
|
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
#define FASTCALL __fastcall
|
#define FASTCALL __fastcall
|
||||||
|
Loading…
x
Reference in New Issue
Block a user