Port a few of the Windows cleanups to the Linux version, and correct a few warnings while I'm at it.

git-svn-id: http://pcsx2-playground.googlecode.com/svn/trunk@307 a6443dda-0b58-4228-96e9-037be469359c
This commit is contained in:
arcum42 2008-11-06 13:10:57 +00:00 committed by Gregory Hainaut
parent 56004a1e8b
commit 22fa366df2
8 changed files with 135 additions and 115 deletions

View File

@ -18,6 +18,56 @@
#include "ConfigDlg.h"
static void ConfPlugin(PluginConf confs, char* plugin, const char* name)
{
void *drv;
void (*conf)();
char file[g_MaxPath];
GetComboText(confs.Combo, confs.plist, plugin);
strcpy(file, Config.PluginsDir);
strcat(file, plugin);
drv = SysLoadLibrary(file);
getcwd(file, ARRAYSIZE(file)); /* store current dir */
chdir(Config.PluginsDir); /* change dirs so that plugins can find their config file*/
if (drv == NULL) return;
conf = (void (*)()) SysLoadSym(drv, name);
if (SysLibError() == NULL) conf();
chdir(file); /* change back*/
SysCloseLibrary(drv);
}
static void TestPlugin(PluginConf confs, char* plugin, const char* name)
{
void *drv;
s32 (* (*conf)())();
char file[g_MaxPath];
int ret = 0;
GetComboText(confs.Combo, confs.plist, plugin);
strcpy(file, Config.PluginsDir);
strcat(file, plugin);
drv = SysLoadLibrary(file);
getcwd(file, ARRAYSIZE(file)); /* store current dir */
chdir(Config.PluginsDir); /* change dirs so that plugins can find their config file*/
if (drv == NULL) return;
conf = (s32 (* (*)())()) SysLoadSym(drv, name);
if (SysLibError() == NULL)
ret = (s32) conf();
chdir(file); /* change back*/
SysCloseLibrary(drv);
if (ret == 0)
SysMessage(_("This plugin reports that should work correctly"));
else
SysMessage(_("This plugin reports that should not work correctly"));
}
void OnConf_Gs(GtkMenuItem *menuitem, gpointer user_data)
{
char file[255];
@ -161,99 +211,99 @@ void OnConfConf_Cancel(GtkButton *button, gpointer user_data) {
}
void OnConfConf_GsConf(GtkButton *button, gpointer user_data) {
ConfPlugin(_GSconfigure, GSConfS, Config.GS, "GSconfigure");
ConfPlugin(GSConfS, Config.GS, "GSconfigure");
}
void OnConfConf_GsTest(GtkButton *button, gpointer user_data) {
TestPlugin(_GStest, GSConfS, Config.GS, "GStest");
TestPlugin(GSConfS, Config.GS, "GStest");
}
void OnConfConf_GsAbout(GtkButton *button, gpointer user_data) {
ConfPlugin(_GSabout, GSConfS, Config.GS, "GSabout");
ConfPlugin(GSConfS, Config.GS, "GSabout");
}
void OnConfConf_Pad1Conf(GtkButton *button, gpointer user_data) {
ConfPlugin(_PADconfigure, PAD1ConfS, Config.PAD1, "PADconfigure");
ConfPlugin(PAD1ConfS, Config.PAD1, "PADconfigure");
}
void OnConfConf_Pad1Test(GtkButton *button, gpointer user_data) {
TestPlugin(_PADtest, PAD1ConfS, Config.PAD1, "PADtest");
TestPlugin(PAD1ConfS, Config.PAD1, "PADtest");
}
void OnConfConf_Pad1About(GtkButton *button, gpointer user_data) {
ConfPlugin(_PADabout, PAD1ConfS, Config.PAD1, "PADabout");
ConfPlugin(PAD1ConfS, Config.PAD1, "PADabout");
}
void OnConfConf_Pad2Conf(GtkButton *button, gpointer user_data) {
ConfPlugin(_PADconfigure, PAD2ConfS, Config.PAD2, "PADconfigure");
ConfPlugin(PAD2ConfS, Config.PAD2, "PADconfigure");
}
void OnConfConf_Pad2Test(GtkButton *button, gpointer user_data) {
TestPlugin(_PADtest, PAD2ConfS, Config.PAD2, "PADtest");
TestPlugin(PAD2ConfS, Config.PAD2, "PADtest");
}
void OnConfConf_Pad2About(GtkButton *button, gpointer user_data) {
ConfPlugin(_PADabout, PAD2ConfS, Config.PAD2, "PADabout");
ConfPlugin(PAD2ConfS, Config.PAD2, "PADabout");
}
void OnConfConf_Spu2Conf(GtkButton *button, gpointer user_data) {
ConfPlugin(_SPU2configure, SPU2ConfS, Config.SPU2, "SPU2configure");
ConfPlugin(SPU2ConfS, Config.SPU2, "SPU2configure");
}
void OnConfConf_Spu2Test(GtkButton *button, gpointer user_data) {
TestPlugin(_SPU2test, SPU2ConfS, Config.SPU2, "SPU2test");
TestPlugin(SPU2ConfS, Config.SPU2, "SPU2test");
}
void OnConfConf_Spu2About(GtkButton *button, gpointer user_data) {
ConfPlugin(_SPU2about, SPU2ConfS, Config.SPU2, "SPU2about");
ConfPlugin(SPU2ConfS, Config.SPU2, "SPU2about");
}
void OnConfConf_CdvdConf(GtkButton *button, gpointer user_data) {
ConfPlugin(_CDVDconfigure, CDVDConfS, Config.CDVD, "CDVDconfigure");
ConfPlugin(CDVDConfS, Config.CDVD, "CDVDconfigure");
}
void OnConfConf_CdvdTest(GtkButton *button, gpointer user_data) {
TestPlugin(_CDVDtest, CDVDConfS, Config.CDVD, "CDVDtest");
TestPlugin(CDVDConfS, Config.CDVD, "CDVDtest");
}
void OnConfConf_CdvdAbout(GtkButton *button, gpointer user_data) {
ConfPlugin(_CDVDabout, CDVDConfS, Config.CDVD, "CDVDabout");
ConfPlugin(CDVDConfS, Config.CDVD, "CDVDabout");
}
void OnConfConf_Dev9Conf(GtkButton *button, gpointer user_data) {
ConfPlugin(_DEV9configure, DEV9ConfS, Config.DEV9, "DEV9configure");
ConfPlugin( DEV9ConfS, Config.DEV9, "DEV9configure");
}
void OnConfConf_Dev9Test(GtkButton *button, gpointer user_data) {
TestPlugin(_DEV9test, DEV9ConfS, Config.DEV9, "DEV9test");
TestPlugin(DEV9ConfS, Config.DEV9, "DEV9test");
}
void OnConfConf_Dev9About(GtkButton *button, gpointer user_data) {
ConfPlugin(_DEV9about, DEV9ConfS, Config.DEV9, "DEV9about");
ConfPlugin( DEV9ConfS, Config.DEV9, "DEV9about");
}
void OnConfConf_UsbConf(GtkButton *button, gpointer user_data) {
ConfPlugin(_USBconfigure, USBConfS, Config.USB, "USBconfigure");
ConfPlugin(USBConfS, Config.USB, "USBconfigure");
}
void OnConfConf_UsbTest(GtkButton *button, gpointer user_data) {
TestPlugin(_USBtest, USBConfS, Config.USB, "USBtest");
TestPlugin(USBConfS, Config.USB, "USBtest");
}
void OnConfConf_UsbAbout(GtkButton *button, gpointer user_data) {
ConfPlugin(_USBabout, USBConfS, Config.USB, "USBabout");
ConfPlugin(USBConfS, Config.USB, "USBabout");
}
void OnConfConf_FWConf(GtkButton *button, gpointer user_data) {
ConfPlugin(_FWconfigure, FWConfS, Config.FW, "FWconfigure");
ConfPlugin( FWConfS, Config.FW, "FWconfigure");
}
void OnConfConf_FWTest(GtkButton *button, gpointer user_data) {
TestPlugin(_FWtest, FWConfS, Config.FW, "FWtest");
TestPlugin(FWConfS, Config.FW, "FWtest");
}
void OnConfConf_FWAbout(GtkButton *button, gpointer user_data) {
ConfPlugin(_FWabout, FWConfS, Config.FW, "FWabout");
ConfPlugin( FWConfS, Config.FW, "FWabout");
}
@ -357,7 +407,7 @@ void FindPlugins() {
DIR *dir;
struct dirent *ent;
void *Handle;
char plugin[256],name[256];
char plugin[g_MaxPath],name[g_MaxPath];
GSConfS.plugins = 0; CDVDConfS.plugins = 0; DEV9ConfS.plugins = 0;
PAD1ConfS.plugins = 0; PAD2ConfS.plugins = 0; SPU2ConfS.plugins = 0;

View File

@ -35,71 +35,6 @@ extern "C" {
}
#endif
// Evil Macros - Destroy when possible
#define FindComboText(combo,plist, list, conf) \
if (strlen(conf) > 0) { \
SetActiveComboItem(GTK_COMBO_BOX(combo), plist, list, conf); \
}
#define GetComboText(combo,list,conf) \
{ \
int i; \
char *tmp = (char*)gtk_combo_box_get_active_text(GTK_COMBO_BOX(combo)); \
for (i=2;i<255;i+=2) { \
if (!strcmp(tmp, list[i-1])) { \
strcpy(conf, list[i-2]); \
break; \
} \
} \
}
#define ConfPlugin(src, confs, plugin, name) \
void *drv; \
src conf; \
char file[256]; \
GetComboText(confs.Combo, confs.plist, plugin); \
strcpy(file, Config.PluginsDir); \
strcat(file, plugin); \
drv = SysLoadLibrary(file); \
getcwd(file, ARRAYSIZE(file)); /* store current dir */ \
chdir(Config.PluginsDir); /* change dirs so that plugins can find their config file*/ \
if (drv == NULL) return; \
conf = (src) SysLoadSym(drv, (char*)name); \
if (SysLibError() == NULL) conf(); \
chdir(file); /* change back*/ \
SysCloseLibrary(drv);
#define TestPlugin(src, confs, plugin, name) \
void *drv; \
src conf; \
int ret = 0; \
char file[256]; \
GetComboText(confs.Combo, confs.plist, plugin); \
strcpy(file, Config.PluginsDir); \
strcat(file, plugin); \
drv = SysLoadLibrary(file); \
if (drv == NULL) return; \
conf = (src) SysLoadSym(drv, (char*)name); \
if (SysLibError() == NULL) { \
ret = conf(); \
if (ret == 0) \
SysMessage(_("This plugin reports that should work correctly")); \
else SysMessage(_("This plugin reports that should not work correctly")); \
} \
SysCloseLibrary(drv);
#define ConfCreatePConf(name, type) \
type##ConfS.Combo = lookup_widget(ConfDlg, "GtkCombo_" name); \
SetComboToGList(GTK_COMBO_BOX(type##ConfS.Combo), type##ConfS.PluginNameList); \
FindComboText(type##ConfS.Combo, type##ConfS.plist, type##ConfS.PluginNameList, Config.type);
#define ComboAddPlugin(type) { \
sprintf (name, "%s %ld.%ld.%ld", PS2EgetLibName(), (version>>8)&0xff ,version&0xff, (version>>24)&0xff); \
type##ConfS.plugins+=2; \
strcpy(type##ConfS.plist[type##ConfS.plugins-1], name); \
strcpy(type##ConfS.plist[type##ConfS.plugins-2], ent->d_name); \
type##ConfS.PluginNameList = g_list_append(type##ConfS.PluginNameList, type##ConfS.plist[type##ConfS.plugins-1]); \
}
// Helper Functions
void FindPlugins();
@ -130,4 +65,39 @@ _PS2EgetLibType PS2EgetLibType = NULL;
_PS2EgetLibVersion2 PS2EgetLibVersion2 = NULL;
_PS2EgetLibName PS2EgetLibName = NULL;
// Evil Macros - Destroy when possible
#define FindComboText(combo,plist, list, conf) \
if (strlen(conf) > 0) { \
SetActiveComboItem(GTK_COMBO_BOX(combo), plist, list, conf); \
}
#define GetComboText(combo,list,conf) \
{ \
int i; \
char *tmp = (char*)gtk_combo_box_get_active_text(GTK_COMBO_BOX(combo)); \
for (i=2;i<255;i+=2) { \
if (!strcmp(tmp, list[i-1])) { \
strcpy(conf, list[i-2]); \
break; \
} \
} \
}
static void ConfPlugin(PluginConf confs, char* plugin, const char* name);
static void TestPlugin(PluginConf confs, char* plugin, const char* name);
#define ConfCreatePConf(name, type) \
type##ConfS.Combo = lookup_widget(ConfDlg, "GtkCombo_" name); \
SetComboToGList(GTK_COMBO_BOX(type##ConfS.Combo), type##ConfS.PluginNameList); \
FindComboText(type##ConfS.Combo, type##ConfS.plist, type##ConfS.PluginNameList, Config.type);
#define ComboAddPlugin(type) { \
sprintf (name, "%s %ld.%ld.%ld", PS2EgetLibName(), (version>>8)&0xff ,version&0xff, (version>>24)&0xff); \
type##ConfS.plugins+=2; \
strcpy(type##ConfS.plist[type##ConfS.plugins-1], name); \
strcpy(type##ConfS.plist[type##ConfS.plugins-2], ent->d_name); \
type##ConfS.PluginNameList = g_list_append(type##ConfS.PluginNameList, type##ConfS.plist[type##ConfS.plugins-1]); \
}
#endif // __CONFIGDLG_H__

View File

@ -46,11 +46,11 @@ GtkWidget *MemWriteDlg, *MemEntry, *DataEntry;
GtkAdjustment *DebugAdj;
extern int efile;
extern char elfname[256];
extern char elfname[g_MaxPath];
int DebugMode; // 0 - EE | 1 - IOP
static u32 dPC, dBPA = -1, dBPC = -1;
static char nullAddr[256];
static char nullAddr[g_MaxPath];
GtkWidget *DebugWnd;

View File

@ -188,7 +188,7 @@ void OnFile_Exit(GtkMenuItem *menuitem, gpointer user_data) {
DIR *dir;
struct dirent *ent;
void *Handle;
char plugin[256];
char plugin[g_MaxPath];
// with this the problem with plugins that are linked with the pthread
// library is solved
@ -237,7 +237,7 @@ void OnEmu_Reset(GtkMenuItem *menuitem, gpointer user_data)
void ResetMenuSlots(GtkMenuItem *menuitem, gpointer user_data) {
GtkWidget *Item;
char str[256];
char str[g_MaxPath];
int i;
for (i=0; i<5; i++) {
@ -251,7 +251,7 @@ void OnEmu_Reset(GtkMenuItem *menuitem, gpointer user_data)
}
void UpdateMenuSlots(GtkMenuItem *menuitem, gpointer user_data) {
char str[256];
char str[g_MaxPath];
int i = 0;
for (i=0; i<5; i++) {
@ -261,7 +261,7 @@ void UpdateMenuSlots(GtkMenuItem *menuitem, gpointer user_data) {
}
void States_Load(int num) {
char Text[256];
char Text[g_MaxPath];
int ret;
efile = 2;
@ -274,7 +274,7 @@ void States_Load(int num) {
}
void States_Save(int num) {
char Text[256];
char Text[g_MaxPath];
int ret;
sprintf (Text, SSTATES_DIR "/%8.8X.%3.3d", ElfCRC, num);
@ -295,7 +295,7 @@ void OnStates_Load5(GtkMenuItem *menuitem, gpointer user_data) { States_Load(4);
void OnLoadOther_Ok(GtkButton* button, gpointer user_data) {
gchar *File;
char str[256];
char str[g_MaxPath];
int ret;
File = (gchar*)gtk_file_selection_get_filename(GTK_FILE_SELECTION(FileSel));
@ -340,7 +340,7 @@ void OnStates_Save5(GtkMenuItem *menuitem, gpointer user_data) { States_Save(4);
void OnSaveOther_Ok(GtkButton* button, gpointer user_data) {
gchar *File;
char str[256];
char str[g_MaxPath];
int ret;
File = (gchar*)gtk_file_selection_get_filename(GTK_FILE_SELECTION(FileSel));
@ -380,7 +380,7 @@ void OnArguments_Ok(GtkButton *button, gpointer user_data) {
char *str;
str = (char*)gtk_entry_get_text(GTK_ENTRY(widgetCmdLine));
memcpy(args, str, 256);
memcpy(args, str, g_MaxPath);
gtk_widget_destroy(CmdLine);
gtk_widget_set_sensitive(MainWindow, TRUE);
@ -587,7 +587,7 @@ void OnHelpAbout_Ok(GtkButton *button, gpointer user_data) {
}
void OnHelp_About(GtkMenuItem *menuitem, gpointer user_data) {
char str[256];
char str[g_MaxPath];
GtkWidget *Label;
AboutDlg = create_AboutDlg();

View File

@ -43,7 +43,7 @@ bool needReset = TRUE;
bool RunExe = FALSE;
int efile = 0;
char elfname[256];
char elfname[g_MaxPath];
int Slots[5] = { -1, -1, -1, -1, -1 };
GtkWidget *CpuDlg;

View File

@ -47,7 +47,7 @@
extern "C" {
#endif
#include "../Paths.h"
#include "Paths.h"
#include "Common.h"
/* Misc.c */
@ -86,7 +86,7 @@ extern void init_widgets();
typedef struct {
char lang[256];
char lang[g_MaxPath];
} _langs;
typedef enum
@ -114,7 +114,7 @@ GtkWidget *radio_normal_limit, *radio_limit_limit, *radio_fs_limit, *radio_vuski
_langs *langs;
unsigned int langsMax;
char cfgfile[256];
char cfgfile[g_MaxPath];
/* Hacks */

View File

@ -39,7 +39,7 @@ GtkWidget *MsgDlg;
int main(int argc, char *argv[]) {
char *file = NULL;
char elfname[256];
char elfname[g_MaxPath];
int efile = 0;
int i = 1;

View File

@ -53,7 +53,7 @@ __forceinline static void _rcntSet( int i, int bitwise )
// thanks to being forceinline'd, this conditional will always be optimized
// to a constant by VC (confirmed via disassembler):
u64 overflowCap = (bitwise==32) ? 0x100000000 : 0x10000;
u64 overflowCap = (bitwise==32) ? 0x100000000ULL : 0x10000;
u64 c;
#ifdef _DEBUG
@ -184,7 +184,7 @@ void psxCheckEndGate16(int i)
psxCounters[i].count += (u16)psxRcntRcount16(i); //Only counts when signal is on
break;
case 0x1: //GATE_ON_ClearStart
if(psxCounters[i].mode & 0x10000000)psxRcntUpd16(i);
if(psxCounters[i].mode & 0x10000000) psxRcntUpd16(i);
psxCounters[i].mode &= ~0x10000000;
break;
case 0x2: //GATE_ON_Clear_OFF_Start
@ -318,10 +318,10 @@ void _testRcnt16target(int i) {
psxCounters[i].count -= psxCounters[i].target;
if((psxCounters[i].mode & 0x40) == 0){
SysPrintf("Counter %x repeat intr not set on zero ret, ignoring target\n", i);
psxCounters[i].target += 0x1000000000;
psxCounters[i].target += 0x1000000000ULL;
}
} else psxCounters[i].target += 0x1000000000;
} else psxCounters[i].target += 0x1000000000ULL;
}
@ -379,10 +379,10 @@ void _testRcnt32target(int i) {
psxCounters[i].count -= psxCounters[i].target;
if((psxCounters[i].mode & 0x40) == 0){
SysPrintf("Counter %x repeat intr not set on zero ret, ignoring target\n", i);
psxCounters[i].target += 0x1000000000;
psxCounters[i].target += 0x1000000000ULL;
}
} else psxCounters[i].target += 0x1000000000;
} else psxCounters[i].target += 0x1000000000ULL;
}
@ -400,7 +400,7 @@ void _testRcnt32overflow(int i) {
psxCounters[i].mode&= ~0x0400; // Interrupt flag
}
}
psxCounters[i].count -= 0x100000000;
psxCounters[i].count -= 0x100000000ULL;
if(psxCounters[i].target > 0xffffffff) {
//SysPrintf("IOP 32 Correcting target on overflow\n");
if((psxCounters[i].mode & 0x50) <= 0x40 && (psxCounters[i].mode & 0x50) != 0) SysPrintf("Counter %x overflowing, no repeat interrupt mode = %x\n", i, psxCounters[i].mode);
@ -762,7 +762,7 @@ void psxRcntWtarget16(int index, u32 value) {
psxCounters[index].target = value & 0xffff;
if(psxCounters[index].target <= psxRcntCycles(index)/* && psxCounters[index].target != 0*/) {
//SysPrintf("IOP 16 Saving %x target from early trigger target = %x, count = %I64x\n", index, psxCounters[index].target, psxRcntCycles(index));
psxCounters[index].target += 0x1000000000;
psxCounters[index].target += 0x1000000000ULL;
}
_rcntSet( index, 16 );
@ -777,7 +777,7 @@ void psxRcntWtarget32(int index, u32 value) {
psxCounters[index].target = value;
if(psxCounters[index].target <= psxRcntCycles(index)/* && psxCounters[index].target != 0*/) {
//SysPrintf("IOP 32 Saving %x target from early trigger target = %x, count = %I64x\n", index, psxCounters[index].target, psxRcntCycles(index));
psxCounters[index].target += 0x1000000000;
psxCounters[index].target += 0x1000000000ULL;
}
_rcntSet( index, 32 );