You've already forked lazarus-ccr
lazstacktrace: Utility program to convert stacktraces address into symbol names
git-svn-id: https://svn.code.sf.net/p/lazarus-ccr/svn@1826 8e941d3f-bd1b-0410-a28a-d453659cc2b4
This commit is contained in:
BIN
applications/lazstacktrace/lazstacktrace.ico
Normal file
BIN
applications/lazstacktrace/lazstacktrace.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 134 KiB |
235
applications/lazstacktrace/lazstacktrace.lpi
Normal file
235
applications/lazstacktrace/lazstacktrace.lpi
Normal file
@ -0,0 +1,235 @@
|
||||
<?xml version="1.0"?>
|
||||
<CONFIG>
|
||||
<ProjectOptions>
|
||||
<Version Value="9"/>
|
||||
<General>
|
||||
<MainUnit Value="0"/>
|
||||
<ResourceType Value="res"/>
|
||||
<UseXPManifest Value="True"/>
|
||||
<Icon Value="0"/>
|
||||
<ActiveWindowIndexAtStart Value="0"/>
|
||||
</General>
|
||||
<i18n>
|
||||
<EnableI18N LFM="False"/>
|
||||
</i18n>
|
||||
<VersionInfo>
|
||||
<StringTable ProductVersion=""/>
|
||||
</VersionInfo>
|
||||
<BuildModes Count="1" Active="Default">
|
||||
<Item1 Name="Default" Default="True"/>
|
||||
</BuildModes>
|
||||
<PublishOptions>
|
||||
<Version Value="2"/>
|
||||
<IncludeFileFilter Value="*.(pas|pp|inc|lfm|lpr|lrs|lpi|lpk|sh|xml)"/>
|
||||
<ExcludeFileFilter Value="*.(bak|ppu|o|so);*~;backup"/>
|
||||
</PublishOptions>
|
||||
<RunParams>
|
||||
<local>
|
||||
<FormatVersion Value="1"/>
|
||||
<LaunchingApplication PathPlusParams="/usr/bin/xterm -T 'Lazarus Run Output' -e $(LazarusDir)/tools/runwait.sh $(TargetCmdLine)"/>
|
||||
</local>
|
||||
</RunParams>
|
||||
<RequiredPackages Count="1">
|
||||
<Item1>
|
||||
<PackageName Value="LCL"/>
|
||||
</Item1>
|
||||
</RequiredPackages>
|
||||
<Units Count="4">
|
||||
<Unit0>
|
||||
<Filename Value="lazstacktrace.lpr"/>
|
||||
<IsPartOfProject Value="True"/>
|
||||
<UnitName Value="lazstacktrace"/>
|
||||
<UsageCount Value="21"/>
|
||||
</Unit0>
|
||||
<Unit1>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<IsPartOfProject Value="True"/>
|
||||
<ComponentName Value="Form1"/>
|
||||
<ResourceBaseClass Value="Form"/>
|
||||
<UnitName Value="mainform"/>
|
||||
<IsVisibleTab Value="True"/>
|
||||
<EditorIndex Value="0"/>
|
||||
<WindowIndex Value="0"/>
|
||||
<TopLine Value="30"/>
|
||||
<CursorPos X="18" Y="33"/>
|
||||
<UsageCount Value="21"/>
|
||||
<Loaded Value="True"/>
|
||||
<LoadedDesigner Value="True"/>
|
||||
</Unit1>
|
||||
<Unit2>
|
||||
<Filename Value="../../../lazarus/lcl/include/control.inc"/>
|
||||
<WindowIndex Value="0"/>
|
||||
<TopLine Value="2262"/>
|
||||
<CursorPos X="1" Y="2286"/>
|
||||
<UsageCount Value="10"/>
|
||||
<DefaultSyntaxHighlighter Value="Delphi"/>
|
||||
</Unit2>
|
||||
<Unit3>
|
||||
<Filename Value="/usr/share/fpcsrc/packages/fcl-process/src/process.pp"/>
|
||||
<UnitName Value="process"/>
|
||||
<EditorIndex Value="1"/>
|
||||
<WindowIndex Value="0"/>
|
||||
<TopLine Value="1"/>
|
||||
<CursorPos X="48" Y="25"/>
|
||||
<UsageCount Value="10"/>
|
||||
<Loaded Value="True"/>
|
||||
<DefaultSyntaxHighlighter Value="Delphi"/>
|
||||
</Unit3>
|
||||
</Units>
|
||||
<JumpHistory Count="30" HistoryIndex="29">
|
||||
<Position1>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="56" Column="1" TopLine="30"/>
|
||||
</Position1>
|
||||
<Position2>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="57" Column="1" TopLine="30"/>
|
||||
</Position2>
|
||||
<Position3>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="55" Column="1" TopLine="30"/>
|
||||
</Position3>
|
||||
<Position4>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="56" Column="1" TopLine="30"/>
|
||||
</Position4>
|
||||
<Position5>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="57" Column="1" TopLine="30"/>
|
||||
</Position5>
|
||||
<Position6>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="55" Column="1" TopLine="30"/>
|
||||
</Position6>
|
||||
<Position7>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="56" Column="1" TopLine="30"/>
|
||||
</Position7>
|
||||
<Position8>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="57" Column="1" TopLine="30"/>
|
||||
</Position8>
|
||||
<Position9>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="58" Column="1" TopLine="30"/>
|
||||
</Position9>
|
||||
<Position10>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="61" Column="1" TopLine="30"/>
|
||||
</Position10>
|
||||
<Position11>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="62" Column="1" TopLine="30"/>
|
||||
</Position11>
|
||||
<Position12>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="63" Column="1" TopLine="30"/>
|
||||
</Position12>
|
||||
<Position13>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="64" Column="1" TopLine="30"/>
|
||||
</Position13>
|
||||
<Position14>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="65" Column="1" TopLine="30"/>
|
||||
</Position14>
|
||||
<Position15>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="68" Column="1" TopLine="30"/>
|
||||
</Position15>
|
||||
<Position16>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="73" Column="7" TopLine="30"/>
|
||||
</Position16>
|
||||
<Position17>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="68" Column="1" TopLine="30"/>
|
||||
</Position17>
|
||||
<Position18>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="64" Column="17" TopLine="30"/>
|
||||
</Position18>
|
||||
<Position19>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="66" Column="1" TopLine="30"/>
|
||||
</Position19>
|
||||
<Position20>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="67" Column="1" TopLine="30"/>
|
||||
</Position20>
|
||||
<Position21>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="68" Column="1" TopLine="30"/>
|
||||
</Position21>
|
||||
<Position22>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="64" Column="93" TopLine="30"/>
|
||||
</Position22>
|
||||
<Position23>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="66" Column="1" TopLine="30"/>
|
||||
</Position23>
|
||||
<Position24>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="67" Column="1" TopLine="30"/>
|
||||
</Position24>
|
||||
<Position25>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="71" Column="1" TopLine="30"/>
|
||||
</Position25>
|
||||
<Position26>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="33" Column="18" TopLine="30"/>
|
||||
</Position26>
|
||||
<Position27>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="32" Column="18" TopLine="29"/>
|
||||
</Position27>
|
||||
<Position28>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="33" Column="18" TopLine="30"/>
|
||||
</Position28>
|
||||
<Position29>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="34" Column="18" TopLine="31"/>
|
||||
</Position29>
|
||||
<Position30>
|
||||
<Filename Value="mainform.pas"/>
|
||||
<Caret Line="33" Column="18" TopLine="30"/>
|
||||
</Position30>
|
||||
</JumpHistory>
|
||||
</ProjectOptions>
|
||||
<CompilerOptions>
|
||||
<Version Value="10"/>
|
||||
<Target>
|
||||
<Filename Value="lazstacktrace"/>
|
||||
</Target>
|
||||
<SearchPaths>
|
||||
<IncludeFiles Value="$(ProjOutDir)"/>
|
||||
<UnitOutputDirectory Value="lib/$(TargetCPU)-$(TargetOS)"/>
|
||||
</SearchPaths>
|
||||
<Linking>
|
||||
<Options>
|
||||
<Win32>
|
||||
<GraphicApplication Value="True"/>
|
||||
</Win32>
|
||||
</Options>
|
||||
</Linking>
|
||||
<Other>
|
||||
<CompilerPath Value="$(CompPath)"/>
|
||||
</Other>
|
||||
</CompilerOptions>
|
||||
<Debugging>
|
||||
<Exceptions Count="3">
|
||||
<Item1>
|
||||
<Name Value="EAbort"/>
|
||||
</Item1>
|
||||
<Item2>
|
||||
<Name Value="ECodetoolError"/>
|
||||
</Item2>
|
||||
<Item3>
|
||||
<Name Value="EFOpenError"/>
|
||||
</Item3>
|
||||
</Exceptions>
|
||||
</Debugging>
|
||||
</CONFIG>
|
21
applications/lazstacktrace/lazstacktrace.lpr
Normal file
21
applications/lazstacktrace/lazstacktrace.lpr
Normal file
@ -0,0 +1,21 @@
|
||||
program lazstacktrace;
|
||||
|
||||
{$mode objfpc}{$H+}
|
||||
|
||||
uses
|
||||
{$IFDEF UNIX}{$IFDEF UseCThreads}
|
||||
cthreads,
|
||||
{$ENDIF}{$ENDIF}
|
||||
Interfaces, // this includes the LCL widgetset
|
||||
Forms, mainform
|
||||
{ you can add units after this };
|
||||
|
||||
{$R *.res}
|
||||
|
||||
begin
|
||||
RequireDerivedFormResource := True;
|
||||
Application.Initialize;
|
||||
Application.CreateForm(TForm1, Form1);
|
||||
Application.Run;
|
||||
end.
|
||||
|
BIN
applications/lazstacktrace/lazstacktrace.res
Normal file
BIN
applications/lazstacktrace/lazstacktrace.res
Normal file
Binary file not shown.
99
applications/lazstacktrace/mainform.lfm
Normal file
99
applications/lazstacktrace/mainform.lfm
Normal file
@ -0,0 +1,99 @@
|
||||
object Form1: TForm1
|
||||
Left = 313
|
||||
Height = 447
|
||||
Top = 186
|
||||
Width = 400
|
||||
Caption = 'Stacktrace resolver'
|
||||
ClientHeight = 447
|
||||
ClientWidth = 400
|
||||
LCLVersion = '0.9.31'
|
||||
object editGDBPath: TFileNameEdit
|
||||
Left = 104
|
||||
Height = 25
|
||||
Top = 56
|
||||
Width = 264
|
||||
FileName = '/usr/bin/gdb'
|
||||
DialogOptions = []
|
||||
FilterIndex = 0
|
||||
HideDirectories = False
|
||||
ButtonWidth = 23
|
||||
NumGlyphs = 0
|
||||
MaxLength = 0
|
||||
TabOrder = 0
|
||||
end
|
||||
object Label1: TLabel
|
||||
Left = 11
|
||||
Height = 18
|
||||
Top = 63
|
||||
Width = 83
|
||||
Caption = 'Path to GDB:'
|
||||
ParentColor = False
|
||||
end
|
||||
object Label2: TLabel
|
||||
Left = 9
|
||||
Height = 39
|
||||
Top = 9
|
||||
Width = 381
|
||||
AutoSize = False
|
||||
Caption = 'This Program resolves stacktraces generated by FPC apps using GDB. It adds the symbol names to addresses.'
|
||||
ParentColor = False
|
||||
WordWrap = True
|
||||
end
|
||||
object Label3: TLabel
|
||||
Left = 11
|
||||
Height = 18
|
||||
Top = 120
|
||||
Width = 78
|
||||
Caption = 'Stack trace:'
|
||||
ParentColor = False
|
||||
end
|
||||
object memoStacktrace: TMemo
|
||||
AnchorSideRight.Control = Owner
|
||||
AnchorSideRight.Side = asrBottom
|
||||
AnchorSideBottom.Control = Owner
|
||||
AnchorSideBottom.Side = asrBottom
|
||||
Left = 8
|
||||
Height = 260
|
||||
Top = 143
|
||||
Width = 387
|
||||
Anchors = [akLeft, akRight, akBottom]
|
||||
BorderSpacing.Right = 5
|
||||
BorderSpacing.Bottom = 44
|
||||
TabOrder = 1
|
||||
end
|
||||
object buttonResolveSymbols: TButton
|
||||
AnchorSideBottom.Control = Owner
|
||||
AnchorSideBottom.Side = asrBottom
|
||||
Left = 136
|
||||
Height = 30
|
||||
Top = 412
|
||||
Width = 123
|
||||
Anchors = [akLeft, akBottom]
|
||||
BorderSpacing.Bottom = 5
|
||||
Caption = 'Resolve Symbols'
|
||||
OnClick = buttonResolveSymbolsClick
|
||||
TabOrder = 2
|
||||
end
|
||||
object Label4: TLabel
|
||||
Left = 11
|
||||
Height = 18
|
||||
Top = 95
|
||||
Width = 109
|
||||
Caption = 'Path to Program:'
|
||||
ParentColor = False
|
||||
end
|
||||
object editProgramPath: TFileNameEdit
|
||||
Left = 128
|
||||
Height = 25
|
||||
Top = 95
|
||||
Width = 240
|
||||
FileName = '/home/felipe/Programas/lazarus-ccr/examples/androidlcl/android/libs/armeabi/libandroidlcltest.so'
|
||||
DialogOptions = []
|
||||
FilterIndex = 0
|
||||
HideDirectories = False
|
||||
ButtonWidth = 23
|
||||
NumGlyphs = 0
|
||||
MaxLength = 0
|
||||
TabOrder = 3
|
||||
end
|
||||
end
|
81
applications/lazstacktrace/mainform.pas
Normal file
81
applications/lazstacktrace/mainform.pas
Normal file
@ -0,0 +1,81 @@
|
||||
unit mainform;
|
||||
|
||||
{$mode objfpc}{$H+}
|
||||
|
||||
interface
|
||||
|
||||
uses
|
||||
Classes, SysUtils, FileUtil, Forms, Controls, Graphics, Dialogs, EditBtn,
|
||||
StdCtrls, process;
|
||||
|
||||
type
|
||||
|
||||
{ TForm1 }
|
||||
|
||||
TForm1 = class(TForm)
|
||||
buttonResolveSymbols: TButton;
|
||||
editGDBPath: TFileNameEdit;
|
||||
editProgramPath: TFileNameEdit;
|
||||
Label1: TLabel;
|
||||
Label2: TLabel;
|
||||
Label3: TLabel;
|
||||
Label4: TLabel;
|
||||
memoStacktrace: TMemo;
|
||||
procedure buttonResolveSymbolsClick(Sender: TObject);
|
||||
private
|
||||
{ private declarations }
|
||||
public
|
||||
{ public declarations }
|
||||
end;
|
||||
|
||||
var
|
||||
Form1: TForm1;
|
||||
|
||||
implementation
|
||||
|
||||
{$R *.lfm}
|
||||
|
||||
{ TForm1 }
|
||||
|
||||
procedure TForm1.buttonResolveSymbolsClick(Sender: TObject);
|
||||
var
|
||||
GDBProcess: TProcess;
|
||||
GDBOutput: TStringList;
|
||||
Str, StackStr, lCurAddress: string;
|
||||
lAddressPos: SizeInt;
|
||||
i: Integer;
|
||||
StrGdbOutput: String;
|
||||
begin
|
||||
GDBProcess := TProcess.Create(nil);
|
||||
GDBOutput := TStringList.Create;
|
||||
memoStacktrace.Lines.BeginUpdate;
|
||||
try
|
||||
for i := 0 to memoStacktrace.Lines.Count - 1 do
|
||||
begin
|
||||
// Obtain the stack address or skip this line
|
||||
StackStr := memoStacktrace.Lines.Strings[i];
|
||||
lAddressPos := Pos('$', StackStr);
|
||||
if lAddressPos <= 0 then Continue;
|
||||
lCurAddress := Copy(StackStr, lAddressPos+1, 8);
|
||||
|
||||
// Run GDB to get the symbol name
|
||||
Str := Format('%s --batch "--eval-command=info symbol 0x%s" %s', [editGDBPath.FileName, lCurAddress, editProgramPath.FileName]);
|
||||
GDBProcess.CommandLine := Str;
|
||||
GDBProcess.Options := GDBProcess.Options + [poWaitOnExit, poUsePipes, poStderrToOutPut];
|
||||
GDBProcess.Execute;
|
||||
GDBOutput.LoadFromStream(GDBProcess.Output);
|
||||
if GDBOutput.Count >= 1 then StrGdbOutput := GDBOutput.Strings[0]
|
||||
else StrGdbOutput := '';
|
||||
|
||||
// Add the symbol name to the memo
|
||||
memoStacktrace.Lines.Strings[i] := Format('%s %s', [StackStr, StrGdbOutput]);
|
||||
end;
|
||||
finally
|
||||
GDBProcess.Free;
|
||||
GDBOutput.Free;
|
||||
memoStacktrace.Lines.EndUpdate;
|
||||
end;
|
||||
end;
|
||||
|
||||
end.
|
||||
|
Reference in New Issue
Block a user