jasonmolenda created this revision.
jasonmolenda added a reviewer: jingham.
jasonmolenda added a project: LLDB.
Herald added a subscriber: JDevlieghere.
jasonmolenda requested review of this revision.
When developing LanguageRuntime plugin unwind plans, it is sometimes helpful to
work with the concrete stacks. This setting allows for that behavior.
Jim, mostly this is a question of the name of the setting, I think. I never
know how to name these things, we seem to have a wide variety of setting name
styles. I don't know what might be considered better than other possibilities.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D99828
Files:
lldb/include/lldb/Target/Process.h
lldb/source/Target/LanguageRuntime.cpp
lldb/source/Target/Process.cpp
lldb/source/Target/TargetProperties.td
Index: lldb/source/Target/TargetProperties.td
===================================================================
--- lldb/source/Target/TargetProperties.td
+++ lldb/source/Target/TargetProperties.td
@@ -206,6 +206,10 @@
Global,
DefaultFalse,
Desc<"If true, stop when a shared library is loaded or unloaded.">;
+ def DisableLangRuntimeUnwindPlans:
Property<"disable-language-runtime-unwindplans", "Boolean">,
+ Global,
+ DefaultFalse,
+ Desc<"If true, LanguageRuntime plugins' UnwindPlans will not be used when
backtracing.">;
def DetachKeepsStopped: Property<"detach-keeps-stopped", "Boolean">,
Global,
DefaultFalse,
Index: lldb/source/Target/Process.cpp
===================================================================
--- lldb/source/Target/Process.cpp
+++ lldb/source/Target/Process.cpp
@@ -238,6 +238,18 @@
m_collection_sp->SetPropertyAtIndexAsBoolean(nullptr, idx, stop);
}
+bool ProcessProperties::GetDisableLangRuntimeUnwindPlans() const {
+ const uint32_t idx = ePropertyDisableLangRuntimeUnwindPlans;
+ return m_collection_sp->GetPropertyAtIndexAsBoolean(
+ nullptr, idx, g_process_properties[idx].default_uint_value != 0);
+}
+
+void ProcessProperties::SetDisableLangRuntimeUnwindPlans(bool disable) {
+ const uint32_t idx = ePropertyDisableLangRuntimeUnwindPlans;
+ m_collection_sp->SetPropertyAtIndexAsBoolean(nullptr, idx, disable);
+ m_process->Flush();
+}
+
bool ProcessProperties::GetDetachKeepsStopped() const {
const uint32_t idx = ePropertyDetachKeepsStopped;
return m_collection_sp->GetPropertyAtIndexAsBoolean(
Index: lldb/source/Target/LanguageRuntime.cpp
===================================================================
--- lldb/source/Target/LanguageRuntime.cpp
+++ lldb/source/Target/LanguageRuntime.cpp
@@ -265,6 +265,8 @@
ProcessSP process_sp = thread.GetProcess();
if (!process_sp.get())
return UnwindPlanSP();
+ if (process_sp->GetDisableLangRuntimeUnwindPlans() == true)
+ return UnwindPlanSP();
for (const lldb::LanguageType lang_type : Language::GetSupportedLanguages())
{
if (LanguageRuntime *runtime = process_sp->GetLanguageRuntime(lang_type)) {
UnwindPlanSP plan_sp = runtime->GetRuntimeUnwindPlan(
Index: lldb/include/lldb/Target/Process.h
===================================================================
--- lldb/include/lldb/Target/Process.h
+++ lldb/include/lldb/Target/Process.h
@@ -84,6 +84,8 @@
void SetUnwindOnErrorInExpressions(bool ignore);
bool GetStopOnSharedLibraryEvents() const;
void SetStopOnSharedLibraryEvents(bool stop);
+ bool GetDisableLangRuntimeUnwindPlans() const;
+ void SetDisableLangRuntimeUnwindPlans(bool disable);
bool GetDetachKeepsStopped() const;
void SetDetachKeepsStopped(bool keep_stopped);
bool GetWarningsOptimization() const;
Index: lldb/source/Target/TargetProperties.td
===================================================================
--- lldb/source/Target/TargetProperties.td
+++ lldb/source/Target/TargetProperties.td
@@ -206,6 +206,10 @@
Global,
DefaultFalse,
Desc<"If true, stop when a shared library is loaded or unloaded.">;
+ def DisableLangRuntimeUnwindPlans: Property<"disable-language-runtime-unwindplans", "Boolean">,
+ Global,
+ DefaultFalse,
+ Desc<"If true, LanguageRuntime plugins' UnwindPlans will not be used when backtracing.">;
def DetachKeepsStopped: Property<"detach-keeps-stopped", "Boolean">,
Global,
DefaultFalse,
Index: lldb/source/Target/Process.cpp
===================================================================
--- lldb/source/Target/Process.cpp
+++ lldb/source/Target/Process.cpp
@@ -238,6 +238,18 @@
m_collection_sp->SetPropertyAtIndexAsBoolean(nullptr, idx, stop);
}
+bool ProcessProperties::GetDisableLangRuntimeUnwindPlans() const {
+ const uint32_t idx = ePropertyDisableLangRuntimeUnwindPlans;
+ return m_collection_sp->GetPropertyAtIndexAsBoolean(
+ nullptr, idx, g_process_properties[idx].default_uint_value != 0);
+}
+
+void ProcessProperties::SetDisableLangRuntimeUnwindPlans(bool disable) {
+ const uint32_t idx = ePropertyDisableLangRuntimeUnwindPlans;
+ m_collection_sp->SetPropertyAtIndexAsBoolean(nullptr, idx, disable);
+ m_process->Flush();
+}
+
bool ProcessProperties::GetDetachKeepsStopped() const {
const uint32_t idx = ePropertyDetachKeepsStopped;
return m_collection_sp->GetPropertyAtIndexAsBoolean(
Index: lldb/source/Target/LanguageRuntime.cpp
===================================================================
--- lldb/source/Target/LanguageRuntime.cpp
+++ lldb/source/Target/LanguageRuntime.cpp
@@ -265,6 +265,8 @@
ProcessSP process_sp = thread.GetProcess();
if (!process_sp.get())
return UnwindPlanSP();
+ if (process_sp->GetDisableLangRuntimeUnwindPlans() == true)
+ return UnwindPlanSP();
for (const lldb::LanguageType lang_type : Language::GetSupportedLanguages()) {
if (LanguageRuntime *runtime = process_sp->GetLanguageRuntime(lang_type)) {
UnwindPlanSP plan_sp = runtime->GetRuntimeUnwindPlan(
Index: lldb/include/lldb/Target/Process.h
===================================================================
--- lldb/include/lldb/Target/Process.h
+++ lldb/include/lldb/Target/Process.h
@@ -84,6 +84,8 @@
void SetUnwindOnErrorInExpressions(bool ignore);
bool GetStopOnSharedLibraryEvents() const;
void SetStopOnSharedLibraryEvents(bool stop);
+ bool GetDisableLangRuntimeUnwindPlans() const;
+ void SetDisableLangRuntimeUnwindPlans(bool disable);
bool GetDetachKeepsStopped() const;
void SetDetachKeepsStopped(bool keep_stopped);
bool GetWarningsOptimization() const;
_______________________________________________
lldb-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits