<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=us-ascii"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:#0563C1;
text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
{mso-style-priority:99;
color:#954F72;
text-decoration:underline;}
span.EmailStyle17
{mso-style-type:personal-compose;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-family:"Calibri",sans-serif;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-US link="#0563C1" vlink="#954F72"><div class=WordSection1><p class=MsoNormal>We’re porting libcxx to Hexagon. Stepping the first line in wait.pass.cpp will put lldb in a bad state – it thinks the target has resumed, but it never sends a step or resume packet to the remote gdbserver. Sometimes it will step part of the line, return control, then stepping again goes to the bad state.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The system has 4 threads; only thread 3 is currently being used. The bad state happens because ProcessGDBRemote::DoResume can’t figure out how to send a resume packet. During the thread plan it resumes all threads. Later it goes to step thread 3, but it also wants to resume threads 1,2,4, but our gdbserver doesn’t support vCont, so it gives up. I don’t think it should be resuming threads 1,2,4.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>How can I fix this?<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The source file is wait.pass.cpp: <a href="https://llvm.org/svn/llvm-project/libcxx/trunk/test/std/thread/thread.condition/thread.condition.condvar/wait.pass.cpp">https://llvm.org/svn/llvm-project/libcxx/trunk/test/std/thread/thread.condition/thread.condition.condvar/wait.pass.cpp</a><o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Disassembly of line 43:<o:p></o:p></p><p class=MsoNormal><span style='font-family:"Courier New"'> 42 {<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>-> 43 std::unique_lock<std::mutex>lk(mut);<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 44 std::thread t(f);<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>-> 0x10011c4 <+20>: { memw(r30+#-20) = r2 }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011c8 <+24>: { immext(#18198784)<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011cc <+28>: r2 = ##18198784 }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011d0 <+32>: { memw(r30+#-24) = r2 }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011d4 <+36>: { r2 = memw(r30 + #-20) }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>wait.pass.cpp.exe`main + 40 [inlined] std::__1::unique_lock<std::__1::mutex>::unique_lock(std::__1::mutex&) at wait.pass.cpp:43<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011d8 <+40>: { r3 = memw(r30 + #-24) }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>wait.pass.cpp.exe`main + 44 [inlined] std::__1::unique_lock<std::__1::mutex>::unique_lock(std::__1::mutex&) + 4 at wait.pass.cpp:43<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011dc <+44>: { memw(r2+#0) = r3 }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>wait.pass.cpp.exe`main + 48 [inlined] std::__1::unique_lock<std::__1::mutex>::unique_lock(std::__1::mutex&) + 8 at wait.pass.cpp:43<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011e0 <+48>: { memb(r2+#4)=#1 }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>wait.pass.cpp.exe`main + 52 [inlined] std::__1::unique_lock<std::__1::mutex>::unique_lock(std::__1::mutex&) + 12 at wait.pass.cpp:43<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011e4 <+52>: { r0 = memw(r2 + #0) }<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'> 0x10011e8 <+56>: { call 0x1001ab4 } ; std::__1::mutex::lock at mutex.cpp:31<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>The only change-of-flow is the call instruction at the end.<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'><o:p> </o:p></span></p><p class=MsoNormal>Select linetable info, from llvm-dwarfdump:<o:p></o:p></p><p class=MsoNormal><span style='font-family:"Courier New"'>Address Line Column File ISA Discriminator Flags<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>------------------ ------ ------ ------ --- ------------- -------------<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>0x00000000010011c4 43 33 11 0 0 is_stmt prologue_end<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>0x00000000010011d8 112 17 3 0 0 is_stmt<o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>0x00000000010011dc 112 11 3 0 0 <o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>0x00000000010011e0 112 23 3 0 0 <o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>0x00000000010011e4 112 38 3 0 0 <o:p></o:p></span></p><p class=MsoNormal><span style='font-family:"Courier New"'>0x00000000010011ec 44 17 11 0 0 is_stmt<o:p></o:p></span></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>File 11 is wait.pass.cpp; file 3 is __mutex_base, where the inlined std::unique_lock is defined.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Step log:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(lldb) r<o:p></o:p></p><p class=MsoNormal>Process 1 launched: 'c:\lldb\test\cxx11\wait.pass.cpp.exe' (hexagon)<o:p></o:p></p><p class=MsoNormal>Process 1 stopped<o:p></o:p></p><p class=MsoNormal>* thread #3: tid = 0x0003, 0x010011c4 wait.pass.cpp.exe`main + 20 at wait.pass.cpp:43, stop reason = breakpoint 1.1<o:p></o:p></p><p class=MsoNormal> frame #0: 0x010011c4 wait.pass.cpp.exe`main + 20 at wait.pass.cpp:43<o:p></o:p></p><p class=MsoNormal> 40<o:p></o:p></p><p class=MsoNormal> 41 int main()<o:p></o:p></p><p class=MsoNormal> 42 {<o:p></o:p></p><p class=MsoNormal>-> 43 std::unique_lock<std::mutex>lk(mut);<o:p></o:p></p><p class=MsoNormal> 44 std::thread t(f);<o:p></o:p></p><p class=MsoNormal> 45 assert(test1 == 0);<o:p></o:p></p><p class=MsoNormal> 46 while (test1 == 0) {<o:p></o:p></p><p class=MsoNormal>(lldb) thread list<o:p></o:p></p><p class=MsoNormal>Process 1 stopped<o:p></o:p></p><p class=MsoNormal> thread #1: tid = 0x0001, 0xff004f64<o:p></o:p></p><p class=MsoNormal> thread #2: tid = 0x0002, 0xff004f64<o:p></o:p></p><p class=MsoNormal>* thread #3: tid = 0x0003, 0x010011c4 wait.pass.cpp.exe`main + 20 at wait.pass.cpp:43, stop reason = breakpoint 1.1<o:p></o:p></p><p class=MsoNormal> thread #4: tid = 0x0004, 0xff004f64<o:p></o:p></p><p class=MsoNormal>(lldb) log enable lldb step<o:p></o:p></p><p class=MsoNormal>(lldb) s<o:p></o:p></p><p class=MsoNormal>Finding branch index from address @ 0x010011c4<o:p></o:p></p><p class=MsoNormal>Instruction @0x010011C4 : 0xA79EE2FB<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Packet start @0x010011C8<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Instruction @0x010011C8 : 0x001156C4<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Instruction @0x010011D0 : 0xA79EE2FA<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Packet start @0x010011D4<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thread::PushPlan(0x0000000004E678D0): "Stepping in through line wait.pass.cpp:43.", tid = 0x0003.<o:p></o:p></p><p class=MsoNormal>Process::PrivateResume() m_stop_id = 2, public state: stopped private state: stopped<o:p></o:p></p><p class=MsoNormal>Failed to create new thread notification breakpoint.<o:p></o:p></p><p class=MsoNormal>Thread::PushPlan(0x0000000004E678D0): "Single stepping past breakpoint site 2 at 0x10011c4", tid = 0x0003.<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #1 (0x00000000045DDE10): tid = 0x0001, pc = 0xff004f64, sp = 0xff00cb78, fp = 0xff002d10, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #2 (0x0000000004E660B0): tid = 0x0002, pc = 0xff004f64, sp = 0xff00cc70, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #3 (0x0000000004E678D0): tid = 0x0003, pc = 0x010011c4, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'Step over breakpoint trap', state = stepping, stop others = 1<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #4 (0x0000000004E69080): tid = 0x0004, pc = 0xff004f64, sp = 0xff00ce60, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>Current Plan for thread 1(00000000045DDE10) (0x0001, suspended): base plan being asked whether we should report run.<o:p></o:p></p><p class=MsoNormal>Current Plan for thread 2(0000000004E660B0) (0x0002, suspended): base plan being asked whether we should report run.<o:p></o:p></p><p class=MsoNormal>Current Plan for thread 3(0000000004E678D0) (0x0003, stepping): Step over breakpoint trap being asked whether we should report run.<o:p></o:p></p><p class=MsoNormal>Current Plan for thread 4(0000000004E69080) (0x0004, suspended): base plan being asked whether we should report run.<o:p></o:p></p><p class=MsoNormal>Process thinks the process has resumed.<o:p></o:p></p><p class=MsoNormal>(lldb) s<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop: 4 threads, 1 unsuspended threads<o:p></o:p></p><p class=MsoNormal>Thread::lldb_private::Thread::ShouldStop for tid = 0x0003 0x0003, pc = 0x00000000010011c8, should_stop = 0 (ignore since no stop reason)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop overall should_stop = 0ThreadList::lldb_private::ThreadList::ShouldReportStop 4 threads<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0001: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0002: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0003: returning vote 0 (thread didn't stop for a reason.)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0004: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop returning no opinionProcess::PrivateResume() m_stop_id = 3, public state: running private state: stopped<o:p></o:p></p><p class=MsoNormal>Failed to create new thread notification breakpoint.<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #1 (0x00000000045DDE10): tid = 0x0001, pc = 0x010011c8, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #2 (0x0000000004E660B0): tid = 0x0002, pc = 0xff004f64, sp = 0xff00cc70, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #3 (0x0000000004E678D0): tid = 0x0003, pc = 0x010011c8, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'Step over breakpoint trap', state = stepping, stop others = 1<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #4 (0x0000000004E69080): tid = 0x0004, pc = 0xff004f64, sp = 0xff00ce60, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>Process thinks the process has resumed.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop: 4 threads, 1 unsuspended threads<o:p></o:p></p><p class=MsoNormal>Thread::lldb_private::Thread::ShouldStop for tid = 0x0003 0x0003, pc = 0x00000000010011d0, should_stop = 0 (ignore since no stop reason)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop overall should_stop = 0ThreadList::lldb_private::ThreadList::ShouldReportStop 4 threads<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0001: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0002: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0003: returning vote 0 (thread didn't stop for a reason.)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0004: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop returning no opinion<o:p></o:p></p><p class=MsoNormal>Process::PrivateResume() m_stop_id = 4, public state: running private state: stopped<o:p></o:p></p><p class=MsoNormal>Failed to create new thread notification breakpoint.<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #1 (0x00000000045DDE10): tid = 0x0001, pc = 0xff004f64, sp = 0xff00cb78, fp = 0xff002d10, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #2 (0x0000000004E660B0): tid = 0x0002, pc = 0xff004f64, sp = 0xff00cc70, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #3 (0x0000000004E678D0): tid = 0x0003, pc = 0x010011d0, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'Step over breakpoint trap', state = stepping, stop others = 1<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #4 (0x0000000004E69080): tid = 0x0004, pc = 0x010011d0, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>Process thinks the process has resumed.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop: 4 threads, 1 unsuspended threads<o:p></o:p></p><p class=MsoNormal>Thread::lldb_private::Thread::ShouldStop(0000000004E678D0) for tid = 0x0003 0x0003, pc = 0x00000000010011d4<o:p></o:p></p><p class=MsoNormal>^^^^^^^^ Thread::ShouldStop Begin ^^^^^^^^<o:p></o:p></p><p class=MsoNormal>Plan stack initial state:<o:p></o:p></p><p class=MsoNormal> thread #3: tid = 0x0003:<o:p></o:p></p><p class=MsoNormal> Active plan stack:<o:p></o:p></p><p class=MsoNormal> Element 0: Base thread plan.<o:p></o:p></p><p class=MsoNormal> Element 1: Stepping in through line wait.pass.cpp:43 using ranges:[0x010011c4-0x010011d8).<o:p></o:p></p><p class=MsoNormal> Element 2: Single stepping past breakpoint site 2 at 0x10011c4<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Plan Step over breakpoint trap explains stop, auto-continue 0.<o:p></o:p></p><p class=MsoNormal>Plan Step over breakpoint trap should stop: 1.<o:p></o:p></p><p class=MsoNormal>Completed step over breakpoint plan.<o:p></o:p></p><p class=MsoNormal>Popping plan: "Step over breakpoint trap", tid = 0x0003.<o:p></o:p></p><p class=MsoNormal>ThreadPlanStepInRange reached 0x010011d4.<o:p></o:p></p><p class=MsoNormal>Plan Step Range stepping in should stop: 0.<o:p></o:p></p><p class=MsoNormal>Plan stack final state:<o:p></o:p></p><p class=MsoNormal> thread #3: tid = 0x0003:<o:p></o:p></p><p class=MsoNormal> Active plan stack:<o:p></o:p></p><p class=MsoNormal> Element 0: Base thread plan.<o:p></o:p></p><p class=MsoNormal> Element 1: Stepping in through line wait.pass.cpp:43 using ranges:[0x010011c4-0x010011d8).<o:p></o:p></p><p class=MsoNormal> Completed Plan Stack:<o:p></o:p></p><p class=MsoNormal> Element 0: Single stepping past breakpoint site 2 at 0x10011c4<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>vvvvvvvv Thread::ShouldStop End (returning 0) vvvvvvvv<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop overall should_stop = 0<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop 4 threads<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0001: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0002: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0003: returning vote for complete stack's back plan<o:p></o:p></p><p class=MsoNormal>ThreadPlan::ShouldReportStop() returning vote: no<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0004: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop returning no<o:p></o:p></p><p class=MsoNormal>Process::PrivateResume() m_stop_id = 5, public state: running private state: stopped<o:p></o:p></p><p class=MsoNormal>Failed to create new thread notification breakpoint.<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #1 (0x00000000045DDE10): tid = 0x0001, pc = 0xff004f64, sp = 0xff00cb78, fp = 0xff002d10, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #2 (0x0000000004E660B0): tid = 0x0002, pc = 0xff004f64, sp = 0xff00cc70, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #3 (0x0000000004E678D0): tid = 0x0003, pc = 0x010011d4, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'Step Range stepping in', state = stepping, stop others = 1<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #4 (0x0000000004E69080): tid = 0x0004, pc = 0xff004f64, sp = 0xff00ce60, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>Process thinks the process has resumed.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop: 4 threads, 1 unsuspended threads<o:p></o:p></p><p class=MsoNormal>Thread::lldb_private::Thread::ShouldStop for tid = 0x0003 0x0003, pc = 0x00000000010011d8, should_stop = 0 (ignore since no stop reason)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop overall should_stop = 0<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop 4 threads<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0001: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0002: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0003: returning vote 0 (thread didn't stop for a reason.)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0004: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop returning no opinion<o:p></o:p></p><p class=MsoNormal>Process::PrivateResume() m_stop_id = 6, public state: running private state: stopped<o:p></o:p></p><p class=MsoNormal>Failed to create new thread notification breakpoint.<o:p></o:p></p><p class=MsoNormal> lldb_private::ThreadPlan::WillResume Thread #1 (0x00000000045DDE10): tid= 0x0001, pc = 0xff004f64, sp = 0xff00cb78, fp = 0xff002d10, plan = 'base plan', state = suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #2 (0x0000000004E660B0): tid = 0x0002, pc = 0xff004f64, sp = 0xff00cc70, fp = 0x00000000, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #3 (0x0000000004E678D0): tid = 0x0003, pc = 0x010011d8, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'Step Range stepping in', state = stepping, stop others = 1<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #4 (0x0000000004E69080): tid = 0x0004, pc = 0x010011d8, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'base plan', state= suspended, stop others = 0<o:p></o:p></p><p class=MsoNormal>Process thinks the process has resumed.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop: 4 threads, 1 unsuspended threads<o:p></o:p></p><p class=MsoNormal>Thread::lldb_private::Thread::ShouldStop(0000000004E678D0) for tid = 0x0003 0x0003, pc = 0x00000000010011dc<o:p></o:p></p><p class=MsoNormal>^^^^^^^^ Thread::ShouldStop Begin ^^^^^^^^<o:p></o:p></p><p class=MsoNormal>Plan stack initial state:<o:p></o:p></p><p class=MsoNormal> thread #3: tid = 0x0003:<o:p></o:p></p><p class=MsoNormal> Active plan stack:<o:p></o:p></p><p class=MsoNormal> Element 0: Base thread plan.<o:p></o:p></p><p class=MsoNormal> Element 1: Stepping in through line wait.pass.cpp:43 using ranges:[0x010011c4-0x010011d8).<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Plan Step Range stepping in explains stop, auto-continue 0.<o:p></o:p></p><p class=MsoNormal>ThreadPlanStepInRange reached 0x010011dc.<o:p></o:p></p><p class=MsoNormal>Couldn't find step through plan from address 0x10011dc.<o:p></o:p></p><p class=MsoNormal>No step through plan found.<o:p></o:p></p><p class=MsoNormal>Stepping out of function "std::__1::unique_lock<std::__1::mutex>::unique_lock(std::__1::mutex&)" because it matches the avoid regexp "^std::" - match substring: "std::".<o:p></o:p></p><p class=MsoNormal>ShouldStopHere callback returned 0 from 0x10011dc.<o:p></o:p></p><p class=MsoNormal>Queuing inlined frame to step past: frame #0: 0x010011dc wait.pass.cpp.exe`main+ 44 [inlined] std::__1::unique_lock<std::__1::mutex>::unique_lock(std::__1::mutex&) + 4 at wait.pass.cpp:43 wait.pass.cpp.exe`main + 40 at wait.pass.cpp:43.<o:p></o:p></p><p class=MsoNormal>Finding branch index from address @ 0x010011dc<o:p></o:p></p><p class=MsoNormal>Instruction @0x010011DC : 0xA182C300<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Packet start @0x010011E0<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Instruction @0x010011E0 : 0x3C02C201<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Packet start @0x010011E4<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Instruction @0x010011E4 : 0x9182C000<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Packet start @0x010011E8<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thread::PushPlan(0x0000000004E678D0): "Stepping over using ranges: [0x010011d8-0x010011ec).", tid = 0x0003.<o:p></o:p></p><p class=MsoNormal>Thread::PushPlan(0x0000000004E678D0): "Stepping out by stepping through inlinedfunction.", tid = 0x0003.<o:p></o:p></p><p class=MsoNormal>Plan Step Range stepping in should stop: 0.<o:p></o:p></p><p class=MsoNormal>Plan stack final state:<o:p></o:p></p><p class=MsoNormal> thread #3: tid = 0x0003:<o:p></o:p></p><p class=MsoNormal> Active plan stack:<o:p></o:p></p><p class=MsoNormal> Element 0: Base thread plan.<o:p></o:p></p><p class=MsoNormal> Element 1: Stepping in through line wait.pass.cpp:43 using ranges:[0x010011c4-0x010011d8).<o:p></o:p></p><p class=MsoNormal> Element 2: Stepping out by stepping through inlined function.<o:p></o:p></p><p class=MsoNormal> Element 3: Stepping over using ranges: [0x010011d8-0x010011ec).<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>vvvvvvvv Thread::ShouldStop End (returning 0) vvvvvvvv<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldStop overall should_stop = 0<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop 4 threads<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0001: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0002: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>ThreadPlanStepRange::ShouldReportStop() returning vote -1<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0003: returning vote -1 for current plan<o:p></o:p></p><p class=MsoNormal>Thread::ShouldReportStop() tid = 0x0004: returning vote 0 (temporary state was suspended or invalid)<o:p></o:p></p><p class=MsoNormal>ThreadList::lldb_private::ThreadList::ShouldReportStop returning no<o:p></o:p></p><p class=MsoNormal>Process::PrivateResume() m_stop_id = 7, public state: running private state: stopped<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #1 (0x00000000045DDE10): tid = 0x0001, pc = 0xff004f64, sp = 0xff00cb78, fp = 0xff002d10, plan = 'base plan', state= running, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #2 (0x0000000004E660B0): tid = 0x0002, pc = 0xff004f64, sp = 0xff00cc70, fp = 0x00000000, plan = 'base plan', state= running, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #3 (0x0000000004E678D0): tid = 0x0003, pc = 0x010011dc, sp = 0x0525eca8, fp = 0x0525ecf8, plan = 'Step range stepping over', state = stepping, stop others = 0<o:p></o:p></p><p class=MsoNormal>lldb_private::ThreadPlan::WillResume Thread #4 (0x0000000004E69080): tid = 0x0004, pc = 0xff004f64, sp = 0xff00ce60, fp = 0x00000000, plan = 'base plan', state= running, stop others = 0<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>--<o:p></o:p></p><p class=MsoNormal>Qualcomm Innovation Center, Inc.<o:p></o:p></p><p class=MsoNormal>The Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p></div></body></html>