File: debug-snaps.md

package info (click to toggle)
mir 2.25.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 22,104 kB
  • sloc: cpp: 192,777; xml: 13,784; ansic: 8,207; python: 1,304; sh: 794; makefile: 258
file content (102 lines) | stat: -rw-r--r-- 3,515 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
(how-to-debug-mir-snaps)=

# How to debug Mir snaps

Getting a useful stack trace or debugging session with snaps requires some set up, as they don't contain debugging information.
This document describes the steps required to supply the debugger with the necessary data.

## Enable `debuginfod`

First, we'll make sure you have `debuginfod` enabled.
It's a service that hosts the debug info stripped from Ubuntu packages, which debuggers can retrieve by matching the `build-id` embedded in the executables and libraries.
In modern Ubuntu it's installed by default, but enable it in GDB by default with:

```shell
sudo apt install libdebuginfod1t64
# If not already there, this will be added to your environment on next login
export DEBUGINFOD_URLS=https://debuginfod.ubuntu.com
echo "set debuginfod enabled on" >> ~/.gdbinfo
```

To learn more, head to {ref}`server:about-debuginfod` on Ubuntu Server documentation pages.

## Install the snap

Next, install the snap you want to debug. You have two options:

### Mir CI snaps

If debugging an issue in a Mir Pull Request, you can install the snap from [Mir Continuous Integration pipelines](https://github.com/canonical/mir/blob/main/.github/workflows/snap.yml#L72-L76).
These are published in the store for as long as the pull request is active - install with, for example:

```shell
snap install mir-test-tools --channel "edge/mir-pr<number>"
```

These are Debug builds, so you can go straight to {ref}`running-mir-snaps-under-gdb` below.

### PPA-based snaps

The snaps available outside of the `mir-pr<number>` branches come from PPA builds, which strip debug info into separate packages, making it a bit more involved to help GDB find them.

1. best create a folder in which you'll hold the debug files and point GDB at it

   ```
   DEBUG_DIR=$HOME/.local/debug
   echo "set debug-file-directory $DEBUG_DIR/usr/lib/debug:/usr/lib/debug/" >> ~/.gdbinit
   mkdir --parents $DEBUG_DIR
   cd $DEBUG_DIR
   ```

1. next, add the PPA source for the `base` of the snap you're looking at:

   ```shell
   PPA=dev
   RELEASE=noble
   sudo add-apt-repository --no-update ppa:mir-team/$PPA
   sed \
      -e "s|^Suites:.*|Suites: $RELEASE|" \
      -e "s|^Components:.*|Components: main/debug|" \
      /etc/apt/sources.list.d/mir-team-ubuntu-$PPA-$( lsb_release -sc ).sources \
      | sudo tee /etc/apt/sources.list.d/mir-team-ubuntu-$PPA-$RELEASE.sources
   sudo apt-get update
   ```

1. then configure the sources' priority down, so they don't get considered for installation

   ```shell
   tee <<EOF > /etc/apt/preferences.d/mir-debug
   Package: *
   Pin: release n=$RELEASE, o=LP-PPA-mir-team-$PPA
   Pin-Priority: -50
   EOF
   ```

1. and download all the dbgsym packages into a folder of choice

   ```shell
   apt download {lib,}mir*-dbgsym/noble
   ```

1. finally, unpack the downloaded packages

   ```shell
   for pkg in *deb; do dpkg-deb --extract $pkg .; done
   ```

(running-mir-snaps-under-gdb)=

## Running Mir snaps under GDB

Next, to get into a GDB session, run the snap with `snap run --gdbserver <snap>` and follow the steps to open a `gdb` prompt.
To avoid breaking out, ignore the `SIGSTOP`s being sent on Mir startup:

```text
handle SIGSTOP nostop nopass
break miral::MirRunner::run_with
continue
# when it breaks out, look at the printed path and point at your local source
set substitute-path /usr/src/mir-<version>/ .
```

You can find out more about debugging snaps in general in Snapcraft's {ref}`snapcraft:how-to-debug-with-gdb`.