[Ubuntu Wiki] Update of "DebuggingProgramCrash" by penalvch

Ubuntu Wiki noreply at ubuntu.com
Wed Dec 24 01:55:09 UTC 2014


Dear Wiki user,

You have subscribed to a wiki page or wiki category on "Ubuntu Wiki" for change notification.

The "DebuggingProgramCrash" page has been changed by penalvch:
http://wiki.ubuntu.com/DebuggingProgramCrash?action=diff&rev1=120&rev2=121

Comment:
1) Sectionized debug symbol installations. 2) Added distinctive support note on dbg/dbgsym overlap may cause issues. 3) Misc. presentation fixes.

  <<Include(Debugging/Header)>>
  ||<tablestyle="float:right; font-size: 0.9em; width:40%; background:#F1F1ED; margin: 0 0 1em 1em;" style="padding:0.5em;"><<TableOfContents>>||
  
- This document describes how to debug Ubuntu package crashes and install debug packages on Ubuntu, which will aid in providing information for bugs.
+ = Introduction =
  
+ This document describes how to install debug packages on Ubuntu, allowing one to provide information regarding providing detailed information when manually performing:
+  1. A [[Backtrace]].
+  1. A [[Valgrind]], if the program crashes with a "Segmentation fault" or "Bus error".
+  1. An [[Strace]].
+ 
- == Using apport-retrace ==
+ = Using apport-retrace =
  
  If you want to debug a crash in packaged Ubuntu software, [[https://wiki.ubuntu.com/Apport|Apport]] will usually pick it up, create a `.crash` report in `/var/crash/` and report the crashed program. From there it is easiest to use [[http://manpages.ubuntu.com/apport-retrace|apport-retrace]].
  
@@ -31, +36 @@

  
  If you do not want an interactive gdb session but just want it to update the already existing `.crash` file with fully symbolic stack traces, you can select the third option.
  
+ = Installing debug symbols manually =
- == Debug Symbol Packages ==
- If you want to debug a crash in a project you are developing yourself or from a third-party package, or need the debug symbols for particular libraries very often, it is helpful to install those permanently into your system.
  
- First, check if there is a package with a -dbg suffix in the main Ubuntu repositories. These are the debug symbol packages, and are equivalent to '-dbgsym' described below. You can safely use either one, but not both at once. Try installing the package, adding -dbg to its name, for example:
- {{{
+ If you want to debug a crash from an application provided by Ubuntu, you are developing yourself, provided by a third-party, or need the debug symbols for particular libraries very often, it is helpful to install the relevant debugging packages.
+ 
+ == Built-in debug symbol packages (*-dbg) ==
+ 
+ For many, but not all, packages, one can simply add a -dbg suffix to the package name to install it. For example:{{{
  sudo apt-get install xserver-xorg-core-dbg
  }}}
- if the package in question is the ''xserver-xorg-core'' package.
  
- If there is no -dbg package:
+ == Non-built-in debug symbol packages (*-dbgsym) ==
  
+ For additional debug symbols that are not built-in, one must add an additional repository. /!\ Please take care to not install both debug symbols for a given package name, as this may cause problems. Your package manager will not check for this overlap and prevent it from happening. For example:{{{
+ libprotobuf-c1-dbg
+ libprotobuf-c1-dbgsym
+ }}} Here are the steps to add this repository:
-  1. Create an `/etc/apt/sources.list.d/ddebs.list` by running the following line at a terminal: {{{
+  1. Create an `/etc/apt/sources.list.d/ddebs.list` by running the following line at a terminal:{{{
- echo "deb http://ddebs.ubuntu.com $(lsb_release -cs) main restricted universe multiverse" | sudo tee -a /etc/apt/sources.list.d/ddebs.list }}}
+ echo "deb http://ddebs.ubuntu.com $(lsb_release -cs) main restricted universe multiverse" | sudo tee -a /etc/apt/sources.list.d/ddebs.list
+ }}}
-  1. Stable releases (not alphas and betas) require two more lines adding to the same file, which is done by the following terminal command: {{{
+  1. Stable releases (not development, alphas, or betas) require two more lines adding to the same file, which is done by the following terminal command:{{{
  echo "deb http://ddebs.ubuntu.com $(lsb_release -cs)-updates main restricted universe multiverse
- deb http://ddebs.ubuntu.com $(lsb_release -cs)-proposed main restricted universe multiverse" | sudo tee -a /etc/apt/sources.list.d/ddebs.list }}}
+ deb http://ddebs.ubuntu.com $(lsb_release -cs)-proposed main restricted universe multiverse" | sudo tee -a /etc/apt/sources.list.d/ddebs.list
+ }}} You may also add these lines using the Synaptic Package Manager:
+  * Choose ''Synaptic'' via the ''System > Administration'' menu.
+  * Choose ''Software Sources'' or ''Repositories'' via the ''Settings'' menu, and click on the ''Third-Party Software'' tab.
+  * Click the ''Add'' button and enter each ''deb ...'' line as above one by one and click the ''Add Source'' button (you will have to add these lines one at a time).
+  1. Import the debug symbol archive signing key:{{{
+ sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 428D7C01
+ }}}
+  1. Then run:{{{
+ sudo apt-get update
+ }}} to update your package list or click the ''Reload'' button if you used the Synaptic Package Manager.
+  1. The debug symbol packages have the '-dbgsym' suffix attached, so to install the debug symbols for the yelp package, you first run:{{{
+ apt-cache policy yelp
+ }}} This will show you the version number currently installed (we'll use 2.22.1-0ubuntu2.8.04.1 in this example). '''NOTE:''' yelp (which is the package name of "Help and Support" located under the 'System' menu) is just an example, and would have to be replaced by the name of the package you want to debug.
+  1. Install the debug symbols:{{{
+ sudo apt-get install yelp-dbgsym=2.22.1-0ubuntu2.8.04.1
+ }}} You can also use the Synaptic Package Manager to search for yelp-dbgsym and install it from there.
  
+ == Manually finding required debug symbols ==
-  You may also add these lines using the Synaptic Package Manager:
-   * Choose ''Synaptic'' via the ''System > Administration'' menu.
-   * Choose ''Software Sources'' or ''Repositories'' via the ''Settings'' menu, and click on the ''Third-Party Software'' tab.
-   * Click the ''Add'' button and enter each ''deb ...'' line as above one by one and click the ''Add Source'' button (you will have to add these lines one at a time).
  
-  1. Import the debug symbol archive signing key: {{{
- sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 428D7C01 }}}
+ The above procedure will install the debug symbol package for yelp only. For many packages, they use libraries shared between different packages. Hence, in order to obtain a readable/more readable stacktrace, or perform other debugging tasks, one must find the debug symbols for these shared libraries. For example, if one had attached gdb to an application and got the following output:{{{
+ Reading symbols from /usr/lib/x86_64-linux-gnu/libffi.so.6...(no debugging symbols found)...done.
+ Loaded symbols for /usr/lib/x86_64-linux-gnu/libffi.so.6
+ }}} This would indicate that the relevant debug symbols are not installed. However, this by itself wouldn't necessarily be enough information to know which package exactly needs the debug symbols. Hence, one may go to [[http://packages.ubuntu.com/]] and paste into the "Search the contents of packages" keyword box:{{{
+ x86_64-linux-gnu/libffi.so.6
+ }}} choose the appropriate Distribution from the drop down, and click Search. This would reveal that the package is libffi6. A check in Synaptic reveals the debug package libffi6-dbg.
  
+ == Automatically installing all debug symbols ==
-  1. Then run: {{{
- sudo apt-get update }}}
-  to update your package list or click the ''Reload'' button if you used the Synaptic Package Manager.
  
-  1. The debug symbol packages have the '-dbgsym' suffix attached, so to install the debug symbols for the package 'yelp', you first run: {{{
- apt-cache policy yelp }}}
-  This will show you the version number currently installed (we'll use 2.22.1-0ubuntu2.8.04.1 in this example).
-  '''NOTE:''' 'yelp' [which is the package name of "Help and Support" located under the 'System' menu] is ''just an example'' and '''not''' a part of the command: 'yelp' is only used to demonstrate the procedure. You must replace 'yelp' with the name of the package you want to debug.
+ This procedure would install every debug symbols, versus only the ones you may need, or are interested in. You can download the following [[attachment:list-symbols-packages-v2.1.sh |shell script (list-symbols-packages-v2.1.sh)]] to resolve all the dependencies. Attaching a debugger to an already running process may require elevated privileges even if you own the process. The following invocation will print out the list of files to install.
+ {{{
+ sudo bash ./list-symbols-packages-v2.sh -p $(pidof yelp)
+ }}} To automatically install them apt can be called with the input from the script. The script is invoked with {{{-t}}} for a terse output without the descriptions of the packages and error messages are suppressed:{{{
+ sudo bash ./list-symbols-packages-v2.sh -t -p $(pidof yelp) 2>/dev/null | xargs -d $'\n' sudo apt-get install }}} /!\ Version 2 of this script makes it compatible with the newer GDB (which no longer loads all libraries at startup by default). -v2 currently only works if you run it against a currently-executing binary (i.e., with '-p $(pidof <whatever>'). The [[attachment:list-symbols-packages.sh|older version]] of the script is also available.
  
+ = Uninstalling all debug symbols =
-  1. Install the debug symbols: {{{
- sudo apt-get install yelp-dbgsym=2.22.1-0ubuntu2.8.04.1 }}}
- You can also use the Synaptic Package Manager to search for 'yelp-dbgsym' and install it from there.
  
- The above procedure will install the debug symbol package for yelp only. Chances are that yelp uses shared libraries in other packages and debug symbols for them might be required in order to obtain a readable stack trace or perform other debugging tasks. 
+ You can remove all debug symbol packages and the ddebs repositories with the following commands:{{{
+ sudo apt-get remove \.*-dbgsym \.*-dbg
+ sudo rm /etc/apt/sources.list.d/ddebs.list
+ sudo apt-get update
+ }}}
  
+ = The Xorg server =
- You can download the following [[attachment:list-symbols-packages-v2.1.sh |shell script (list-symbols-packages-v2.1.sh)]] to resolve all the dependencies. Attaching a debugger to an already running process may require elevated privileges even if you own the process. The following invocation will print out the list of files to install. {{{
- sudo bash ./list-symbols-packages-v2.sh -p $(pidof yelp)}}}
  
+ Depending on the circumstances, X server will trap its own crashes and dump a stack trace in /var/log/Xorg.0.log. However, this stack trace is modified by the signal handler itself. If apport is not catching the crash, add this to your /etc/X11/xorg.conf:{{{
- To automatically install them apt can be called with the input from the script. The script is invoked with {{{-t}}} for a terse output without the descriptions of the packages and error messages are suppressed {{{
- sudo bash ./list-symbols-packages-v2.sh -t -p $(pidof yelp) 2>/dev/null | xargs -d $'\n' sudo apt-get install }}}
- 
- /!\ Version 2 of this script makes it compatible with the newer GDB (which no longer loads all libraries at startup by default). -v2 currently only works if you run it against a currently-executing binary (i.e., with '-p $(pidof <whatever>'). The [[attachment:list-symbols-packages.sh|older version]] of the script is also available.
- 
-  a. Now you make a [[Backtrace]].
-  a. You can also run [[Valgrind]], if the program crashes with a "Segmentation fault" or "Bus error".
-  a. Optionally, you may be asked to produce an [[Strace]].
-  a. You can also provide this file : '''~/.xsession-errors'''
- 
- === How do we remove all this stuff after getting the trace and get back to a normal system? ===
- 
- You can remove all debug symbol packages and the ddebs repositories with the following commands: {{{
- sudo apt-get remove \.*-dbgsym
- sudo rm /etc/apt/sources.list.d/ddebs.list
- sudo apt-get update }}}
- 
- === References ===
- 
-  * Announcement: https://lists.ubuntu.com/archives/ubuntu-devel-announce/2006-September/000195.html
- 
- == The Xorg server ==
- 
- The X server will by default trap its own crashes and dump a stack trace in /var/log/Xorg.0.log. However, this stack trace is modified by the signal handler itself. To get a "normal" crash, which will trigger a core dump (and ''apport'' reporting), add this to your /etc/X11/xorg.conf: {{{
  Section "ServerFlags"
          Option "NoTrapSignals" "true"
- EndSection }}}
+ EndSection
- Please see [[X/Debugging]] for how to debug Xorg server crashes.
+ }}} Please see [[X/Debugging]] for how to debug Xorg server crashes.
  
- == Info for the BugSquad ==
+ = Info for the BugSquad =
  
+ If you're trying to apport-retrace a crash report from a bug that didn't happen on the same Ubuntu release as the one you're running, it would be easiest to just virtualize the environment it is reproducible in. However, if this would not be available to you, one may perform the following example. Say that you're running Trusty and the crash happened on Precise:
- If you're trying to `apport-retrace` a crash report from a bug that didn't happen on the same Ubuntu release as the one you're running, do the following:
- 
- Say that you're running `Gutsy` and the crash happened on `Feisty`:
- 
-  0. This will create a minimal `feisty` system. {{{
+  0. This will create a minimal Precise system:{{{
- sudo mkdir -p /chroots/feisty
+ sudo mkdir -p /chroots/precise
- sudo debootstrap feisty /chroots/feisty/}}}
+ sudo debootstrap precise /chroots/precise/
+ }}}
-  0. Now you change into this minimal `feisty` system. {{{
+  0. Now change into this minimal precise system:{{{
- sudo chroot /chroots/feisty}}}
+ sudo chroot /chroots/precise
+ }}}
-  0. edit `/etc/apt/sources/list` and all the repositories you need, especially Martin's ddeb repository.
+  0. Edit /etc/apt/sources/list and add all the repositories you need, including the ddeb repository.
-  0. {{{
+  0. Execute the following in a terminal:{{{
- apt-get update; apt-get install gdb apport}}}
+ sudo apt-get update; sudo apt-get install gdb apport
+ }}}
-  0. use `apport-retrace` as you're used to.
+  0. use apport-retrace as you're used to.
  
  For more information on dealing with bug reports [[Apport]] see [[Bugs/ApportRetraces]].
  



More information about the Ubuntu-bugsquad mailing list