[Lldb-commits] [lldb] r230237 - Fix a problem where lldb-mi would not stop the debuggee after -exec-interrupt command.
Ilia K
ki.stfu at gmail.com
Tue Feb 24 02:19:24 PST 2015
Hello Dawn,
I'll fix this problem soon. Sorry for inconvenience.
Thanks,
Ilia
On Tue, Feb 24, 2015 at 4:31 AM, <dawn at burble.org> wrote:
> This commit the broke test_lldbmi_stopped_when_stopatentry_remote test of
> TestMiNotification.py on our master/upstream OSX build.
>
> On Mon, Feb 23, 2015 at 06:27:18PM -0000, Hafiz Abid Qadeer wrote:
> > Author: abidh
> > Date: Mon Feb 23 12:27:17 2015
> > New Revision: 230237
> >
> > URL: http://llvm.org/viewvc/llvm-project?rev=230237&view=rev
> > Log:
> > Fix a problem where lldb-mi would not stop the debuggee after
> -exec-interrupt command.
> >
> > Summary:
> > This revision fixes a problem where lldb-mi would not stop the execution
> after exec-interrupt call.
> > On Linux, SIGSTOP is used to stop the debuggee process. LLDB stopped the
> debuggee alright. But when
> > lldb-mi received the notification of stopping with reason as SIGSTOP, it
> would resume the process.
> > This was heppening in
> CMICmnLLDBDebuggerHandleEvents::HandleProcessEventStopSignal. This function
> aslo
> > used hard coded numbers for signal istead of symbolic names.
> >
> > This revision changes code to treat SIGSTOP reason as SIGINT. Also used
> symbolic names for signals
> > instead of numbers.
> >
> > Reviewers: ki.stfu, clayborg
> >
> > Reviewed By: ki.stfu, clayborg
> >
> > Subscribers: zturner, lldb-commits
> >
> > Differential Revision: http://reviews.llvm.org/D7783
> >
> > Modified:
> > lldb/trunk/test/tools/lldb-mi/signal/TestMiSignal.py
> > lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.cpp
> > lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.h
> >
> > Modified: lldb/trunk/test/tools/lldb-mi/signal/TestMiSignal.py
> > URL:
> http://llvm.org/viewvc/llvm-project/lldb/trunk/test/tools/lldb-mi/signal/TestMiSignal.py?rev=230237&r1=230236&r2=230237&view=diff
> >
> ==============================================================================
> > --- lldb/trunk/test/tools/lldb-mi/signal/TestMiSignal.py (original)
> > +++ lldb/trunk/test/tools/lldb-mi/signal/TestMiSignal.py Mon Feb 23
> 12:27:17 2015
> > @@ -37,7 +37,7 @@ class MiSignalTestCase(lldbmi_testcase.M
> >
> > # Test that -exec-interrupt can interrupt an execution
> > self.runCmd("-exec-interrupt")
> > - self.expect("\*stopped,reason=\"signal-received\"")
> > +
> self.expect("\*stopped,reason=\"signal-received\",signal-name=\"SIGINT\",signal-meaning=\"Interrupt\",.*thread-id=\"1\",stopped-threads=\"all\"")
> >
> > # Continue (to loop forever)
> > self.runCmd("-exec-continue")
> > @@ -45,7 +45,7 @@ class MiSignalTestCase(lldbmi_testcase.M
> >
> > # Test that Ctrl+C can interrupt an execution
> > self.child.sendintr() #FIXME: here uses self.child directly
> > - self.expect("\*stopped,reason=\"signal-received\"")
> > +
> self.expect("\*stopped,reason=\"signal-received\",signal-name=\"SIGINT\",signal-meaning=\"Interrupt\",.*thread-id=\"1\",stopped-threads=\"all\"")
> >
> > @lldbmi_test
> > @expectedFailureWindows("llvm.org/pr22274: need a pexpect
> replacement for windows")
> >
> > Modified: lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.cpp
> > URL:
> http://llvm.org/viewvc/llvm-project/lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.cpp?rev=230237&r1=230236&r2=230237&view=diff
> >
> ==============================================================================
> > --- lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.cpp (original)
> > +++ lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.cpp Mon Feb
> 23 12:27:17 2015
> > @@ -27,6 +27,7 @@
> > #include "lldb/API/SBThread.h"
> > #include "lldb/API/SBCommandInterpreter.h"
> > #include "lldb/API/SBCommandReturnObject.h"
> > +#include "lldb/API/SBUnixSignals.h"
> > #ifdef _WIN32
> > #include <io.h> // For the ::_access()
> > #else
> > @@ -88,6 +89,11 @@ CMICmnLLDBDebuggerHandleEvents::Initiali
> > return MIstatus::success;
> >
> > m_bInitialized = MIstatus::success;
> > + m_bSignalsInitialized = false;
> > + m_SIGINT = 0;
> > + m_SIGSTOP = 0;
> > + m_SIGSEGV = 0;
> > + m_SIGTRAP = 0;
> >
> > return m_bInitialized;
> > }
> > @@ -832,106 +838,103 @@ CMICmnLLDBDebuggerHandleEvents::HandlePr
> > {
> > bool bOk = MIstatus::success;
> >
> > + InitializeSignals ();
> > lldb::SBProcess sbProcess =
> CMICmnLLDBDebugSessionInfo::Instance().GetProcess();
> > const MIuint64 nStopReason =
> sbProcess.GetSelectedThread().GetStopReasonDataAtIndex(0);
> > - switch (nStopReason)
> > + if (nStopReason == m_SIGINT || nStopReason == m_SIGSTOP)
> > {
> > - case 2: // Terminal interrupt signal. SIGINT
> > - {
> > - // MI print
> "*stopped,reason=\"signal-received\",signal-name=\"SIGNINT\",signal-meaning=\"Interrupt\",frame={%s}"
> > - const CMICmnMIValueConst miValueConst("signal-received");
> > - const CMICmnMIValueResult miValueResult("reason",
> miValueConst);
> > - CMICmnMIOutOfBandRecord
> miOutOfBandRecord(CMICmnMIOutOfBandRecord::eOutOfBand_Stopped,
> miValueResult);
> > - const CMICmnMIValueConst miValueConst2("SIGINT");
> > - const CMICmnMIValueResult miValueResult2("signal-name",
> miValueConst2);
> > - bOk = miOutOfBandRecord.Add(miValueResult2);
> > - const CMICmnMIValueConst miValueConst3("Interrupt");
> > - const CMICmnMIValueResult miValueResult3("signal-meaning",
> miValueConst3);
> > - bOk = bOk && miOutOfBandRecord.Add(miValueResult3);
> > - CMICmnMIValueTuple miValueTuple;
> > - bOk = bOk && MiHelpGetCurrentThreadFrame(miValueTuple);
> > - const CMICmnMIValueResult miValueResult5("frame",
> miValueTuple);
> > - bOk = bOk && miOutOfBandRecord.Add(miValueResult5);
> > - bOk = bOk && MiOutOfBandRecordToStdout(miOutOfBandRecord);
> > - bOk = bOk && TextToStdout("(gdb)");
> > - }
> > - break;
> > - case 11: // Invalid memory reference. SIGSEGV
> > - {
> > - // MI print
> "*stopped,reason=\"signal-received\",signal-name=\"SIGSEGV\",signal-meaning=\"Segmentation
> > - // fault\",thread-id=\"%d\",frame={%s}"
> > - const CMICmnMIValueConst miValueConst("signal-received");
> > - const CMICmnMIValueResult miValueResult("reason",
> miValueConst);
> > - CMICmnMIOutOfBandRecord
> miOutOfBandRecord(CMICmnMIOutOfBandRecord::eOutOfBand_Stopped,
> miValueResult);
> > - const CMICmnMIValueConst miValueConst2("SIGSEGV");
> > - const CMICmnMIValueResult miValueResult2("signal-name",
> miValueConst2);
> > - bOk = miOutOfBandRecord.Add(miValueResult2);
> > - const CMICmnMIValueConst miValueConst3("Segmentation
> fault");
> > - const CMICmnMIValueResult miValueResult3("signal-meaning",
> miValueConst3);
> > - bOk = bOk && miOutOfBandRecord.Add(miValueResult3);
> > - const CMIUtilString strThreadId(CMIUtilString::Format("%d",
> sbProcess.GetSelectedThread().GetIndexID()));
> > - const CMICmnMIValueConst miValueConst4(strThreadId);
> > - const CMICmnMIValueResult miValueResult4("thread-id",
> miValueConst4);
> > - bOk = bOk && miOutOfBandRecord.Add(miValueResult4);
> > - CMICmnMIValueTuple miValueTuple;
> > - bOk = bOk && MiHelpGetCurrentThreadFrame(miValueTuple);
> > - const CMICmnMIValueResult miValueResult5("frame",
> miValueTuple);
> > - bOk = bOk && miOutOfBandRecord.Add(miValueResult5);
> > - bOk = bOk && MiOutOfBandRecordToStdout(miOutOfBandRecord);
> > - // Note no "(gdb)" output here
> > - }
> > - break;
> > - case 19:
> > - if (sbProcess.IsValid())
> > - sbProcess.Continue();
> > - break;
> > - case 5: // Trace/breakpoint trap. SIGTRAP
> > + // MI print
> "*stopped,reason=\"signal-received\",signal-name=\"SIGNINT\",signal-meaning=\"Interrupt\",frame={%s}"
> > + const CMICmnMIValueConst miValueConst("signal-received");
> > + const CMICmnMIValueResult miValueResult("reason", miValueConst);
> > + CMICmnMIOutOfBandRecord
> miOutOfBandRecord(CMICmnMIOutOfBandRecord::eOutOfBand_Stopped,
> miValueResult);
> > + const CMICmnMIValueConst miValueConst2("SIGINT");
> > + const CMICmnMIValueResult miValueResult2("signal-name",
> miValueConst2);
> > + bOk = miOutOfBandRecord.Add(miValueResult2);
> > + const CMICmnMIValueConst miValueConst3("Interrupt");
> > + const CMICmnMIValueResult miValueResult3("signal-meaning",
> miValueConst3);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult3);
> > + CMICmnMIValueTuple miValueTuple;
> > + bOk = bOk && MiHelpGetCurrentThreadFrame(miValueTuple);
> > + const CMICmnMIValueResult miValueResult5("frame", miValueTuple);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult5);
> > + const CMIUtilString strThreadId(CMIUtilString::Format("%d",
> sbProcess.GetSelectedThread().GetIndexID()));
> > + const CMICmnMIValueConst miValueConst6(strThreadId);
> > + const CMICmnMIValueResult miValueResult6("thread-id",
> miValueConst6);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult6);
> > + const CMICmnMIValueConst miValueConst7("all");
> > + const CMICmnMIValueResult miValueResult7("stopped-threads",
> miValueConst7);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult7);
> > + bOk = bOk && MiOutOfBandRecordToStdout(miOutOfBandRecord);
> > + bOk = bOk && TextToStdout("(gdb)");
> > + }
> > + else if (nStopReason == m_SIGSEGV)
> > + {
> > + // MI print
> "*stopped,reason=\"signal-received\",signal-name=\"SIGSEGV\",signal-meaning=\"Segmentation
> > + // fault\",thread-id=\"%d\",frame={%s}"
> > + const CMICmnMIValueConst miValueConst("signal-received");
> > + const CMICmnMIValueResult miValueResult("reason", miValueConst);
> > + CMICmnMIOutOfBandRecord
> miOutOfBandRecord(CMICmnMIOutOfBandRecord::eOutOfBand_Stopped,
> miValueResult);
> > + const CMICmnMIValueConst miValueConst2("SIGSEGV");
> > + const CMICmnMIValueResult miValueResult2("signal-name",
> miValueConst2);
> > + bOk = miOutOfBandRecord.Add(miValueResult2);
> > + const CMICmnMIValueConst miValueConst3("Segmentation fault");
> > + const CMICmnMIValueResult miValueResult3("signal-meaning",
> miValueConst3);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult3);
> > + const CMIUtilString strThreadId(CMIUtilString::Format("%d",
> sbProcess.GetSelectedThread().GetIndexID()));
> > + const CMICmnMIValueConst miValueConst4(strThreadId);
> > + const CMICmnMIValueResult miValueResult4("thread-id",
> miValueConst4);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult4);
> > + CMICmnMIValueTuple miValueTuple;
> > + bOk = bOk && MiHelpGetCurrentThreadFrame(miValueTuple);
> > + const CMICmnMIValueResult miValueResult5("frame", miValueTuple);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult5);
> > + bOk = bOk && MiOutOfBandRecordToStdout(miOutOfBandRecord);
> > + // Note no "(gdb)" output here
> > + }
> > + else if (nStopReason == m_SIGTRAP)
> > + {
> > + lldb::SBThread thread = sbProcess.GetSelectedThread();
> > + const MIuint nFrames = thread.GetNumFrames();
> > + if (nFrames > 0)
> > {
> > - lldb::SBThread thread = sbProcess.GetSelectedThread();
> > - const MIuint nFrames = thread.GetNumFrames();
> > - if (nFrames > 0)
> > + lldb::SBFrame frame = thread.GetFrameAtIndex(0);
> > + const char *pFnName = frame.GetFunctionName();
> > + if (pFnName != nullptr)
> > {
> > - lldb::SBFrame frame = thread.GetFrameAtIndex(0);
> > - const char *pFnName = frame.GetFunctionName();
> > - if (pFnName != nullptr)
> > - {
> > - const CMIUtilString fnName = CMIUtilString(pFnName);
> > - static const CMIUtilString threadCloneFn =
> CMIUtilString("__pthread_clone");
> > + const CMIUtilString fnName = CMIUtilString(pFnName);
> > + static const CMIUtilString threadCloneFn =
> CMIUtilString("__pthread_clone");
> >
> > - if (CMIUtilString::Compare(threadCloneFn, fnName))
> > + if (CMIUtilString::Compare(threadCloneFn, fnName))
> > + {
> > + if (sbProcess.IsValid())
> > {
> > - if (sbProcess.IsValid())
> > - {
> > - sbProcess.Continue();
> > - vwrbShouldBrk = true;
> > - break;
> > - }
> > + sbProcess.Continue();
> > + vwrbShouldBrk = true;
> > }
> > }
> > }
> > }
> > - default:
> > - {
> > - // MI print
> "*stopped,reason=\"signal-received\",signal=\"%lld\",thread-id=\"%d\",stopped-threads=\"all\""
> > - const CMICmnMIValueConst miValueConst("signal-received");
> > - const CMICmnMIValueResult miValueResult("reason",
> miValueConst);
> > - CMICmnMIOutOfBandRecord
> miOutOfBandRecord(CMICmnMIOutOfBandRecord::eOutOfBand_Stopped,
> miValueResult);
> > - const CMIUtilString strReason(CMIUtilString::Format("%lld",
> nStopReason));
> > - const CMICmnMIValueConst miValueConst2(strReason);
> > - const CMICmnMIValueResult miValueResult2("signal",
> miValueConst2);
> > - bOk = miOutOfBandRecord.Add(miValueResult2);
> > - const CMIUtilString strThreadId(CMIUtilString::Format("%d",
> sbProcess.GetSelectedThread().GetIndexID()));
> > - const CMICmnMIValueConst miValueConst3(strThreadId);
> > - const CMICmnMIValueResult miValueResult3("thread-id",
> miValueConst3);
> > - bOk = bOk && miOutOfBandRecord.Add(miValueResult3);
> > - const CMICmnMIValueConst miValueConst4("all");
> > - const CMICmnMIValueResult miValueResult4("stopped-threads",
> miValueConst4);
> > - bOk = bOk && miOutOfBandRecord.Add(miValueResult4);
> > - bOk = bOk && MiOutOfBandRecordToStdout(miOutOfBandRecord);
> > - bOk = bOk && TextToStdout("(gdb)");
> > - }
> > - } // switch( nStopReason )
> > -
> > + }
> > + else
> > + {
> > + // MI print
> "*stopped,reason=\"signal-received\",signal=\"%lld\",thread-id=\"%d\",stopped-threads=\"all\""
> > + const CMICmnMIValueConst miValueConst("signal-received");
> > + const CMICmnMIValueResult miValueResult("reason", miValueConst);
> > + CMICmnMIOutOfBandRecord
> miOutOfBandRecord(CMICmnMIOutOfBandRecord::eOutOfBand_Stopped,
> miValueResult);
> > + const CMIUtilString strReason(CMIUtilString::Format("%lld",
> nStopReason));
> > + const CMICmnMIValueConst miValueConst2(strReason);
> > + const CMICmnMIValueResult miValueResult2("signal",
> miValueConst2);
> > + bOk = miOutOfBandRecord.Add(miValueResult2);
> > + const CMIUtilString strThreadId(CMIUtilString::Format("%d",
> sbProcess.GetSelectedThread().GetIndexID()));
> > + const CMICmnMIValueConst miValueConst3(strThreadId);
> > + const CMICmnMIValueResult miValueResult3("thread-id",
> miValueConst3);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult3);
> > + const CMICmnMIValueConst miValueConst4("all");
> > + const CMICmnMIValueResult miValueResult4("stopped-threads",
> miValueConst4);
> > + bOk = bOk && miOutOfBandRecord.Add(miValueResult4);
> > + bOk = bOk && MiOutOfBandRecordToStdout(miOutOfBandRecord);
> > + bOk = bOk && TextToStdout("(gdb)");
> > + }
> > return bOk;
> > }
> >
> > @@ -1651,3 +1654,29 @@ CMICmnLLDBDebuggerHandleEvents::TextToSt
> > {
> > return CMICmnStreamStderr::TextToStderr(vrTxt);
> > }
> > +
> > +//++
> ------------------------------------------------------------------------------------
> > +// Details: Initialize the member variables with the signal values in
> this process
> > +// file.
> > +// Type: Method.
> > +// Args: None
> > +// Return: Noen
> > +// Throws: None.
> > +//--
> > +void
> > +CMICmnLLDBDebuggerHandleEvents::InitializeSignals()
> > +{
> > + if (!m_bSignalsInitialized)
> > + {
> > + lldb::SBProcess sbProcess =
> CMICmnLLDBDebugSessionInfo::Instance().GetProcess();
> > + if (sbProcess.IsValid())
> > + {
> > + lldb::SBUnixSignals unix_signals =
> sbProcess.GetUnixSignals();
> > + m_SIGINT = unix_signals.GetSignalNumberFromName("SIGINT");
> > + m_SIGSTOP = unix_signals.GetSignalNumberFromName("SIGSTOP");
> > + m_SIGSEGV = unix_signals.GetSignalNumberFromName("SIGSEGV");
> > + m_SIGTRAP = unix_signals.GetSignalNumberFromName("SIGTRAP");
> > + m_bSignalsInitialized = true;
> > + }
> > + }
> > +}
> >
> > Modified: lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.h
> > URL:
> http://llvm.org/viewvc/llvm-project/lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.h?rev=230237&r1=230236&r2=230237&view=diff
> >
> ==============================================================================
> > --- lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.h (original)
> > +++ lldb/trunk/tools/lldb-mi/MICmnLLDBDebuggerHandleEvents.h Mon Feb 23
> 12:27:17 2015
> > @@ -92,4 +92,10 @@ class CMICmnLLDBDebuggerHandleEvents : p
> > private:
> > // From CMICmnBase
> > /* dtor */ virtual ~CMICmnLLDBDebuggerHandleEvents(void);
> > + void InitializeSignals();
> > + bool m_bSignalsInitialized;
> > + MIuint64 m_SIGINT;
> > + MIuint64 m_SIGSTOP;
> > + MIuint64 m_SIGSEGV;
> > + MIuint64 m_SIGTRAP;
> > };
> >
> >
> > _______________________________________________
> > lldb-commits mailing list
> > lldb-commits at cs.uiuc.edu
> > http://lists.cs.uiuc.edu/mailman/listinfo/lldb-commits
> _______________________________________________
> lldb-commits mailing list
> lldb-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/lldb-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20150224/ba26b150/attachment.html>
More information about the lldb-commits
mailing list