CDLOGGER: avoid to log VRAM access
This commit is contained in:
parent
2524abbb3c
commit
7dfd0d6242
|
@ -47,20 +47,15 @@ extern uint8 *trainerpoo;
|
||||||
extern volatile int rendercount, vromreadcount, undefinedvromcount;
|
extern volatile int rendercount, vromreadcount, undefinedvromcount;
|
||||||
extern unsigned char *cdloggervdata;
|
extern unsigned char *cdloggervdata;
|
||||||
extern int newppu;
|
extern int newppu;
|
||||||
|
extern uint32 VROM_size;
|
||||||
|
|
||||||
int CDLogger_wndx=0, CDLogger_wndy=0;
|
int CDLogger_wndx=0, CDLogger_wndy=0;
|
||||||
|
|
||||||
//extern uint8 *ROM;
|
|
||||||
//extern uint8 *VROM;
|
|
||||||
|
|
||||||
extern uint8 *NSFDATA;
|
extern uint8 *NSFDATA;
|
||||||
extern int NSFMaxBank;
|
extern int NSFMaxBank;
|
||||||
static uint8 NSFLoadLow;
|
static uint8 NSFLoadLow;
|
||||||
static uint8 NSFLoadHigh;
|
static uint8 NSFLoadHigh;
|
||||||
|
|
||||||
//volatile int loggingcodedata;
|
|
||||||
//int cdlogger_open;
|
|
||||||
|
|
||||||
HWND hCDLogger;
|
HWND hCDLogger;
|
||||||
char loadedcdfile[1024];
|
char loadedcdfile[1024];
|
||||||
|
|
||||||
|
@ -117,11 +112,14 @@ BOOL CALLBACK CDLoggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
hCDLogger = hwndDlg;
|
hCDLogger = hwndDlg;
|
||||||
codecount = datacount = rendercount = vromreadcount = 0;
|
codecount = datacount = rendercount = vromreadcount = 0;
|
||||||
undefinedcount = PRGsize[0];
|
undefinedcount = PRGsize[0];
|
||||||
undefinedvromcount = CHRsize[0];
|
|
||||||
cdloggerdata = (unsigned char*)malloc(PRGsize[0]); //mbg merge 7/18/06 added cast
|
cdloggerdata = (unsigned char*)malloc(PRGsize[0]); //mbg merge 7/18/06 added cast
|
||||||
cdloggervdata = (unsigned char*)malloc(CHRsize[0]);
|
|
||||||
ZeroMemory(cdloggerdata,PRGsize[0]);
|
ZeroMemory(cdloggerdata,PRGsize[0]);
|
||||||
|
if(VROM_size)
|
||||||
|
{
|
||||||
|
undefinedvromcount = CHRsize[0];
|
||||||
|
cdloggervdata = (unsigned char*)malloc(CHRsize[0]);
|
||||||
ZeroMemory(cdloggervdata,CHRsize[0]);
|
ZeroMemory(cdloggervdata,CHRsize[0]);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case WM_CLOSE:
|
case WM_CLOSE:
|
||||||
case WM_QUIT:
|
case WM_QUIT:
|
||||||
|
@ -147,9 +145,12 @@ MB_OK);
|
||||||
case BTN_CDLOGGER_RESET:
|
case BTN_CDLOGGER_RESET:
|
||||||
codecount = datacount = rendercount = vromreadcount = 0;
|
codecount = datacount = rendercount = vromreadcount = 0;
|
||||||
undefinedcount = PRGsize[0];
|
undefinedcount = PRGsize[0];
|
||||||
undefinedvromcount = CHRsize[0];
|
|
||||||
ZeroMemory(cdloggerdata,PRGsize[0]);
|
ZeroMemory(cdloggerdata,PRGsize[0]);
|
||||||
|
if(VROM_size)
|
||||||
|
{
|
||||||
|
undefinedvromcount = CHRsize[0];
|
||||||
ZeroMemory(cdloggervdata,CHRsize[0]);
|
ZeroMemory(cdloggervdata,CHRsize[0]);
|
||||||
|
}
|
||||||
UpdateCDLogger();
|
UpdateCDLogger();
|
||||||
break;
|
break;
|
||||||
case BTN_CDLOGGER_LOAD:
|
case BTN_CDLOGGER_LOAD:
|
||||||
|
@ -228,6 +229,8 @@ void LoadCDLog (const char* nameo)
|
||||||
cdloggerdata[i] |= j;
|
cdloggerdata[i] |= j;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(VROM_size)
|
||||||
|
{
|
||||||
for(i = 0;i < (int)CHRsize[0];i++){
|
for(i = 0;i < (int)CHRsize[0];i++){
|
||||||
j = fgetc(FP);
|
j = fgetc(FP);
|
||||||
if(j == EOF)break;
|
if(j == EOF)break;
|
||||||
|
@ -236,6 +239,7 @@ void LoadCDLog (const char* nameo)
|
||||||
if((j & 3) && !(cdloggervdata[i] & 3))undefinedvromcount--; //the appropriate counter.
|
if((j & 3) && !(cdloggervdata[i] & 3))undefinedvromcount--; //the appropriate counter.
|
||||||
cdloggervdata[i] |= j;
|
cdloggervdata[i] |= j;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fclose(FP);
|
fclose(FP);
|
||||||
UpdateCDLogger();
|
UpdateCDLogger();
|
||||||
|
@ -261,10 +265,7 @@ void LoadCDLogFile(){
|
||||||
}
|
}
|
||||||
|
|
||||||
void SaveCDLogFileAs(){
|
void SaveCDLogFileAs(){
|
||||||
//don't be stupid
|
|
||||||
const char filter[]="Code Data Log File (*.CDL)\0*.cdl\0All Files (*.*)\0*.*\0\0";
|
const char filter[]="Code Data Log File (*.CDL)\0*.cdl\0All Files (*.*)\0*.*\0\0";
|
||||||
//this feature not for select desired file extension for saved filename
|
|
||||||
//this feature only for filter file list only for desired file extension.
|
|
||||||
char nameo[2048];
|
char nameo[2048];
|
||||||
OPENFILENAME ofn;
|
OPENFILENAME ofn;
|
||||||
memset(&ofn,0,sizeof(ofn));
|
memset(&ofn,0,sizeof(ofn));
|
||||||
|
@ -273,23 +274,12 @@ void SaveCDLogFileAs(){
|
||||||
ofn.lpstrTitle="Save Code Data Log File As...";
|
ofn.lpstrTitle="Save Code Data Log File As...";
|
||||||
ofn.lpstrFilter=filter;
|
ofn.lpstrFilter=filter;
|
||||||
strcpy(nameo,GetRomName());
|
strcpy(nameo,GetRomName());
|
||||||
//don't be stupid,
|
|
||||||
ofn.lpstrDefExt = "cdl";
|
ofn.lpstrDefExt = "cdl";
|
||||||
//do this automatically with system function, it is doing exactly what it written for
|
|
||||||
//why do you need to do this one more time? All we need here, filled extension in dialog window
|
|
||||||
//BEFORE saving it, there is no other options.
|
|
||||||
ofn.lpstrFile=nameo;
|
ofn.lpstrFile=nameo;
|
||||||
ofn.nMaxFile=256;
|
ofn.nMaxFile=256;
|
||||||
ofn.Flags=OFN_EXPLORER|OFN_FILEMUSTEXIST|OFN_HIDEREADONLY;
|
ofn.Flags=OFN_EXPLORER|OFN_FILEMUSTEXIST|OFN_HIDEREADONLY;
|
||||||
ofn.hwndOwner = hCDLogger;
|
ofn.hwndOwner = hCDLogger;
|
||||||
//after that we will get complete file with ext added automatically from DefExt string
|
|
||||||
//change ext in Save Dialog and it will be saved
|
|
||||||
if(!GetSaveFileName(&ofn))return;
|
if(!GetSaveFileName(&ofn))return;
|
||||||
//there is bad if something is written AFTER i selectdesired file extension in Save Dialog
|
|
||||||
//when I want NOT to have any extension, it will write me default one, that is stupid,
|
|
||||||
//in addition, this is silently forcing default extension to file, but user didn't know about it at all
|
|
||||||
|
|
||||||
//that's all what needed to work. I checked this and it works exactly what it should
|
|
||||||
strcpy(loadedcdfile,nameo);
|
strcpy(loadedcdfile,nameo);
|
||||||
SaveCDLogFile();
|
SaveCDLogFile();
|
||||||
return;
|
return;
|
||||||
|
@ -297,8 +287,6 @@ void SaveCDLogFileAs(){
|
||||||
|
|
||||||
void SaveCDLogFile(){ //todo make this button work before you've saved as
|
void SaveCDLogFile(){ //todo make this button work before you've saved as
|
||||||
FILE *FP;
|
FILE *FP;
|
||||||
//if(loadedcdfile[0] == 0)SaveCDLogFileAs();
|
|
||||||
//FCEUD_PrintError(loadedcdfile);
|
|
||||||
|
|
||||||
FP = fopen(loadedcdfile,"wb");
|
FP = fopen(loadedcdfile,"wb");
|
||||||
if(FP == NULL){
|
if(FP == NULL){
|
||||||
|
@ -306,6 +294,7 @@ void SaveCDLogFile(){ //todo make this button work before you've saved as
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
fwrite(cdloggerdata,PRGsize[0],1,FP);
|
fwrite(cdloggerdata,PRGsize[0],1,FP);
|
||||||
|
if(VROM_size)
|
||||||
fwrite(cdloggervdata,CHRsize[0],1,FP);
|
fwrite(cdloggervdata,CHRsize[0],1,FP);
|
||||||
fclose(FP);
|
fclose(FP);
|
||||||
return;
|
return;
|
||||||
|
@ -317,17 +306,12 @@ void DoCDLogger()
|
||||||
FCEUD_PrintError("You must have a game loaded before you can use the Code Data Logger.");
|
FCEUD_PrintError("You must have a game loaded before you can use the Code Data Logger.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//if (GameInfo->type==GIT_NSF) { //todo: NSF support!
|
|
||||||
// FCEUD_PrintError("Sorry, you can't yet use the Code Data Logger with NSFs.");
|
|
||||||
// return;
|
|
||||||
//}
|
|
||||||
|
|
||||||
if(!hCDLogger)
|
if(!hCDLogger)
|
||||||
{
|
{
|
||||||
CreateDialog(fceu_hInstance,"CDLOGGER",NULL,CDLoggerCallB);
|
CreateDialog(fceu_hInstance,"CDLOGGER",NULL,CDLoggerCallB);
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
//SetWindowPos(hCDLogger,HWND_TOP,0,0,0,0,SWP_NOSIZE|SWP_NOMOVE|SWP_NOOWNERZORDER);
|
|
||||||
ShowWindow(hCDLogger, SW_SHOWNORMAL);
|
ShowWindow(hCDLogger, SW_SHOWNORMAL);
|
||||||
SetForegroundWindow(hCDLogger);
|
SetForegroundWindow(hCDLogger);
|
||||||
}
|
}
|
||||||
|
@ -344,7 +328,7 @@ void UpdateCDLogger(){
|
||||||
float fundefinedcount = undefinedcount;
|
float fundefinedcount = undefinedcount;
|
||||||
float fundefinedvromcount = undefinedvromcount;
|
float fundefinedvromcount = undefinedvromcount;
|
||||||
float fromsize = PRGsize[0];
|
float fromsize = PRGsize[0];
|
||||||
float fvromsize = CHRsize[0];
|
float fvromsize = VROM_size ? CHRsize[0] : 1;
|
||||||
|
|
||||||
sprintf(str,"0x%06x %.2f%%",codecount,fcodecount/fromsize*100);
|
sprintf(str,"0x%06x %.2f%%",codecount,fcodecount/fromsize*100);
|
||||||
SetDlgItemText(hCDLogger,LBL_CDLOGGER_CODECOUNT,str);
|
SetDlgItemText(hCDLogger,LBL_CDLOGGER_CODECOUNT,str);
|
||||||
|
@ -441,7 +425,7 @@ void SaveStrippedRom(int invert){ //this is based off of iNesSave()
|
||||||
fwrite(trainerpoo,512,1,fp);
|
fwrite(trainerpoo,512,1,fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(i = 0;i < head.ROM_size*0x4000;i++){
|
for(i = 0; i < (int)PRGsize[0]; i++){
|
||||||
unsigned char pchar;
|
unsigned char pchar;
|
||||||
if(cdloggerdata[i] & 3)
|
if(cdloggerdata[i] & 3)
|
||||||
pchar = invert?0:ROM[i];
|
pchar = invert?0:ROM[i];
|
||||||
|
@ -450,7 +434,9 @@ void SaveStrippedRom(int invert){ //this is based off of iNesSave()
|
||||||
fputc(pchar, fp);
|
fputc(pchar, fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(i = 0;i < head.VROM_size*0x2000;i++){
|
if(VROM_size)
|
||||||
|
{
|
||||||
|
for(i = 0; i < (int)CHRsize[0]; i++){
|
||||||
unsigned char vchar;
|
unsigned char vchar;
|
||||||
if(cdloggervdata[i] & 1)
|
if(cdloggervdata[i] & 1)
|
||||||
vchar = invert?0:VROM[i];
|
vchar = invert?0:VROM[i];
|
||||||
|
@ -459,6 +445,7 @@ void SaveStrippedRom(int invert){ //this is based off of iNesSave()
|
||||||
fputc(vchar, fp);
|
fputc(vchar, fp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -438,10 +438,12 @@ inline void FFCEUX_PPUWrite_Default(uint32 A, uint8 V) {
|
||||||
|
|
||||||
volatile int rendercount, vromreadcount, undefinedvromcount, LogAddress = -1;
|
volatile int rendercount, vromreadcount, undefinedvromcount, LogAddress = -1;
|
||||||
unsigned char *cdloggervdata;
|
unsigned char *cdloggervdata;
|
||||||
|
extern uint32 VROM_size;
|
||||||
|
|
||||||
int GetCHRAddress(int A){
|
int GetCHRAddress(int A){
|
||||||
int result;
|
int result;
|
||||||
if((A > 0x1fff))return -1;
|
if((A > 0x1fff))return -1;
|
||||||
|
if(!VROM_size)return -1;
|
||||||
result = &VPage[A>>10][A]-CHRptr[0];
|
result = &VPage[A>>10][A]-CHRptr[0];
|
||||||
if((result > (int)CHRsize[0]) || (result < 0))return -1;
|
if((result > (int)CHRsize[0]) || (result < 0))return -1;
|
||||||
else return result;
|
else return result;
|
||||||
|
|
Loading…
Reference in New Issue