ide: PDB debugger threads tab improved

git-svn-id: svn://ultimatepp.org/upp/trunk@15609 f0d560ea-af0d-0410-9eb7-867de7ffcac7
This commit is contained in:
cxl 2020-12-18 17:51:37 +00:00
parent a869ce5ed1
commit cfd6f443d8
2 changed files with 51 additions and 24 deletions

View file

@ -451,7 +451,7 @@ struct Pdb : Debugger, ParentCtrl {
// code
Thread& Current();
Array<Frame> Backtrace(Thread& ctx, bool single_frame = false);
Array<Frame> Backtrace(Thread& ctx, bool single_frame = false, bool thread_info = false);
int Disassemble(adr_t ip);
bool IsValidFrame(adr_t eip);
void Sync0(Thread& ctx);

View file

@ -14,7 +14,7 @@ Pdb::Thread& Pdb::Current()
return zero;
}
Array<Pdb::Frame> Pdb::Backtrace(Thread& ctx, bool single_frame)
Array<Pdb::Frame> Pdb::Backtrace(Thread& ctx, bool single_frame, bool thread_info)
{
Array<Frame> frame;
STACKFRAME64 stackFrame = {0};
@ -54,30 +54,36 @@ Array<Pdb::Frame> Pdb::Backtrace(Thread& ctx, bool single_frame)
f.frame = stackFrame.AddrFrame.Offset;
f.stack = stackFrame.AddrStack.Offset;
f.fn = GetFnInfo(f.pc);
if(IsNull(f.fn.name)) {
if(single_frame)
return frame;
f.text = Hex(f.pc);
for(int i = 0; i < module.GetCount(); i++) {
const ModuleInfo& m = module[i];
if(f.pc >= m.base && f.pc < m.base + m.size) {
f.text << " (" << GetFileName(m.path) << ")";
break;
}
}
if(thread_info) {
if(frame.GetCount() > 20)
break;
}
else {
GetLocals(f, cctx, f.param, f.local);
if(single_frame)
return frame;
f.text = f.fn.name;
f.text << '(';
for(int i = 0; i < f.param.GetCount(); i++) {
if(i)
f.text << ", ";
f.text << f.param.GetKey(i) << "=" << Visualise(f.param[i], MEMBER).GetString();
if(IsNull(f.fn.name)) {
if(single_frame)
return frame;
f.text = Hex(f.pc);
for(int i = 0; i < module.GetCount(); i++) {
const ModuleInfo& m = module[i];
if(f.pc >= m.base && f.pc < m.base + m.size) {
f.text << " (" << GetFileName(m.path) << ")";
break;
}
}
}
else {
GetLocals(f, cctx, f.param, f.local);
if(single_frame)
return frame;
f.text = f.fn.name;
f.text << '(';
for(int i = 0; i < f.param.GetCount(); i++) {
if(i)
f.text << ", ";
f.text << f.param.GetKey(i) << "=" << Visualise(f.param[i], MEMBER).GetString();
}
f.text << ')';
}
f.text << ')';
}
}
return frame;
@ -135,7 +141,28 @@ void Pdb::BTs()
for(int i = 0; i < threads.GetCount(); i++) {
dword thid = threads.GetKey(i);
String stid = AsString(thid);
int id = bts.Add(0, DbgImg::Thread(), stid, Format("0x%x", (int)thid), true);
String info;
bool waiting = false;
bool cowork = false;
for(const Frame& f : Backtrace(threads[i], false, true)) {
if(info.GetCount() + f.fn.name.GetCount() > 160) {
info << "...";
break;
}
bool zwait = f.fn.name.StartsWith("ZwWait");
waiting |= zwait;
if(!f.fn.name.StartsWith("RtlSleep") && !f.fn.name.StartsWith("ZwWaitForAlertByThreadId"))
MergeWith(info, ", ", f.fn.name);
if(f.fn.name == "Upp::CoWork::Pool::ThreadRun") {
cowork = true;
break;
}
}
int id = bts.Add(0, DbgImg::Thread(), stid,
AttrText(Format("0x%x ", (int)thid) + info)
.NormalInk(waiting ? cowork ? Blend(SLtBlue, SGray(), 200) : SGray()
: cowork ? SLtBlue() : SColorText()),
true);
if(open.Find(stid) >= 0)
bts.Open(id);
}