mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-21 06:38:19 +00:00
report: Add a way to force backtraces on reports
And stop report simple debug message Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-devtools/-/merge_requests/172>
This commit is contained in:
parent
06793d1d34
commit
779817cb91
3 changed files with 46 additions and 9 deletions
|
@ -464,12 +464,17 @@ gst_validate_report_load_issues (void)
|
||||||
("Pad buffers push frequency is lower than the minimum required by the config"),
|
("Pad buffers push frequency is lower than the minimum required by the config"),
|
||||||
NULL);
|
NULL);
|
||||||
REGISTER_VALIDATE_ISSUE_FULL (WARNING, G_LOG_WARNING,
|
REGISTER_VALIDATE_ISSUE_FULL (WARNING, G_LOG_WARNING,
|
||||||
_("We got a g_log warning"), NULL, GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS);
|
_("We got a g_log warning"), NULL,
|
||||||
|
GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE |
|
||||||
|
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS);
|
||||||
REGISTER_VALIDATE_ISSUE_FULL (CRITICAL, G_LOG_CRITICAL,
|
REGISTER_VALIDATE_ISSUE_FULL (CRITICAL, G_LOG_CRITICAL,
|
||||||
"We got a g_log critical issue", NULL,
|
"We got a g_log critical issue", NULL,
|
||||||
|
GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE |
|
||||||
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS);
|
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS);
|
||||||
REGISTER_VALIDATE_ISSUE_FULL (ISSUE, G_LOG_ISSUE, "We got a g_log issue",
|
REGISTER_VALIDATE_ISSUE_FULL (ISSUE, G_LOG_ISSUE, "We got a g_log issue",
|
||||||
NULL, GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS);
|
NULL,
|
||||||
|
GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE |
|
||||||
|
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS);
|
||||||
|
|
||||||
REGISTER_VALIDATE_ISSUE (CRITICAL, PULL_RANGE_FROM_WRONG_THREAD,
|
REGISTER_VALIDATE_ISSUE (CRITICAL, PULL_RANGE_FROM_WRONG_THREAD,
|
||||||
"gst_pad_pull_range called from wrong thread",
|
"gst_pad_pull_range called from wrong thread",
|
||||||
|
@ -763,6 +768,34 @@ _report_free (GstValidateReport * report)
|
||||||
g_slice_free (GstValidateReport, report);
|
g_slice_free (GstValidateReport, report);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_validate_report_should_generate_backtrace (GstValidateIssue * issue,
|
||||||
|
GstValidateReport * report,
|
||||||
|
GstValidateReportingDetails default_details,
|
||||||
|
GstValidateReportingDetails issue_type_details,
|
||||||
|
GstValidateReportingDetails reporter_details)
|
||||||
|
{
|
||||||
|
if (issue->flags & GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
if (issue->flags & GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (default_details == GST_VALIDATE_SHOW_ALL)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
if (issue_type_details == GST_VALIDATE_SHOW_ALL)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
if (gst_validate_report_check_abort (report))
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
if (report->level == GST_VALIDATE_REPORT_LEVEL_CRITICAL)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
GstValidateReport *
|
GstValidateReport *
|
||||||
gst_validate_report_new (GstValidateIssue * issue,
|
gst_validate_report_new (GstValidateIssue * issue,
|
||||||
GstValidateReporter * reporter, const gchar * message)
|
GstValidateReporter * reporter, const gchar * message)
|
||||||
|
@ -802,11 +835,8 @@ gst_validate_report_new (GstValidateIssue * issue,
|
||||||
reporter_details != GST_VALIDATE_SHOW_UNKNOWN)
|
reporter_details != GST_VALIDATE_SHOW_UNKNOWN)
|
||||||
return report;
|
return report;
|
||||||
|
|
||||||
if ((default_details == GST_VALIDATE_SHOW_ALL ||
|
if (gst_validate_report_should_generate_backtrace (issue, report,
|
||||||
issue_type_details == GST_VALIDATE_SHOW_ALL ||
|
default_details, issue_type_details, reporter_details))
|
||||||
gst_validate_report_check_abort (report) ||
|
|
||||||
report->level == GST_VALIDATE_REPORT_LEVEL_CRITICAL) &&
|
|
||||||
(!(issue->flags & GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE)))
|
|
||||||
report->trace = gst_debug_get_stack_trace (GST_STACK_TRACE_SHOW_FULL);
|
report->trace = gst_debug_get_stack_trace (GST_STACK_TRACE_SHOW_FULL);
|
||||||
|
|
||||||
return report;
|
return report;
|
||||||
|
|
|
@ -157,6 +157,15 @@ typedef enum {
|
||||||
GST_VALIDATE_ISSUE_FLAGS_NONE = 0,
|
GST_VALIDATE_ISSUE_FLAGS_NONE = 0,
|
||||||
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS = 1 << 0,
|
GST_VALIDATE_ISSUE_FLAGS_FULL_DETAILS = 1 << 0,
|
||||||
GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE = 1 << 1,
|
GST_VALIDATE_ISSUE_FLAGS_NO_BACKTRACE = 1 << 1,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE:
|
||||||
|
*
|
||||||
|
* Always generate backtrace, even if not a critical issue
|
||||||
|
*
|
||||||
|
* Since: 1.20
|
||||||
|
*/
|
||||||
|
GST_VALIDATE_ISSUE_FLAGS_FORCE_BACKTRACE = 1 << 2,
|
||||||
} GstValidateIssueFlags;
|
} GstValidateIssueFlags;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
|
|
@ -299,8 +299,6 @@ gst_validate_reporter_g_log_func (const gchar * log_domain,
|
||||||
GST_VALIDATE_REPORT (reporter, G_LOG_CRITICAL, "%s", message);
|
GST_VALIDATE_REPORT (reporter, G_LOG_CRITICAL, "%s", message);
|
||||||
else if (log_level & G_LOG_LEVEL_WARNING)
|
else if (log_level & G_LOG_LEVEL_WARNING)
|
||||||
GST_VALIDATE_REPORT (reporter, G_LOG_WARNING, "%s", message);
|
GST_VALIDATE_REPORT (reporter, G_LOG_WARNING, "%s", message);
|
||||||
else
|
|
||||||
GST_VALIDATE_REPORT (reporter, G_LOG_ISSUE, "%s", message);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue