Compare commits

..

1 commit

Author SHA1 Message Date
Deleted user
3a04f1f987
Merge cd6d129540 into 72b0fe6c1c 2024-01-20 18:35:18 -08:00
4 changed files with 6 additions and 19 deletions

View file

@ -45,7 +45,7 @@ namespace ams::dmnt {
} }
if (R_FAILED(result)) { if (R_FAILED(result)) {
AMS_DMNT2_GDB_LOG_DEBUG("BreakPointManager::SetBreakPoint %p 0x%lx !!! Fail 0x%08x !!!\n", bp, address, result.GetValue()); AMS_DMNT2_GDB_LOG_DEBUG("BreakPointManager::SetBreakPoint %p 0x%lx !!! Fail 0x%08x !!!\n", bp, bp->m_address, result.GetValue());
} }
R_RETURN(result); R_RETURN(result);

View file

@ -1538,18 +1538,13 @@ namespace ams::dmnt {
} }
void GdbServerImpl::Q() { void GdbServerImpl::Q() {
if (ParsePrefix(m_receive_packet, "QStartNoAckMode")) { if (false) {
this->QStartNoAckMode(); /* TODO: QStartNoAckMode? */
} else { } else {
AMS_DMNT2_GDB_LOG_DEBUG("Not Implemented Q: %s\n", m_receive_packet); AMS_DMNT2_GDB_LOG_DEBUG("Not Implemented Q: %s\n", m_receive_packet);
} }
} }
void GdbServerImpl::QStartNoAckMode() {
m_packet_io.SetNoAck();
AppendReplyOk(m_reply_cur, m_reply_end);
}
void GdbServerImpl::T() { void GdbServerImpl::T() {
if (const char *dot = std::strchr(m_receive_packet, '.'); dot != nullptr) { if (const char *dot = std::strchr(m_receive_packet, '.'); dot != nullptr) {
const u64 thread_id = DecodeHex(dot + 1); const u64 thread_id = DecodeHex(dot + 1);
@ -1924,7 +1919,6 @@ namespace ams::dmnt {
R_SUCCEED(); R_SUCCEED();
} }
void GdbServerImpl::q() { void GdbServerImpl::q() {
if (ParsePrefix(m_receive_packet, "qAttached:")) { if (ParsePrefix(m_receive_packet, "qAttached:")) {
this->qAttached(); this->qAttached();
@ -2151,7 +2145,6 @@ namespace ams::dmnt {
AppendReplyFormat(m_reply_cur, m_reply_end, ";swbreak+"); AppendReplyFormat(m_reply_cur, m_reply_end, ";swbreak+");
AppendReplyFormat(m_reply_cur, m_reply_end, ";hwbreak+"); AppendReplyFormat(m_reply_cur, m_reply_end, ";hwbreak+");
AppendReplyFormat(m_reply_cur, m_reply_end, ";vContSupported+"); AppendReplyFormat(m_reply_cur, m_reply_end, ";vContSupported+");
AppendReplyFormat(m_reply_cur, m_reply_end, ";QStartNoAckMode+");
} }
void GdbServerImpl::qXfer() { void GdbServerImpl::qXfer() {

View file

@ -77,8 +77,6 @@ namespace ams::dmnt {
void Q(); void Q();
void QStartNoAckMode();
void T(); void T();
void Z(); void Z();
@ -117,4 +115,4 @@ namespace ams::dmnt {
Result ParseVCont(char * const token, u64 *thread_ids, u8 *continue_modes, s32 num_threads, DebugProcess::ContinueMode &default_continue_mode); Result ParseVCont(char * const token, u64 *thread_ids, u8 *continue_modes, s32 num_threads, DebugProcess::ContinueMode &default_continue_mode);
}; };
} }

View file

@ -46,11 +46,8 @@ namespace ams::dmnt::cheat::impl {
void CheatVirtualMachine::OpenDebugLogFile() { void CheatVirtualMachine::OpenDebugLogFile() {
#ifdef DMNT_CHEAT_VM_DEBUG_LOG #ifdef DMNT_CHEAT_VM_DEBUG_LOG
CloseDebugLogFile(); CloseDebugLogFile();
fs::EnsureDirectory("sdmc:/atmosphere/cheat_vm_logs"); R_ABORT_UNLESS(fs::OpenFile(std::addressof(m_debug_log_file), "sdmc:/atmosphere/cheat_vm_logs/debug_log.txt"));
fs::CreateFile("sdmc:/atmosphere/cheat_vm_logs/debug_log.txt", 0);
R_ABORT_UNLESS(fs::OpenFile(std::addressof(m_debug_log_file), "sdmc:/atmosphere/cheat_vm_logs/debug_log.txt", fs::OpenMode_Write | fs::OpenMode_AllowAppend));
m_debug_log_file_offset = 0; m_debug_log_file_offset = 0;
m_has_debug_log_file = true;
#endif #endif
} }
@ -83,8 +80,7 @@ namespace ams::dmnt::cheat::impl {
fmt_len += 1; fmt_len += 1;
} }
fs::WriteFile(m_debug_log_file, m_debug_log_file_offset, m_debug_log_format_buf, fmt_len, fs::WriteOption::Flush); fs::WriteFile(m_debug_log_file, m_debug_log_offset, m_debug_log_format_buf, fmt_len, fs::WriteOption::Flush);
m_debug_log_file_offset += fmt_len;
#else #else
AMS_UNUSED(format); AMS_UNUSED(format);
#endif #endif