mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-24 23:11:14 +01:00
Merge pull request #1869 from Stevoisiak/GeneralConsistency
Minor consistency changes
This commit is contained in:
commit
80e6367e46
@ -132,7 +132,7 @@ void OpenALStream::SoundLoop()
|
|||||||
#if defined(__APPLE__)
|
#if defined(__APPLE__)
|
||||||
bool float32_capable = false;
|
bool float32_capable = false;
|
||||||
const ALenum AL_FORMAT_STEREO_FLOAT32 = 0;
|
const ALenum AL_FORMAT_STEREO_FLOAT32 = 0;
|
||||||
// OSX does not have the alext AL_FORMAT_51CHN32 yet.
|
// OS X does not have the alext AL_FORMAT_51CHN32 yet.
|
||||||
surround_capable = false;
|
surround_capable = false;
|
||||||
const ALenum AL_FORMAT_51CHN32 = 0;
|
const ALenum AL_FORMAT_51CHN32 = 0;
|
||||||
#else
|
#else
|
||||||
|
@ -149,11 +149,11 @@ CPUInfo::CPUInfo()
|
|||||||
Detect();
|
Detect();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Detects the various cpu features
|
// Detects the various CPU features
|
||||||
void CPUInfo::Detect()
|
void CPUInfo::Detect()
|
||||||
{
|
{
|
||||||
// Set some defaults here
|
// Set some defaults here
|
||||||
// When ARMv8 cpus come out, these need to be updated.
|
// When ARMv8 CPUs come out, these need to be updated.
|
||||||
HTT = false;
|
HTT = false;
|
||||||
#ifdef _M_ARM_64
|
#ifdef _M_ARM_64
|
||||||
OS64bit = true;
|
OS64bit = true;
|
||||||
@ -251,7 +251,7 @@ void CPUInfo::Detect()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// Turn the cpu info into a string we can show
|
// Turn the CPU info into a string we can show
|
||||||
std::string CPUInfo::Summarize()
|
std::string CPUInfo::Summarize()
|
||||||
{
|
{
|
||||||
std::string sum;
|
std::string sum;
|
||||||
|
@ -390,7 +390,7 @@ public:
|
|||||||
void MCR(u32 coproc, u32 opc1, ARMReg Rt, u32 CRn, u32 CRm, u32 opc2 = 0);
|
void MCR(u32 coproc, u32 opc1, ARMReg Rt, u32 CRn, u32 CRm, u32 opc2 = 0);
|
||||||
|
|
||||||
// Do nothing
|
// Do nothing
|
||||||
void NOP(int count = 1); //nop padding - TODO: fast nop slides, for amd and intel (check their manuals)
|
void NOP(int count = 1); //nop padding - TODO: fast nop slides, for AMD and Intel (check their manuals)
|
||||||
|
|
||||||
#ifdef CALL
|
#ifdef CALL
|
||||||
#undef CALL
|
#undef CALL
|
||||||
@ -476,7 +476,7 @@ public:
|
|||||||
void UBFX(ARMReg dest, ARMReg op2, u8 lsb, u8 width);
|
void UBFX(ARMReg dest, ARMReg op2, u8 lsb, u8 width);
|
||||||
void CLZ(ARMReg rd, ARMReg rm);
|
void CLZ(ARMReg rd, ARMReg rm);
|
||||||
|
|
||||||
// Using just MSR here messes with our defines on the PPC side of stuff (when this code was in dolphin...)
|
// Using just MSR here messes with our defines on the PPC side of stuff (when this code was in Dolphin...)
|
||||||
// Just need to put an underscore here, bit annoying.
|
// Just need to put an underscore here, bit annoying.
|
||||||
void _MSR (bool nzcvq, bool g, Operand2 op2);
|
void _MSR (bool nzcvq, bool g, Operand2 op2);
|
||||||
void _MSR (bool nzcvq, bool g, ARMReg src);
|
void _MSR (bool nzcvq, bool g, ARMReg src);
|
||||||
|
@ -81,7 +81,7 @@ private:
|
|||||||
#define GC_ALIGNED16_DECL(x) __declspec(align(16)) x
|
#define GC_ALIGNED16_DECL(x) __declspec(align(16)) x
|
||||||
#define GC_ALIGNED64_DECL(x) __declspec(align(64)) x
|
#define GC_ALIGNED64_DECL(x) __declspec(align(64)) x
|
||||||
|
|
||||||
// Since they are always around on windows
|
// Since they are always around on Windows
|
||||||
#define HAVE_WX 1
|
#define HAVE_WX 1
|
||||||
#define HAVE_OPENAL 1
|
#define HAVE_OPENAL 1
|
||||||
|
|
||||||
|
@ -108,7 +108,7 @@ inline u64 _rotr64(u64 x, unsigned int shift)
|
|||||||
#define snprintf _snprintf
|
#define snprintf _snprintf
|
||||||
#define vscprintf _vscprintf
|
#define vscprintf _vscprintf
|
||||||
|
|
||||||
// 64 bit offsets for windows
|
// 64 bit offsets for Windows
|
||||||
#define fseeko _fseeki64
|
#define fseeko _fseeki64
|
||||||
#define ftello _ftelli64
|
#define ftello _ftelli64
|
||||||
#define atoll _atoi64
|
#define atoll _atoi64
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Shared data dirs (Sys and shared User for linux)
|
// Shared data dirs (Sys and shared User for Linux)
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#define SYSDATA_DIR "Sys"
|
#define SYSDATA_DIR "Sys"
|
||||||
#elif defined __APPLE__
|
#elif defined __APPLE__
|
||||||
|
@ -40,7 +40,7 @@ typedef int32_t s32;
|
|||||||
typedef int64_t s64;
|
typedef int64_t s64;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// For using windows lock code
|
// For using Windows lock code
|
||||||
#define TCHAR char
|
#define TCHAR char
|
||||||
#define LONG int
|
#define LONG int
|
||||||
|
|
||||||
|
@ -469,7 +469,7 @@ u32 ScanDirectoryTree(const std::string &directory, FSTEntry& parentEntry)
|
|||||||
FindClose(hFind);
|
FindClose(hFind);
|
||||||
return foundEntries;
|
return foundEntries;
|
||||||
}
|
}
|
||||||
// windows loop
|
// Windows loop
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
FSTEntry entry;
|
FSTEntry entry;
|
||||||
@ -481,7 +481,7 @@ u32 ScanDirectoryTree(const std::string &directory, FSTEntry& parentEntry)
|
|||||||
if (!dirp)
|
if (!dirp)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// non windows loop
|
// non Windows loop
|
||||||
while (!readdir_r(dirp, &dirent, &result) && result)
|
while (!readdir_r(dirp, &dirent, &result) && result)
|
||||||
{
|
{
|
||||||
FSTEntry entry;
|
FSTEntry entry;
|
||||||
@ -538,7 +538,7 @@ bool DeleteDirRecursively(const std::string &directory)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// windows loop
|
// Windows loop
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
const std::string virtualName(TStrToUTF8(ffd.cFileName));
|
const std::string virtualName(TStrToUTF8(ffd.cFileName));
|
||||||
@ -548,7 +548,7 @@ bool DeleteDirRecursively(const std::string &directory)
|
|||||||
if (!dirp)
|
if (!dirp)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// non windows loop
|
// non Windows loop
|
||||||
while (!readdir_r(dirp, &dirent, &result) && result)
|
while (!readdir_r(dirp, &dirent, &result) && result)
|
||||||
{
|
{
|
||||||
const std::string virtualName = result->d_name;
|
const std::string virtualName = result->d_name;
|
||||||
|
@ -218,7 +218,7 @@ bool SplitPath(const std::string& full_path, std::string* _pPath, std::string* _
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
size_t dir_end = full_path.find_last_of("/"
|
size_t dir_end = full_path.find_last_of("/"
|
||||||
// windows needs the : included for something like just "C:" to be considered a directory
|
// Windows needs the : included for something like just "C:" to be considered a directory
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
":"
|
":"
|
||||||
#endif
|
#endif
|
||||||
|
@ -32,7 +32,7 @@ int CurrentThreadId();
|
|||||||
void SetThreadAffinity(std::thread::native_handle_type thread, u32 mask);
|
void SetThreadAffinity(std::thread::native_handle_type thread, u32 mask);
|
||||||
void SetCurrentThreadAffinity(u32 mask);
|
void SetCurrentThreadAffinity(u32 mask);
|
||||||
|
|
||||||
// TODO: doesn't work on windows with (count > 2)
|
// TODO: doesn't work on Windows with (count > 2)
|
||||||
class Barrier
|
class Barrier
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -374,7 +374,7 @@ void XEmitter::JMPptr(const OpArg &arg2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
//Can be used to trap other processors, before overwriting their code
|
//Can be used to trap other processors, before overwriting their code
|
||||||
// not used in dolphin
|
// not used in Dolphin
|
||||||
void XEmitter::JMPself()
|
void XEmitter::JMPself()
|
||||||
{
|
{
|
||||||
Write8(0xEB);
|
Write8(0xEB);
|
||||||
@ -968,8 +968,8 @@ void XEmitter::WriteShift(int bits, OpArg dest, OpArg &shift, int ext)
|
|||||||
Write8((u8)shift.offset);
|
Write8((u8)shift.offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
// large rotates and shift are slower on intel than amd
|
// large rotates and shift are slower on Intel than AMD
|
||||||
// intel likes to rotate by 1, and the op is smaller too
|
// Intel likes to rotate by 1, and the op is smaller too
|
||||||
void XEmitter::ROL(int bits, OpArg dest, OpArg shift) {WriteShift(bits, dest, shift, 0);}
|
void XEmitter::ROL(int bits, OpArg dest, OpArg shift) {WriteShift(bits, dest, shift, 0);}
|
||||||
void XEmitter::ROR(int bits, OpArg dest, OpArg shift) {WriteShift(bits, dest, shift, 1);}
|
void XEmitter::ROR(int bits, OpArg dest, OpArg shift) {WriteShift(bits, dest, shift, 1);}
|
||||||
void XEmitter::RCL(int bits, OpArg dest, OpArg shift) {WriteShift(bits, dest, shift, 2);}
|
void XEmitter::RCL(int bits, OpArg dest, OpArg shift) {WriteShift(bits, dest, shift, 2);}
|
||||||
|
@ -375,7 +375,7 @@ static bool batchdecrypt(u32 *codes, u16 size)
|
|||||||
getbitstring(tmparray,tmparray2+5,2); // Region
|
getbitstring(tmparray,tmparray2+5,2); // Region
|
||||||
|
|
||||||
// Grab gameid and region from the last decrypted code
|
// Grab gameid and region from the last decrypted code
|
||||||
// TODO: Maybe check this against dolphin's GameID? - "code is for wrong game" type msg
|
// TODO: Maybe check this against Dolphin's GameID? - "code is for wrong game" type msg
|
||||||
//gameid = tmparray2[1];
|
//gameid = tmparray2[1];
|
||||||
//region = tmparray2[5];
|
//region = tmparray2[5];
|
||||||
|
|
||||||
|
@ -901,7 +901,7 @@ bool RunCode(const ARCode &arcode)
|
|||||||
|
|
||||||
default:
|
default:
|
||||||
LogInfo("ZCode: Unknown");
|
LogInfo("ZCode: Unknown");
|
||||||
PanicAlertT("Zero code unknown to dolphin: %08x", zcode);
|
PanicAlertT("Zero code unknown to Dolphin: %08x", zcode);
|
||||||
return false;
|
return false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -374,7 +374,7 @@ void EmuThread()
|
|||||||
{
|
{
|
||||||
Wiimote::Initialize(s_window_handle, !s_state_filename.empty());
|
Wiimote::Initialize(s_window_handle, !s_state_filename.empty());
|
||||||
|
|
||||||
// Activate wiimotes which don't have source set to "None"
|
// Activate Wiimotes which don't have source set to "None"
|
||||||
for (unsigned int i = 0; i != MAX_BBMOTES; ++i)
|
for (unsigned int i = 0; i != MAX_BBMOTES; ++i)
|
||||||
if (g_wiimote_sources[i])
|
if (g_wiimote_sources[i])
|
||||||
GetUsbPointer()->AccessWiiMote(i | 0x100)->Activate(true);
|
GetUsbPointer()->AccessWiiMote(i | 0x100)->Activate(true);
|
||||||
@ -440,7 +440,7 @@ void EmuThread()
|
|||||||
// The EmuThread is thus an idle thread, which sleeps while
|
// The EmuThread is thus an idle thread, which sleeps while
|
||||||
// waiting for the program to terminate. Without this extra
|
// waiting for the program to terminate. Without this extra
|
||||||
// thread, the video backend window hangs in single core mode
|
// thread, the video backend window hangs in single core mode
|
||||||
// because noone is pumping messages.
|
// because no one is pumping messages.
|
||||||
Common::SetCurrentThreadName("Emuthread - Idle");
|
Common::SetCurrentThreadName("Emuthread - Idle");
|
||||||
|
|
||||||
// Spawn the CPU+GPU thread
|
// Spawn the CPU+GPU thread
|
||||||
|
@ -44,7 +44,7 @@ static s16 ADPCM_Step(u32& _rSamplePos)
|
|||||||
|
|
||||||
_rSamplePos++;
|
_rSamplePos++;
|
||||||
|
|
||||||
// The advanced interpolation (linear, polyphase,...) is done by the UCode,
|
// The advanced interpolation (linear, polyphase,...) is done by the ucode,
|
||||||
// so we don't need to bother with it here.
|
// so we don't need to bother with it here.
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
@ -87,7 +87,7 @@ void dsp_write_aram_d3(u16 value)
|
|||||||
// Zelda ucode writes a bunch of zeros to ARAM through d3 during
|
// Zelda ucode writes a bunch of zeros to ARAM through d3 during
|
||||||
// initialization. Don't know if it ever does it later, too.
|
// initialization. Don't know if it ever does it later, too.
|
||||||
// Pikmin 2 Wii writes non-stop to 0x10008000-0x1000801f (non-zero values too)
|
// Pikmin 2 Wii writes non-stop to 0x10008000-0x1000801f (non-zero values too)
|
||||||
// Zelda TP WII writes non-stop to 0x10000000-0x1000001f (non-zero values too)
|
// Zelda TP Wii writes non-stop to 0x10000000-0x1000001f (non-zero values too)
|
||||||
u32 Address = (g_dsp.ifx_regs[DSP_ACCAH] << 16) | g_dsp.ifx_regs[DSP_ACCAL];
|
u32 Address = (g_dsp.ifx_regs[DSP_ACCAH] << 16) | g_dsp.ifx_regs[DSP_ACCAL];
|
||||||
|
|
||||||
switch (g_dsp.ifx_regs[DSP_FORMAT])
|
switch (g_dsp.ifx_regs[DSP_FORMAT])
|
||||||
@ -116,7 +116,7 @@ u16 dsp_read_accelerator()
|
|||||||
// let's do the "hardware" decode DSP_FORMAT is interesting - the Zelda
|
// let's do the "hardware" decode DSP_FORMAT is interesting - the Zelda
|
||||||
// ucode seems to indicate that the bottom two bits specify the "read size"
|
// ucode seems to indicate that the bottom two bits specify the "read size"
|
||||||
// and the address multiplier. The bits above that may be things like sign
|
// and the address multiplier. The bits above that may be things like sign
|
||||||
// extention and do/do not use ADPCM. It also remains to be figured out
|
// extension and do/do not use ADPCM. It also remains to be figured out
|
||||||
// whether there's a difference between the usual accelerator "read
|
// whether there's a difference between the usual accelerator "read
|
||||||
// address" and 0xd3.
|
// address" and 0xd3.
|
||||||
switch (g_dsp.ifx_regs[DSP_FORMAT])
|
switch (g_dsp.ifx_regs[DSP_FORMAT])
|
||||||
@ -152,7 +152,7 @@ u16 dsp_read_accelerator()
|
|||||||
|
|
||||||
// TODO: Take GAIN into account
|
// TODO: Take GAIN into account
|
||||||
// adpcm = 0, pcm8 = 0x100, pcm16 = 0x800
|
// adpcm = 0, pcm8 = 0x100, pcm16 = 0x800
|
||||||
// games using pcm8 : Phoenix Wright Ace Attorney (Wiiware), Megaman 9-10 (WiiWare)
|
// games using pcm8 : Phoenix Wright Ace Attorney (WiiWare), Megaman 9-10 (WiiWare)
|
||||||
// games using pcm16: GC Sega games, ...
|
// games using pcm16: GC Sega games, ...
|
||||||
|
|
||||||
// Check for loop.
|
// Check for loop.
|
||||||
|
@ -34,7 +34,7 @@ namespace Ext
|
|||||||
|
|
||||||
inline bool IsSameMemArea(u16 a, u16 b)
|
inline bool IsSameMemArea(u16 a, u16 b)
|
||||||
{
|
{
|
||||||
//LM: tested on WII
|
// LM: tested on Wii
|
||||||
if ((a>>10)==(b>>10))
|
if ((a>>10)==(b>>10))
|
||||||
return true;
|
return true;
|
||||||
else
|
else
|
||||||
@ -532,7 +532,7 @@ void applyWriteBackLog()
|
|||||||
// then 0 | ext output = ext output and if it did then bitwise or is still the
|
// then 0 | ext output = ext output and if it did then bitwise or is still the
|
||||||
// right thing to do
|
// right thing to do
|
||||||
// Only needed for cases when mainop and extended are modifying the same ACC
|
// Only needed for cases when mainop and extended are modifying the same ACC
|
||||||
// Games are not doing that + in motorola (similar dsp) dox this is forbidden to do.
|
// Games are not doing that + in motorola (similar DSP) dox this is forbidden to do.
|
||||||
void zeroWriteBackLog()
|
void zeroWriteBackLog()
|
||||||
{
|
{
|
||||||
#ifdef PRECISE_BACKLOG
|
#ifdef PRECISE_BACKLOG
|
||||||
|
@ -48,7 +48,7 @@ void WriteCR(u16 val)
|
|||||||
else if (val == 4)
|
else if (val == 4)
|
||||||
{
|
{
|
||||||
// HAX!
|
// HAX!
|
||||||
// OSInitAudioSystem ucode should send this mail - not dsp core itself
|
// OSInitAudioSystem ucode should send this mail - not DSP core itself
|
||||||
INFO_LOG(DSPLLE,"DSP_CONTROL INIT");
|
INFO_LOG(DSPLLE,"DSP_CONTROL INIT");
|
||||||
init_hax = true;
|
init_hax = true;
|
||||||
val |= 0x800;
|
val |= 0x800;
|
||||||
|
@ -509,7 +509,7 @@ void DSPEmitter::decrease_addr_reg(int reg)
|
|||||||
|
|
||||||
|
|
||||||
// EAX - destination address
|
// EAX - destination address
|
||||||
// ECX - Base of dram
|
// ECX - Base of DRAM
|
||||||
void DSPEmitter::dmem_write(X64Reg value)
|
void DSPEmitter::dmem_write(X64Reg value)
|
||||||
{
|
{
|
||||||
// if (saddr == 0)
|
// if (saddr == 0)
|
||||||
|
@ -121,7 +121,7 @@ void GetStringVA(std::string& _rOutBuffer, u32 strReg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
case 'p':
|
case 'p':
|
||||||
// Override, so 64bit dolphin prints 32bit pointers, since the ppc is 32bit :)
|
// Override, so 64bit Dolphin prints 32bit pointers, since the ppc is 32bit :)
|
||||||
_rOutBuffer += StringFromFormat("%x", (u32)Parameter);
|
_rOutBuffer += StringFromFormat("%x", (u32)Parameter);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -184,7 +184,7 @@ static DSPEmulator *dsp_emulator;
|
|||||||
static int dsp_slice = 0;
|
static int dsp_slice = 0;
|
||||||
static bool dsp_is_lle = false;
|
static bool dsp_is_lle = false;
|
||||||
|
|
||||||
//time given to lle dsp on every read of the high bits in a mailbox
|
// time given to LLE DSP on every read of the high bits in a mailbox
|
||||||
static const int DSP_MAIL_SLICE=72;
|
static const int DSP_MAIL_SLICE=72;
|
||||||
|
|
||||||
void DoState(PointerWrap &p)
|
void DoState(PointerWrap &p)
|
||||||
@ -245,7 +245,7 @@ void Init(bool hle)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// On the GC, ARAM is accessible only through this interface.
|
// On the GameCube, ARAM is accessible only through this interface.
|
||||||
g_ARAM.wii_mode = false;
|
g_ARAM.wii_mode = false;
|
||||||
g_ARAM.size = ARAM_SIZE;
|
g_ARAM.size = ARAM_SIZE;
|
||||||
g_ARAM.mask = ARAM_MASK;
|
g_ARAM.mask = ARAM_MASK;
|
||||||
@ -366,7 +366,7 @@ void RegisterMMIO(MMIO::Mapping* mmio, u32 base)
|
|||||||
|
|
||||||
// Not really sure if this is correct, but it works...
|
// Not really sure if this is correct, but it works...
|
||||||
// Kind of a hack because DSP_CONTROL_MASK should make this bit
|
// Kind of a hack because DSP_CONTROL_MASK should make this bit
|
||||||
// only viewable to dsp emulator
|
// only viewable to DSP emulator
|
||||||
if (val & 1 /*DSPReset*/)
|
if (val & 1 /*DSPReset*/)
|
||||||
{
|
{
|
||||||
g_audioDMA.AudioDMAControl.Hex = 0;
|
g_audioDMA.AudioDMAControl.Hex = 0;
|
||||||
@ -480,15 +480,15 @@ void GenerateDSPInterruptFromDSPEmu(DSPInterruptType type)
|
|||||||
CoreTiming::ScheduleEvent_Threadsafe_Immediate(et_GenerateDSPInterrupt, type);
|
CoreTiming::ScheduleEvent_Threadsafe_Immediate(et_GenerateDSPInterrupt, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
// called whenever SystemTimers thinks the dsp deserves a few more cycles
|
// called whenever SystemTimers thinks the DSP deserves a few more cycles
|
||||||
void UpdateDSPSlice(int cycles)
|
void UpdateDSPSlice(int cycles)
|
||||||
{
|
{
|
||||||
if (dsp_is_lle)
|
if (dsp_is_lle)
|
||||||
{
|
{
|
||||||
//use up the rest of the slice(if any)
|
// use up the rest of the slice(if any)
|
||||||
dsp_emulator->DSP_Update(dsp_slice);
|
dsp_emulator->DSP_Update(dsp_slice);
|
||||||
dsp_slice %= 6;
|
dsp_slice %= 6;
|
||||||
//note the new budget
|
// note the new budget
|
||||||
dsp_slice += cycles;
|
dsp_slice += cycles;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -588,7 +588,7 @@ static void Do_ARAM_DMA()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Assuming no external ARAM installed; returns zeroes on out of bounds reads (verified on real HW)
|
// Assuming no external ARAM installed; returns zeros on out of bounds reads (verified on real HW)
|
||||||
while (g_arDMA.Cnt.count)
|
while (g_arDMA.Cnt.count)
|
||||||
{
|
{
|
||||||
Memory::Write_U64(0, g_arDMA.MMAddr);
|
Memory::Write_U64(0, g_arDMA.MMAddr);
|
||||||
@ -646,7 +646,7 @@ static void Do_ARAM_DMA()
|
|||||||
|
|
||||||
// (shuffle2) I still don't believe that this hack is actually needed... :(
|
// (shuffle2) I still don't believe that this hack is actually needed... :(
|
||||||
// Maybe the Wii Sports ucode is processed incorrectly?
|
// Maybe the Wii Sports ucode is processed incorrectly?
|
||||||
// (LM) It just means that dsp reads via '0xffdd' on WII can end up in EXRAM or main RAM
|
// (LM) It just means that DSP reads via '0xffdd' on Wii can end up in EXRAM or main RAM
|
||||||
u8 ReadARAM(u32 _iAddress)
|
u8 ReadARAM(u32 _iAddress)
|
||||||
{
|
{
|
||||||
//NOTICE_LOG(DSPINTERFACE, "ReadARAM 0x%08x", _iAddress);
|
//NOTICE_LOG(DSPINTERFACE, "ReadARAM 0x%08x", _iAddress);
|
||||||
@ -665,8 +665,8 @@ u8 ReadARAM(u32 _iAddress)
|
|||||||
|
|
||||||
void WriteARAM(u8 value, u32 _uAddress)
|
void WriteARAM(u8 value, u32 _uAddress)
|
||||||
{
|
{
|
||||||
//NOTICE_LOG(DSPINTERFACE, "WriteARAM 0x%08x", _uAddress);
|
// NOTICE_LOG(DSPINTERFACE, "WriteARAM 0x%08x", _uAddress);
|
||||||
//TODO: verify this on WII
|
// TODO: verify this on Wii
|
||||||
g_ARAM.ptr[_uAddress & g_ARAM.mask] = value;
|
g_ARAM.ptr[_uAddress & g_ARAM.mask] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ void GBAUCode::HandleMail(u32 mail)
|
|||||||
u32 pad[3];
|
u32 pad[3];
|
||||||
} sec_params;
|
} sec_params;
|
||||||
|
|
||||||
// 32 bytes from mram addr to dram @ 0
|
// 32 bytes from mram addr to DRAM @ 0
|
||||||
for (int i = 0; i < 8; i++, mramaddr += 4)
|
for (int i = 0; i < 8; i++, mramaddr += 4)
|
||||||
((u32*)&sec_params)[i] = HLEMemory_Read_U32(mramaddr);
|
((u32*)&sec_params)[i] = HLEMemory_Read_U32(mramaddr);
|
||||||
|
|
||||||
|
@ -66,11 +66,11 @@ UCodeInterface* UCodeFactory(u32 crc, DSPHLE* dsphle, bool wii)
|
|||||||
INFO_LOG(DSPHLE, "CRC %08x: Zelda ucode chosen", crc);
|
INFO_LOG(DSPHLE, "CRC %08x: Zelda ucode chosen", crc);
|
||||||
return new ZeldaUCode(dsphle, crc);
|
return new ZeldaUCode(dsphle, crc);
|
||||||
|
|
||||||
// WII CRCs
|
// Wii CRCs
|
||||||
case 0xb7eb9a9c: // Wii Pikmin - PAL
|
case 0xb7eb9a9c: // Wii Pikmin - PAL
|
||||||
case 0xeaeb38cc: // Wii Pikmin 2 - PAL
|
case 0xeaeb38cc: // Wii Pikmin 2 - PAL
|
||||||
case 0x6c3f6f94: // Zelda TP - PAL
|
case 0x6c3f6f94: // Zelda TP - PAL
|
||||||
case 0xd643001f: // Mario Galaxy - PAL / WII DK Jungle Beat - PAL
|
case 0xd643001f: // Mario Galaxy - PAL / Wii DK Jungle Beat - PAL
|
||||||
INFO_LOG(DSPHLE, "CRC %08x: Zelda Wii ucode chosen\n", crc);
|
INFO_LOG(DSPHLE, "CRC %08x: Zelda Wii ucode chosen\n", crc);
|
||||||
return new ZeldaUCode(dsphle, crc);
|
return new ZeldaUCode(dsphle, crc);
|
||||||
|
|
||||||
@ -166,12 +166,12 @@ void UCodeInterface::PrepareBootUCode(u32 mail)
|
|||||||
if (m_next_ucode.mram_size)
|
if (m_next_ucode.mram_size)
|
||||||
{
|
{
|
||||||
WARN_LOG(DSPHLE,
|
WARN_LOG(DSPHLE,
|
||||||
"Trying to boot new ucode with dram download - not implemented");
|
"Trying to boot new ucode with DRAM download - not implemented");
|
||||||
}
|
}
|
||||||
if (m_next_ucode.dram_size)
|
if (m_next_ucode.dram_size)
|
||||||
{
|
{
|
||||||
WARN_LOG(DSPHLE,
|
WARN_LOG(DSPHLE,
|
||||||
"Trying to boot new ucode with dram upload - not implemented");
|
"Trying to boot new ucode with DRAM upload - not implemented");
|
||||||
}
|
}
|
||||||
|
|
||||||
m_dsphle->SwapUCode(ector_crc);
|
m_dsphle->SwapUCode(ector_crc);
|
||||||
|
@ -353,7 +353,7 @@ void ZeldaUCode::HandleMail_NormalVersion(u32 mail)
|
|||||||
case 0x0003: // Do nothing - continue normally
|
case 0x0003: // Do nothing - continue normally
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case 0x0001: // accepts params to either dma to iram and/or dram (used for hotbooting a new ucode)
|
case 0x0001: // accepts params to either DMA to iram and/or DRAM (used for hotbooting a new ucode)
|
||||||
// TODO find a better way to protect from HLEMixer?
|
// TODO find a better way to protect from HLEMixer?
|
||||||
m_upload_setup_in_progress = true;
|
m_upload_setup_in_progress = true;
|
||||||
return;
|
return;
|
||||||
|
@ -337,7 +337,7 @@ void DSPLLE::DSP_Update(int cycles)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Wait for dsp thread to complete its cycle. Note: this logic should be thought through.
|
// Wait for DSP thread to complete its cycle. Note: this logic should be thought through.
|
||||||
ppcEvent.Wait();
|
ppcEvent.Wait();
|
||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lk(m_csDSPCycleCountActive);
|
std::lock_guard<std::mutex> lk(m_csDSPCycleCountActive);
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
#include "Core/HW/Memmap.h"
|
#include "Core/HW/Memmap.h"
|
||||||
|
|
||||||
// XXX: The BBA stores multi-byte elements as little endian.
|
// XXX: The BBA stores multi-byte elements as little endian.
|
||||||
// Multiple parts of this implementation depend on dolphin
|
// Multiple parts of this implementation depend on Dolphin
|
||||||
// being compiled for a little endian host.
|
// being compiled for a little endian host.
|
||||||
|
|
||||||
|
|
||||||
|
@ -296,7 +296,7 @@ void CEXIIPL::TransferByte(u8& _uByte)
|
|||||||
case REGION_WRTC0:
|
case REGION_WRTC0:
|
||||||
case REGION_WRTC1:
|
case REGION_WRTC1:
|
||||||
case REGION_WRTC2:
|
case REGION_WRTC2:
|
||||||
// WII only RTC flags... afaik just the Wii menu initialize it
|
// Wii only RTC flags... afaik just the Wii Menu initialize it
|
||||||
default:
|
default:
|
||||||
if ((m_uAddress >> 6) < ROM_SIZE)
|
if ((m_uAddress >> 6) < ROM_SIZE)
|
||||||
{
|
{
|
||||||
|
@ -216,7 +216,7 @@ void CEXIMemoryCard::SetupGciFolder(u16 sizeMb)
|
|||||||
{
|
{
|
||||||
// TODO more user friendly abort
|
// TODO more user friendly abort
|
||||||
PanicAlertT("%s is not a directory, failed to move to *.original.\n Verify your write permissions or move "
|
PanicAlertT("%s is not a directory, failed to move to *.original.\n Verify your write permissions or move "
|
||||||
"the file outside of dolphin",
|
"the file outside of Dolphin",
|
||||||
strDirectoryName.c_str());
|
strDirectoryName.c_str());
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
@ -140,7 +140,7 @@ void GCPad::LoadDefaults(const ControllerInterface& ciface)
|
|||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
set_control(m_buttons, 5, "RETURN"); // Start
|
set_control(m_buttons, 5, "RETURN"); // Start
|
||||||
#else
|
#else
|
||||||
// osx/linux
|
// OS X/Linux
|
||||||
set_control(m_buttons, 5, "Return"); // Start
|
set_control(m_buttons, 5, "Return"); // Start
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -290,7 +290,7 @@ struct SVIFilterCoefTables
|
|||||||
UVIFilterCoefTable4 Tables36[4];
|
UVIFilterCoefTable4 Tables36[4];
|
||||||
};
|
};
|
||||||
|
|
||||||
// Debug video mode only, probably never used in dolphin...
|
// Debug video mode only, probably never used in Dolphin...
|
||||||
union UVIBorderBlankRegister
|
union UVIBorderBlankRegister
|
||||||
{
|
{
|
||||||
u32 Hex;
|
u32 Hex;
|
||||||
|
@ -39,7 +39,7 @@ void Shutdown()
|
|||||||
// if plugin isn't initialized, init and load config
|
// if plugin isn't initialized, init and load config
|
||||||
void Initialize(void* const hwnd, bool wait)
|
void Initialize(void* const hwnd, bool wait)
|
||||||
{
|
{
|
||||||
// add 4 wiimotes
|
// add 4 Wiimotes
|
||||||
for (unsigned int i = WIIMOTE_CHAN_0; i<MAX_BBMOTES; ++i)
|
for (unsigned int i = WIIMOTE_CHAN_0; i<MAX_BBMOTES; ++i)
|
||||||
s_config.controllers.push_back(new WiimoteEmu::Wiimote(i));
|
s_config.controllers.push_back(new WiimoteEmu::Wiimote(i));
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ void Wiimote::HidOutputReport(const wm_report* const sr, const bool send_ack)
|
|||||||
{
|
{
|
||||||
INFO_LOG(WIIMOTE, "HidOutputReport (page: %i, cid: 0x%02x, wm: 0x%02x)", m_index, m_reporting_channel, sr->wm);
|
INFO_LOG(WIIMOTE, "HidOutputReport (page: %i, cid: 0x%02x, wm: 0x%02x)", m_index, m_reporting_channel, sr->wm);
|
||||||
|
|
||||||
// wiibrew:
|
// WiiBrew:
|
||||||
// In every single Output Report, bit 0 (0x01) of the first byte controls the Rumble feature.
|
// In every single Output Report, bit 0 (0x01) of the first byte controls the Rumble feature.
|
||||||
m_rumble_on = sr->rumble;
|
m_rumble_on = sr->rumble;
|
||||||
|
|
||||||
@ -221,7 +221,7 @@ void Wiimote::RequestStatus(const wm_request_status* const rs)
|
|||||||
// status values
|
// status values
|
||||||
*(wm_status_report*)(data + 2) = m_status;
|
*(wm_status_report*)(data + 2) = m_status;
|
||||||
|
|
||||||
// hybrid wiimote stuff
|
// hybrid Wiimote stuff
|
||||||
if (WIIMOTE_SRC_REAL & g_wiimote_sources[m_index] && (m_extension->switch_extension <= 0))
|
if (WIIMOTE_SRC_REAL & g_wiimote_sources[m_index] && (m_extension->switch_extension <= 0))
|
||||||
{
|
{
|
||||||
using namespace WiimoteReal;
|
using namespace WiimoteReal;
|
||||||
@ -380,13 +380,13 @@ void Wiimote::ReadData(const wm_read_data* const rd)
|
|||||||
// ignore the 0x010000 bit
|
// ignore the 0x010000 bit
|
||||||
address &= 0xFEFFFF;
|
address &= 0xFEFFFF;
|
||||||
|
|
||||||
// hybrid wiimote stuff
|
// hybrid Wiimote stuff
|
||||||
// relay the read data request to real-wiimote
|
// relay the read data request to real-Wiimote
|
||||||
if (WIIMOTE_SRC_REAL & g_wiimote_sources[m_index] && ((0xA4 != (address >> 16)) || (m_extension->switch_extension <= 0)))
|
if (WIIMOTE_SRC_REAL & g_wiimote_sources[m_index] && ((0xA4 != (address >> 16)) || (m_extension->switch_extension <= 0)))
|
||||||
{
|
{
|
||||||
WiimoteReal::InterruptChannel(m_index, m_reporting_channel, ((u8*)rd) - 2, sizeof(wm_read_data) + 2); // hacky
|
WiimoteReal::InterruptChannel(m_index, m_reporting_channel, ((u8*)rd) - 2, sizeof(wm_read_data) + 2); // hacky
|
||||||
|
|
||||||
// don't want emu-wiimote to send reply
|
// don't want emu-Wiimote to send reply
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -338,17 +338,17 @@ bool Wiimote::Step()
|
|||||||
m_read_requests.pop();
|
m_read_requests.pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
// dont send any other reports
|
// don't send any other reports
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// check if a status report needs to be sent
|
// check if a status report needs to be sent
|
||||||
// this happens on wiimote sync and when extensions are switched
|
// this happens on Wiimote sync and when extensions are switched
|
||||||
if (m_extension->active_extension != m_extension->switch_extension)
|
if (m_extension->active_extension != m_extension->switch_extension)
|
||||||
{
|
{
|
||||||
RequestStatus();
|
RequestStatus();
|
||||||
|
|
||||||
// Wiibrew: Following a connection or disconnection event on the Extension Port,
|
// WiiBrew: Following a connection or disconnection event on the Extension Port,
|
||||||
// data reporting is disabled and the Data Reporting Mode must be reset before new data can arrive.
|
// data reporting is disabled and the Data Reporting Mode must be reset before new data can arrive.
|
||||||
// after a game receives an unrequested status report,
|
// after a game receives an unrequested status report,
|
||||||
// it expects data reports to stop until it sets the reporting mode again
|
// it expects data reports to stop until it sets the reporting mode again
|
||||||
@ -655,7 +655,7 @@ void Wiimote::Update()
|
|||||||
if (rptf.ext)
|
if (rptf.ext)
|
||||||
GetExtData(data + rptf.ext);
|
GetExtData(data + rptf.ext);
|
||||||
|
|
||||||
// hybrid wiimote stuff (for now, it's not supported while recording)
|
// hybrid Wiimote stuff (for now, it's not supported while recording)
|
||||||
if (WIIMOTE_SRC_HYBRID == g_wiimote_sources[m_index] && !Movie::IsRecordingInput())
|
if (WIIMOTE_SRC_HYBRID == g_wiimote_sources[m_index] && !Movie::IsRecordingInput())
|
||||||
{
|
{
|
||||||
using namespace WiimoteReal;
|
using namespace WiimoteReal;
|
||||||
@ -675,7 +675,7 @@ void Wiimote::Update()
|
|||||||
{
|
{
|
||||||
const ReportFeatures& real_rptf = reporting_mode_features[real_data[1] - WM_REPORT_CORE];
|
const ReportFeatures& real_rptf = reporting_mode_features[real_data[1] - WM_REPORT_CORE];
|
||||||
|
|
||||||
// force same report type from real-wiimote
|
// force same report type from real-Wiimote
|
||||||
if (&real_rptf != &rptf)
|
if (&real_rptf != &rptf)
|
||||||
rptf_size = 0;
|
rptf_size = 0;
|
||||||
|
|
||||||
@ -723,7 +723,7 @@ void Wiimote::Update()
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// copy over report from real-wiimote
|
// copy over report from real-Wiimote
|
||||||
if (-1 == rptf_size)
|
if (-1 == rptf_size)
|
||||||
{
|
{
|
||||||
std::copy(rpt.begin(), rpt.end(), data);
|
std::copy(rpt.begin(), rpt.end(), data);
|
||||||
@ -760,7 +760,7 @@ void Wiimote::ControlChannel(const u16 _channelID, const void* _pData, u32 _Size
|
|||||||
// Check for custom communication
|
// Check for custom communication
|
||||||
if (99 == _channelID)
|
if (99 == _channelID)
|
||||||
{
|
{
|
||||||
// wiimote disconnected
|
// Wiimote disconnected
|
||||||
//PanicAlert( "Wiimote Disconnected" );
|
//PanicAlert( "Wiimote Disconnected" );
|
||||||
|
|
||||||
// reset eeprom/register/reporting mode
|
// reset eeprom/register/reporting mode
|
||||||
|
@ -169,10 +169,10 @@ private:
|
|||||||
Extension* m_extension;
|
Extension* m_extension;
|
||||||
ControlGroup* m_options;
|
ControlGroup* m_options;
|
||||||
|
|
||||||
// WiiMote accel data
|
// Wiimote accel data
|
||||||
AccelData m_accel;
|
AccelData m_accel;
|
||||||
|
|
||||||
// wiimote index, 0-3
|
// Wiimote index, 0-3
|
||||||
const u8 m_index;
|
const u8 m_index;
|
||||||
|
|
||||||
double ir_sin, ir_cos; //for the low pass filter
|
double ir_sin, ir_cos; //for the low pass filter
|
||||||
|
@ -40,7 +40,7 @@ WiimoteScanner::WiimoteScanner()
|
|||||||
, device_id(-1)
|
, device_id(-1)
|
||||||
, device_sock(-1)
|
, device_sock(-1)
|
||||||
{
|
{
|
||||||
// Get the id of the first bluetooth device.
|
// Get the id of the first Bluetooth device.
|
||||||
device_id = hci_get_route(nullptr);
|
device_id = hci_get_route(nullptr);
|
||||||
if (device_id < 0)
|
if (device_id < 0)
|
||||||
{
|
{
|
||||||
@ -52,7 +52,7 @@ WiimoteScanner::WiimoteScanner()
|
|||||||
device_sock = hci_open_dev(device_id);
|
device_sock = hci_open_dev(device_id);
|
||||||
if (device_sock < 0)
|
if (device_sock < 0)
|
||||||
{
|
{
|
||||||
ERROR_LOG(WIIMOTE, "Unable to open bluetooth.");
|
ERROR_LOG(WIIMOTE, "Unable to open Bluetooth.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -81,15 +81,15 @@ void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimot
|
|||||||
auto* scan_infos_ptr = scan_infos;
|
auto* scan_infos_ptr = scan_infos;
|
||||||
found_board = nullptr;
|
found_board = nullptr;
|
||||||
|
|
||||||
// Scan for bluetooth devices
|
// Scan for Bluetooth devices
|
||||||
int const found_devices = hci_inquiry(device_id, wait_len, max_infos, nullptr, &scan_infos_ptr, IREQ_CACHE_FLUSH);
|
int const found_devices = hci_inquiry(device_id, wait_len, max_infos, nullptr, &scan_infos_ptr, IREQ_CACHE_FLUSH);
|
||||||
if (found_devices < 0)
|
if (found_devices < 0)
|
||||||
{
|
{
|
||||||
ERROR_LOG(WIIMOTE, "Error searching for bluetooth devices.");
|
ERROR_LOG(WIIMOTE, "Error searching for Bluetooth devices.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG_LOG(WIIMOTE, "Found %i bluetooth device(s).", found_devices);
|
DEBUG_LOG(WIIMOTE, "Found %i Bluetooth device(s).", found_devices);
|
||||||
|
|
||||||
// Display discovered devices
|
// Display discovered devices
|
||||||
for (int i = 0; i < found_devices; ++i)
|
for (int i = 0; i < found_devices; ++i)
|
||||||
@ -111,7 +111,7 @@ void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimot
|
|||||||
|
|
||||||
// TODO: do this
|
// TODO: do this
|
||||||
|
|
||||||
// Determine if this wiimote has already been found.
|
// Determine if this Wiimote has already been found.
|
||||||
//for (int j = 0; j < MAX_WIIMOTES && new_wiimote; ++j)
|
//for (int j = 0; j < MAX_WIIMOTES && new_wiimote; ++j)
|
||||||
//{
|
//{
|
||||||
// if (wm[j] && bacmp(&scan_infos[i].bdaddr,&wm[j]->bdaddr) == 0)
|
// if (wm[j] && bacmp(&scan_infos[i].bdaddr,&wm[j]->bdaddr) == 0)
|
||||||
@ -133,7 +133,7 @@ void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimot
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
found_wiimotes.push_back(wm);
|
found_wiimotes.push_back(wm);
|
||||||
NOTICE_LOG(WIIMOTE, "Found wiimote (%s).", bdaddr_str);
|
NOTICE_LOG(WIIMOTE, "Found Wiimote (%s).", bdaddr_str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -163,7 +163,7 @@ WiimoteLinux::~WiimoteLinux()
|
|||||||
close(m_wakeup_pipe_r);
|
close(m_wakeup_pipe_r);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Connect to a wiimote with a known address.
|
// Connect to a Wiimote with a known address.
|
||||||
bool WiimoteLinux::ConnectInternal()
|
bool WiimoteLinux::ConnectInternal()
|
||||||
{
|
{
|
||||||
sockaddr_l2 addr = {};
|
sockaddr_l2 addr = {};
|
||||||
@ -176,7 +176,7 @@ bool WiimoteLinux::ConnectInternal()
|
|||||||
if ((m_cmd_sock = socket(AF_BLUETOOTH, SOCK_SEQPACKET, BTPROTO_L2CAP)) == -1 ||
|
if ((m_cmd_sock = socket(AF_BLUETOOTH, SOCK_SEQPACKET, BTPROTO_L2CAP)) == -1 ||
|
||||||
connect(m_cmd_sock, (sockaddr*)&addr, sizeof(addr)) < 0)
|
connect(m_cmd_sock, (sockaddr*)&addr, sizeof(addr)) < 0)
|
||||||
{
|
{
|
||||||
WARN_LOG(WIIMOTE, "Unable to open output socket to wiimote: %s", strerror(errno));
|
WARN_LOG(WIIMOTE, "Unable to open output socket to Wiimote: %s", strerror(errno));
|
||||||
close(m_cmd_sock);
|
close(m_cmd_sock);
|
||||||
m_cmd_sock = -1;
|
m_cmd_sock = -1;
|
||||||
return false;
|
return false;
|
||||||
@ -187,7 +187,7 @@ bool WiimoteLinux::ConnectInternal()
|
|||||||
if ((m_int_sock = socket(AF_BLUETOOTH, SOCK_SEQPACKET, BTPROTO_L2CAP)) == -1 ||
|
if ((m_int_sock = socket(AF_BLUETOOTH, SOCK_SEQPACKET, BTPROTO_L2CAP)) == -1 ||
|
||||||
connect(m_int_sock, (sockaddr*)&addr, sizeof(addr)) < 0)
|
connect(m_int_sock, (sockaddr*)&addr, sizeof(addr)) < 0)
|
||||||
{
|
{
|
||||||
WARN_LOG(WIIMOTE, "Unable to open input socket from wiimote: %s", strerror(errno));
|
WARN_LOG(WIIMOTE, "Unable to open input socket from Wiimote: %s", strerror(errno));
|
||||||
close(m_int_sock);
|
close(m_int_sock);
|
||||||
close(m_cmd_sock);
|
close(m_cmd_sock);
|
||||||
m_int_sock = m_cmd_sock = -1;
|
m_int_sock = m_cmd_sock = -1;
|
||||||
@ -234,7 +234,7 @@ int WiimoteLinux::IORead(u8* buf)
|
|||||||
|
|
||||||
if (select(m_int_sock + 1, &fds, nullptr, nullptr, nullptr) == -1)
|
if (select(m_int_sock + 1, &fds, nullptr, nullptr, nullptr) == -1)
|
||||||
{
|
{
|
||||||
ERROR_LOG(WIIMOTE, "Unable to select wiimote %i input socket.", m_index + 1);
|
ERROR_LOG(WIIMOTE, "Unable to select Wiimote %i input socket.", m_index + 1);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,11 +256,11 @@ int WiimoteLinux::IORead(u8* buf)
|
|||||||
if (r == -1)
|
if (r == -1)
|
||||||
{
|
{
|
||||||
// Error reading data
|
// Error reading data
|
||||||
ERROR_LOG(WIIMOTE, "Receiving data from wiimote %i.", m_index + 1);
|
ERROR_LOG(WIIMOTE, "Receiving data from Wiimote %i.", m_index + 1);
|
||||||
|
|
||||||
if (errno == ENOTCONN)
|
if (errno == ENOTCONN)
|
||||||
{
|
{
|
||||||
// This can happen if the bluetooth dongle is disconnected
|
// This can happen if the Bluetooth dongle is disconnected
|
||||||
ERROR_LOG(WIIMOTE, "Bluetooth appears to be disconnected. "
|
ERROR_LOG(WIIMOTE, "Bluetooth appears to be disconnected. "
|
||||||
"Wiimote %i will be disconnected.", m_index + 1);
|
"Wiimote %i will be disconnected.", m_index + 1);
|
||||||
}
|
}
|
||||||
|
@ -176,7 +176,7 @@ inline void init_lib()
|
|||||||
if (!load_hid() || !load_bthprops())
|
if (!load_hid() || !load_bthprops())
|
||||||
{
|
{
|
||||||
NOTICE_LOG(WIIMOTE,
|
NOTICE_LOG(WIIMOTE,
|
||||||
"Failed to load bluetooth support libraries, wiimotes will not function");
|
"Failed to load Bluetooth support libraries, Wiimotes will not function");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,11 +202,11 @@ protected:
|
|||||||
int IOWrite(u8 const* buf, size_t len) override;
|
int IOWrite(u8 const* buf, size_t len) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::basic_string<TCHAR> m_devicepath; // Unique wiimote reference
|
std::basic_string<TCHAR> m_devicepath; // Unique Wiimote reference
|
||||||
HANDLE m_dev_handle; // HID handle
|
HANDLE m_dev_handle; // HID handle
|
||||||
OVERLAPPED m_hid_overlap_read; // Overlap handles
|
OVERLAPPED m_hid_overlap_read; // Overlap handles
|
||||||
OVERLAPPED m_hid_overlap_write;
|
OVERLAPPED m_hid_overlap_write;
|
||||||
enum win_bt_stack_t m_stack; // Type of bluetooth stack to use
|
enum win_bt_stack_t m_stack; // Type of Bluetooth stack to use
|
||||||
};
|
};
|
||||||
|
|
||||||
int _IOWrite(HANDLE &dev_handle, OVERLAPPED &hid_overlap_write, enum win_bt_stack_t &stack, const u8* buf, size_t len, DWORD* written);
|
int _IOWrite(HANDLE &dev_handle, OVERLAPPED &hid_overlap_write, enum win_bt_stack_t &stack, const u8* buf, size_t len, DWORD* written);
|
||||||
@ -250,15 +250,15 @@ void WiimoteScanner::Update()
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Some hacks that allows disconnects to be detected before connections are handled
|
// Some hacks that allows disconnects to be detected before connections are handled
|
||||||
// workaround for wiimote 1 moving to slot 2 on temporary disconnect
|
// workaround for Wiimote 1 moving to slot 2 on temporary disconnect
|
||||||
if (forgot_some)
|
if (forgot_some)
|
||||||
SLEEP(100);
|
SLEEP(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Find and connect wiimotes.
|
// Find and connect Wiimotes.
|
||||||
// Does not replace already found wiimotes even if they are disconnected.
|
// Does not replace already found Wiimotes even if they are disconnected.
|
||||||
// wm is an array of max_wiimotes wiimotes
|
// wm is an array of max_wiimotes Wiimotes
|
||||||
// Returns the total number of found and connected wiimotes.
|
// Returns the total number of found and connected Wiimotes.
|
||||||
void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimote* & found_board)
|
void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimote* & found_board)
|
||||||
{
|
{
|
||||||
if (!s_loaded_ok)
|
if (!s_loaded_ok)
|
||||||
@ -359,7 +359,7 @@ int CheckDeviceType_Read(HANDLE &dev_handle, u8* buf, int attempts)
|
|||||||
|
|
||||||
// A convoluted way of checking if a device is a Wii Balance Board and if it is a connectible Wiimote.
|
// A convoluted way of checking if a device is a Wii Balance Board and if it is a connectible Wiimote.
|
||||||
// Because nothing on Windows should be easy.
|
// Because nothing on Windows should be easy.
|
||||||
// (We can't seem to easily identify the bluetooth device an HID device belongs to...)
|
// (We can't seem to easily identify the Bluetooth device an HID device belongs to...)
|
||||||
void WiimoteScanner::CheckDeviceType(std::basic_string<TCHAR> &devicepath, bool &real_wiimote, bool &is_bb)
|
void WiimoteScanner::CheckDeviceType(std::basic_string<TCHAR> &devicepath, bool &real_wiimote, bool &is_bb)
|
||||||
{
|
{
|
||||||
real_wiimote = false;
|
real_wiimote = false;
|
||||||
@ -519,7 +519,7 @@ bool WiimoteScanner::IsReady() const
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Connect to a wiimote with a known device path.
|
// Connect to a Wiimote with a known device path.
|
||||||
bool WiimoteWindows::ConnectInternal()
|
bool WiimoteWindows::ConnectInternal()
|
||||||
{
|
{
|
||||||
if (IsConnected())
|
if (IsConnected())
|
||||||
@ -532,8 +532,8 @@ bool WiimoteWindows::ConnectInternal()
|
|||||||
|
|
||||||
auto const open_flags = FILE_SHARE_READ | FILE_SHARE_WRITE;
|
auto const open_flags = FILE_SHARE_READ | FILE_SHARE_WRITE;
|
||||||
#else
|
#else
|
||||||
// Having no FILE_SHARE_WRITE disallows us from connecting to the same wiimote twice.
|
// Having no FILE_SHARE_WRITE disallows us from connecting to the same Wiimote twice.
|
||||||
// (And disallows using wiimotes in use by other programs)
|
// (And disallows using Wiimotes in use by other programs)
|
||||||
// This is what "WiiYourself" does.
|
// This is what "WiiYourself" does.
|
||||||
// Apparently this doesn't work for everyone. It might be their fault.
|
// Apparently this doesn't work for everyone. It might be their fault.
|
||||||
auto const open_flags = FILE_SHARE_READ;
|
auto const open_flags = FILE_SHARE_READ;
|
||||||
@ -727,7 +727,7 @@ int _IOWrite(HANDLE &dev_handle, OVERLAPPED &hid_overlap_write, enum win_bt_stac
|
|||||||
NOTICE_LOG(WIIMOTE, "WiimoteIOWrite[MSBT_STACK_MS]: Unable to send data to the Wiimote");
|
NOTICE_LOG(WIIMOTE, "WiimoteIOWrite[MSBT_STACK_MS]: Unable to send data to the Wiimote");
|
||||||
}
|
}
|
||||||
else if (err != 0x1F) // Some third-party adapters (DolphinBar) use this
|
else if (err != 0x1F) // Some third-party adapters (DolphinBar) use this
|
||||||
// error code to signal the absence of a WiiMote
|
// error code to signal the absence of a Wiimote
|
||||||
// linked to the HID device.
|
// linked to the HID device.
|
||||||
{
|
{
|
||||||
WARN_LOG(WIIMOTE, "IOWrite[MSBT_STACK_MS]: ERROR: %08x", err);
|
WARN_LOG(WIIMOTE, "IOWrite[MSBT_STACK_MS]: ERROR: %08x", err);
|
||||||
@ -795,7 +795,7 @@ int WiimoteWindows::IOWrite(const u8* buf, size_t len)
|
|||||||
return _IOWrite(m_dev_handle, m_hid_overlap_write, m_stack, buf, len, nullptr);
|
return _IOWrite(m_dev_handle, m_hid_overlap_write, m_stack, buf, len, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
// invokes callback for each found wiimote bluetooth device
|
// invokes callback for each found Wiimote Bluetooth device
|
||||||
template <typename T>
|
template <typename T>
|
||||||
void ProcessWiimotes(bool new_scan, T& callback)
|
void ProcessWiimotes(bool new_scan, T& callback)
|
||||||
{
|
{
|
||||||
|
@ -68,7 +68,7 @@ void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimot
|
|||||||
bth = [[IOBluetoothHostController alloc] init];
|
bth = [[IOBluetoothHostController alloc] init];
|
||||||
if ([bth addressAsString] == nil)
|
if ([bth addressAsString] == nil)
|
||||||
{
|
{
|
||||||
WARN_LOG(WIIMOTE, "No bluetooth host controller");
|
WARN_LOG(WIIMOTE, "No Bluetooth host controller");
|
||||||
[bth release];
|
[bth release];
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -81,7 +81,7 @@ void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimot
|
|||||||
|
|
||||||
if ([bti start] != kIOReturnSuccess)
|
if ([bti start] != kIOReturnSuccess)
|
||||||
{
|
{
|
||||||
ERROR_LOG(WIIMOTE, "Unable to do bluetooth discovery");
|
ERROR_LOG(WIIMOTE, "Unable to do Bluetooth discovery");
|
||||||
[bth release];
|
[bth release];
|
||||||
[sbt release];
|
[sbt release];
|
||||||
return;
|
return;
|
||||||
@ -96,7 +96,7 @@ void WiimoteScanner::FindWiimotes(std::vector<Wiimote*> & found_wiimotes, Wiimot
|
|||||||
int found_devices = [[bti foundDevices] count];
|
int found_devices = [[bti foundDevices] count];
|
||||||
|
|
||||||
if (found_devices)
|
if (found_devices)
|
||||||
NOTICE_LOG(WIIMOTE, "Found %i bluetooth devices", found_devices);
|
NOTICE_LOG(WIIMOTE, "Found %i Bluetooth devices", found_devices);
|
||||||
|
|
||||||
en = [[bti foundDevices] objectEnumerator];
|
en = [[bti foundDevices] objectEnumerator];
|
||||||
for (int i = 0; i < found_devices; i++)
|
for (int i = 0; i < found_devices; i++)
|
||||||
@ -149,7 +149,7 @@ WiimoteDarwin::~WiimoteDarwin()
|
|||||||
DisablePowerAssertionInternal();
|
DisablePowerAssertionInternal();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Connect to a wiimote with a known address.
|
// Connect to a Wiimote with a known address.
|
||||||
bool WiimoteDarwin::ConnectInternal()
|
bool WiimoteDarwin::ConnectInternal()
|
||||||
{
|
{
|
||||||
if (IsConnected())
|
if (IsConnected())
|
||||||
@ -162,7 +162,7 @@ bool WiimoteDarwin::ConnectInternal()
|
|||||||
IOReturn ret = [m_btd openConnection];
|
IOReturn ret = [m_btd openConnection];
|
||||||
if (ret)
|
if (ret)
|
||||||
{
|
{
|
||||||
ERROR_LOG(WIIMOTE, "Unable to open Bluetooth connection to wiimote %i: %x",
|
ERROR_LOG(WIIMOTE, "Unable to open Bluetooth connection to Wiimote %i: %x",
|
||||||
m_index + 1, ret);
|
m_index + 1, ret);
|
||||||
[cbt release];
|
[cbt release];
|
||||||
return false;
|
return false;
|
||||||
@ -172,7 +172,7 @@ bool WiimoteDarwin::ConnectInternal()
|
|||||||
withPSM: kBluetoothL2CAPPSMHIDControl delegate: cbt];
|
withPSM: kBluetoothL2CAPPSMHIDControl delegate: cbt];
|
||||||
if (ret)
|
if (ret)
|
||||||
{
|
{
|
||||||
ERROR_LOG(WIIMOTE, "Unable to open control channel for wiimote %i: %x",
|
ERROR_LOG(WIIMOTE, "Unable to open control channel for Wiimote %i: %x",
|
||||||
m_index + 1, ret);
|
m_index + 1, ret);
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
@ -187,13 +187,13 @@ bool WiimoteDarwin::ConnectInternal()
|
|||||||
withPSM: kBluetoothL2CAPPSMHIDInterrupt delegate: cbt];
|
withPSM: kBluetoothL2CAPPSMHIDInterrupt delegate: cbt];
|
||||||
if (ret)
|
if (ret)
|
||||||
{
|
{
|
||||||
WARN_LOG(WIIMOTE, "Unable to open interrupt channel for wiimote %i: %x",
|
WARN_LOG(WIIMOTE, "Unable to open interrupt channel for Wiimote %i: %x",
|
||||||
m_index + 1, ret);
|
m_index + 1, ret);
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
[m_ichan retain];
|
[m_ichan retain];
|
||||||
|
|
||||||
NOTICE_LOG(WIIMOTE, "Connected to wiimote %i at %s",
|
NOTICE_LOG(WIIMOTE, "Connected to Wiimote %i at %s",
|
||||||
m_index + 1, [[m_btd addressString] UTF8String]);
|
m_index + 1, [[m_btd addressString] UTF8String]);
|
||||||
|
|
||||||
m_connected = true;
|
m_connected = true;
|
||||||
@ -210,7 +210,7 @@ bad:
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Disconnect a wiimote.
|
// Disconnect a Wiimote.
|
||||||
void WiimoteDarwin::DisconnectInternal()
|
void WiimoteDarwin::DisconnectInternal()
|
||||||
{
|
{
|
||||||
[m_ichan closeChannel];
|
[m_ichan closeChannel];
|
||||||
@ -226,7 +226,7 @@ void WiimoteDarwin::DisconnectInternal()
|
|||||||
if (!IsConnected())
|
if (!IsConnected())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NOTICE_LOG(WIIMOTE, "Disconnecting wiimote %i", m_index + 1);
|
NOTICE_LOG(WIIMOTE, "Disconnecting Wiimote %i", m_index + 1);
|
||||||
|
|
||||||
m_connected = false;
|
m_connected = false;
|
||||||
}
|
}
|
||||||
@ -301,7 +301,7 @@ void WiimoteDarwin::DisablePowerAssertionInternal()
|
|||||||
- (void) deviceInquiryDeviceFound: (IOBluetoothDeviceInquiry *) sender
|
- (void) deviceInquiryDeviceFound: (IOBluetoothDeviceInquiry *) sender
|
||||||
device: (IOBluetoothDevice *) device
|
device: (IOBluetoothDevice *) device
|
||||||
{
|
{
|
||||||
NOTICE_LOG(WIIMOTE, "Discovered bluetooth device at %s: %s",
|
NOTICE_LOG(WIIMOTE, "Discovered Bluetooth device at %s: %s",
|
||||||
[[device addressString] UTF8String],
|
[[device addressString] UTF8String],
|
||||||
[[device name] UTF8String]);
|
[[device name] UTF8String]);
|
||||||
|
|
||||||
@ -330,18 +330,18 @@ void WiimoteDarwin::DisablePowerAssertionInternal()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (wm == nullptr) {
|
if (wm == nullptr) {
|
||||||
ERROR_LOG(WIIMOTE, "Received packet for unknown wiimote");
|
ERROR_LOG(WIIMOTE, "Received packet for unknown Wiimote");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (length > MAX_PAYLOAD) {
|
if (length > MAX_PAYLOAD) {
|
||||||
WARN_LOG(WIIMOTE, "Dropping packet for wiimote %i, too large",
|
WARN_LOG(WIIMOTE, "Dropping packet for Wiimote %i, too large",
|
||||||
wm->m_index + 1);
|
wm->m_index + 1);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wm->m_inputlen != -1) {
|
if (wm->m_inputlen != -1) {
|
||||||
WARN_LOG(WIIMOTE, "Dropping packet for wiimote %i, queue full",
|
WARN_LOG(WIIMOTE, "Dropping packet for Wiimote %i, queue full",
|
||||||
wm->m_index + 1);
|
wm->m_index + 1);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -369,11 +369,11 @@ void WiimoteDarwin::DisablePowerAssertionInternal()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (wm == nullptr) {
|
if (wm == nullptr) {
|
||||||
ERROR_LOG(WIIMOTE, "Channel for unknown wiimote was closed");
|
ERROR_LOG(WIIMOTE, "Channel for unknown Wiimote was closed");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
WARN_LOG(WIIMOTE, "Lost channel to wiimote %i", wm->m_index + 1);
|
WARN_LOG(WIIMOTE, "Lost channel to Wiimote %i", wm->m_index + 1);
|
||||||
|
|
||||||
wm->DisconnectInternal();
|
wm->DisconnectInternal();
|
||||||
}
|
}
|
||||||
|
@ -630,7 +630,7 @@ void Stop()
|
|||||||
wiimote->EmuStop();
|
wiimote->EmuStop();
|
||||||
}
|
}
|
||||||
|
|
||||||
// called when the dolphin app exits
|
// called when the Dolphin app exits
|
||||||
void Shutdown()
|
void Shutdown()
|
||||||
{
|
{
|
||||||
g_wiimote_scanner.StopScanning();
|
g_wiimote_scanner.StopScanning();
|
||||||
|
@ -53,7 +53,7 @@ public:
|
|||||||
|
|
||||||
// connecting and disconnecting from physical devices
|
// connecting and disconnecting from physical devices
|
||||||
// (using address inserted by FindWiimotes)
|
// (using address inserted by FindWiimotes)
|
||||||
// these are called from the wiimote's thread.
|
// these are called from the Wiimote's thread.
|
||||||
virtual bool ConnectInternal() = 0;
|
virtual bool ConnectInternal() = 0;
|
||||||
virtual void DisconnectInternal() = 0;
|
virtual void DisconnectInternal() = 0;
|
||||||
|
|
||||||
@ -124,7 +124,7 @@ public:
|
|||||||
|
|
||||||
void FindWiimotes(std::vector<Wiimote*>&, Wiimote*&);
|
void FindWiimotes(std::vector<Wiimote*>&, Wiimote*&);
|
||||||
|
|
||||||
// function called when not looking for more wiimotes
|
// function called when not looking for more Wiimotes
|
||||||
void Update();
|
void Update();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -81,8 +81,8 @@ CWII_IPC_HLE_Device_usb_oh1_57e_305::CWII_IPC_HLE_Device_usb_oh1_57e_305(u32 _De
|
|||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
// save now so that when games load sysconf file it includes the new wiimotes
|
// save now so that when games load sysconf file it includes the new Wiimotes
|
||||||
// and the correct order for connected wiimotes
|
// and the correct order for connected Wiimotes
|
||||||
if (!SConfig::GetInstance().m_SYSCONF->SetArrayData("BT.DINF", (u8*)&BT_DINF, sizeof(_conf_pads)) || !SConfig::GetInstance().m_SYSCONF->Save())
|
if (!SConfig::GetInstance().m_SYSCONF->SetArrayData("BT.DINF", (u8*)&BT_DINF, sizeof(_conf_pads)) || !SConfig::GetInstance().m_SYSCONF->Save())
|
||||||
PanicAlertT("Failed to write BT.DINF to SYSCONF");
|
PanicAlertT("Failed to write BT.DINF to SYSCONF");
|
||||||
}
|
}
|
||||||
@ -441,7 +441,7 @@ u32 CWII_IPC_HLE_Device_usb_oh1_57e_305::Update()
|
|||||||
packet_transferred = true;
|
packet_transferred = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// We wait for ScanEnable to be sent from the bt stack through HCI_CMD_WRITE_SCAN_ENABLE
|
// We wait for ScanEnable to be sent from the Bluetooth stack through HCI_CMD_WRITE_SCAN_ENABLE
|
||||||
// before we initiate the connection.
|
// before we initiate the connection.
|
||||||
//
|
//
|
||||||
// FiRES: TODO find a better way to do this
|
// FiRES: TODO find a better way to do this
|
||||||
@ -1857,8 +1857,8 @@ CWII_IPC_HLE_WiiMote* CWII_IPC_HLE_Device_usb_oh1_57e_305::AccessWiiMote(u16 _Co
|
|||||||
return &wiimote;
|
return &wiimote;
|
||||||
}
|
}
|
||||||
|
|
||||||
ERROR_LOG(WII_IPC_WIIMOTE, "Can't find WiiMote by connection handle %02x", _ConnectionHandle);
|
ERROR_LOG(WII_IPC_WIIMOTE, "Can't find Wiimote by connection handle %02x", _ConnectionHandle);
|
||||||
PanicAlertT("Can't find WiiMote by connection handle %02x", _ConnectionHandle);
|
PanicAlertT("Can't find Wiimote by connection handle %02x", _ConnectionHandle);
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ struct SQueuedEvent
|
|||||||
// Important to remember that this class is for /dev/usb/oh1/57e/305 ONLY
|
// Important to remember that this class is for /dev/usb/oh1/57e/305 ONLY
|
||||||
// /dev/usb/oh1 -> internal usb bus
|
// /dev/usb/oh1 -> internal usb bus
|
||||||
// 57e/305 -> VendorID/ProductID of device on usb bus
|
// 57e/305 -> VendorID/ProductID of device on usb bus
|
||||||
// This device is ONLY the internal bluetooth module (based on BCM2045 chip)
|
// This device is ONLY the internal Bluetooth module (based on BCM2045 chip)
|
||||||
class CWII_IPC_HLE_Device_usb_oh1_57e_305 : public IWII_IPC_HLE_Device
|
class CWII_IPC_HLE_Device_usb_oh1_57e_305 : public IWII_IPC_HLE_Device
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -60,12 +60,12 @@ public:
|
|||||||
|
|
||||||
static void EnqueueReply(u32 CommandAddress);
|
static void EnqueueReply(u32 CommandAddress);
|
||||||
|
|
||||||
// Send ACL data back to bt stack
|
// Send ACL data back to Bluetooth stack
|
||||||
void SendACLPacket(u16 _ConnectionHandle, u8* _pData, u32 _Size);
|
void SendACLPacket(u16 _ConnectionHandle, u8* _pData, u32 _Size);
|
||||||
|
|
||||||
bool RemoteDisconnect(u16 _connectionHandle);
|
bool RemoteDisconnect(u16 _connectionHandle);
|
||||||
|
|
||||||
// hack for wiimote plugin
|
// hack for Wiimote plugin
|
||||||
public:
|
public:
|
||||||
std::vector<CWII_IPC_HLE_WiiMote> m_WiiMotes;
|
std::vector<CWII_IPC_HLE_WiiMote> m_WiiMotes;
|
||||||
CWII_IPC_HLE_WiiMote* AccessWiiMote(const bdaddr_t& _rAddr);
|
CWII_IPC_HLE_WiiMote* AccessWiiMote(const bdaddr_t& _rAddr);
|
||||||
|
@ -546,7 +546,7 @@ void CWII_IPC_HLE_WiiMote::ReceiveDisconnectionReq(u8 _Ident, u8* _pData, u32 _S
|
|||||||
//
|
//
|
||||||
//
|
//
|
||||||
|
|
||||||
// We assume WiiMote is always connected
|
// We assume Wiimote is always connected
|
||||||
void CWII_IPC_HLE_WiiMote::SendConnectionRequest(u16 scid, u16 psm)
|
void CWII_IPC_HLE_WiiMote::SendConnectionRequest(u16 scid, u16 psm)
|
||||||
{
|
{
|
||||||
// create the channel
|
// create the channel
|
||||||
@ -604,7 +604,7 @@ void CWII_IPC_HLE_WiiMote::SendConfigurationRequest(u16 scid, u16 MTU, u16 Flush
|
|||||||
// (shuffle2) currently we end up not appending options. this is because we don't
|
// (shuffle2) currently we end up not appending options. this is because we don't
|
||||||
// negotiate after trying to set MTU = 0 fails (stack will respond with
|
// negotiate after trying to set MTU = 0 fails (stack will respond with
|
||||||
// "configuration failed" msg...). This is still fine, we'll just use whatever the
|
// "configuration failed" msg...). This is still fine, we'll just use whatever the
|
||||||
// bt stack defaults to.
|
// Bluetooth stack defaults to.
|
||||||
if (MTU || rChannel.MTU)
|
if (MTU || rChannel.MTU)
|
||||||
{
|
{
|
||||||
if (MTU == 0)
|
if (MTU == 0)
|
||||||
|
@ -54,7 +54,7 @@ public:
|
|||||||
void ResetChannels();
|
void ResetChannels();
|
||||||
void Activate(bool ready);
|
void Activate(bool ready);
|
||||||
void ExecuteL2capCmd(u8* _pData, u32 _Size); // From CPU
|
void ExecuteL2capCmd(u8* _pData, u32 _Size); // From CPU
|
||||||
void ReceiveL2capData(u16 scid, const void* _pData, u32 _Size); // From wiimote
|
void ReceiveL2capData(u16 scid, const void* _pData, u32 _Size); // From Wiimote
|
||||||
|
|
||||||
int NetPlay_GetWiimoteNum(int _number);
|
int NetPlay_GetWiimoteNum(int _number);
|
||||||
|
|
||||||
|
@ -424,7 +424,7 @@ void WiiSocket::Update(bool read, bool write, bool except)
|
|||||||
u32 flags = Memory::Read_U32(BufferIn2 + 0x04);
|
u32 flags = Memory::Read_U32(BufferIn2 + 0x04);
|
||||||
u32 has_destaddr = Memory::Read_U32(BufferIn2 + 0x08);
|
u32 has_destaddr = Memory::Read_U32(BufferIn2 + 0x08);
|
||||||
|
|
||||||
// Not a string, windows requires a const char* for sendto
|
// Not a string, Windows requires a const char* for sendto
|
||||||
const char* data = (const char*)Memory::GetPointer(BufferIn);
|
const char* data = (const char*)Memory::GetPointer(BufferIn);
|
||||||
|
|
||||||
// Act as non blocking when SO_MSG_NONBLOCK is specified
|
// Act as non blocking when SO_MSG_NONBLOCK is specified
|
||||||
@ -459,7 +459,7 @@ void WiiSocket::Update(bool read, bool write, bool except)
|
|||||||
case IOCTLV_SO_RECVFROM:
|
case IOCTLV_SO_RECVFROM:
|
||||||
{
|
{
|
||||||
u32 flags = Memory::Read_U32(BufferIn + 0x04);
|
u32 flags = Memory::Read_U32(BufferIn + 0x04);
|
||||||
// Not a string, windows requires a char* for recvfrom
|
// Not a string, Windows requires a char* for recvfrom
|
||||||
char* data = (char*)Memory::GetPointer(BufferOut);
|
char* data = (char*)Memory::GetPointer(BufferOut);
|
||||||
int data_len = BufferOutSize;
|
int data_len = BufferOutSize;
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
// Added some info from bluetooth.h
|
// Added some info from bluetooth.h
|
||||||
// All packet headers have had the packet type field removed. This is because
|
// All packet headers have had the packet type field removed. This is because
|
||||||
// IOS adds the packet type to the header, and strips it before returning the
|
// IOS adds the packet type to the header, and strips it before returning the
|
||||||
// packet to the overlying bt stack.
|
// packet to the overlying Bluetooth stack.
|
||||||
|
|
||||||
/* $NetBSD: hci.h,v 1.33 2009/09/11 18:35:50 plunky Exp $ */
|
/* $NetBSD: hci.h,v 1.33 2009/09/11 18:35:50 plunky Exp $ */
|
||||||
|
|
||||||
|
@ -213,7 +213,7 @@ unsigned int NetPlayClient::OnData(sf::Packet& packet)
|
|||||||
delete[] data;
|
delete[] data;
|
||||||
|
|
||||||
// trusting server for good map value (>=0 && <4)
|
// trusting server for good map value (>=0 && <4)
|
||||||
// add to wiimote buffer
|
// add to Wiimote buffer
|
||||||
m_wiimote_buffer[(unsigned)map].Push(nw);
|
m_wiimote_buffer[(unsigned)map].Push(nw);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -620,9 +620,9 @@ bool NetPlayClient::WiimoteUpdate(int _number, u8* data, const u8 size)
|
|||||||
{
|
{
|
||||||
std::lock_guard<std::recursive_mutex> lkp(m_crit.players);
|
std::lock_guard<std::recursive_mutex> lkp(m_crit.players);
|
||||||
|
|
||||||
// in game mapping for this local wiimote
|
// in game mapping for this local Wiimote
|
||||||
unsigned int in_game_num = LocalWiimoteToInGameWiimote(_number);
|
unsigned int in_game_num = LocalWiimoteToInGameWiimote(_number);
|
||||||
// does this local wiimote map in game?
|
// does this local Wiimote map in game?
|
||||||
if (in_game_num < 4)
|
if (in_game_num < 4)
|
||||||
{
|
{
|
||||||
if (previousSize[in_game_num] == size)
|
if (previousSize[in_game_num] == size)
|
||||||
|
@ -133,7 +133,7 @@ unsigned int NetPlayServer::OnConnect(std::unique_ptr<sf::TcpSocket>& socket)
|
|||||||
|
|
||||||
std::string npver;
|
std::string npver;
|
||||||
rpac >> npver;
|
rpac >> npver;
|
||||||
// dolphin netplay version
|
// Dolphin netplay version
|
||||||
if (npver != NETPLAY_VERSION)
|
if (npver != NETPLAY_VERSION)
|
||||||
return CON_ERR_VERSION_MISMATCH;
|
return CON_ERR_VERSION_MISMATCH;
|
||||||
|
|
||||||
@ -416,7 +416,7 @@ unsigned int NetPlayServer::OnData(sf::Packet& packet, Client& player)
|
|||||||
|
|
||||||
case NP_MSG_WIIMOTE_DATA :
|
case NP_MSG_WIIMOTE_DATA :
|
||||||
{
|
{
|
||||||
// if this is wiimote data from the last game still being received, ignore it
|
// if this is Wiimote data from the last game still being received, ignore it
|
||||||
if (player.current_game != m_current_game)
|
if (player.current_game != m_current_game)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -832,7 +832,7 @@ void Interpreter::sync(UGeckoInstruction _inst)
|
|||||||
void Interpreter::tlbia(UGeckoInstruction _inst)
|
void Interpreter::tlbia(UGeckoInstruction _inst)
|
||||||
{
|
{
|
||||||
// Gekko does not support this instructions.
|
// Gekko does not support this instructions.
|
||||||
PanicAlert("The GC CPU does not support tlbia");
|
PanicAlert("The GameCube CPU does not support tlbia");
|
||||||
// invalid the whole TLB
|
// invalid the whole TLB
|
||||||
//MessageBox(0,"TLBIA","TLBIA",0);
|
//MessageBox(0,"TLBIA","TLBIA",0);
|
||||||
}
|
}
|
||||||
|
@ -163,7 +163,7 @@ static void fregSpill(RegInfo& RI, X64Reg reg)
|
|||||||
// (TODO: if we could lock RCX here too then we could allocate it - needed for
|
// (TODO: if we could lock RCX here too then we could allocate it - needed for
|
||||||
// shifts)
|
// shifts)
|
||||||
|
|
||||||
// 64-bit - calling conventions differ between linux & windows, so...
|
// 64-bit - calling conventions differ between Linux & Windows, so...
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
static const X64Reg RegAllocOrder[] = {RSI, RDI, R12, R13, R14, R8, R9, R10, R11};
|
static const X64Reg RegAllocOrder[] = {RSI, RDI, R12, R13, R14, R8, R9, R10, R11};
|
||||||
#else
|
#else
|
||||||
|
@ -52,7 +52,7 @@ IVolume::ECountry CountrySwitch(u8 CountryCode)
|
|||||||
// NTSC
|
// NTSC
|
||||||
case 'E':
|
case 'E':
|
||||||
case 'N': // Japanese import to USA and other NTSC regions
|
case 'N': // Japanese import to USA and other NTSC regions
|
||||||
case 'Z': // Prince Of Persia - The Forgotten Sands (WII)
|
case 'Z': // Prince of Persia - The Forgotten Sands (Wii)
|
||||||
case 'B': // Ufouria: The Saga (Virtual Console)
|
case 'B': // Ufouria: The Saga (Virtual Console)
|
||||||
return IVolume::COUNTRY_USA;
|
return IVolume::COUNTRY_USA;
|
||||||
|
|
||||||
|
@ -296,8 +296,8 @@ wxStaticBoxSizer* ControllerConfigDiag::CreateRealWiimoteSizer()
|
|||||||
wxBoxSizer* const real_wiimotes_sizer = new wxBoxSizer(wxHORIZONTAL);
|
wxBoxSizer* const real_wiimotes_sizer = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
|
||||||
if (!WiimoteReal::g_wiimote_scanner.IsReady())
|
if (!WiimoteReal::g_wiimote_scanner.IsReady())
|
||||||
real_wiimotes_group->Add(new wxStaticText(this, wxID_ANY, _("A supported bluetooth device could not be found.\n"
|
real_wiimotes_group->Add(new wxStaticText(this, wxID_ANY, _("A supported Bluetooth device could not be found.\n"
|
||||||
"You must manually connect your wiimotes.")), 0, wxALIGN_CENTER | wxALL, 5);
|
"You must manually connect your Wiimotes.")), 0, wxALIGN_CENTER | wxALL, 5);
|
||||||
|
|
||||||
wxCheckBox* const continuous_scanning = new wxCheckBox(this, wxID_ANY, _("Continuous Scanning"));
|
wxCheckBox* const continuous_scanning = new wxCheckBox(this, wxID_ANY, _("Continuous Scanning"));
|
||||||
continuous_scanning->Bind(wxEVT_CHECKBOX, &ControllerConfigDiag::OnContinuousScanning, this);
|
continuous_scanning->Bind(wxEVT_CHECKBOX, &ControllerConfigDiag::OnContinuousScanning, this);
|
||||||
|
@ -1195,7 +1195,7 @@ void CFrame::OnKeyDown(wxKeyEvent& event)
|
|||||||
// On OS X, we claim all keyboard events while
|
// On OS X, we claim all keyboard events while
|
||||||
// emulation is running to avoid wxWidgets sounding
|
// emulation is running to avoid wxWidgets sounding
|
||||||
// the system beep for unhandled key events when
|
// the system beep for unhandled key events when
|
||||||
// receiving pad/wiimote keypresses which take an
|
// receiving pad/Wiimote keypresses which take an
|
||||||
// entirely different path through the HID subsystem.
|
// entirely different path through the HID subsystem.
|
||||||
#ifndef __APPLE__
|
#ifndef __APPLE__
|
||||||
// On other platforms, we leave the key event alone
|
// On other platforms, we leave the key event alone
|
||||||
@ -1205,7 +1205,7 @@ void CFrame::OnKeyDown(wxKeyEvent& event)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// Actually perform the wiimote connection or disconnection
|
// Actually perform the Wiimote connection or disconnection
|
||||||
if (WiimoteId >= 0)
|
if (WiimoteId >= 0)
|
||||||
{
|
{
|
||||||
wxCommandEvent evt;
|
wxCommandEvent evt;
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
#define PREVIEW_UPDATE_TIME 25
|
#define PREVIEW_UPDATE_TIME 25
|
||||||
#define DEFAULT_HIGH_VALUE 100
|
#define DEFAULT_HIGH_VALUE 100
|
||||||
|
|
||||||
// might have to change this setup for wiimote
|
// might have to change this setup for Wiimote
|
||||||
#define PROFILES_PATH "Profiles/"
|
#define PROFILES_PATH "Profiles/"
|
||||||
|
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
@ -125,7 +125,7 @@ NetPlaySetupDiag::NetPlaySetupDiag(wxWindow* const parent, const CGameListCtrl*
|
|||||||
"Netplay will only work with the following settings:\n"
|
"Netplay will only work with the following settings:\n"
|
||||||
" - DSP Emulator Engine Must be the same on all computers!\n"
|
" - DSP Emulator Engine Must be the same on all computers!\n"
|
||||||
" - DSP on Dedicated Thread [OFF]\n"
|
" - DSP on Dedicated Thread [OFF]\n"
|
||||||
" - Manually set the extensions for each wiimote\n"
|
" - Manually set the extensions for each Wiimote\n"
|
||||||
"\n"
|
"\n"
|
||||||
"All players should use the same Dolphin version and settings.\n"
|
"All players should use the same Dolphin version and settings.\n"
|
||||||
"All memory cards must be identical between players or disabled.\n"
|
"All memory cards must be identical between players or disabled.\n"
|
||||||
|
@ -220,7 +220,7 @@ protected:
|
|||||||
choice_backend->Disable();
|
choice_backend->Disable();
|
||||||
label_backend->Disable();
|
label_backend->Disable();
|
||||||
|
|
||||||
//D3D only
|
// D3D only
|
||||||
if (vconfig.backend_info.Adapters.size())
|
if (vconfig.backend_info.Adapters.size())
|
||||||
{
|
{
|
||||||
choice_adapter->Disable();
|
choice_adapter->Disable();
|
||||||
@ -228,7 +228,7 @@ protected:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifndef __APPLE__
|
#ifndef __APPLE__
|
||||||
// This isn't supported on OSX.
|
// This isn't supported on OS X.
|
||||||
|
|
||||||
choice_display_resolution->Disable();
|
choice_display_resolution->Disable();
|
||||||
label_display_resolution->Disable();
|
label_display_resolution->Disable();
|
||||||
|
@ -328,9 +328,9 @@ static void InitDriverInfo()
|
|||||||
int glrelease = 0;
|
int glrelease = 0;
|
||||||
int major = 0;
|
int major = 0;
|
||||||
int minor = 0;
|
int minor = 0;
|
||||||
// TODO: this is known to be broken on windows
|
// TODO: this is known to be broken on Windows
|
||||||
// nvidia seems to have removed their driver version from this string, so we can't get it.
|
// Nvidia seems to have removed their driver version from this string, so we can't get it.
|
||||||
// hopefully we'll never have to workaround nvidia bugs
|
// hopefully we'll never have to workaround Nvidia bugs
|
||||||
sscanf(g_ogl_config.gl_version, "%d.%d.%d NVIDIA %d.%d", &glmajor, &glminor, &glrelease, &major, &minor);
|
sscanf(g_ogl_config.gl_version, "%d.%d.%d NVIDIA %d.%d", &glmajor, &glminor, &glrelease, &major, &minor);
|
||||||
version = 100*major + minor;
|
version = 100*major + minor;
|
||||||
}
|
}
|
||||||
@ -556,7 +556,7 @@ Renderer::Renderer()
|
|||||||
// It also isn't useful as we don't render anything to the default framebuffer.
|
// It also isn't useful as we don't render anything to the default framebuffer.
|
||||||
// We also try to get a non-msaa fb, so this only happens when forced by the driver.
|
// We also try to get a non-msaa fb, so this only happens when forced by the driver.
|
||||||
PanicAlert("MSAA on default framebuffer isn't supported.\n"
|
PanicAlert("MSAA on default framebuffer isn't supported.\n"
|
||||||
"Please avoid forcing dolphin to use MSAA by the driver.\n"
|
"Please avoid forcing Dolphin to use MSAA by the driver.\n"
|
||||||
"%d samples on default framebuffer found.", samples);
|
"%d samples on default framebuffer found.", samples);
|
||||||
bSuccess = false;
|
bSuccess = false;
|
||||||
}
|
}
|
||||||
|
@ -36,9 +36,9 @@ StreamBuffer::~StreamBuffer()
|
|||||||
glDeleteBuffers(1, &m_buffer);
|
glDeleteBuffers(1, &m_buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Shared synchronisation code for ring buffers
|
/* Shared synchronization code for ring buffers
|
||||||
*
|
*
|
||||||
* The next three functions are to create/delete/use the OpenGL synchronisation.
|
* The next three functions are to create/delete/use the OpenGL synchronization.
|
||||||
* ARB_sync (OpenGL 3.2) is used and required.
|
* ARB_sync (OpenGL 3.2) is used and required.
|
||||||
*
|
*
|
||||||
* To reduce overhead, the complete buffer is splitted up into SYNC_POINTS chunks.
|
* To reduce overhead, the complete buffer is splitted up into SYNC_POINTS chunks.
|
||||||
@ -52,11 +52,11 @@ StreamBuffer::~StreamBuffer()
|
|||||||
*
|
*
|
||||||
* So on alloc, we have to wait for all slots between m_free_iterator and m_iterator (and set m_free_iterator to m_iterator afterwards).
|
* So on alloc, we have to wait for all slots between m_free_iterator and m_iterator (and set m_free_iterator to m_iterator afterwards).
|
||||||
*
|
*
|
||||||
* We also assume that this buffer is accessed by the gpu between the Unmap and Map function,
|
* We also assume that this buffer is accessed by the GPU between the Unmap and Map function,
|
||||||
* so we may create the fences on the start of mapping.
|
* so we may create the fences on the start of mapping.
|
||||||
* Some here, new fences for the chunks between m_used_iterator and m_iterator (also update m_used_iterator).
|
* Some here, new fences for the chunks between m_used_iterator and m_iterator (also update m_used_iterator).
|
||||||
*
|
*
|
||||||
* As ring buffers have an ugly behavoir on rollover, have fun to read this code ;)
|
* As ring buffers have an ugly behavior on rollover, have fun to read this code ;)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void StreamBuffer::CreateFences()
|
void StreamBuffer::CreateFences()
|
||||||
@ -116,7 +116,7 @@ void StreamBuffer::AllocMemory(u32 size)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The usual way to stream data to the gpu.
|
/* The usual way to stream data to the GPU.
|
||||||
* Described here: https://www.opengl.org/wiki/Buffer_Object_Streaming#Unsynchronized_buffer_mapping
|
* Described here: https://www.opengl.org/wiki/Buffer_Object_Streaming#Unsynchronized_buffer_mapping
|
||||||
* Just do unsync appends until the buffer is full.
|
* Just do unsync appends until the buffer is full.
|
||||||
* When it's full, orphan (alloc a new buffer and free the old one)
|
* When it's full, orphan (alloc a new buffer and free the old one)
|
||||||
@ -159,7 +159,7 @@ public:
|
|||||||
/* A modified streaming way without reallocation
|
/* A modified streaming way without reallocation
|
||||||
* This one fixes the reallocation overhead of the MapAndOrphan one.
|
* This one fixes the reallocation overhead of the MapAndOrphan one.
|
||||||
* So it alloc a ring buffer on initialization.
|
* So it alloc a ring buffer on initialization.
|
||||||
* But with this limited ressource, we have to care about the cpu-gpu distance.
|
* But with this limited resource, we have to care about the CPU-GPU distance.
|
||||||
* Else this fifo may overflow.
|
* Else this fifo may overflow.
|
||||||
* So we had traded orphan vs syncing.
|
* So we had traded orphan vs syncing.
|
||||||
*/
|
*/
|
||||||
@ -194,9 +194,9 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Streaming fifo without mapping ovearhead.
|
/* Streaming fifo without mapping overhead.
|
||||||
* This one usually requires ARB_buffer_storage (OpenGL 4.4).
|
* This one usually requires ARB_buffer_storage (OpenGL 4.4).
|
||||||
* And is usually not available on OpenGL3 gpus.
|
* And is usually not available on OpenGL3 GPUs.
|
||||||
*
|
*
|
||||||
* ARB_buffer_storage allows us to render from a mapped buffer.
|
* ARB_buffer_storage allows us to render from a mapped buffer.
|
||||||
* So we map it persistently in the initialization.
|
* So we map it persistently in the initialization.
|
||||||
@ -250,7 +250,7 @@ public:
|
|||||||
* Another streaming fifo without mapping overhead.
|
* Another streaming fifo without mapping overhead.
|
||||||
* As we can't orphan without mapping, we have to sync.
|
* As we can't orphan without mapping, we have to sync.
|
||||||
*
|
*
|
||||||
* This one uses AMD_pinned_memory which is available on all AMD gpus.
|
* This one uses AMD_pinned_memory which is available on all AMD GPUs.
|
||||||
* OpenGL 4.4 drivers should use BufferStorage.
|
* OpenGL 4.4 drivers should use BufferStorage.
|
||||||
*/
|
*/
|
||||||
class PinnedMemory : public StreamBuffer
|
class PinnedMemory : public StreamBuffer
|
||||||
@ -371,7 +371,7 @@ StreamBuffer* StreamBuffer::Create(u32 type, u32 size)
|
|||||||
// Prefer the syncing buffers over the orphaning one
|
// Prefer the syncing buffers over the orphaning one
|
||||||
if (g_ogl_config.bSupportsGLSync)
|
if (g_ogl_config.bSupportsGLSync)
|
||||||
{
|
{
|
||||||
// pinned memory is much faster than buffer storage on amd cards
|
// pinned memory is much faster than buffer storage on AMD cards
|
||||||
if (g_ogl_config.bSupportsGLPinnedMemory &&
|
if (g_ogl_config.bSupportsGLPinnedMemory &&
|
||||||
!(DriverDetails::HasBug(DriverDetails::BUG_BROKENPINNEDMEMORY) && type == GL_ELEMENT_ARRAY_BUFFER))
|
!(DriverDetails::HasBug(DriverDetails::BUG_BROKENPINNEDMEMORY) && type == GL_ELEMENT_ARRAY_BUFFER))
|
||||||
return new PinnedMemory(type, size);
|
return new PinnedMemory(type, size);
|
||||||
@ -382,7 +382,7 @@ StreamBuffer* StreamBuffer::Create(u32 type, u32 size)
|
|||||||
!(DriverDetails::HasBug(DriverDetails::BUG_INTELBROKENBUFFERSTORAGE) && type == GL_ELEMENT_ARRAY_BUFFER))
|
!(DriverDetails::HasBug(DriverDetails::BUG_INTELBROKENBUFFERSTORAGE) && type == GL_ELEMENT_ARRAY_BUFFER))
|
||||||
return new BufferStorage(type, size);
|
return new BufferStorage(type, size);
|
||||||
|
|
||||||
// don't fall back to MapAnd* for nvidia drivers
|
// don't fall back to MapAnd* for Nvidia drivers
|
||||||
if (DriverDetails::HasBug(DriverDetails::BUG_BROKENUNSYNCMAPPING))
|
if (DriverDetails::HasBug(DriverDetails::BUG_BROKENUNSYNCMAPPING))
|
||||||
return new BufferSubData(type, size);
|
return new BufferSubData(type, size);
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ public:
|
|||||||
|
|
||||||
/* This mapping function will return a pair of:
|
/* This mapping function will return a pair of:
|
||||||
* - the pointer to the mapped buffer
|
* - the pointer to the mapped buffer
|
||||||
* - the offset into the real gpu buffer (always multiple of stride)
|
* - the offset into the real GPU buffer (always multiple of stride)
|
||||||
* On mapping, the maximum of size for allocation has to be set.
|
* On mapping, the maximum of size for allocation has to be set.
|
||||||
* The size really pushed into this fifo only has to be known on Unmapping.
|
* The size really pushed into this fifo only has to be known on Unmapping.
|
||||||
* Mapping invalidates the current buffer content,
|
* Mapping invalidates the current buffer content,
|
||||||
|
@ -134,8 +134,8 @@ static void InitBackendInfo()
|
|||||||
{
|
{
|
||||||
g_Config.backend_info.APIType = API_OPENGL;
|
g_Config.backend_info.APIType = API_OPENGL;
|
||||||
g_Config.backend_info.bSupportsExclusiveFullscreen = false;
|
g_Config.backend_info.bSupportsExclusiveFullscreen = false;
|
||||||
//g_Config.backend_info.bSupportsDualSourceBlend = true; // is gpu dependent and must be set in renderer
|
//g_Config.backend_info.bSupportsDualSourceBlend = true; // is GPU dependent and must be set in renderer
|
||||||
//g_Config.backend_info.bSupportsEarlyZ = true; // is gpu dependent and must be set in renderer
|
//g_Config.backend_info.bSupportsEarlyZ = true; // is GPU dependent and must be set in renderer
|
||||||
g_Config.backend_info.bSupportsOversizedViewports = true;
|
g_Config.backend_info.bSupportsOversizedViewports = true;
|
||||||
g_Config.backend_info.bSupportsGeometryShaders = true;
|
g_Config.backend_info.bSupportsGeometryShaders = true;
|
||||||
g_Config.backend_info.bSupports3DVision = false;
|
g_Config.backend_info.bSupports3DVision = false;
|
||||||
|
@ -34,7 +34,7 @@ static u8 lastPrimCmd;
|
|||||||
void DoState(PointerWrap &p)
|
void DoState(PointerWrap &p)
|
||||||
{
|
{
|
||||||
p.Do(minCommandSize);
|
p.Do(minCommandSize);
|
||||||
// Not sure what is wrong with this. Something(s) in here is causing dolphin to crash/hang when loading states saved from another run of dolphin. Doesn't seem too important anyway...
|
// Not sure what is wrong with this. Something(s) in here is causing Dolphin to crash/hang when loading states saved from another run of Dolphin. Doesn't seem too important anyway...
|
||||||
//vertexLoader.DoState(p);
|
//vertexLoader.DoState(p);
|
||||||
p.Do(readOpcode);
|
p.Do(readOpcode);
|
||||||
p.Do(inObjectStream);
|
p.Do(inObjectStream);
|
||||||
|
@ -163,7 +163,7 @@ void SetupUnit::SetupPoint()
|
|||||||
|
|
||||||
void SetupUnit::DoState(PointerWrap &p)
|
void SetupUnit::DoState(PointerWrap &p)
|
||||||
{
|
{
|
||||||
// TODO: some or all of this is making the save states stop working once dolphin is closed...sometimes (usually)
|
// TODO: some or all of this is making the save states stop working once Dolphin is closed...sometimes (usually)
|
||||||
// I have no idea what specifically is wrong, or if this is even important. Disabling it doesn't seem to make any noticible difference...
|
// I have no idea what specifically is wrong, or if this is even important. Disabling it doesn't seem to make any noticible difference...
|
||||||
/* p.Do(m_PrimType);
|
/* p.Do(m_PrimType);
|
||||||
p.Do(m_VertexCounter);
|
p.Do(m_VertexCounter);
|
||||||
|
@ -97,10 +97,10 @@ namespace DriverDetails
|
|||||||
// Started Version: ?
|
// Started Version: ?
|
||||||
// Ended Version: 13.9 working for me (neobrain).
|
// Ended Version: 13.9 working for me (neobrain).
|
||||||
// Affected OS: Linux
|
// Affected OS: Linux
|
||||||
// Pinned memory is disabled for index buffer as the amd driver (the only one with pinned memory support) seems
|
// Pinned memory is disabled for index buffer as the AMD driver (the only one with pinned memory support) seems
|
||||||
// to be broken. We just get flickering/black rendering when using pinned memory here -- degasus - 2013/08/20
|
// to be broken. We just get flickering/black rendering when using pinned memory here -- degasus - 2013/08/20
|
||||||
// This bug only happens when paired with base_vertex.
|
// This bug only happens when paired with base_vertex.
|
||||||
// Please see issue #6105 on google code. Let's hope buffer storage solves this issues.
|
// Please see issue #6105 on Google Code. Let's hope buffer storage solves this issues.
|
||||||
// TODO: Detect broken drivers.
|
// TODO: Detect broken drivers.
|
||||||
BUG_BROKENPINNEDMEMORY,
|
BUG_BROKENPINNEDMEMORY,
|
||||||
// Bug: Entirely broken UBOs
|
// Bug: Entirely broken UBOs
|
||||||
@ -134,7 +134,7 @@ namespace DriverDetails
|
|||||||
// If a shader includes a textureSize function call then the shader compiler will call abort()
|
// If a shader includes a textureSize function call then the shader compiler will call abort()
|
||||||
BUG_BROKENTEXTURESIZE,
|
BUG_BROKENTEXTURESIZE,
|
||||||
// Bug: ARB_buffer_storage doesn't work with ARRAY_BUFFER type streams
|
// Bug: ARB_buffer_storage doesn't work with ARRAY_BUFFER type streams
|
||||||
// Affected devices: Geforce 4xx+
|
// Affected devices: GeForce 4xx+
|
||||||
// Started Version: -1
|
// Started Version: -1
|
||||||
// Ended Version: 332.21
|
// Ended Version: 332.21
|
||||||
// The buffer_storage streaming method is required for greater speed gains in our buffer streaming
|
// The buffer_storage streaming method is required for greater speed gains in our buffer streaming
|
||||||
@ -150,14 +150,14 @@ namespace DriverDetails
|
|||||||
// Intel HD 4000 series isn't affected by the bug
|
// Intel HD 4000 series isn't affected by the bug
|
||||||
BUG_PRIMITIVERESTART,
|
BUG_PRIMITIVERESTART,
|
||||||
// Bug: unsync mapping doesn't work fine
|
// Bug: unsync mapping doesn't work fine
|
||||||
// Affected devices: nvidia driver
|
// Affected devices: Nvidia driver
|
||||||
// Started Version: -1
|
// Started Version: -1
|
||||||
// Ended Version: -1
|
// Ended Version: -1
|
||||||
// The nvidia driver (both windows + linux) doesn't like unsync mapping performance wise.
|
// The Nvidia driver (both Windows + Linux) doesn't like unsync mapping performance wise.
|
||||||
// Because of their threaded behavoir, they seem not to handle unsync mapping complete unsync,
|
// Because of their threaded behavior, they seem not to handle unsync mapping complete unsync,
|
||||||
// in fact, they serialize the driver which adds a much bigger overhead.
|
// in fact, they serialize the driver which adds a much bigger overhead.
|
||||||
// Workaround: Use BufferSubData
|
// Workaround: Use BufferSubData
|
||||||
// TODO: some windows AMD driver/gpu combination seems also affected
|
// TODO: some Windows AMD driver/GPU combination seems also affected
|
||||||
// but as they all support pinned memory, it doesn't matter
|
// but as they all support pinned memory, it doesn't matter
|
||||||
BUG_BROKENUNSYNCMAPPING,
|
BUG_BROKENUNSYNCMAPPING,
|
||||||
// Bug: Intel's Window driver broke buffer_storage with GL_ELEMENT_ARRAY_BUFFER
|
// Bug: Intel's Window driver broke buffer_storage with GL_ELEMENT_ARRAY_BUFFER
|
||||||
|
@ -924,7 +924,7 @@ static inline void WriteTevRegular(T& out, const char* components, int bias, int
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Regular TEV stage: (d + bias + lerp(a,b,c)) * scale
|
// Regular TEV stage: (d + bias + lerp(a,b,c)) * scale
|
||||||
// The GC/Wii GPU uses a very sophisticated algorithm for scale-lerping:
|
// The GameCube/Wii GPU uses a very sophisticated algorithm for scale-lerping:
|
||||||
// - c is scaled from 0..255 to 0..256, which allows dividing the result by 256 instead of 255
|
// - c is scaled from 0..255 to 0..256, which allows dividing the result by 256 instead of 255
|
||||||
// - if scale is bigger than one, it is moved inside the lerp calculation for increased accuracy
|
// - if scale is bigger than one, it is moved inside the lerp calculation for increased accuracy
|
||||||
// - a rounding bias is added before dividing by 256
|
// - a rounding bias is added before dividing by 256
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
// ---------------------------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------------------------
|
||||||
// GC graphics pipeline
|
// GC graphics pipeline
|
||||||
// ---------------------------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------------------------
|
||||||
// 3d commands are issued through the fifo. The gpu draws to the 2MB EFB.
|
// 3d commands are issued through the fifo. The GPU draws to the 2MB EFB.
|
||||||
// The efb can be copied back into ram in two forms: as textures or as XFB.
|
// The efb can be copied back into ram in two forms: as textures or as XFB.
|
||||||
// The XFB is the region in RAM that the VI chip scans out to the television.
|
// The XFB is the region in RAM that the VI chip scans out to the television.
|
||||||
// So, after all rendering to EFB is done, the image is copied into one of two XFBs in RAM.
|
// So, after all rendering to EFB is done, the image is copied into one of two XFBs in RAM.
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
// ---------------------------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------------------------
|
||||||
// GC graphics pipeline
|
// GC graphics pipeline
|
||||||
// ---------------------------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------------------------
|
||||||
// 3d commands are issued through the fifo. The gpu draws to the 2MB EFB.
|
// 3d commands are issued through the fifo. The GPU draws to the 2MB EFB.
|
||||||
// The efb can be copied back into ram in two forms: as textures or as XFB.
|
// The efb can be copied back into ram in two forms: as textures or as XFB.
|
||||||
// The XFB is the region in RAM that the VI chip scans out to the television.
|
// The XFB is the region in RAM that the VI chip scans out to the television.
|
||||||
// So, after all rendering to EFB is done, the image is copied into one of two XFBs in RAM.
|
// So, after all rendering to EFB is done, the image is copied into one of two XFBs in RAM.
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
// DSPCR bits
|
// DSPCR bits
|
||||||
#define DSPCR_DSPRESET 0x0800 // Reset DSP
|
#define DSPCR_DSPRESET 0x0800 // Reset DSP
|
||||||
#define DSPCR_ARDMA 0x0200 // ARAM dma in progress, if set
|
#define DSPCR_ARDMA 0x0200 // ARAM DMA in progress, if set
|
||||||
#define DSPCR_DSPINTMSK 0x0100 // * interrupt mask (RW)
|
#define DSPCR_DSPINTMSK 0x0100 // * interrupt mask (RW)
|
||||||
#define DSPCR_DSPINT 0x0080 // * interrupt active (RWC)
|
#define DSPCR_DSPINT 0x0080 // * interrupt active (RWC)
|
||||||
#define DSPCR_ARINTMSK 0x0040
|
#define DSPCR_ARINTMSK 0x0040
|
||||||
|
@ -35,12 +35,12 @@ clr15
|
|||||||
;step 1: context setup
|
;step 1: context setup
|
||||||
call send_back_40
|
call send_back_40
|
||||||
|
|
||||||
call 0x807e ; loop until dsp->cpu mailbox is empty
|
call 0x807e ; loop until DSP->CPU mailbox is empty
|
||||||
si @DMBH, #0xdcd1
|
si @DMBH, #0xdcd1
|
||||||
si @DMBL, #0x0000 ; sendmail 0xdcd10000
|
si @DMBL, #0x0000 ; sendmail 0xdcd10000
|
||||||
si @DIRQ, #0x0001
|
si @DIRQ, #0x0001
|
||||||
|
|
||||||
; wait for cpu mail == 0xabbaxxxx
|
; wait for CPU mail == 0xabbaxxxx
|
||||||
wait_cpu_init:
|
wait_cpu_init:
|
||||||
call 0x8078
|
call 0x8078
|
||||||
lrs $AC0.L, @CMBL
|
lrs $AC0.L, @CMBL
|
||||||
@ -53,28 +53,28 @@ call 0x8078
|
|||||||
lrs $AX0.L, @CMBL
|
lrs $AX0.L, @CMBL
|
||||||
andi $AC0.M, #0x0fff
|
andi $AC0.M, #0x0fff
|
||||||
mrr $AX0.H, $AC0.M
|
mrr $AX0.H, $AC0.M
|
||||||
lri $AX1.H, #0x0000 ; DSP-dram addr
|
lri $AX1.H, #0x0000 ; DSP-DRAM addr
|
||||||
lri $AX1.L, #0x0020 ; length (32 bytes = 16 words, word 9 and 10 are addr where result should DMA'd to in main mem)
|
lri $AX1.L, #0x0020 ; length (32 bytes = 16 words, word 9 and 10 are addr where result should DMA'd to in main mem)
|
||||||
lri $IX3, #0x0000 ; there will be no ucode/iram upload
|
lri $IX3, #0x0000 ; there will be no ucode/iram upload
|
||||||
lri $AR0, #do_main ; return addr after dram upload
|
lri $AR0, #do_main ; return addr after DRAM upload
|
||||||
jmp 0x80bc ; DRAM upload !!
|
jmp 0x80bc ; DRAM upload !!
|
||||||
; $AX0.H-$AX0.L - CPU(PPC) addr = mail & 0x0fffffff
|
; $AX0.H-$AX0.L - CPU(PPC) addr = mail & 0x0fffffff
|
||||||
; upload data from mainmem to dsp dram and jump to 0x41 after that
|
; upload data from mainmem to DSP DRAM and jump to 0x41 after that
|
||||||
|
|
||||||
; ucode addr 0x0041
|
; ucode addr 0x0041
|
||||||
do_main:
|
do_main:
|
||||||
;step 2: got data from cpu, before going into BigCrazyFunction
|
;step 2: got data from CPU, before going into BigCrazyFunction
|
||||||
call send_back
|
call send_back
|
||||||
|
|
||||||
call BigCrazyFunction ; <<------------- main crap is here!!!!!!!!!
|
call BigCrazyFunction ; <<------------- main crap is here!!!!!!!!!
|
||||||
call 0x807e ; loop until dsp->cpu mailbox is empty
|
call 0x807e ; loop until DSP->CPU mailbox is empty
|
||||||
|
|
||||||
si @DMBH, #0xdcd1
|
si @DMBH, #0xdcd1
|
||||||
si @DMBL, #0x0003 ; sendmail 0xdcd10003 (aka... calc is over, result is in main mem now)
|
si @DMBL, #0x0003 ; sendmail 0xdcd10003 (aka... calc is over, result is in main mem now)
|
||||||
si @DIRQ, #0x0001
|
si @DIRQ, #0x0001
|
||||||
set40
|
set40
|
||||||
|
|
||||||
; wait for cpu to tell us what to do after calc'ing
|
; wait for CPU to tell us what to do after calc'ing
|
||||||
wait_cpu_end:
|
wait_cpu_end:
|
||||||
call 0x8078
|
call 0x8078
|
||||||
cmpi $AC0.M, #0xcdd1
|
cmpi $AC0.M, #0xcdd1
|
||||||
@ -82,16 +82,16 @@ jnz wait_cpu_end
|
|||||||
|
|
||||||
lrs $AC0.M, @CMBL
|
lrs $AC0.M, @CMBL
|
||||||
cmpi $AC0.M, #0x0001
|
cmpi $AC0.M, #0x0001
|
||||||
jz PrepareBootUcode ; if cpu->dsp mail was 0xcdd10001 -> 005e_PrepareBootUcode()
|
jz PrepareBootUcode ; if CPU->DSP mail was 0xcdd10001 -> 005e_PrepareBootUcode()
|
||||||
|
|
||||||
cmpi $AC0.M, #0x0002
|
cmpi $AC0.M, #0x0002
|
||||||
jz 0x8000 ; if cpu->dsp mail was 0xcdd10002 -> dsp reset ( jmp to irom(0x8000))
|
jz 0x8000 ; if CPU->DSP mail was 0xcdd10002 -> DSP reset ( jmp to irom(0x8000))
|
||||||
|
|
||||||
; THIS IS CUSTOM CODE
|
; THIS IS CUSTOM CODE
|
||||||
cmpi $AC0.M, #0xbabe
|
cmpi $AC0.M, #0xbabe
|
||||||
jz end_of_test ; wait for dsp to be reset by cpu
|
jz end_of_test ; wait for DSP to be reset by CPU
|
||||||
|
|
||||||
jmp wait_cpu_end ; wait for next mail from cpu
|
jmp wait_cpu_end ; wait for next mail from CPU
|
||||||
halt
|
halt
|
||||||
|
|
||||||
|
|
||||||
@ -127,7 +127,7 @@ jmp 0x80b5 ; BootUcode()
|
|||||||
halt
|
halt
|
||||||
|
|
||||||
|
|
||||||
; does some crazy stuff with data at dram @0x3/0x5/0x6/0x7 with help of some values from drom :)
|
; does some crazy stuff with data at DRAM @0x3/0x5/0x6/0x7 with help of some values from drom :)
|
||||||
; result is @0x22,@0x23 and written back to main memory to dmem-0x08:dmem-0x09
|
; result is @0x22,@0x23 and written back to main memory to dmem-0x08:dmem-0x09
|
||||||
BigCrazyFunction:
|
BigCrazyFunction:
|
||||||
; {
|
; {
|
||||||
@ -574,21 +574,21 @@ call send_back
|
|||||||
|
|
||||||
Unk_01a5:
|
Unk_01a5:
|
||||||
; this is where result is written to main memory
|
; this is where result is written to main memory
|
||||||
; dsp mem 0x20-0x23 (8 bytes) are written back (DMA limitation),
|
; DSP mem 0x20-0x23 (8 bytes) are written back (DMA limitation),
|
||||||
; but only values @22 and @23 were modified (result is 32bit)
|
; but only values @22 and @23 were modified (result is 32bit)
|
||||||
sr @0x0023, $AC0.M
|
sr @0x0023, $AC0.M
|
||||||
call send_back
|
call send_back
|
||||||
lr $AX0.H, @0x0008 ; cpu addr high
|
lr $AX0.H, @0x0008 ; CPU addr high
|
||||||
call send_back
|
call send_back
|
||||||
lr $AX0.L, @0x0009 ; cpu addr low
|
lr $AX0.L, @0x0009 ; CPU addr low
|
||||||
call send_back
|
call send_back
|
||||||
lri $AX1.H, #0x0020 ; dsp addr
|
lri $AX1.H, #0x0020 ; DSP addr
|
||||||
call send_back
|
call send_back
|
||||||
lri $AX1.L, #0x0008 ; length
|
lri $AX1.L, #0x0008 ; length
|
||||||
call send_back
|
call send_back
|
||||||
lri $IX3, #0x0000 ; there will be no iram dma
|
lri $IX3, #0x0000 ; there will be no iram DMA
|
||||||
call send_back
|
call send_back
|
||||||
call 0x808b ; dram->cpu <<<--- important!!
|
call 0x808b ; DRAM->CPU <<<--- important!!
|
||||||
call send_back
|
call send_back
|
||||||
ret
|
ret
|
||||||
; }
|
; }
|
||||||
|
@ -353,7 +353,7 @@ void handle_dsp_mail(void)
|
|||||||
}
|
}
|
||||||
else if (mail == 0x8888dead)
|
else if (mail == 0x8888dead)
|
||||||
{
|
{
|
||||||
// Send memory dump (dsp dram from someone's cube?)
|
// Send memory dump (DSP DRAM from someone's GameCube?)
|
||||||
// not really sure why this is important - I guess just to try to keep tests predictable
|
// not really sure why this is important - I guess just to try to keep tests predictable
|
||||||
u16* tmpBuf = (u16 *)MEM_VIRTUAL_TO_PHYSICAL(mem_dump);
|
u16* tmpBuf = (u16 *)MEM_VIRTUAL_TO_PHYSICAL(mem_dump);
|
||||||
|
|
||||||
@ -363,7 +363,7 @@ void handle_dsp_mail(void)
|
|||||||
}
|
}
|
||||||
else if (mail == 0x8888beef)
|
else if (mail == 0x8888beef)
|
||||||
{
|
{
|
||||||
// Provide register base to dsp (if using dsp_base.inc, it will dma them to the correct place)
|
// Provide register base to DSP (if using dsp_base.inc, it will DMA them to the correct place)
|
||||||
while (real_dsp.CheckMailTo());
|
while (real_dsp.CheckMailTo());
|
||||||
real_dsp.SendMailTo((u32)dspbufP);
|
real_dsp.SendMailTo((u32)dspbufP);
|
||||||
while (real_dsp.CheckMailTo());
|
while (real_dsp.CheckMailTo());
|
||||||
@ -385,14 +385,14 @@ void handle_dsp_mail(void)
|
|||||||
// ROM dumping mails
|
// ROM dumping mails
|
||||||
else if (mail == 0x8888c0de)
|
else if (mail == 0x8888c0de)
|
||||||
{
|
{
|
||||||
// DSP has copied irom to its dram...send address so it can dma it back
|
// DSP has copied irom to its DRAM...send address so it can dma it back
|
||||||
while (real_dsp.CheckMailTo());
|
while (real_dsp.CheckMailTo());
|
||||||
real_dsp.SendMailTo((u32)dspbufP);
|
real_dsp.SendMailTo((u32)dspbufP);
|
||||||
while (real_dsp.CheckMailTo());
|
while (real_dsp.CheckMailTo());
|
||||||
}
|
}
|
||||||
else if (mail == 0x8888da7a)
|
else if (mail == 0x8888da7a)
|
||||||
{
|
{
|
||||||
// DSP has copied coef to its dram...send address so it can dma it back
|
// DSP has copied coef to its DRAM...send address so it can DMA it back
|
||||||
while (real_dsp.CheckMailTo());
|
while (real_dsp.CheckMailTo());
|
||||||
real_dsp.SendMailTo((u32)&dspbufP[0x1000]);
|
real_dsp.SendMailTo((u32)&dspbufP[0x1000]);
|
||||||
while (real_dsp.CheckMailTo());
|
while (real_dsp.CheckMailTo());
|
||||||
@ -415,7 +415,7 @@ void handle_dsp_mail(void)
|
|||||||
}
|
}
|
||||||
else if (mail == 0xdcd10003) // DSP_DONE
|
else if (mail == 0xdcd10003) // DSP_DONE
|
||||||
{
|
{
|
||||||
real_dsp.SendMailTo(0xcdd1babe); // custom mail to tell dsp to halt (calls end_of_test)
|
real_dsp.SendMailTo(0xcdd1babe); // custom mail to tell DSP to halt (calls end_of_test)
|
||||||
while (real_dsp.CheckMailTo());
|
while (real_dsp.CheckMailTo());
|
||||||
|
|
||||||
DCInvalidateRange(SecParams_out, sizeof(SecParams_out));
|
DCInvalidateRange(SecParams_out, sizeof(SecParams_out));
|
||||||
@ -525,7 +525,7 @@ void InitGeneral()
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Obtain the preferred video mode from the system
|
// Obtain the preferred video mode from the system
|
||||||
// This will correspond to the settings in the Wii menu
|
// This will correspond to the settings in the Wii Menu
|
||||||
rmode = VIDEO_GetPreferredMode(nullptr);
|
rmode = VIDEO_GetPreferredMode(nullptr);
|
||||||
|
|
||||||
// Allocate memory for the display in the uncached region
|
// Allocate memory for the display in the uncached region
|
||||||
|
@ -70,7 +70,7 @@
|
|||||||
// This numeral indicates the "minimum system required" to run the resulting
|
// This numeral indicates the "minimum system required" to run the resulting
|
||||||
// program. Dolphin targets Vista+, so it should be 0x0600. However in practice,
|
// program. Dolphin targets Vista+, so it should be 0x0600. However in practice,
|
||||||
// _WIN32_WINNT just removes up-level API declarations from headers. This is a
|
// _WIN32_WINNT just removes up-level API declarations from headers. This is a
|
||||||
// problem for XAudio2 and XInput, where dolphin expects to compile against the
|
// problem for XAudio2 and XInput, where Dolphin expects to compile against the
|
||||||
// Win8+ versions of their headers. So while we really need Vista+ level of
|
// Win8+ versions of their headers. So while we really need Vista+ level of
|
||||||
// support, we declare Win8+ here globally. If this becomes a problem, the
|
// support, we declare Win8+ here globally. If this becomes a problem, the
|
||||||
// higher declaration can be contained to just the XAudio2/XInput related code.
|
// higher declaration can be contained to just the XAudio2/XInput related code.
|
||||||
@ -78,7 +78,7 @@
|
|||||||
|
|
||||||
// Exclude rarely-used stuff from Windows headers
|
// Exclude rarely-used stuff from Windows headers
|
||||||
#define WIN32_LEAN_AND_MEAN
|
#define WIN32_LEAN_AND_MEAN
|
||||||
// Don't include windows min/max definitions. They would conflict with the STL.
|
// Don't include Windows min/max definitions. They would conflict with the STL.
|
||||||
#define NOMINMAX
|
#define NOMINMAX
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user