Slight optimization for dtb change

Avoids reopening the same process after a dtb change
master
MisterY52 1 month ago
parent 684a0a797c
commit 92c155d477

@ -192,17 +192,22 @@ void Memory::open_proc(const char *name)
printf("Kernel initialized: %p\n", kernel.get()->container.instance.instance); printf("Kernel initialized: %p\n", kernel.get()->container.instance.instance);
} }
if (lastCorrectDtbPhysicalAddress && bruteforceDtb(0x0, 0x100000))
{
return;
}
close_proc();
ProcessInfo info; ProcessInfo info;
info.dtb2 = Address_INVALID; info.dtb2 = Address_INVALID;
if (kernel.get()->process_info_by_name(name, &info)) if (kernel.get()->process_info_by_name(name, &info))
{ {
status = process_status::NOT_FOUND; status = process_status::NOT_FOUND;
lastCorrectDtbPhysicalAddress = 0;
return; return;
} }
close_proc();
if (kernel.get()->clone().into_process_by_info(info, &proc.hProcess)) if (kernel.get()->clone().into_process_by_info(info, &proc.hProcess))
{ {
status = process_status::FOUND_NO_ACCESS; status = process_status::FOUND_NO_ACCESS;
@ -240,6 +245,7 @@ void Memory::close_proc()
{ {
std::lock_guard<std::mutex> l(m); std::lock_guard<std::mutex> l(m);
proc.hProcess.~IntoProcessInstance(); proc.hProcess.~IntoProcessInstance();
lastCorrectDtbPhysicalAddress = 0;
proc.baseaddr = 0; proc.baseaddr = 0;
} }

Loading…
Cancel
Save