Just submitting some boring minor cleanup and improved error msgs, to isolate my next change.

git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@92 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
hrydgard 2008-07-27 20:51:02 +00:00
parent 9d312559cf
commit 27a141ecca
9 changed files with 92 additions and 44 deletions

View File

@ -24,6 +24,7 @@
#endif #endif
#include "Common.h" #include "Common.h"
#include "StringUtil.h"
#include "DynamicLibrary.h" #include "DynamicLibrary.h"
DynamicLibrary::DynamicLibrary() DynamicLibrary::DynamicLibrary()
@ -31,6 +32,29 @@ DynamicLibrary::DynamicLibrary()
library = 0; library = 0;
} }
#ifdef _WIN32
std::string GetLastErrorAsString()
{
LPVOID lpMsgBuf = 0;
DWORD error = GetLastError();
FormatMessage(
FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM,
NULL,
error,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
(LPTSTR) &lpMsgBuf,
0, NULL);
std::string s;
if (lpMsgBuf)
{
s = ((char *)lpMsgBuf);
LocalFree(lpMsgBuf);
} else {
s = StringFromFormat("(unknown error %08x)", error);
}
return s;
}
#endif
bool DynamicLibrary::Load(const char* filename) bool DynamicLibrary::Load(const char* filename)
{ {
@ -48,6 +72,9 @@ bool DynamicLibrary::Load(const char* filename)
#ifdef _WIN32 #ifdef _WIN32
library = LoadLibrary(filename); library = LoadLibrary(filename);
if (!library) {
//PanicAlert("Error loading DLL %s: %s", filename, GetLastErrorAsString().c_str());
}
#else #else
library = dlopen(filename, RTLD_NOW | RTLD_LOCAL); library = dlopen(filename, RTLD_NOW | RTLD_LOCAL);
@ -55,12 +82,10 @@ bool DynamicLibrary::Load(const char* filename)
{ {
PanicAlert(dlerror()); PanicAlert(dlerror());
} }
else
{
printf("Successfully loaded %s", filename);
}
#endif #endif
if (library) {
library_file = filename;
}
return(library != 0); return(library != 0);
} }
@ -86,11 +111,14 @@ void* DynamicLibrary::Get(const char* funcname) const
{ {
void* retval; void* retval;
#ifdef _WIN32 #ifdef _WIN32
if (!library)
{
PanicAlert("Can't find function %s - Library not loaded.");
}
retval = GetProcAddress(library, funcname); retval = GetProcAddress(library, funcname);
if (!retval) if (!retval)
{ {
// PanicAlert("Did not find function %s in DLL", funcname); PanicAlert("Did not find function %s in library %s.", funcname, library_file.c_str());
} }
return(retval); return(retval);
@ -103,7 +131,6 @@ void* DynamicLibrary::Get(const char* funcname) const
printf("%s\n", dlerror()); printf("%s\n", dlerror());
} }
#endif #endif
} }

View File

@ -21,6 +21,8 @@
#include <windows.h> #include <windows.h>
#endif #endif
#include <string>
class DynamicLibrary class DynamicLibrary
{ {
public: public:
@ -35,7 +37,7 @@ class DynamicLibrary
private: private:
std::string library_file;
#ifdef _WIN32 #ifdef _WIN32
HINSTANCE library; HINSTANCE library;
#else #else

View File

@ -2,6 +2,8 @@
#include "FileUtil.h" #include "FileUtil.h"
#ifdef _WIN32 #ifdef _WIN32
#include <shellapi.h> #include <shellapi.h>
#else
#include <sys/stat.h>
#endif #endif
bool File::Exists(const std::string &filename) bool File::Exists(const std::string &filename)
@ -9,7 +11,9 @@ bool File::Exists(const std::string &filename)
#ifdef _WIN32 #ifdef _WIN32
return GetFileAttributes(filename.c_str()) != INVALID_FILE_ATTRIBUTES; return GetFileAttributes(filename.c_str()) != INVALID_FILE_ATTRIBUTES;
#else #else
return true; //TODO struct stat file_info;
int result = stat(filename.c_str(), &file_info);
return result == 0;
#endif #endif
} }
@ -17,14 +21,16 @@ bool File::IsDirectory(const std::string &filename) {
#ifdef _WIN32 #ifdef _WIN32
return (GetFileAttributes(filename.c_str()) & FILE_ATTRIBUTE_DIRECTORY) != 0; return (GetFileAttributes(filename.c_str()) & FILE_ATTRIBUTE_DIRECTORY) != 0;
#else #else
return false; //TODO // TODO: Insert POSIX code here.
return false;
#endif #endif
} }
std::string SanitizePath(const std::string &filename) { std::string SanitizePath(const std::string &filename) {
std::string copy = filename; std::string copy = filename;
for (int i = 0; i < copy.size(); i++) for (int i = 0; i < copy.size(); i++)
if (copy[i] == '/') copy[i] = '\\'; if (copy[i] == '/')
copy[i] = '\\';
return copy; return copy;
} }
@ -38,6 +44,8 @@ void File::Launch(const std::string &filename)
shex.lpFile = win_filename.c_str(); shex.lpFile = win_filename.c_str();
shex.nShow = SW_SHOWNORMAL; shex.nShow = SW_SHOWNORMAL;
ShellExecuteEx(&shex); ShellExecuteEx(&shex);
#else
// TODO: Insert GNOME/KDE code here.
#endif #endif
} }
@ -51,6 +59,8 @@ void File::Explore(const std::string &path)
shex.lpFile = win_path.c_str(); shex.lpFile = win_path.c_str();
shex.nShow = SW_SHOWNORMAL; shex.nShow = SW_SHOWNORMAL;
ShellExecuteEx(&shex); ShellExecuteEx(&shex);
#else
// TODO: Insert GNOME/KDE code here.
#endif #endif
} }
@ -59,11 +69,7 @@ bool File::CreateDir(const std::string &path)
{ {
#ifdef _WIN32 #ifdef _WIN32
if (::CreateDirectory(path.c_str(), NULL)) if (::CreateDirectory(path.c_str(), NULL))
{
return true; return true;
}
else
{
DWORD error = GetLastError(); DWORD error = GetLastError();
if (error == ERROR_ALREADY_EXISTS) if (error == ERROR_ALREADY_EXISTS)
{ {
@ -72,6 +78,7 @@ bool File::CreateDir(const std::string &path)
} }
PanicAlert("Error creating directory: %i", error); PanicAlert("Error creating directory: %i", error);
return false; return false;
} #else
// TODO: Insert POSIX code here.
#endif #endif
} }

View File

@ -17,7 +17,9 @@
#pragma once #pragma once
#ifndef _WIN32_WINNT
#define _WIN32_WINNT 0x501 #define _WIN32_WINNT 0x501
#endif
#ifndef _WIN32_IE #ifndef _WIN32_IE
#define _WIN32_IE 0x0500 // Default value is 0x0400 #define _WIN32_IE 0x0500 // Default value is 0x0400
#endif #endif

View File

@ -74,20 +74,20 @@ namespace Gen
inline void Write16(u16 value) inline void Write16(u16 value)
{ {
*(u16*)code = value; *(u16*)code = value;
code+=2; code += 2;
} }
inline void Write32(u32 value) inline void Write32(u32 value)
{ {
*(u32*)code = value; *(u32*)code = value;
code+=4; code += 4;
} }
inline void Write64(u64 value) inline void Write64(u64 value)
{ {
_dbg_assert_msg_(DYNA_REC,!mode32,"!mode32"); _dbg_assert_msg_(DYNA_REC,!mode32,"!mode32");
*(u64*)code = value; *(u64*)code = value;
code+=8; code += 8;
} }
void WriteModRM( int mod, int rm, int reg ) void WriteModRM( int mod, int rm, int reg )
@ -100,7 +100,6 @@ namespace Gen
Write8((u8)((scale << 6) | ((index & 7) << 3) | (base & 7))); Write8((u8)((scale << 6) | ((index & 7) << 3) | (base & 7)));
} }
void OpArg::WriteRex(bool op64, int customOp) const void OpArg::WriteRex(bool op64, int customOp) const
{ {
#ifdef _M_X64 #ifdef _M_X64
@ -1198,7 +1197,6 @@ namespace Gen
void PMOVMSKB(X64Reg dest, OpArg arg) {WriteSSEOp(64, 0xD7, true, dest, arg); } void PMOVMSKB(X64Reg dest, OpArg arg) {WriteSSEOp(64, 0xD7, true, dest, arg); }
// Prefixes // Prefixes
void LOCK() { Write8(0xF0); } void LOCK() { Write8(0xF0); }

View File

@ -94,8 +94,10 @@ Common::Event emuThreadGoing;
// Called from GUI thread // Called from GUI thread
bool Init(const SCoreStartupParameter _CoreParameter) bool Init(const SCoreStartupParameter _CoreParameter)
{ {
if (g_pThread != NULL) if (g_pThread != NULL) {
PanicAlert("ERROR: Emu Thread already running. Report this bug.");
return false; return false;
}
LogManager::Init(); LogManager::Init();
Host_SetWaitCursor(true); Host_SetWaitCursor(true);
@ -330,7 +332,7 @@ THREAD_RETURN EmuThread(void *pArg)
HW::Shutdown(); HW::Shutdown();
LOG(MASTER_LOG,"EmuThread exited"); LOG(MASTER_LOG, "EmuThread exited");
//The CPU should return when a game is stopped and cleanup should be done here, //The CPU should return when a game is stopped and cleanup should be done here,
//so we can restart the plugins (or load new ones) for the next game //so we can restart the plugins (or load new ones) for the next game

View File

@ -17,6 +17,7 @@
#include "Common.h" #include "Common.h"
#include "Boot/Boot.h" #include "Boot/Boot.h"
#include "FileUtil.h"
#include "StringUtil.h" #include "StringUtil.h"
#include "CoreParameter.h" #include "CoreParameter.h"
#include "VolumeCreator.h" #include "VolumeCreator.h"
@ -142,6 +143,10 @@ bool SCoreStartupParameter::AutoSetup(EBootBios _BootBios)
m_strMemoryCardA = BaseDataPath + "/MemoryCardA.raw"; m_strMemoryCardA = BaseDataPath + "/MemoryCardA.raw";
m_strMemoryCardB = BaseDataPath + "/MemoryCardB.raw"; m_strMemoryCardB = BaseDataPath + "/MemoryCardB.raw";
m_strSRAM = BaseDataPath + "/SRAM.raw"; m_strSRAM = BaseDataPath + "/SRAM.raw";
if (!File::Exists(m_strBios)) {
LOG(BOOT, "BIOS file %s not found - using HLE.", m_strBios.c_str());
bHLEBios = true;
}
return true; return true;
} }

View File

@ -512,8 +512,7 @@ void CInterpreter::mulhwux(UGeckoInstruction _inst)
{ {
u32 a = m_GPR[_inst.RA]; u32 a = m_GPR[_inst.RA];
u32 b = m_GPR[_inst.RB]; u32 b = m_GPR[_inst.RB];
u32 d; u32 d = (u32)(((u64)a * (u64)b) >> 32);
d = (u32)(((u64)a * (u64)b) >> 32);
m_GPR[_inst.RD] = d; m_GPR[_inst.RD] = d;
if (_inst.Rc) Helper_UpdateCR0(m_GPR[_inst.RD]); if (_inst.Rc) Helper_UpdateCR0(m_GPR[_inst.RD]);
} }
@ -522,8 +521,7 @@ void CInterpreter::mullwx(UGeckoInstruction _inst)
{ {
u32 a = m_GPR[_inst.RA]; u32 a = m_GPR[_inst.RA];
u32 b = m_GPR[_inst.RB]; u32 b = m_GPR[_inst.RB];
u32 d; u32 d = (u32)((s32)a * (s32)b);
d = (u32)((s32)a * (s32)b);
m_GPR[_inst.RD] = d; m_GPR[_inst.RD] = d;
if (_inst.OE) PanicAlert("OE: mullwx"); if (_inst.OE) PanicAlert("OE: mullwx");

View File

@ -394,15 +394,6 @@ void CInterpreter::lswx(UGeckoInstruction _inst)
bFirst = false; bFirst = false;
} }
void CInterpreter::lwarx(UGeckoInstruction _inst)
{
m_GPR[_inst.RD] = Memory::Read_U32(Helper_Get_EA_X(_inst));
//static bool bFirst = true;
//if (bFirst)
// MessageBox(NULL, "lwarx", "Instruction unimplemented", MB_OK);
//bFirst = false;
}
void CInterpreter::lwbrx(UGeckoInstruction _inst) void CInterpreter::lwbrx(UGeckoInstruction _inst)
{ {
m_GPR[_inst.RD] = Common::swap32(Memory::Read_U32(Helper_Get_EA_X(_inst))); m_GPR[_inst.RD] = Common::swap32(Memory::Read_U32(Helper_Get_EA_X(_inst)));
@ -594,12 +585,28 @@ void CInterpreter::stwbrx(UGeckoInstruction _inst)
Memory::Write_U32(Common::swap32(m_GPR[_inst.RS]), uAddress); Memory::Write_U32(Common::swap32(m_GPR[_inst.RS]), uAddress);
} }
// The following two instructions are for inter-cpu communications. On a single CPU, they cannot
// fail unless an interrupt happens in between, which usually won't happen with the JIT, so we just pretend
// they are regular loads and stores for now. If this proves to be a problem, we could add a reservation flag.
void CInterpreter::lwarx(UGeckoInstruction _inst)
{
m_GPR[_inst.RD] = Memory::Read_U32(Helper_Get_EA_X(_inst));
//static bool bFirst = true;
//if (bFirst)
// MessageBox(NULL, "lwarx", "Instruction unimplemented", MB_OK);
//bFirst = false;
}
void CInterpreter::stwcxd(UGeckoInstruction _inst) void CInterpreter::stwcxd(UGeckoInstruction _inst)
{ {
// This instruction, to
static bool bFirst = true; static bool bFirst = true;
if (bFirst) if (bFirst)
PanicAlert("stwcxd - Instruction unimplemented"); PanicAlert("stwcxd - suspicious instruction");
bFirst = false; bFirst = false;
u32 uAddress = Helper_Get_EA_X(_inst);
Memory::Write_U32(m_GPR[_inst.RS], uAddress);
} }
void CInterpreter::stwux(UGeckoInstruction _inst) void CInterpreter::stwux(UGeckoInstruction _inst)