Skip to content

Commit

Permalink
Added support for lldb core analysis in mtr
Browse files Browse the repository at this point in the history
  • Loading branch information
svoj authored and vaintroub committed May 21, 2018
1 parent a1d57ca commit 9692f37
Showing 1 changed file with 39 additions and 0 deletions.
39 changes: 39 additions & 0 deletions mysql-test/lib/My/CoreDump.pm
Original file line number Diff line number Diff line change
Expand Up @@ -264,6 +264,44 @@ EOF
}


sub _lldb
{
my ($core_name)= @_;

print "\nTrying 'lldb' to get a backtrace from coredump $core_name\n";

# Create tempfile containing lldb commands
my ($tmp, $tmp_name)= tempfile();
print $tmp
"bt\n",
"thread backtrace all\n",
"quit\n";
close $tmp or die "Error closing $tmp_name: $!";

my $lldb_output= `lldb -c '$core_name' -s '$tmp_name' 2>&1`;

unlink $tmp_name or die "Error removing $tmp_name: $!";

if ($? == 127)
{
print "lldb not found, cannot get the stack trace\n";
return;
}

return if $?;
return unless $lldb_output;

resfile_print <<EOF . $lldb_output . "\n";
Output from lldb follows. The first stack trace is from the failing thread.
The following stack traces are from all threads (so the failing one is
duplicated).
--------------------------
EOF
return 1;
}



sub show {
my ($class, $core_name, $exe_mysqld, $parallel)= @_;
$hint_mysqld= $exe_mysqld;
Expand All @@ -282,6 +320,7 @@ sub show {
(
\&_dbx,
\&_gdb,
\&_lldb,
# TODO...
);

Expand Down

0 comments on commit 9692f37

Please sign in to comment.