From 32d3d1fbe5677a5b682e9f46f2f7f78f76d6208f Mon Sep 17 00:00:00 2001 From: Nekotekina Date: Thu, 2 Jul 2015 04:54:36 +0300 Subject: [PATCH] EXCEPTION() macro usage, sceNpTrophy improved --- Utilities/Thread.cpp | 8 +- Utilities/rPlatform.cpp | 2 +- Utilities/rTime.cpp | 2 +- rpcs3/Emu/ARMv7/ARMv7Decoder.cpp | 8 +- rpcs3/Emu/ARMv7/ARMv7Interpreter.cpp | 136 +++--- rpcs3/Emu/ARMv7/ARMv7Thread.cpp | 2 +- rpcs3/Emu/ARMv7/Modules/sceLibc.cpp | 2 +- rpcs3/Emu/ARMv7/Modules/scePerf.cpp | 5 +- rpcs3/Emu/ARMv7/PSVFuncList.cpp | 4 +- rpcs3/Emu/ARMv7/PSVObjectList.h | 5 - rpcs3/Emu/CPU/CPUThread.h | 2 +- rpcs3/Emu/Cell/PPUInterpreter.h | 30 +- rpcs3/Emu/Cell/PPUThread.cpp | 4 +- rpcs3/Emu/Cell/PPUThread.h | 2 +- rpcs3/Emu/Cell/SPURecompiler.h | 22 +- rpcs3/Emu/Cell/SPURecompilerCore.cpp | 22 +- rpcs3/Emu/Cell/SPUThread.cpp | 2 +- rpcs3/Emu/Cell/SPUThread.h | 3 +- rpcs3/Emu/IdManager.h | 10 - rpcs3/Emu/Memory/vm.cpp | 43 +- rpcs3/Emu/Memory/vm.h | 51 ++- rpcs3/Emu/RSX/RSXThread.cpp | 10 +- rpcs3/Emu/SysCalls/LogBase.cpp | 52 +-- rpcs3/Emu/SysCalls/LogBase.h | 16 - rpcs3/Emu/SysCalls/Modules.cpp | 16 +- rpcs3/Emu/SysCalls/Modules/cellAudio.cpp | 18 +- rpcs3/Emu/SysCalls/Modules/cellSpurs.cpp | 86 ++-- rpcs3/Emu/SysCalls/Modules/sceNp.h | 43 +- rpcs3/Emu/SysCalls/Modules/sceNpTrophy.cpp | 446 +++++++++---------- rpcs3/Emu/SysCalls/Modules/sceNpTrophy.h | 16 +- rpcs3/Emu/SysCalls/Modules/sysPrxForUser.cpp | 12 +- rpcs3/Emu/SysCalls/lv2/sys_lwcond.cpp | 6 - 32 files changed, 477 insertions(+), 609 deletions(-) diff --git a/Utilities/Thread.cpp b/Utilities/Thread.cpp index cfd6980f29..8010fd7b56 100644 --- a/Utilities/Thread.cpp +++ b/Utilities/Thread.cpp @@ -1097,7 +1097,7 @@ void _se_translator(unsigned int u, EXCEPTION_POINTERS* pExp) if (u == EXCEPTION_ACCESS_VIOLATION && (u32)addr64 == addr64) { - throw fmt::format("Access violation %s location 0x%llx", is_writing ? "writing" : "reading", addr64); + throw EXCEPTION("Access violation %s location 0x%llx", is_writing ? "writing" : "reading", addr64); } } @@ -1146,7 +1146,7 @@ void signal_handler(int sig, siginfo_t* info, void* uct) } // TODO: this may be wrong - throw fmt::format("Access violation %s location 0x%llx", is_writing ? "writing" : "reading", addr64); + throw EXCEPTION("Access violation %s location 0x%llx", is_writing ? "writing" : "reading", addr64); } // else some fatal error @@ -1297,11 +1297,11 @@ void thread_t::start(std::function name, std::function fu func(); } - catch (const char* e) + catch (const char* e) // obsolete { error(e); } - catch (const std::string& e) + catch (const std::string& e) // obsolete { error(e.c_str()); } diff --git a/Utilities/rPlatform.cpp b/Utilities/rPlatform.cpp index 63eae5d141..ba1bee9455 100644 --- a/Utilities/rPlatform.cpp +++ b/Utilities/rPlatform.cpp @@ -35,7 +35,7 @@ void rImage::SaveFile(const std::string& name, rImageType type) } else { - throw std::string("unsupported type"); + throw EXCEPTION("unsupported type"); } } diff --git a/Utilities/rTime.cpp b/Utilities/rTime.cpp index 58f607d1e3..9687141302 100644 --- a/Utilities/rTime.cpp +++ b/Utilities/rTime.cpp @@ -133,7 +133,7 @@ wxDateTime::TimeZone convertTZ(rDateTime::rTimeZone tz) case rDateTime::UTC: return wxDateTime::UTC; default: - throw std::string("WRONG DATETIME"); + throw EXCEPTION("WRONG DATETIME"); } } diff --git a/rpcs3/Emu/ARMv7/ARMv7Decoder.cpp b/rpcs3/Emu/ARMv7/ARMv7Decoder.cpp index aa0a4398fe..bf73953e2e 100644 --- a/rpcs3/Emu/ARMv7/ARMv7Decoder.cpp +++ b/rpcs3/Emu/ARMv7/ARMv7Decoder.cpp @@ -1183,7 +1183,7 @@ struct ARMv7_op4t_table_t } } - throw "HACK instruction not found"; + throw EXCEPTION("HACK instruction not found"); } } g_op4t; @@ -1221,6 +1221,8 @@ void armv7_decoder_initialize(u32 addr, u32 end_addr, bool dump) //g_opct.clear(); //g_opct.reserve(end_addr - addr); + const auto hack = g_op4t.HACK(); + while (addr < end_addr) { ARMv7Code code = {}; @@ -1288,7 +1290,7 @@ void armv7_decoder_initialize(u32 addr, u32 end_addr, bool dump) // replace BLX with "HACK" instruction directly (in Thumb form), it can help to see where it was called from const u32 index = (instr & 0xfff00) >> 4 | (instr & 0xf); vm::psv::write32(addr, 0xf870 | index << 16); - g_opct[0xf8700000 | index] = g_op4t.HACK(); + g_opct[0xf8700000 | index] = hack; } else { @@ -1355,7 +1357,7 @@ u32 ARMv7Decoder::DecodeMemory(const u32 address) } else { - throw "ARMv7Decoder::DecodeMemory() failed (invalid instruction set set)"; + throw EXCEPTION("Invalid instruction set"); } ARMv7_instrs::UNK(m_ctx, code); diff --git a/rpcs3/Emu/ARMv7/ARMv7Interpreter.cpp b/rpcs3/Emu/ARMv7/ARMv7Interpreter.cpp index 7f02b66f94..4a3300fe85 100644 --- a/rpcs3/Emu/ARMv7/ARMv7Interpreter.cpp +++ b/rpcs3/Emu/ARMv7/ARMv7Interpreter.cpp @@ -108,7 +108,7 @@ namespace ARMv7_instrs u32 LSL_C(u32 x, s32 shift, bool& carry_out) { assert(shift > 0); - carry_out = shift <= 32 ? x & (1 << (32 - shift)) : false; + carry_out = shift <= 32 ? (x & (1 << (32 - shift))) != 0 : false; return shift < 32 ? x << shift : 0; } @@ -121,7 +121,7 @@ namespace ARMv7_instrs u32 LSR_C(u32 x, s32 shift, bool& carry_out) { assert(shift > 0); - carry_out = shift <= 32 ? x & (1 << (shift - 1)) : false; + carry_out = shift <= 32 ? (x & (1 << (shift - 1))) != 0 : false; return shift < 32 ? x >> shift : 0; } @@ -134,7 +134,7 @@ namespace ARMv7_instrs s32 ASR_C(s32 x, s32 shift, bool& carry_out) { assert(shift > 0); - carry_out = shift <= 32 ? x & (1 << (shift - 1)) : x < 0; + carry_out = shift <= 32 ? (x & (1 << (shift - 1))) != 0 : x < 0; return shift < 32 ? x >> shift : x >> 31; } @@ -148,7 +148,7 @@ namespace ARMv7_instrs { assert(shift); const u32 result = x >> shift | x << (32 - shift); - carry_out = result >> 31; + carry_out = (result >> 31) != 0; return result; } @@ -200,8 +200,8 @@ namespace ARMv7_instrs const T sign_mask = (T)1 << (sizeof(T) * 8 - 1); T result = x + y; - carry_out = ((x & y) | ((x ^ y) & ~result)) & sign_mask; - overflow = (x ^ result) & (y ^ result) & sign_mask; + carry_out = (((x & y) | ((x ^ y) & ~result)) & sign_mask) != 0; + overflow = ((x ^ result) & (y ^ result) & sign_mask) != 0; if (carry_in) { result += 1; @@ -283,7 +283,7 @@ namespace ARMv7_instrs { if (found->second != context.debug_str) { - throw context.debug_str; + throw EXCEPTION("Disasm inconsistency: '%s' != '%s'", found->second.c_str(), context.debug_str.c_str()); } } else @@ -487,11 +487,11 @@ void ARMv7_instrs::UNK(ARMv7Context& context, const ARMv7Code code) { if (context.ISET == Thumb) { - throw fmt::format("Unknown/illegal opcode: 0x%04X 0x%04X", code.code1, code.code0); + throw EXCEPTION("Unknown/illegal opcode: 0x%04X 0x%04X", code.code1, code.code0); } else { - throw fmt::format("Unknown/illegal opcode: 0x%08X", code.data); + throw EXCEPTION("Unknown/illegal opcode: 0x%08X", code.data); } } @@ -613,7 +613,7 @@ void ARMv7_instrs::ADC_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff)); reject(d == 13 || d == 15 || n == 13 || n == 15, "UNPREDICTABLE"); @@ -667,7 +667,7 @@ void ARMv7_instrs::ADC_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 13 || d == 15 || n == 13 || n == 15 || m == 13 || m == 15, "UNPREDICTABLE"); @@ -737,7 +737,7 @@ void ARMv7_instrs::ADD_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff)); reject(d == 15 && set_flags, "CMN (immediate)"); @@ -821,7 +821,7 @@ void ARMv7_instrs::ADD_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 15 && set_flags, "CMN (register)"); @@ -892,7 +892,7 @@ void ARMv7_instrs::ADD_SPI(ARMv7Context& context, const ARMv7Code code, const AR { cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff)); reject(d == 15 && set_flags, "CMN (immediate)"); @@ -968,7 +968,7 @@ void ARMv7_instrs::ADD_SPR(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 13 && (shift_t != SRType_LSL || shift_n > 3), "UNPREDICTABLE"); @@ -1070,7 +1070,7 @@ void ARMv7_instrs::AND_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm_C((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff), carry, carry); reject(d == 15 && set_flags, "TST (immediate)"); @@ -1123,7 +1123,7 @@ void ARMv7_instrs::AND_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 15 && set_flags, "TST (register)"); @@ -1289,7 +1289,7 @@ void ARMv7_instrs::BIC_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm_C((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff), carry, carry); reject(d == 13 || d == 15 || n == 13 || n == 15, "UNPREDICTABLE"); @@ -1341,7 +1341,7 @@ void ARMv7_instrs::BIC_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 13 || d == 15 || n == 13 || n == 15 || m == 13 || m == 15, "UNPREDICTABLE"); @@ -1556,7 +1556,7 @@ void ARMv7_instrs::CB_Z(ARMv7Context& context, const ARMv7Code code, const ARMv7 { n = code.data & 0x7; imm32 = (code.data & 0xf8) >> 2 | (code.data & 0x200) >> 3; - nonzero = (code.data & 0x800); + nonzero = (code.data & 0x800) != 0; reject(context.ITSTATE, "UNPREDICTABLE"); break; @@ -1797,7 +1797,7 @@ void ARMv7_instrs::EOR_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm_C((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff), carry, carry); reject(d == 15 && set_flags, "TEQ (immediate)"); @@ -1850,7 +1850,7 @@ void ARMv7_instrs::EOR_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 15 && set_flags, "TEQ (register)"); @@ -1943,7 +1943,7 @@ void ARMv7_instrs::LDM(ARMv7Context& context, const ARMv7Code code, const ARMv7_ cond = context.ITSTATE.advance(); n = (code.data & 0xf0000) >> 16; reg_list = (code.data & 0xdfff); - wback = (code.data & 0x200000); + wback = (code.data & 0x200000) != 0; reject(wback && n == 13, "POP"); reject(n == 15 || BitCount(reg_list, 16) < 2 || reg_list >= 0xc000, "UNPREDICTABLE"); @@ -2057,9 +2057,9 @@ void ARMv7_instrs::LDR_IMM(ARMv7Context& context, const ARMv7Code code, const AR t = (code.data & 0xf000) >> 12; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff); - index = (code.data & 0x400); - add = (code.data & 0x200); - wback = (code.data & 0x100); + index = (code.data & 0x400) != 0; + add = (code.data & 0x200) != 0; + wback = (code.data & 0x100) != 0; reject(n == 15, "LDR (literal)"); reject(index && add && !wback, "LDRT"); @@ -2111,7 +2111,7 @@ void ARMv7_instrs::LDR_LIT(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); t = (code.data & 0xf000) >> 12; imm32 = (code.data & 0xfff); - add = (code.data & 0x800000); + add = (code.data & 0x800000) != 0; reject(t == 15 && context.ITSTATE, "UNPREDICTABLE"); break; @@ -2237,9 +2237,9 @@ void ARMv7_instrs::LDRB_IMM(ARMv7Context& context, const ARMv7Code code, const A t = (code.data & 0xf000) >> 12; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff); - index = (code.data & 0x400); - add = (code.data & 0x200); - wback = (code.data & 0x100); + index = (code.data & 0x400) != 0; + add = (code.data & 0x200) != 0; + wback = (code.data & 0x100) != 0; reject(t == 15 && index && !add && !wback, "PLD"); reject(n == 15, "LDRB (literal)"); @@ -2356,9 +2356,9 @@ void ARMv7_instrs::LDRD_IMM(ARMv7Context& context, const ARMv7Code code, const A t2 = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff) << 2; - index = (code.data & 0x1000000); - add = (code.data & 0x800000); - wback = (code.data & 0x200000); + index = (code.data & 0x1000000) != 0; + add = (code.data & 0x800000) != 0; + wback = (code.data & 0x200000) != 0; reject(!index && !wback, "Related encodings"); reject(n == 15, "LDRD (literal)"); @@ -2404,7 +2404,7 @@ void ARMv7_instrs::LDRD_LIT(ARMv7Context& context, const ARMv7Code code, const A t = (code.data & 0xf000) >> 12; t2 = (code.data & 0xf00) >> 8; imm32 = (code.data & 0xff) << 2; - add = (code.data & 0x800000); + add = (code.data & 0x800000) != 0; reject(!(code.data & 0x1000000), "Related encodings"); // ??? reject(t == 13 || t == 15 || t2 == 13 || t2 == 15 || t == t2, "UNPREDICTABLE"); @@ -2480,9 +2480,9 @@ void ARMv7_instrs::LDRH_IMM(ARMv7Context& context, const ARMv7Code code, const A t = (code.data & 0xf000) >> 12; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff); - index = (code.data & 0x400); - add = (code.data & 0x200); - wback = (code.data & 0x100); + index = (code.data & 0x400) != 0; + add = (code.data & 0x200) != 0; + wback = (code.data & 0x100) != 0; reject(n == 15, "LDRH (literal)"); reject(t == 15 && index && !add && !wback, "Unallocated memory hints"); @@ -2561,9 +2561,9 @@ void ARMv7_instrs::LDRSB_IMM(ARMv7Context& context, const ARMv7Code code, const t = (code.data & 0xf000) >> 12; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff); - index = (code.data & 0x400); - add = (code.data & 0x200); - wback = (code.data & 0x100); + index = (code.data & 0x400) != 0; + add = (code.data & 0x200) != 0; + wback = (code.data & 0x100) != 0; reject(t == 15 && index && !add && !wback, "PLI"); reject(n == 15, "LDRSB (literal)"); @@ -2730,7 +2730,7 @@ void ARMv7_instrs::LSL_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; DecodeImmShift(0, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(!shift_n, "MOV (register)"); @@ -2782,7 +2782,7 @@ void ARMv7_instrs::LSL_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; reject(d == 13 || d == 15 || n == 13 || n == 15 || m == 13 || m == 15, "UNPREDICTABLE"); break; @@ -2833,7 +2833,7 @@ void ARMv7_instrs::LSR_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; DecodeImmShift(1, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 13 || d == 15 || m == 13 || m == 15, "UNPREDICTABLE"); @@ -2911,7 +2911,7 @@ void ARMv7_instrs::MOV_IMM(ARMv7Context& context, const ARMv7Code code, const AR case T2: { cond = context.ITSTATE.advance(); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; d = (code.data >> 8) & 0xf; imm32 = ThumbExpandImm_C((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff), carry, carry); @@ -2990,7 +2990,7 @@ void ARMv7_instrs::MOV_REG(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; reject((d == 13 || m == 13 || m == 15) && set_flags, "UNPREDICTABLE"); reject((d == 13 && (m == 13 || m == 15)) || d == 15, "UNPREDICTABLE"); @@ -3144,7 +3144,7 @@ void ARMv7_instrs::MVN_IMM(ARMv7Context& context, const ARMv7Code code, const AR { cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm_C((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff), context.APSR.C, carry); reject(d == 13 || d == 15, "UNPREDICTABLE"); @@ -3195,7 +3195,7 @@ void ARMv7_instrs::MVN_REG(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 13 || d == 15 || m == 13 || m == 15, "UNPREDICTABLE"); @@ -3304,7 +3304,7 @@ void ARMv7_instrs::ORR_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm_C((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff), carry, carry); reject(n == 15, "MOV (immediate)"); @@ -3357,7 +3357,7 @@ void ARMv7_instrs::ORR_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(n == 15, "ROR (immediate)"); @@ -3725,7 +3725,7 @@ void ARMv7_instrs::ROR_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; const u32 shift_t = DecodeImmShift(3, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(shift_t == SRType_RRX, "RRX"); @@ -3777,7 +3777,7 @@ void ARMv7_instrs::ROR_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; reject(d == 13 || d == 15 || n == 13 || n == 15 || m == 13 || m == 15, "UNPREDICTABLE"); break; @@ -3839,7 +3839,7 @@ void ARMv7_instrs::RSB_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff)); reject(d == 13 || d == 15 || n == 13 || n == 15, "UNPREDICTABLE"); @@ -4272,7 +4272,7 @@ void ARMv7_instrs::STM(ARMv7Context& context, const ARMv7Code code, const ARMv7_ cond = context.ITSTATE.advance(); n = (code.data & 0xf0000) >> 16; reg_list = (code.data & 0x5fff); - wback = (code.data & 0x200000); + wback = (code.data & 0x200000) != 0; reject(n == 15 || BitCount(reg_list, 16) < 2, "UNPREDICTABLE"); reject(wback && reg_list & (1 << n), "UNPREDICTABLE"); @@ -4384,9 +4384,9 @@ void ARMv7_instrs::STR_IMM(ARMv7Context& context, const ARMv7Code code, const AR t = (code.data & 0xf000) >> 12; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff); - index = (code.data & 0x400); - add = (code.data & 0x200); - wback = (code.data & 0x100); + index = (code.data & 0x400) != 0; + add = (code.data & 0x200) != 0; + wback = (code.data & 0x100) != 0; reject(index && add && !wback, "STRT"); reject(n == 13 && index && !add && wback && imm32 == 4, "PUSH"); @@ -4516,9 +4516,9 @@ void ARMv7_instrs::STRB_IMM(ARMv7Context& context, const ARMv7Code code, const A t = (code.data & 0xf000) >> 12; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff); - index = (code.data & 0x400); - add = (code.data & 0x200); - wback = (code.data & 0x100); + index = (code.data & 0x400) != 0; + add = (code.data & 0x200) != 0; + wback = (code.data & 0x100) != 0; reject(index && add && !wback, "STRBT"); reject(n == 15 || (!index && !wback), "UNDEFINED"); @@ -4623,9 +4623,9 @@ void ARMv7_instrs::STRD_IMM(ARMv7Context& context, const ARMv7Code code, const A t2 = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff) << 2; - index = (code.data & 0x1000000); - add = (code.data & 0x800000); - wback = (code.data & 0x200000); + index = (code.data & 0x1000000) != 0; + add = (code.data & 0x800000) != 0; + wback = (code.data & 0x200000) != 0; reject(!index && !wback, "Related encodings"); reject(wback && (n == t || n == t2), "UNPREDICTABLE"); @@ -4704,9 +4704,9 @@ void ARMv7_instrs::STRH_IMM(ARMv7Context& context, const ARMv7Code code, const A t = (code.data & 0xf000) >> 12; n = (code.data & 0xf0000) >> 16; imm32 = (code.data & 0xff); - index = (code.data & 0x400); - add = (code.data & 0x200); - wback = (code.data & 0x100); + index = (code.data & 0x400) != 0; + add = (code.data & 0x200) != 0; + wback = (code.data & 0x100) != 0; reject(index && add && !wback, "STRHT"); reject(n == 15 || (!index && !wback), "UNDEFINED"); @@ -4888,7 +4888,7 @@ void ARMv7_instrs::SUB_IMM(ARMv7Context& context, const ARMv7Code code, const AR cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff)); reject(d == 15 && set_flags, "CMP (immediate)"); @@ -4958,7 +4958,7 @@ void ARMv7_instrs::SUB_REG(ARMv7Context& context, const ARMv7Code code, const AR d = (code.data & 0xf00) >> 8; n = (code.data & 0xf0000) >> 16; m = (code.data & 0xf); - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; shift_t = DecodeImmShift((code.data & 0x30) >> 4, (code.data & 0x7000) >> 10 | (code.data & 0xc0) >> 6, &shift_n); reject(d == 15 && set_flags, "CMP (register)"); @@ -5021,7 +5021,7 @@ void ARMv7_instrs::SUB_SPI(ARMv7Context& context, const ARMv7Code code, const AR { cond = context.ITSTATE.advance(); d = (code.data & 0xf00) >> 8; - set_flags = (code.data & 0x100000); + set_flags = (code.data & 0x100000) != 0; imm32 = ThumbExpandImm((code.data & 0x4000000) >> 15 | (code.data & 0x7000) >> 4 | (code.data & 0xff)); reject(d == 15 && set_flags, "CMP (immediate)"); diff --git a/rpcs3/Emu/ARMv7/ARMv7Thread.cpp b/rpcs3/Emu/ARMv7/ARMv7Thread.cpp index 6452fc464c..e757ff0301 100644 --- a/rpcs3/Emu/ARMv7/ARMv7Thread.cpp +++ b/rpcs3/Emu/ARMv7/ARMv7Thread.cpp @@ -60,7 +60,7 @@ u32 armv7_get_tls(u32 thread) } } - throw "Out of TLS memory"; + throw EXCEPTION("Out of TLS memory"); } void armv7_free_tls(u32 thread) diff --git a/rpcs3/Emu/ARMv7/Modules/sceLibc.cpp b/rpcs3/Emu/ARMv7/Modules/sceLibc.cpp index 324cd03c00..3e43def544 100644 --- a/rpcs3/Emu/ARMv7/Modules/sceLibc.cpp +++ b/rpcs3/Emu/ARMv7/Modules/sceLibc.cpp @@ -137,7 +137,7 @@ std::string armv7_fmt(ARMv7Context& context, vm::cptr fmt, u32 g_count, u3 } } - throw fmt::format("armv7_fmt(): unknown formatting: '%s'", start.get_ptr()); + throw EXCEPTION("Unknown formatting '%s'", start.get_ptr()); } } diff --git a/rpcs3/Emu/ARMv7/Modules/scePerf.cpp b/rpcs3/Emu/ARMv7/Modules/scePerf.cpp index cc6641efeb..9a5c2614f0 100644 --- a/rpcs3/Emu/ARMv7/Modules/scePerf.cpp +++ b/rpcs3/Emu/ARMv7/Modules/scePerf.cpp @@ -60,7 +60,10 @@ s32 scePerfArmPmonSelectEvent(ARMv7Context& context, s32 threadId, u32 counter, break; } - default: throw "scePerfArmPmonSelectEvent(): unknown event requested"; + default: + { + throw EXCEPTION("Unknown event requested"); + } } context.counters[counter].event = eventCode; diff --git a/rpcs3/Emu/ARMv7/PSVFuncList.cpp b/rpcs3/Emu/ARMv7/PSVFuncList.cpp index d42040bba8..0296e11714 100644 --- a/rpcs3/Emu/ARMv7/PSVFuncList.cpp +++ b/rpcs3/Emu/ARMv7/PSVFuncList.cpp @@ -79,7 +79,7 @@ void execute_psv_func_by_index(ARMv7Context& context, u32 index) } else { - throw "Unimplemented function"; + throw EXCEPTION("Unimplemented function"); } // rough error code processing @@ -92,7 +92,7 @@ void execute_psv_func_by_index(ARMv7Context& context, u32 index) } else { - throw "Invalid function index"; + throw EXCEPTION("Invalid function index"); } } diff --git a/rpcs3/Emu/ARMv7/PSVObjectList.h b/rpcs3/Emu/ARMv7/PSVObjectList.h index 3cf33b0b30..cb15c6f173 100644 --- a/rpcs3/Emu/ARMv7/PSVObjectList.h +++ b/rpcs3/Emu/ARMv7/PSVObjectList.h @@ -28,11 +28,6 @@ class psv_object_list_t // Class for managing object data std::atomic m_hint; // guessing next free position std::mutex m_mutex; - void error(s32 uid) - { - throw fmt::format("Invalid UID requested (type=0x%x, uid=0x%x)", uid_class, uid); - } - public: psv_object_list_t() : m_hint(0) diff --git a/rpcs3/Emu/CPU/CPUThread.h b/rpcs3/Emu/CPU/CPUThread.h index 94202fb4ab..5fb64486bd 100644 --- a/rpcs3/Emu/CPU/CPUThread.h +++ b/rpcs3/Emu/CPU/CPUThread.h @@ -199,7 +199,7 @@ public: //u64 join() //{ // if (!joinable()) - // throw "thread must be joinable for join"; + // throw EXCEPTION("thread must be joinable for join"); // thread->SetJoinable(false); diff --git a/rpcs3/Emu/Cell/PPUInterpreter.h b/rpcs3/Emu/Cell/PPUInterpreter.h index 5b5fb408b6..3f50008275 100644 --- a/rpcs3/Emu/Cell/PPUInterpreter.h +++ b/rpcs3/Emu/Cell/PPUInterpreter.h @@ -109,7 +109,7 @@ private: void NULL_OP() { - throw "Null operation"; + throw EXCEPTION("Null operation"); } void NOP() @@ -173,7 +173,7 @@ private: case 0x117: return CPU.SPRG[n - 0x110]; } - throw fmt::Format("ReadSPR(0x%x) error: unknown SPR (0x%x)", spr, n); + throw EXCEPTION("Unknown SPR (spr=0x%x, n=0x%x)", spr, n); } void WriteSPR(u32 spr, u64 value) @@ -186,10 +186,10 @@ private: case 0x008: CPU.LR = value; return; case 0x009: CPU.CTR = value; return; case 0x100: CPU.VRSAVE = (u32)value; return; - case 0x103: throw fmt::Format("WriteSPR(0x103, 0x%llx): Write to read-only SPR", value); + case 0x103: throw EXCEPTION("WriteSPR(0x103, 0x%llx): Write to read-only SPR", value); - case 0x10C: throw fmt::Format("WriteSPR(0x10C, 0x%llx): Write to time-based SPR", value); - case 0x10D: throw fmt::Format("WriteSPR(0x10D, 0x%llx): Write to time-based SPR", value); + case 0x10C: throw EXCEPTION("WriteSPR(0x10C, 0x%llx): Write to time-based SPR", value); + case 0x10D: throw EXCEPTION("WriteSPR(0x10D, 0x%llx): Write to time-based SPR", value); case 0x110: case 0x111: @@ -201,7 +201,7 @@ private: case 0x117: CPU.SPRG[n - 0x110] = value; return; } - throw fmt::Format("WriteSPR(0x%x, 0x%llx) error: unknown SPR (0x%x)", spr, value, n); + throw EXCEPTION("Unknown SPR (spr=0x%x, n=0x%x, value=0x%llx)", spr, n, value); } void TDI(u32 to, u32 ra, s32 simm16) @@ -214,7 +214,7 @@ private: ((u64)a < (u64)simm16 && (to & 0x2)) || ((u64)a > (u64)simm16 && (to & 0x1)) ) { - throw fmt::Format("Trap! (tdi 0x%x, r%d, 0x%x)", to, ra, simm16); + throw EXCEPTION("Trap! (tdi 0x%x, r%d, 0x%x)", to, ra, simm16); } } @@ -228,7 +228,7 @@ private: ((u32)a < (u32)simm16 && (to & 0x2)) || ((u32)a > (u32)simm16 && (to & 0x1)) ) { - throw fmt::Format("Trap! (twi 0x%x, r%d, 0x%x)", to, ra, simm16); + throw EXCEPTION("Trap! (twi 0x%x, r%d, 0x%x)", to, ra, simm16); } } @@ -2239,9 +2239,9 @@ private: switch (lev) { case 0x0: SysCalls::DoSyscall(CPU, CPU.GPR[11]); break; - case 0x1: throw "SC(): HyperCall LV1"; + case 0x1: throw EXCEPTION("HyperCall LV1"); case 0x3: CPU.FastStop(); break; - default: throw fmt::Format("SC(): unknown level (0x%x)", lev); + default: throw EXCEPTION("Unknown level (0x%x)", lev); } } void B(s32 ll, u32 aa, u32 lk) @@ -2405,7 +2405,7 @@ private: ((u32)a < (u32)b && (to & 0x2)) || ((u32)a > (u32)b && (to & 0x1)) ) { - throw fmt::Format("Trap! (tw 0x%x, r%d, r%d)", to, ra, rb); + throw EXCEPTION("Trap! (tw 0x%x, r%d, r%d)", to, ra, rb); } } void LVSL(u32 vd, u32 ra, u32 rb) @@ -2608,7 +2608,7 @@ private: } void TD(u32 to, u32 ra, u32 rb) { - throw "TD()"; + throw EXCEPTION(""); } void LVEWX(u32 vd, u32 ra, u32 rb) { @@ -2661,8 +2661,6 @@ private: } void LBZUX(u32 rd, u32 ra, u32 rb) { - //if(ra == 0 || ra == rd) throw "Bad instruction [LBZUX]"; - const u64 addr = CPU.GPR[ra] + CPU.GPR[rb]; CPU.GPR[rd] = vm::read8(vm::cast(addr)); CPU.GPR[ra] = addr; @@ -2930,7 +2928,7 @@ private: { case 0x10C: CPU.GPR[rd] = CPU.TB; break; case 0x10D: CPU.GPR[rd] = CPU.TB >> 32; break; - default: throw fmt::Format("mftb r%d, %d", rd, spr); + default: throw EXCEPTION("mftb r%d, %d", rd, spr); } } void LWAUX(u32 rd, u32 ra, u32 rb) @@ -4403,6 +4401,6 @@ private: void UNK(const u32 code, const u32 opcode, const u32 gcode) { - throw fmt::Format("Unknown/Illegal opcode! (0x%08x : 0x%x : 0x%x)", code, opcode, gcode); + throw EXCEPTION("Unknown/Illegal opcode! (0x%08x : 0x%x : 0x%x)", code, opcode, gcode); } }; diff --git a/rpcs3/Emu/Cell/PPUThread.cpp b/rpcs3/Emu/Cell/PPUThread.cpp index ce050847a8..6a26b9cda8 100644 --- a/rpcs3/Emu/Cell/PPUThread.cpp +++ b/rpcs3/Emu/Cell/PPUThread.cpp @@ -509,12 +509,12 @@ void PPUThread::DumpInformation() const { if (hle_code < 0) { - LOG_SUCCESS(HLE, "Information: syscall %lld (%s)", ~hle_code, SysCalls::GetFuncName(hle_code)); + LOG_SUCCESS(HLE, "Last function: syscall %lld (%s)", ~hle_code, SysCalls::GetFuncName(hle_code)); } if (hle_code > 0) { - LOG_SUCCESS(HLE, "Information: function 0x%llx (%s)", hle_code, SysCalls::GetFuncName(hle_code)); + LOG_SUCCESS(HLE, "Last function: %s (0x%llx)", SysCalls::GetFuncName(hle_code), hle_code); } CPUThread::DumpInformation(); diff --git a/rpcs3/Emu/Cell/PPUThread.h b/rpcs3/Emu/Cell/PPUThread.h index 673f4eed84..6204e799a3 100644 --- a/rpcs3/Emu/Cell/PPUThread.h +++ b/rpcs3/Emu/Cell/PPUThread.h @@ -363,7 +363,7 @@ struct PPCdouble case _FPCLASS_PD: return FPR_PD; case _FPCLASS_PN: return FPR_PN; case _FPCLASS_PINF: return FPR_PINF; - default: throw fmt::Format("PPCdouble::UpdateType() -> unknown fpclass (0x%04x).", fpc); + default: throw EXCEPTION("Unknown fpclass (0x%04x)", fpc); } #else switch (fpc) diff --git a/rpcs3/Emu/Cell/SPURecompiler.h b/rpcs3/Emu/Cell/SPURecompiler.h index 57b79757f5..3780519975 100644 --- a/rpcs3/Emu/Cell/SPURecompiler.h +++ b/rpcs3/Emu/Cell/SPURecompiler.h @@ -69,26 +69,16 @@ public: struct XmmLink { - asmjit::X86XmmVar* data; - s8 reg; - bool taken; - mutable bool got; - mutable u32 access; - - XmmLink() - : data(nullptr) - , reg(-1) - , taken(false) - , got(false) - , access(0) - { - } + asmjit::X86XmmVar* data = nullptr; + s8 reg = -1; + bool taken = false; + mutable bool got = false; + mutable u32 access = 0; const asmjit::X86XmmVar& get() const { assert(data); - assert(taken); - if (!taken) throw "XmmLink::get(): wrong use"; + if (!taken) throw EXCEPTION("Register not taken"); got = true; return *data; } diff --git a/rpcs3/Emu/Cell/SPURecompilerCore.cpp b/rpcs3/Emu/Cell/SPURecompilerCore.cpp index 81dcd379ae..15f2a2c400 100644 --- a/rpcs3/Emu/Cell/SPURecompilerCore.cpp +++ b/rpcs3/Emu/Cell/SPURecompilerCore.cpp @@ -303,6 +303,7 @@ const SPURecompiler::XmmLink& SPURecompiler::XmmAlloc(s8 pref) // get empty xmm return xmm_var[i]; } } + for (u32 i = 0; i < 16; i++) { if ((xmm_var[i].reg == -1) && !xmm_var[i].taken) @@ -314,6 +315,7 @@ const SPURecompiler::XmmLink& SPURecompiler::XmmAlloc(s8 pref) // get empty xmm return xmm_var[i]; } } + int last = -1, max = -1; for (u32 i = 0; i < 16; i++) { @@ -326,6 +328,7 @@ const SPURecompiler::XmmLink& SPURecompiler::XmmAlloc(s8 pref) // get empty xmm } } } + if (last >= 0) { // (saving cached data?) @@ -337,7 +340,8 @@ const SPURecompiler::XmmLink& SPURecompiler::XmmAlloc(s8 pref) // get empty xmm xmm_var[last].access = 0; return xmm_var[last]; } - throw "XmmAlloc() failed"; + + throw EXCEPTION("Failure"); } const SPURecompiler::XmmLink* SPURecompiler::XmmRead(const s8 reg) const // get xmm register with specific SPU reg or nullptr @@ -348,7 +352,7 @@ const SPURecompiler::XmmLink* SPURecompiler::XmmRead(const s8 reg) const // get if (xmm_var[i].reg == reg) { //assert(!xmm_var[i].got); - //if (xmm_var[i].got) throw "XmmRead(): wrong reuse"; + //if (xmm_var[i].got) throw EXCEPTION("Wrong reuse"); LOG4_OPCODE("GPR[%d] has been read (i=%d)", reg, i); xmm_var[i].access++; return &xmm_var[i]; @@ -369,13 +373,13 @@ const SPURecompiler::XmmLink& SPURecompiler::XmmGet(s8 reg, s8 target) // get xm if (xmm_var[i].reg == reg) { res = &xmm_var[i]; - if (xmm_var[i].taken) throw "XmmGet(): xmm_var is taken"; + if (xmm_var[i].taken) throw EXCEPTION("xmm_var is taken"); xmm_var[i].taken = true; xmm_var[i].got = false; //xmm_var[i].reg = -1; for (u32 j = i + 1; j < 16; j++) { - if (xmm_var[j].reg == reg) throw "XmmGet(): xmm_var duplicate"; + if (xmm_var[j].reg == reg) throw EXCEPTION("xmm_var duplicate"); } LOG4_OPCODE("cached GPR[%d] used (i=%d)", reg, i); break; @@ -422,7 +426,7 @@ void SPURecompiler::XmmInvalidate(const s8 reg) // invalidate cached register { if (xmm_var[i].reg == reg) { - if (xmm_var[i].taken) throw "XmmInvalidate(): xmm_var is taken"; + if (xmm_var[i].taken) throw EXCEPTION("xmm_var is taken"); LOG4_OPCODE("GPR[%d] invalidated (i=%d)", reg, i); xmm_var[i].reg = -1; xmm_var[i].access = 0; @@ -3324,10 +3328,6 @@ void SPURecompiler::FMA(u32 rt, u32 ra, u32 rb, u32 rc) XmmFinalize(va, rt); XmmFinalize(vc); } - else - { - throw "FMA: invalid case"; // should never happen - } LOG_OPCODE(); } @@ -3410,10 +3410,6 @@ void SPURecompiler::FMS(u32 rt, u32 ra, u32 rb, u32 rc) XmmFinalize(va, rt); XmmFinalize(vc); } - else - { - throw "FMS: invalid case"; // should never happen - } LOG_OPCODE(); } diff --git a/rpcs3/Emu/Cell/SPUThread.cpp b/rpcs3/Emu/Cell/SPUThread.cpp index c81432a022..a660c4c58f 100644 --- a/rpcs3/Emu/Cell/SPUThread.cpp +++ b/rpcs3/Emu/Cell/SPUThread.cpp @@ -1184,7 +1184,7 @@ void SPUThread::halt() } status |= SPU_STATUS_STOPPED_BY_HALT; - throw "HALT"; + throw EXCEPTION("Halt"); } spu_thread::spu_thread(u32 entry, const std::string& name, u32 stack_size, u32 prio) diff --git a/rpcs3/Emu/Cell/SPUThread.h b/rpcs3/Emu/Cell/SPUThread.h index fd22ec111a..f6be10300a 100644 --- a/rpcs3/Emu/Cell/SPUThread.h +++ b/rpcs3/Emu/Cell/SPUThread.h @@ -452,8 +452,7 @@ public: return this->_u32[3] >> 10 & 0x3; default: - throw fmt::Format("Unexpected slice value in FPSCR::checkSliceRounding(): %d", slice); - return 0; + throw EXCEPTION("Unexpected slice value (%d)", slice); } } diff --git a/rpcs3/Emu/IdManager.h b/rpcs3/Emu/IdManager.h index f0050d3df5..3783f2f513 100644 --- a/rpcs3/Emu/IdManager.h +++ b/rpcs3/Emu/IdManager.h @@ -91,16 +91,6 @@ public: m_id_map.clear(); m_cur_id = 1; // first ID } - - //// add new ID using existing std::shared_ptr (not recommended, use make() instead) - //template u32 add(std::shared_ptr data, u32 type = ID_type::type) - //{ - // std::lock_guard lock(m_mutex); - - // m_id_map.emplace(m_cur_id, ID_data_t(std::move(data), type)); - - // return m_cur_id++; - //} // add new ID of specified type with specified constructor arguments (returns object) template::value>> std::shared_ptr make_ptr(Args&&... args) diff --git a/rpcs3/Emu/Memory/vm.cpp b/rpcs3/Emu/Memory/vm.cpp index 3e71b537b9..8624ef5c40 100644 --- a/rpcs3/Emu/Memory/vm.cpp +++ b/rpcs3/Emu/Memory/vm.cpp @@ -147,7 +147,7 @@ namespace vm if (mprotect(vm::get_ptr(addr & ~0xfff), 4096, no_access ? PROT_NONE : PROT_READ)) #endif { - throw fmt::format("vm::_reservation_set() failed (addr=0x%x)", addr); + throw EXCEPTION("System failure (addr=0x%x)", addr); } //LOG_NOTICE(MEMORY, "VirtualProtect: %f us", (get_time() - stamp0) / 80.f); @@ -166,7 +166,7 @@ namespace vm if (mprotect(vm::get_ptr(addr & ~0xfff), 4096, PROT_READ | PROT_WRITE)) #endif { - throw fmt::format("vm::_reservation_break() failed (addr=0x%x)", addr); + throw EXCEPTION("System failure (addr=0x%x)", addr); } //LOG_NOTICE(MEMORY, "VirtualAlloc: %f us", (get_time() - stamp0) / 80.f); @@ -209,7 +209,7 @@ namespace vm u8 flags = g_page_info[addr >> 12].load(); if (!(flags & page_writable) || !(flags & page_allocated) || (flags & page_no_reservations)) { - throw fmt::format("vm::reservation_acquire(addr=0x%x, size=0x%x) failed (invalid page flags: 0x%x)", addr, size, flags); + throw EXCEPTION("Invalid page flags (addr=0x%x, size=0x%x, flags=0x%x)", addr, size, flags); } // silent unlocking to prevent priority boost for threads going to break reservation @@ -355,7 +355,7 @@ namespace vm { if (g_page_info[i].load()) { - throw fmt::format("vm::page_map(addr=0x%x, size=0x%x, flags=0x%x) failed (already mapped at 0x%x)", addr, size, flags, i * 4096); + throw EXCEPTION("Memory already mapped (addr=0x%x, size=0x%x, flags=0x%x, current_addr=0x%x)", addr, size, flags, i * 4096); } } @@ -370,14 +370,14 @@ namespace vm if (mprotect(priv_addr, size, PROT_READ | PROT_WRITE) || mprotect(real_addr, size, protection)) #endif { - throw fmt::format("vm::page_map(addr=0x%x, size=0x%x, flags=0x%x) failed (API)", addr, size, flags); + throw EXCEPTION("System failure (addr=0x%x, size=0x%x, flags=0x%x)", addr, size, flags); } for (u32 i = addr / 4096; i < addr / 4096 + size / 4096; i++) { if (g_page_info[i].exchange(flags | page_allocated)) { - throw fmt::format("vm::page_map(addr=0x%x, size=0x%x, flags=0x%x) failed (concurrent access at 0x%x)", addr, size, flags, i * 4096); + throw EXCEPTION("Concurrent access (addr=0x%x, size=0x%x, flags=0x%x, current_addr=0x%x)", addr, size, flags, i * 4096); } } @@ -429,7 +429,7 @@ namespace vm if (mprotect(real_addr, 4096, protection)) #endif { - throw fmt::format("vm::page_protect(addr=0x%x, size=0x%x, flags_test=0x%x, flags_set=0x%x, flags_clear=0x%x) failed (API)", addr, size, flags_test, flags_set, flags_clear); + throw EXCEPTION("System failure (addr=0x%x, size=0x%x, flags_test=0x%x, flags_set=0x%x, flags_clear=0x%x)", addr, size, flags_test, flags_set, flags_clear); } } } @@ -447,7 +447,7 @@ namespace vm { if (!(g_page_info[i].load() & page_allocated)) { - throw fmt::format("vm::page_unmap(addr=0x%x, size=0x%x) failed (not mapped at 0x%x)", addr, size, i * 4096); + throw EXCEPTION("Memory not mapped (addr=0x%x, size=0x%x, current_addr=0x%x)", addr, size, i * 4096); } } @@ -457,7 +457,7 @@ namespace vm if (!(g_page_info[i].exchange(0) & page_allocated)) { - throw fmt::format("vm::page_unmap(addr=0x%x, size=0x%x) failed (concurrent access at 0x%x)", addr, size, i * 4096); + throw EXCEPTION("Concurrent access (addr=0x%x, size=0x%x, current_addr=0x%x)", addr, size, i * 4096); } } @@ -472,7 +472,7 @@ namespace vm if (mprotect(real_addr, size, PROT_NONE) || mprotect(priv_addr, size, PROT_NONE)) #endif { - throw fmt::format("vm::page_unmap(addr=0x%x, size=0x%x) failed (API)", addr, size); + throw EXCEPTION("System failure (addr=0x%x, size=0x%x)", addr, size); } } @@ -524,29 +524,6 @@ namespace vm return g_locations[location].deallocator(addr); } - u32 get_addr(const void* real_pointer) - { - const u64 diff = (u64)real_pointer - (u64)g_base_addr; - const u32 res = (u32)diff; - - if (res == diff) - { - return res; - } - - if (real_pointer) - { - throw fmt::format("vm::get_addr(0x%016llx) failed: not a part of virtual memory", (u64)real_pointer); - } - - return 0; - } - - void error(const u64 addr, const char* func) - { - throw fmt::format("%s(): failed to cast 0x%llx (too big value)", func, addr); - } - namespace ps3 { u32 main_alloc(u32 size) diff --git a/rpcs3/Emu/Memory/vm.h b/rpcs3/Emu/Memory/vm.h index a95c8f53b7..66b8d1c956 100644 --- a/rpcs3/Emu/Memory/vm.h +++ b/rpcs3/Emu/Memory/vm.h @@ -64,36 +64,45 @@ namespace vm u32 alloc(u32 addr, u32 size, memory_location location = user_space); void dealloc(u32 addr, memory_location location = user_space); - template - T* get_ptr(u32 addr) + template T* get_ptr(u32 addr) { return reinterpret_cast(static_cast(g_base_addr) + addr); } - template - T& get_ref(u32 addr) + template T& get_ref(u32 addr) { return *get_ptr(addr); } - template - T* priv_ptr(u32 addr) + template T* priv_ptr(u32 addr) { return reinterpret_cast(static_cast(g_priv_addr) + addr); } - template - T& priv_ref(u32 addr) + template T& priv_ref(u32 addr) { return *priv_ptr(addr); } - u32 get_addr(const void* real_pointer); + inline u32 get_addr(const void* real_pointer) + { + const uintptr_t diff = reinterpret_cast(real_pointer) - reinterpret_cast(g_base_addr); + const u32 res = static_cast(diff); - never_inline void error(const u64 addr, const char* func); + if (res == diff) + { + return res; + } - template - struct cast_ptr + if (real_pointer) + { + throw EXCEPTION("Not a virtual memory pointer (%p)", real_pointer); + } + + return 0; + } + + template struct cast_ptr { static_assert(std::is_same::value, "Unsupported vm::cast() type"); @@ -103,8 +112,7 @@ namespace vm } }; - template<> - struct cast_ptr + template<> struct cast_ptr { force_inline static u32 cast(const u32 addr, const char* func) { @@ -112,23 +120,22 @@ namespace vm } }; - template<> - struct cast_ptr + template<> struct cast_ptr { force_inline static u32 cast(const u64 addr, const char* func) { const u32 res = static_cast(addr); + if (res != addr) { - vm::error(addr, func); + throw EXCEPTION("%s(): failed to cast 0x%llx (too big value)", func, addr); } return res; } }; - template - struct cast_ptr> + template struct cast_ptr> { force_inline static u32 cast(const be_t& addr, const char* func) { @@ -136,8 +143,7 @@ namespace vm } }; - template - struct cast_ptr> + template struct cast_ptr> { force_inline static u32 cast(const le_t& addr, const char* func) { @@ -145,8 +151,7 @@ namespace vm } }; - template - force_inline static u32 cast(const T& addr, const char* func = "vm::cast") + template force_inline static u32 cast(const T& addr, const char* func = "vm::cast") { return cast_ptr::cast(addr, func); } diff --git a/rpcs3/Emu/RSX/RSXThread.cpp b/rpcs3/Emu/RSX/RSXThread.cpp index 7f05def8a7..1e9558acc4 100644 --- a/rpcs3/Emu/RSX/RSXThread.cpp +++ b/rpcs3/Emu/RSX/RSXThread.cpp @@ -39,7 +39,7 @@ u32 GetAddress(u32 offset, u32 location) res = (u32)Memory.RSXIOMem.RealAddr(offset); // TODO: Error Check? if (res == 0) { - throw fmt::format("GetAddress(offset=0x%x, location=0x%x): RSXIO memory not mapped", offset, location); + throw EXCEPTION("RSXIO memory not mapped (offset=0x%x)", offset); } if (Emu.GetGSManager().GetRender().m_strict_ordering[offset >> 20]) @@ -51,7 +51,7 @@ u32 GetAddress(u32 offset, u32 location) } default: { - throw fmt::format("GetAddress(offset=0x%x, location=0x%x): invalid location", offset, location); + throw EXCEPTION("Invalid location (offset=0x%x, location=0x%x)", offset, location); } } @@ -2594,10 +2594,12 @@ void RSXThread::Init(const u32 ioAddress, const u32 ioSize, const u32 ctrlAddres u32 RSXThread::ReadIO32(u32 addr) { u32 value; + if (!Memory.RSXIOMem.Read32(addr, &value)) { - throw fmt::Format("%s(addr=0x%x): RSXIO memory not mapped", __FUNCTION__, addr); + throw EXCEPTION("RSXIO memory not mapped (addr=0x%x)", addr); } + return value; } @@ -2605,6 +2607,6 @@ void RSXThread::WriteIO32(u32 addr, u32 value) { if (!Memory.RSXIOMem.Write32(addr, value)) { - throw fmt::Format("%s(addr=0x%x): RSXIO memory not mapped", __FUNCTION__, addr); + throw EXCEPTION("RSXIO memory not mapped (addr=0x%x)", addr); } } diff --git a/rpcs3/Emu/SysCalls/LogBase.cpp b/rpcs3/Emu/SysCalls/LogBase.cpp index 651e131eea..fb70d09dcd 100644 --- a/rpcs3/Emu/SysCalls/LogBase.cpp +++ b/rpcs3/Emu/SysCalls/LogBase.cpp @@ -18,56 +18,6 @@ void LogBase::LogOutput(LogType type, const std::string& text) const case LogWarning: LOG_WARNING(HLE, GetName() + ": " + text); break; case LogError: LOG_ERROR(HLE, GetName() + " error: " + text); break; case LogTodo: LOG_ERROR(HLE, GetName() + " TODO: " + text); break; - case LogFatal: throw GetName() + " error: " + text; - } -} - -hle::error::error(s32 errorCode, const char* errorText) - : code(errorCode) - , base(nullptr) - , text(errorText ? errorText : "") -{ -} - -hle::error::error(s32 errorCode, const LogBase& errorBase, const char* errorText) - : code(errorCode) - , base(&errorBase) - , text(errorText ? errorText : "") -{ -} - -hle::error::error(s32 errorCode, const LogBase* errorBase, const char* errorText) - : code(errorCode) - , base(errorBase) - , text(errorText ? errorText : "") -{ -} - -void hle::error::print(const char* func) -{ - if (!text.empty()) - { - if (base) - { - if (func) - { - base->Error("%s(): %s (0x%x)", func, text.c_str(), code); - } - else - { - base->Error("%s (0x%x)", text.c_str(), code); - } - } - else - { - if (func) - { - LOG_ERROR(HLE, "%s(): %s (0x%x)", func, text.c_str(), code); - } - else - { - LOG_ERROR(HLE, "%s (0x%x)", text.c_str(), code); - } - } + case LogFatal: throw EXCEPTION("%s error: %s", GetName().c_str(), text.c_str()); } } diff --git a/rpcs3/Emu/SysCalls/LogBase.h b/rpcs3/Emu/SysCalls/LogBase.h index 4acdc0d11b..d2332957e1 100644 --- a/rpcs3/Emu/SysCalls/LogBase.h +++ b/rpcs3/Emu/SysCalls/LogBase.h @@ -73,19 +73,3 @@ public: LogPrepare(LogTodo, fmt, fmt::do_unveil(args)...); } }; - -namespace hle -{ - struct error - { - const s32 code; - const LogBase* const base; - const std::string text; - - error(s32 errorCode, const char* errorText = nullptr); - error(s32 errorCode, const LogBase& base, const char* errorText = nullptr); - error(s32 errorCode, const LogBase* base, const char* errorText = nullptr); - - void print(const char* func = nullptr); - }; -} diff --git a/rpcs3/Emu/SysCalls/Modules.cpp b/rpcs3/Emu/SysCalls/Modules.cpp index d8c88254a8..77eee42239 100644 --- a/rpcs3/Emu/SysCalls/Modules.cpp +++ b/rpcs3/Emu/SysCalls/Modules.cpp @@ -119,31 +119,27 @@ void execute_ppu_func_by_index(PPUThread& CPU, u32 index) if (last_code) { - CPU.hle_code = func->id; - throw "Unfortunately, this function cannot be called from the callback."; + throw EXCEPTION("This function cannot be called from the callback: %s (0x%llx)", SysCalls::GetFuncName(func->id), func->id); } if (!func->lle_func) { - CPU.hle_code = func->id; - throw "Wrong usage: LLE function not set."; + throw EXCEPTION("LLE function not set: %s (0x%llx)", SysCalls::GetFuncName(func->id), func->id); } if (func->flags & MFF_FORCED_HLE) { - CPU.hle_code = func->id; - throw "Wrong usage: Forced HLE enabled."; + throw EXCEPTION("Forced HLE enabled: %s (0x%llx)", SysCalls::GetFuncName(func->id), func->id); } if (Ini.HLELogging.GetValue()) { - LOG_NOTICE(HLE, "Branch to LLE function: %s", SysCalls::GetFuncName(func->id)); + LOG_NOTICE(HLE, "Branch to LLE function: %s (0x%llx)", SysCalls::GetFuncName(func->id), func->id); } if (index & EIF_PERFORM_BLR) { - CPU.hle_code = func->id; - throw EXCEPTION("TODO: Branch with link (%s)", SysCalls::GetFuncName(func->id)); + throw EXCEPTION("TODO: Branch with link: %s (0x%llx)", SysCalls::GetFuncName(func->id), func->id); // CPU.LR = CPU.PC + 4; } @@ -207,7 +203,7 @@ void execute_ppu_func_by_index(PPUThread& CPU, u32 index) } else { - throw "Invalid function index"; + throw EXCEPTION("Invalid function index (0x%x)", index); } } diff --git a/rpcs3/Emu/SysCalls/Modules/cellAudio.cpp b/rpcs3/Emu/SysCalls/Modules/cellAudio.cpp index 76578bb0e3..a118b5a576 100644 --- a/rpcs3/Emu/SysCalls/Modules/cellAudio.cpp +++ b/rpcs3/Emu/SysCalls/Modules/cellAudio.cpp @@ -64,7 +64,7 @@ s32 cellAudioInit() AudioDumper m_dump; if (do_dump && !m_dump.Init(2)) // Init AudioDumper for 2 channels { - throw "AudioDumper::Init() failed"; + throw EXCEPTION("AudioDumper::Init() failed"); } float buf2ch[2 * BUFFER_SIZE]; // intermediate buffer for 2 channels @@ -335,7 +335,7 @@ s32 cellAudioInit() } else { - throw fmt::format("Unknown channel count (port=%d, channel=%d)", &port - g_audio.ports, port.channel); + throw EXCEPTION("Unknown channel count (port=%lld, channel=%d)", &port - g_audio.ports, port.channel); } memset(buf, 0, block_size * sizeof(float)); @@ -410,19 +410,19 @@ s32 cellAudioInit() { if (m_dump.WriteData(&buf8ch, sizeof(buf8ch)) != sizeof(buf8ch)) // write file data (8 ch) { - throw "AudioDumper::WriteData() failed (8 ch)"; + throw EXCEPTION("AudioDumper::WriteData() failed (8 ch)"); } } else if (m_dump.GetCh() == 2) { if (m_dump.WriteData(&buf2ch, sizeof(buf2ch)) != sizeof(buf2ch)) // write file data (2 ch) { - throw "AudioDumper::WriteData() failed (2 ch)"; + throw EXCEPTION("AudioDumper::WriteData() failed (2 ch)"); } } else { - throw fmt::format("AudioDumper::GetCh() returned unknown value (%d)", m_dump.GetCh()); + throw EXCEPTION("AudioDumper::GetCh() returned unknown value (%d)", m_dump.GetCh()); } } @@ -576,7 +576,7 @@ s32 cellAudioGetPortConfig(u32 portNum, vm::ptr portConfig) case AUDIO_PORT_STATE_CLOSED: portConfig->status = CELL_AUDIO_STATUS_CLOSE; break; case AUDIO_PORT_STATE_OPENED: portConfig->status = CELL_AUDIO_STATUS_READY; break; case AUDIO_PORT_STATE_STARTED: portConfig->status = CELL_AUDIO_STATUS_RUN; break; - default: throw fmt::format("cellAudioGetPortConfig(%d): invalid port state (%d)", portNum, state); + default: throw EXCEPTION("Invalid port state (%d: %d)", portNum, state); } portConfig->nChannel = port.channel; @@ -605,7 +605,7 @@ s32 cellAudioPortStart(u32 portNum) case AUDIO_PORT_STATE_CLOSED: return CELL_AUDIO_ERROR_PORT_NOT_OPEN; case AUDIO_PORT_STATE_STARTED: return CELL_AUDIO_ERROR_PORT_ALREADY_RUN; case AUDIO_PORT_STATE_OPENED: return CELL_OK; - default: throw fmt::format("cellAudioPortStart(%d): invalid port state (%d)", portNum, state); + default: throw EXCEPTION("Invalid port state (%d: %d)", portNum, state); } } @@ -628,7 +628,7 @@ s32 cellAudioPortClose(u32 portNum) case AUDIO_PORT_STATE_CLOSED: return CELL_AUDIO_ERROR_PORT_NOT_OPEN; case AUDIO_PORT_STATE_STARTED: return CELL_OK; case AUDIO_PORT_STATE_OPENED: return CELL_OK; - default: throw fmt::format("cellAudioPortClose(%d): invalid port state (%d)", portNum, state); + default: throw EXCEPTION("Invalid port state (%d: %d)", portNum, state); } } @@ -651,7 +651,7 @@ s32 cellAudioPortStop(u32 portNum) case AUDIO_PORT_STATE_CLOSED: return CELL_AUDIO_ERROR_PORT_NOT_RUN; case AUDIO_PORT_STATE_STARTED: return CELL_OK; case AUDIO_PORT_STATE_OPENED: return CELL_AUDIO_ERROR_PORT_NOT_RUN; - default: throw fmt::format("cellAudioPortStop(%d): invalid port state (%d)", portNum, state); + default: throw EXCEPTION("Invalid port state (%d: %d)", portNum, state); } } diff --git a/rpcs3/Emu/SysCalls/Modules/cellSpurs.cpp b/rpcs3/Emu/SysCalls/Modules/cellSpurs.cpp index 484642bc2b..0d43b0ad69 100644 --- a/rpcs3/Emu/SysCalls/Modules/cellSpurs.cpp +++ b/rpcs3/Emu/SysCalls/Modules/cellSpurs.cpp @@ -38,7 +38,6 @@ bool spursKernelEntry(SPUThread & spu); // // SPURS utility functions // -void spursPpuThreadExit(PPUThread& CPU, u64 errorStatus); u32 spursGetSdkVersion(); bool spursIsLibProfLoaded(); @@ -260,13 +259,6 @@ s32 cellSpursAddUrgentCall(); // SPURS utility functions //---------------------------------------------------------------------------- -/// Terminate a SPURS PPU thread -void spursPpuThreadExit(PPUThread& CPU, u64 errorStatus) -{ - sys_ppu_thread_exit(CPU, errorStatus); - throw SpursModuleExit(); -} - /// Get the version of SDK used by this process u32 spursGetSdkVersion() { @@ -433,7 +425,7 @@ void spursHandlerWaitReady(PPUThread& CPU, vm::ptr spurs) { if (Emu.IsStopped()) { - spursPpuThreadExit(CPU, 0); + sys_ppu_thread_exit(CPU, 0); } if (spurs->handlerExiting.load()) @@ -443,7 +435,7 @@ void spursHandlerWaitReady(PPUThread& CPU, vm::ptr spurs) throw EXCEPTION("sys_lwmutex_unlock() failed (0x%x)", rc); } - spursPpuThreadExit(CPU, 0); + sys_ppu_thread_exit(CPU, 0); } // Find a runnable workload @@ -519,49 +511,43 @@ void spursHandlerEntry(PPUThread& CPU) { auto spurs = vm::ptr::make(vm::cast(CPU.GPR[3])); - try + if (spurs->flags & SAF_UNKNOWN_FLAG_30) { - if (spurs->flags & SAF_UNKNOWN_FLAG_30) - { - spursPpuThreadExit(CPU, 0); - } - - while (true) - { - if (spurs->flags1 & SF1_EXIT_IF_NO_WORK) - { - spursHandlerWaitReady(CPU, spurs); - } - - if (s32 rc = sys_spu_thread_group_start(spurs->spuTG)) - { - throw EXCEPTION("sys_spu_thread_group_start() failed (0x%x)", rc); - } - - if (s32 rc = sys_spu_thread_group_join(spurs->spuTG, vm::null, vm::null)) - { - if (rc == CELL_ESTAT) - { - spursPpuThreadExit(CPU, 0); - } - - throw EXCEPTION("sys_spu_thread_group_join() failed (0x%x)", rc); - } - - if (Emu.IsStopped()) - { - continue; - } - - if ((spurs->flags1 & SF1_EXIT_IF_NO_WORK) == 0) - { - assert(spurs->handlerExiting.load() == 1 || Emu.IsStopped()); - spursPpuThreadExit(CPU, 0); - } - } + sys_ppu_thread_exit(CPU, 0); } - catch(SpursModuleExit) + + while (true) { + if (spurs->flags1 & SF1_EXIT_IF_NO_WORK) + { + spursHandlerWaitReady(CPU, spurs); + } + + if (s32 rc = sys_spu_thread_group_start(spurs->spuTG)) + { + throw EXCEPTION("sys_spu_thread_group_start() failed (0x%x)", rc); + } + + if (s32 rc = sys_spu_thread_group_join(spurs->spuTG, vm::null, vm::null)) + { + if (rc == CELL_ESTAT) + { + sys_ppu_thread_exit(CPU, 0); + } + + throw EXCEPTION("sys_spu_thread_group_join() failed (0x%x)", rc); + } + + if (Emu.IsStopped()) + { + continue; + } + + if ((spurs->flags1 & SF1_EXIT_IF_NO_WORK) == 0) + { + assert(spurs->handlerExiting.load() == 1 || Emu.IsStopped()); + sys_ppu_thread_exit(CPU, 0); + } } } diff --git a/rpcs3/Emu/SysCalls/Modules/sceNp.h b/rpcs3/Emu/SysCalls/Modules/sceNp.h index bbd1f6d323..467cca9f7f 100644 --- a/rpcs3/Emu/SysCalls/Modules/sceNp.h +++ b/rpcs3/Emu/SysCalls/Modules/sceNp.h @@ -99,7 +99,7 @@ enum SCE_NP_COMMUNITY_ERROR_TOO_MANY_SLOTID = 0x8002a1b1, }; -typedef int(*SceNpBasicEventHandler)(s32 event, s32 retCode, u32 reqId, vm::ptr arg); +using SceNpBasicEventHandler = func_def arg)>; // NP Manager Utility statuses enum @@ -692,41 +692,41 @@ enum // NP communication ID structure struct SceNpCommunicationId { - s8 data[9]; - s8 term; + char data[9]; + char term; u8 num; - //s8 dummy; + char dummy; }; // OnlineId structure struct SceNpOnlineId { - s8 data[16]; - s8 term; - //s8 dummy[3]; + char data[16]; + char term; + char dummy[3]; }; // NP ID structure struct SceNpId { SceNpOnlineId handle; - //u8 opt[8]; - //u8 reserved[8]; + u8 opt[8]; + u8 reserved[8]; }; // Online Name structure struct SceNpOnlineName { - s8 data[48]; - s8 term; - s8 padding[3]; + char data[48]; + char term; + char padding[3]; }; // Avatar structure struct SceNpAvatarUrl { - s8 data[127]; - s8 term; + char data[127]; + char term; }; // Avatar image structure @@ -734,14 +734,14 @@ struct SceNpAvatarImage { u8 data[SCE_NET_NP_AVATAR_IMAGE_MAX_SIZE]; be_t size; - //u8 reserved[12]; + u8 reserved[12]; }; // Self introduction structure struct SceNpAboutMe { - s8 data[SCE_NET_NP_ABOUT_ME_MAX_LENGTH]; - s8 term; + char data[SCE_NET_NP_ABOUT_ME_MAX_LENGTH]; + char term; }; // User information structure @@ -752,12 +752,12 @@ struct SceNpUserInfo SceNpAvatarUrl icon; }; -// User information structure (pointer version) +// User information structure struct SceNpUserInfo2 { SceNpId npId; - SceNpOnlineName onlineName; - SceNpAvatarUrl avatarUrl; + vm::bptr onlineName; + vm::bptr avatarUrl; }; // Often used languages structure @@ -784,6 +784,7 @@ struct SceNpCommunicationSignature // NP cache information structure struct SceNpManagerCacheParam { + be_t size; SceNpOnlineId onlineId; SceNpId npId; SceNpOnlineName onlineName; @@ -793,7 +794,7 @@ struct SceNpManagerCacheParam // Message attachment data struct SceNpBasicAttachmentData { - be_t id; + be_t id; // SceNpBasicAttachmentDataId be_t size; }; diff --git a/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.cpp b/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.cpp index 54db810420..27dd0b26bf 100644 --- a/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.cpp +++ b/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.cpp @@ -1,6 +1,7 @@ #include "stdafx.h" #include "Emu/Memory/Memory.h" #include "Emu/System.h" +#include "Emu/IdManager.h" #include "Emu/SysCalls/Modules.h" #include "Emu/SysCalls/CB_FUNC.h" @@ -18,156 +19,157 @@ extern Module sceNpTrophy; // Internal Structs -struct sceNpTrophyInternalContext +struct trophy_context_t { - // TODO + const u32 id; + std::string trp_name; std::unique_ptr trp_stream; - std::unique_ptr tropusr; -// TODO: remove the following code when Visual C++ no longer generates -// compiler errors for it. All of this should be auto-generated -#if defined(_MSC_VER) && _MSC_VER <= 1800 - sceNpTrophyInternalContext() - : trp_stream(), - tropusr() + trophy_context_t() + : id(Emu.GetIdManager().get_current_id()) { } - - sceNpTrophyInternalContext(sceNpTrophyInternalContext&& other) - { - std::swap(trp_stream,other.trp_stream); - std::swap(tropusr, other.tropusr); - std::swap(trp_name, other.trp_name); - } - - sceNpTrophyInternalContext& operator =(sceNpTrophyInternalContext&& other) - { - std::swap(trp_stream, other.trp_stream); - std::swap(tropusr, other.tropusr); - std::swap(trp_name, other.trp_name); - return *this; - } - - sceNpTrophyInternalContext(sceNpTrophyInternalContext& other) = delete; - sceNpTrophyInternalContext& operator =(sceNpTrophyInternalContext& other) = delete; -#endif - }; -struct sceNpTrophyInternal +struct trophy_handle_t { - bool m_bInitialized; - std::vector contexts; + const u32 id; - sceNpTrophyInternal() - : m_bInitialized(false) + trophy_handle_t() + : id(Emu.GetIdManager().get_current_id()) { } }; -sceNpTrophyInternal sceNpTrophyInstance; - -static sceNpTrophyInternalContext& getContext(u32 context) { - // The invalid context is 0, so remap contexts 1... to indices 0... - if (context == 0) - throw "getContext: context == 0"; - return sceNpTrophyInstance.contexts[context - 1]; -} - // Functions -int sceNpTrophyInit(u32 pool_addr, u32 poolSize, u32 containerId, u64 options) +s32 sceNpTrophyInit(vm::ptr pool, u32 poolSize, u32 containerId, u64 options) { - sceNpTrophy.Log("sceNpTrophyInit(pool_addr=0x%x, poolSize=%d, containerId=0x%x, options=0x%llx)", pool_addr, poolSize, containerId, options); - - if (sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_ALREADY_INITIALIZED; - if (options) - return SCE_NP_TROPHY_ERROR_NOT_SUPPORTED; - - sceNpTrophyInstance.m_bInitialized = true; + sceNpTrophy.Warning("sceNpTrophyInit(pool=*0x%x, poolSize=0x%x, containerId=0x%x, options=0x%llx)", pool, poolSize, containerId, options); return CELL_OK; } -int sceNpTrophyCreateContext(vm::ptr context, vm::cptr commID, vm::cptr commSign, u64 options) +s32 sceNpTrophyTerm() { - sceNpTrophy.Warning("sceNpTrophyCreateContext(context=*0x%x, commID=*0x%x, commSign=*0x%x, options=0x%llx)", context, commID, commSign, options); + sceNpTrophy.Warning("sceNpTrophyTerm()"); - if (!sceNpTrophyInstance.m_bInitialized) + return CELL_OK; +} + +s32 sceNpTrophyCreateHandle(vm::ptr handle) +{ + sceNpTrophy.Warning("sceNpTrophyCreateHandle(handle=*0x%x)", handle); + + if (!handle) { - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; + return SCE_NP_TROPHY_ERROR_INVALID_ARGUMENT; } - if (options & ~1) - { - return SCE_NP_TROPHY_ERROR_NOT_SUPPORTED; - } - // TODO: There are other possible errors + *handle = Emu.GetIdManager().make(); - // TODO: Is the TROPHY.TRP file necessarily located in this path? - if (!Emu.GetVFS().ExistsDir("/app_home/../TROPDIR/")) + return CELL_OK; +} + +s32 sceNpTrophyDestroyHandle(u32 handle) +{ + sceNpTrophy.Warning("sceNpTrophyDestroyHandle(handle=0x%x)", handle); + + const auto hndl = Emu.GetIdManager().get(handle); + + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } + + Emu.GetIdManager().remove(handle); + + return CELL_OK; +} + +s32 sceNpTrophyAbortHandle(u32 handle) +{ + sceNpTrophy.Todo("sceNpTrophyAbortHandle(handle=0x%x)", handle); + + const auto hndl = Emu.GetIdManager().get(handle); + + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } + + return CELL_OK; +} + +s32 sceNpTrophyCreateContext(vm::ptr context, vm::cptr commId, vm::cptr commSign, u64 options) +{ + sceNpTrophy.Warning("sceNpTrophyCreateContext(context=*0x%x, commId=*0x%x, commSign=*0x%x, options=0x%llx)", context, commId, commSign, options); + + // rough checks for further fmt::format call + if (commId->term || commId->num > 99) + { + return SCE_NP_TROPHY_ERROR_INVALID_NP_COMM_ID; + } + + // generate trophy context name + std::string name = fmt::format("%s_%02d", commId->data, commId->num); + + // open trophy pack file + std::unique_ptr stream(Emu.GetVFS().OpenFile("/app_home/../TROPDIR/" + name + "/TROPHY.TRP", vfsRead)); + + // check if exists and opened + if (!stream || !stream->IsOpened()) { return SCE_NP_TROPHY_ERROR_CONF_DOES_NOT_EXIST; } - // TODO: Following method will retrieve the TROPHY.TRP of the first folder that contains such file - for (const auto entry : vfsDir("/app_home/../TROPDIR/")) - { - if (entry->flags & DirEntry_TypeDir) - { - vfsStream* stream = Emu.GetVFS().OpenFile("/app_home/../TROPDIR/" + entry->name + "/TROPHY.TRP", vfsRead); + // create trophy context + const auto ctxt = Emu.GetIdManager().make_ptr(); - if (stream && stream->IsOpened()) - { - sceNpTrophyInstance.contexts.emplace_back(); - sceNpTrophyInternalContext& ctxt = sceNpTrophyInstance.contexts.back(); - ctxt.trp_stream.reset(stream); - ctxt.trp_name = entry->name; - stream = nullptr; - *context = sceNpTrophyInstance.contexts.size(); // contexts start from 1 - return CELL_OK; - } - } - } - - return SCE_NP_TROPHY_ERROR_CONF_DOES_NOT_EXIST; -} - -int sceNpTrophyCreateHandle(vm::ptr handle) -{ - sceNpTrophy.Todo("sceNpTrophyCreateHandle(handle_addr=0x%x)", handle.addr()); - - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; - // TODO: There are other possible errors - - // TODO: ? + // set trophy context parameters (could be passed to constructor through make_ptr call) + ctxt->trp_name = std::move(name); + ctxt->trp_stream = std::move(stream); + *context = ctxt->id; return CELL_OK; } -int sceNpTrophyRegisterContext(PPUThread& CPU, u32 context, u32 handle, vm::ptr statusCb, u32 arg_addr, u64 options) +s32 sceNpTrophyDestroyContext(u32 context) { - sceNpTrophy.Warning("sceNpTrophyRegisterContext(context=0x%x, handle=0x%x, statusCb_addr=0x%x, arg_addr=0x%x, options=0x%llx)", - context, handle, statusCb.addr(), arg_addr, options); + sceNpTrophy.Warning("sceNpTrophyDestroyContext(context=0x%x)", context); - if (!(sceNpTrophyInstance.m_bInitialized)) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; - if (options & (~(u64)1)) - return SCE_NP_TROPHY_ERROR_NOT_SUPPORTED; - if (context == 0 || context > sceNpTrophyInstance.contexts.size()) { - sceNpTrophy.Warning("sceNpTrophyRegisterContext: invalid context (%d)", context); + const auto ctxt = Emu.GetIdManager().get(context); + + if (!ctxt) + { return SCE_NP_TROPHY_ERROR_UNKNOWN_CONTEXT; } - // TODO: There are other possible errors - sceNpTrophyInternalContext& ctxt = getContext(context); - if (!ctxt.trp_stream) - return SCE_NP_TROPHY_ERROR_CONF_DOES_NOT_EXIST; + Emu.GetIdManager().remove(context); - TRPLoader trp(*(ctxt.trp_stream)); + return CELL_OK; +} + +s32 sceNpTrophyRegisterContext(PPUThread& CPU, u32 context, u32 handle, vm::ptr statusCb, vm::ptr arg, u64 options) +{ + sceNpTrophy.Error("sceNpTrophyRegisterContext(context=0x%x, handle=0x%x, statusCb=*0x%x, arg=*0x%x, options=0x%llx)", context, handle, statusCb, arg, options); + + const auto ctxt = Emu.GetIdManager().get(context); + + if (!ctxt) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_CONTEXT; + } + + const auto hndl = Emu.GetIdManager().get(handle); + + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } + + TRPLoader trp(*ctxt->trp_stream); if (!trp.LoadHeader()) return SCE_NP_TROPHY_ERROR_ILLEGAL_UPDATE; @@ -191,14 +193,14 @@ int sceNpTrophyRegisterContext(PPUThread& CPU, u32 context, u32 handle, vm::ptr< } // Discard unnecessary TROP_XX.SFM files - for (int i=0; i<=18; i++) { + for (s32 i=0; i<=18; i++) { strcpy_trunc(target, fmt::Format("TROP_%02d.SFM", i)); if (i != Ini.SysLanguage.GetValue()) trp.RemoveEntry(target); } // TODO: Get the path of the current user - std::string trophyPath = "/dev_hdd0/home/00000001/trophy/" + ctxt.trp_name; + std::string trophyPath = "/dev_hdd0/home/00000001/trophy/" + ctxt->trp_name; if (!trp.Install(trophyPath)) return SCE_NP_TROPHY_ERROR_ILLEGAL_UPDATE; @@ -206,79 +208,67 @@ int sceNpTrophyRegisterContext(PPUThread& CPU, u32 context, u32 handle, vm::ptr< std::string trophyUsrPath = trophyPath + "/TROPUSR.DAT"; std::string trophyConfPath = trophyPath + "/TROPCONF.SFM"; tropusr->Load(trophyUsrPath, trophyConfPath); - ctxt.tropusr.reset(tropusr); + ctxt->tropusr.reset(tropusr); // TODO: Callbacks - statusCb(CPU, context, SCE_NP_TROPHY_STATUS_INSTALLED, 100, 100, arg_addr); - statusCb(CPU, context, SCE_NP_TROPHY_STATUS_PROCESSING_COMPLETE, 100, 100, arg_addr); + statusCb(CPU, context, SCE_NP_TROPHY_STATUS_INSTALLED, 100, 100, arg); + statusCb(CPU, context, SCE_NP_TROPHY_STATUS_PROCESSING_COMPLETE, 100, 100, arg); return CELL_OK; } -int sceNpTrophyGetGameProgress() +s32 sceNpTrophyGetRequiredDiskSpace(u32 context, u32 handle, vm::ptr reqspace, u64 options) { - UNIMPLEMENTED_FUNC(sceNpTrophy); - return CELL_OK; -} + sceNpTrophy.Error("sceNpTrophyGetRequiredDiskSpace(context=0x%x, handle=0x%x, reqspace*=0x%x, options=0x%llx)", context, handle, reqspace, options); -int sceNpTrophySetSoundLevel() -{ - UNIMPLEMENTED_FUNC(sceNpTrophy); - return CELL_OK; -} + const auto ctxt = Emu.GetIdManager().get(context); -int sceNpTrophyGetRequiredDiskSpace(u32 context, u32 handle, vm::ptr reqspace, u64 options) -{ - sceNpTrophy.Warning("sceNpTrophyGetRequiredDiskSpace(context=0x%x, handle=0x%x, reqspace_addr=0x%x, options=0x%llx)", - context, handle, reqspace.addr(), options); - - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; - if (context == 0 || context > sceNpTrophyInstance.contexts.size()) { - sceNpTrophy.Warning("sceNpTrophyGetRequiredDiskSpace: invalid context (%d)", context); + if (!ctxt) + { return SCE_NP_TROPHY_ERROR_UNKNOWN_CONTEXT; } - // TODO: There are other possible errors - const sceNpTrophyInternalContext& ctxt = getContext(context); - if (!ctxt.trp_stream) - return SCE_NP_TROPHY_ERROR_CONF_DOES_NOT_EXIST; + const auto hndl = Emu.GetIdManager().get(handle); - *reqspace = ctxt.trp_stream->GetSize(); // TODO: This is not accurate. It's just an approximation of the real value - return CELL_OK; -} + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } -int sceNpTrophyDestroyContext() -{ - UNIMPLEMENTED_FUNC(sceNpTrophy); - return CELL_OK; -} - -int sceNpTrophyAbortHandle(u32 handle) -{ - sceNpTrophy.Todo("sceNpTrophyAbortHandle(handle=0x%x)", handle); - - // TODO: ? - - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; + // TODO: This is not accurate. It's just an approximation of the real value + *reqspace = ctxt->trp_stream->GetSize(); return CELL_OK; } -int sceNpTrophyGetGameInfo(u32 context, u32 handle, vm::ptr details, vm::ptr data) +s32 sceNpTrophySetSoundLevel(u32 context, u32 handle, u32 level, u64 options) { - sceNpTrophy.Warning("sceNpTrophyGetGameInfo(context=0x%x, handle=0x%x, details_addr=0x%x, data_addr=0x%x)", - context, handle, details.addr(), data.addr()); + sceNpTrophy.Todo("sceNpTrophySetSoundLevel(context=0x%x, handle=0x%x, level=%d, options=0x%llx)", context, handle, level, options); - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; - // TODO: There are other possible errors + return CELL_OK; +} + +s32 sceNpTrophyGetGameInfo(u32 context, u32 handle, vm::ptr details, vm::ptr data) +{ + sceNpTrophy.Error("sceNpTrophyGetGameInfo(context=0x%x, handle=0x%x, details=*0x%x, data=*0x%x)", context, handle, details, data); + + const auto ctxt = Emu.GetIdManager().get(context); + + if (!ctxt) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_CONTEXT; + } + + const auto hndl = Emu.GetIdManager().get(handle); + + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } std::string path; rXmlDocument doc; - const sceNpTrophyInternalContext& ctxt = getContext(context); - Emu.GetVFS().GetDevice("/dev_hdd0/home/00000001/trophy/" + ctxt.trp_name + "/TROPCONF.SFM", path); // TODO: Get the path of the current user + Emu.GetVFS().GetDevice("/dev_hdd0/home/00000001/trophy/" + ctxt->trp_name + "/TROPCONF.SFM", path); // TODO: Get the path of the current user doc.Load(path); std::string titleName; @@ -300,7 +290,7 @@ int sceNpTrophyGetGameInfo(u32 context, u32 handle, vm::ptrnumPlatinum++; break; } - if (ctxt.tropusr->GetTrophyUnlockState(trophy_id)) + if (ctxt->tropusr->GetTrophyUnlockState(trophy_id)) { data->unlockedTrophies++; switch (n->GetAttribute("ttype")[0]) { @@ -313,77 +303,71 @@ int sceNpTrophyGetGameInfo(u32 context, u32 handle, vm::ptrtitle, titleName.c_str(), std::min((size_t) SCE_NP_TROPHY_NAME_MAX_SIZE, titleName.length() + 1)); - memcpy(details->description, titleDetail.c_str(), std::min((size_t) SCE_NP_TROPHY_DESCR_MAX_SIZE, titleDetail.length() + 1)); + strcpy_trunc(details->title, titleName); + strcpy_trunc(details->description, titleDetail); return CELL_OK; } -int sceNpTrophyDestroyHandle() +s32 sceNpTrophyUnlockTrophy(u32 context, u32 handle, s32 trophyId, vm::ptr platinumId) { - UNIMPLEMENTED_FUNC(sceNpTrophy); - return CELL_OK; -} + sceNpTrophy.Error("sceNpTrophyUnlockTrophy(context=0x%x, handle=0x%x, trophyId=%d, platinumId=*0x%x)", context, handle, trophyId, platinumId); -int sceNpTrophyUnlockTrophy(u32 context, u32 handle, s32 trophyId, vm::ptr platinumId) -{ - sceNpTrophy.Warning("sceNpTrophyUnlockTrophy(context=0x%x, handle=0x%x, trophyId=%d, platinumId_addr=0x%x)", - context, handle, trophyId, platinumId.addr()); - - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; - // TODO: There are other possible errors + const auto ctxt = Emu.GetIdManager().get(context); - sceNpTrophyInternalContext& ctxt = getContext(context); - if (trophyId >= (s32)ctxt.tropusr->GetTrophiesCount()) + if (!ctxt) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_CONTEXT; + } + + const auto hndl = Emu.GetIdManager().get(handle); + + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } + + if (trophyId >= (s32)ctxt->tropusr->GetTrophiesCount()) return SCE_NP_TROPHY_ERROR_INVALID_TROPHY_ID; - if (ctxt.tropusr->GetTrophyUnlockState(trophyId)) + if (ctxt->tropusr->GetTrophyUnlockState(trophyId)) return SCE_NP_TROPHY_ERROR_ALREADY_UNLOCKED; u64 timestamp1 = get_system_time(); // TODO: Either timestamp1 or timestamp2 is wrong u64 timestamp2 = get_system_time(); // TODO: Either timestamp1 or timestamp2 is wrong - ctxt.tropusr->UnlockTrophy(trophyId, timestamp1, timestamp2); - std::string trophyPath = "/dev_hdd0/home/00000001/trophy/" + ctxt.trp_name + "/TROPUSR.DAT"; - ctxt.tropusr->Save(trophyPath); + ctxt->tropusr->UnlockTrophy(trophyId, timestamp1, timestamp2); + std::string trophyPath = "/dev_hdd0/home/00000001/trophy/" + ctxt->trp_name + "/TROPUSR.DAT"; + ctxt->tropusr->Save(trophyPath); *platinumId = SCE_NP_TROPHY_INVALID_TROPHY_ID; // TODO return CELL_OK; } -int sceNpTrophyTerm() +s32 sceNpTrophyGetTrophyUnlockState(u32 context, u32 handle, vm::ptr flags, vm::ptr count) { - sceNpTrophy.Warning("sceNpTrophyTerm()"); + sceNpTrophy.Error("sceNpTrophyGetTrophyUnlockState(context=0x%x, handle=0x%x, flags=*0x%x, count=*0x%x)", context, handle, flags, count); - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; + const auto ctxt = Emu.GetIdManager().get(context); - sceNpTrophyInstance.m_bInitialized = false; - - return CELL_OK; -} - -int sceNpTrophyGetTrophyUnlockState(u32 context, u32 handle, vm::ptr flags, vm::ptr count) -{ - sceNpTrophy.Warning("sceNpTrophyGetTrophyUnlockState(context=0x%x, handle=0x%x, flags_addr=0x%x, count_addr=0x%x)", - context, handle, flags.addr(), count.addr()); - - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; - if (context == 0 || context > sceNpTrophyInstance.contexts.size()) { - sceNpTrophy.Warning("sceNpTrophyGetTrophyUnlockState: invalid context (%d)", context); + if (!ctxt) + { return SCE_NP_TROPHY_ERROR_UNKNOWN_CONTEXT; } - // TODO: There are other possible errors - const sceNpTrophyInternalContext& ctxt = getContext(context); - u32 count_ = ctxt.tropusr->GetTrophiesCount(); + const auto hndl = Emu.GetIdManager().get(handle); + + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } + + u32 count_ = ctxt->tropusr->GetTrophiesCount(); *count = count_; if (count_ > 128) - sceNpTrophy.Warning("sceNpTrophyGetTrophyUnlockState: More than 128 trophies detected!"); + sceNpTrophy.Error("sceNpTrophyGetTrophyUnlockState: More than 128 trophies detected!"); // Pack up to 128 bools in u32 flag_bits[4] for (u32 id = 0; id < count_; id++) { - if (ctxt.tropusr->GetTrophyUnlockState(id)) + if (ctxt->tropusr->GetTrophyUnlockState(id)) flags->flag_bits[id/32] |= 1<<(id%32); else flags->flag_bits[id/32] &= ~(1<<(id%32)); @@ -392,25 +376,27 @@ int sceNpTrophyGetTrophyUnlockState(u32 context, u32 handle, vm::ptr details, vm::ptr data) { - UNIMPLEMENTED_FUNC(sceNpTrophy); - return CELL_OK; -} + sceNpTrophy.Warning("sceNpTrophyGetTrophyInfo(context=0x%x, handle=0x%x, trophyId=%d, details=*0x%x, data=*0x%x)", context, handle, trophyId, details, data); -int sceNpTrophyGetTrophyInfo(u32 context, u32 handle, s32 trophyId, vm::ptr details, vm::ptr data) -{ - sceNpTrophy.Warning("sceNpTrophyGetTrophyInfo(context=0x%x, handle=0x%x, trophyId=%d, details_addr=0x%x, data_addr=0x%x)", - context, handle, trophyId, details.addr(), data.addr()); + const auto ctxt = Emu.GetIdManager().get(context); - if (!sceNpTrophyInstance.m_bInitialized) - return SCE_NP_TROPHY_ERROR_NOT_INITIALIZED; - // TODO: There are other possible errors + if (!ctxt) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_CONTEXT; + } + + const auto hndl = Emu.GetIdManager().get(handle); + + if (!hndl) + { + return SCE_NP_TROPHY_ERROR_UNKNOWN_HANDLE; + } std::string path; rXmlDocument doc; - const sceNpTrophyInternalContext& ctxt = getContext(context); - Emu.GetVFS().GetDevice("/dev_hdd0/home/00000001/trophy/" + ctxt.trp_name + "/TROPCONF.SFM", path); // TODO: Get the path of the current user + Emu.GetVFS().GetDevice("/dev_hdd0/home/00000001/trophy/" + ctxt->trp_name + "/TROPCONF.SFM", path); // TODO: Get the path of the current user doc.Load(path); std::string name; @@ -437,8 +423,8 @@ int sceNpTrophyGetTrophyInfo(u32 context, u32 handle, s32 trophyId, vm::ptrtrophyId = trophyId; - data->unlocked = ctxt.tropusr->GetTrophyUnlockState(trophyId) ? true : false; // ??? - data->timestamp.tick = ctxt.tropusr->GetTrophyTimestamp(trophyId); + data->unlocked = ctxt->tropusr->GetTrophyUnlockState(trophyId) != 0; // ??? + data->timestamp = ctxt->tropusr->GetTrophyTimestamp(trophyId); } } @@ -447,16 +433,30 @@ int sceNpTrophyGetTrophyInfo(u32 context, u32 handle, s32 trophyId, vm::ptr percentage) { - UNIMPLEMENTED_FUNC(sceNpTrophy); + sceNpTrophy.Todo("sceNpTrophyGetGameProgress(context=0x%x, handle=0x%x, percentage=*0x%x)", context, handle, percentage); + return CELL_OK; } +s32 sceNpTrophyGetGameIcon(u32 context, u32 handle, vm::ptr buffer, vm::ptr size) +{ + sceNpTrophy.Todo("sceNpTrophyGetGameIcon(context=0x%x, handle=0x%x, buffer=*0x%x, size=*0x%x)", context, handle, buffer, size); + + return CELL_OK; +} + +s32 sceNpTrophyGetTrophyIcon(u32 context, u32 handle, s32 trophyId, vm::ptr buffer, vm::ptr size) +{ + sceNpTrophy.Todo("sceNpTrophyGetTrophyIcon(context=0x%x, handle=0x%x, trophyId=%d, buffer=*0x%x, size=*0x%x)", context, handle, trophyId, buffer, size); + + return CELL_OK; +} + + Module sceNpTrophy("sceNpTrophy", []() { - sceNpTrophyInstance.m_bInitialized = false; - REG_FUNC(sceNpTrophy, sceNpTrophyGetGameProgress); REG_FUNC(sceNpTrophy, sceNpTrophyRegisterContext); REG_FUNC(sceNpTrophy, sceNpTrophyCreateHandle); diff --git a/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.h b/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.h index 5d5a0a5da8..f61f8d7bab 100644 --- a/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.h +++ b/rpcs3/Emu/SysCalls/Modules/sceNpTrophy.h @@ -82,8 +82,8 @@ struct SceNpTrophyGameDetails be_t numGold; be_t numSilver; be_t numBronze; - u8 title[SCE_NP_TROPHY_TITLE_MAX_SIZE]; - u8 description[SCE_NP_TROPHY_GAME_DESCR_MAX_SIZE]; + char title[SCE_NP_TROPHY_TITLE_MAX_SIZE]; + char description[SCE_NP_TROPHY_GAME_DESCR_MAX_SIZE]; u8 reserved[4]; }; @@ -100,17 +100,17 @@ struct SceNpTrophyDetails { be_t trophyId; // SceNpTrophyId be_t trophyGrade; // SceNpTrophyGrade - u8 name[SCE_NP_TROPHY_NAME_MAX_SIZE]; - u8 description[SCE_NP_TROPHY_DESCR_MAX_SIZE]; - bool hidden; + char name[SCE_NP_TROPHY_NAME_MAX_SIZE]; + char description[SCE_NP_TROPHY_DESCR_MAX_SIZE]; + b8 hidden; u8 reserved[3]; }; struct SceNpTrophyData { - CellRtcTick timestamp; + be_t timestamp; // CellRtcTick be_t trophyId; // SceNpTrophyId - bool unlocked; + b8 unlocked; u8 reserved[3]; }; @@ -136,4 +136,4 @@ enum SCE_NP_TROPHY_STATUS_CHANGES_DETECTED = 9, }; -typedef s32 (SceNpTrophyStatusCallback)(u32 context, u32 status, s32 completed, s32 total, u32 arg_addr); +using SceNpTrophyStatusCallback = func_def arg)>; diff --git a/rpcs3/Emu/SysCalls/Modules/sysPrxForUser.cpp b/rpcs3/Emu/SysCalls/Modules/sysPrxForUser.cpp index cd6c28b5e1..685002a593 100644 --- a/rpcs3/Emu/SysCalls/Modules/sysPrxForUser.cpp +++ b/rpcs3/Emu/SysCalls/Modules/sysPrxForUser.cpp @@ -75,7 +75,7 @@ u32 ppu_get_tls(u32 thread) } } - throw "Out of TLS memory"; + throw EXCEPTION("Out of TLS memory"); } void ppu_free_tls(u32 thread) @@ -752,7 +752,7 @@ std::string ps3_fmt(PPUThread& context, vm::cptr fmt, u32 g_count, u32 f_c } } - throw fmt::format("ps3_fmt(): unknown formatting: '%s'", start.get_ptr()); + throw EXCEPTION("Unknown formatting: '%s'", start.get_ptr()); } } @@ -981,7 +981,7 @@ vm::ptr _sys_strcat(vm::ptr dest, vm::cptr source) if (strcat(dest.get_ptr(), source.get_ptr()) != dest.get_ptr()) { - throw "_sys_strcat() failed: unexpected strcat() result"; + throw EXCEPTION("Unexpected strcat() result"); } return dest; @@ -1000,7 +1000,7 @@ vm::ptr _sys_strncat(vm::ptr dest, vm::cptr source, u32 len) if (strncat(dest.get_ptr(), source.get_ptr(), len) != dest.get_ptr()) { - throw "_sys_strncat() failed: unexpected strncat() result"; + throw EXCEPTION("Unexpected strncat() result"); } return dest; @@ -1012,7 +1012,7 @@ vm::ptr _sys_strcpy(vm::ptr dest, vm::cptr source) if (strcpy(dest.get_ptr(), source.get_ptr()) != dest.get_ptr()) { - throw "_sys_strcpy() failed: unexpected strcpy() result"; + throw EXCEPTION("Unexpected strcpy() result"); } return dest; @@ -1029,7 +1029,7 @@ vm::ptr _sys_strncpy(vm::ptr dest, vm::cptr source, u32 len) if (strncpy(dest.get_ptr(), source.get_ptr(), len) != dest.get_ptr()) { - throw "_sys_strncpy() failed: unexpected strncpy() result"; + throw EXCEPTION("Unexpected strncpy() result"); } return dest; diff --git a/rpcs3/Emu/SysCalls/lv2/sys_lwcond.cpp b/rpcs3/Emu/SysCalls/lv2/sys_lwcond.cpp index 744f907863..8892d5ef9e 100644 --- a/rpcs3/Emu/SysCalls/lv2/sys_lwcond.cpp +++ b/rpcs3/Emu/SysCalls/lv2/sys_lwcond.cpp @@ -13,12 +13,6 @@ SysCallBase sys_lwcond("sys_lwcond"); -void lwcond_create(sys_lwcond_t& lwcond, sys_lwmutex_t& lwmutex, u64 name) -{ - lwcond.lwmutex.set(vm::get_addr(&lwmutex)); - lwcond.lwcond_queue = Emu.GetIdManager().make(name); -} - s32 _sys_lwcond_create(vm::ptr lwcond_id, u32 lwmutex_id, vm::ptr control, u64 name, u32 arg5) { sys_lwcond.Warning("_sys_lwcond_create(lwcond_id=*0x%x, lwmutex_id=0x%x, control=*0x%x, name=0x%llx, arg5=0x%x)", lwcond_id, lwmutex_id, control, name, arg5);