Wiki Ubuntu-it

Indice
Partecipa
FAQ
Wiki Blog
------------------
Ubuntu-it.org
Forum
Chiedi
Chat
Cerca
Planet
  • Pagina non alterabile
  • Informazioni
  • Allegati
  • Differenze per "Programmazione/Debug"
Differenze tra le versioni 1 e 7 (in 6 versioni)
Versione 1 del 29/06/2007 11.20.44
Dimensione: 4028
Commento:
Versione 7 del 29/06/2007 12.10.51
Dimensione: 3386
Commento:
Le cancellazioni sono segnalate in questo modo. Le aggiunte sono segnalate in questo modo.
Linea 7: Linea 7:
This document describes how to install debug packages on Ubuntu, which will aid in providing information for bugs. Questo documento descrive come installare pacchetti di debug in Ubuntu.
Linea 12: Linea 12:
Use this section only if you are using Ubuntu Edgy 6.10. See the following section if you are using a prior version. Usare questa sezione solo se si possiede Ubuntu Edgy 6.10. Anche in caso di versioni precedenti seguire quanto segue:
Linea 14: Linea 14:
1. Add the following line to `/etc/apt/sources.list`: 1. Aggiungere la seguente linea in `/etc/apt/sources.list`:
Linea 18: Linea 18:
2. Import Martin's public key to your keyring: 2. Importare la chiave pubblica di Martin sul sistema:
Linea 23: Linea 23:
3. Then run 3. Quindi digitare
Linea 27: Linea 27:
to update your package list. per aggiornare la lista dei pacchetti.
Linea 29: Linea 29:
4. The debug symbol packages have the '-dbgsym' suffix attached, so to install the debug symbols for the package 'yelp', you run: 4. I simboli dei pacchetti del debug hanno allegato il suffisso '-dbgsym', cosi' per installare i simboli di debug per il pacchetto 'yelp', digitare:
Linea 34: Linea 34:
 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. Adesso e' stata realizzata una ["Backtrace"].
 a. Eseguire ["Valgrind"], se il programma crasha causa "Segmentation fault" o "Bus error".
 a. A scelta, potrebbe venir chiesta una ["Strace"].
Linea 39: Linea 39:
=== References === === Referenze ===
Linea 41: Linea 41:
 * Announcement: https://lists.ubuntu.com/archives/ubuntu-devel-announce/2006-September/000195.html  * Annunci: https://lists.ubuntu.com/archives/ubuntu-devel-announce/2006-September/000195.html
Linea 46: Linea 46:
The steps described above for Edgy also work for Feisty, just add the following line to `/etc/apt/sources.list`: Questo passo descrive quanto detto in precedenza per Edgy anche per Feisty, aggiungere la seguente linea al file `/etc/apt/sources.list`:
Linea 53: Linea 53:
The steps described above for Edgy also work for Gutsy, just add the following line to '/etc/apt/sources.list' : Come gia' esposto in precedenza, aggiungere la seguente linea in '/etc/apt/sources.list' :
Linea 57: Linea 57:
== Prior Ubuntu versions == == Versioni di Ubuntu precedenti ==
Linea 59: Linea 59:
Use this section if you are using an Ubuntu version prior to Edgy 6.10. Questa sezione riguarda le versioni che precedono Edgy 6.10.
Linea 61: Linea 61:
 1. Check if the package has a debugging version available. In general, debugging packages will be named with a `-dbg` suffix
 1. If not, you can generally* build one this way:
 1. Contrllare se il pacchetto e' disponibile per la versione di debbugging. Generalmente, i pacchetti di debug saranno identificati con il suffisso `-dbg`
 1. Se non e' disponibile, e' possibile crearne uno in questo modo:
Linea 64: Linea 64:
Something to keep in mind: if you would like to create a build you're going to need to have the relevant deb-src lines in your /etc/apt/sources.list Da tenere a mente: se si vuole creare un pacchetto, assicurarsi di avere la linea deb-src in /etc/apt/sources.list
Linea 66: Linea 66:
  a. Install the development scripts:   a. Installare lo script seguente:
Linea 71: Linea 71:
  a. Find out to which package your program belongs to:   a. Scoprire quale pacchetto appartiene al vostro programma:
Linea 76: Linea 76:
  a. Install the build-time dependencies for the package:   a. Installare le dipendenze:
Linea 80: Linea 80:
  a. Build .debs for debugging:   a. Creare .deb per il debugging:
Linea 85: Linea 85:
  a. Install the needed .debs (they will be in the current working directory if the build succeeded):   a. Installare i necessari .deb (si troveranno nella cartella di lavoro, in caso di successo nella creazione):
Linea 91: Linea 91:
* Most packages support the build of debugging version in this way. If this process doesn't work for a package, please open a bug against it.
Linea 93: Linea 92:

== 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:
== Xorg server ==
Il server X server e' in grado di gestire i crash creando uno "scarico" (dump) lasciando la traccia in /var/log/Xorg.0.log. Questa traccia e' modificata dallo stesso segnale responsabile. Per ottenere un "normale" crash, cioe' che crei un core dump (ed un resoconto tramite ''apport''), aggiungere questo nel file /etc/X11/xorg.conf:
Linea 103: Linea 101:
== Info for the BugSquad == = Ulteriori risorse =
Linea 105: Linea 103:
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:  * [https://wiki.ubuntu.com/DebuggingProgramCrash Documento originale]
Linea 107: Linea 105:
Say that you're running `feisty` and the crash happened on `edgy`:

 0. This will create a minimal `edgy` system. {{{
sudo mkdir -p /chroots/edgy
sudo debootstrap edgy /chroots/edgy/}}}
 0. Now you change into this minimal `edgy` system. {{{
sudo chroot /chroot/edgy}}}
 0. edit `/etc/apt/sources/list` and all the repositories you need, especially Martin's ddeb repository.
 0. {{{
apt-get update; apt-get install gdb apport}}}
 0. use `apport-retrace` as you're used to.
Linea 120: Linea 107:

CategoryNuoviDocumenti

BR

Questo documento descrive come installare pacchetti di debug in Ubuntu.

Edgy Eft 6.10

Usare questa sezione solo se si possiede Ubuntu Edgy 6.10. Anche in caso di versioni precedenti seguire quanto segue:

1. Aggiungere la seguente linea in /etc/apt/sources.list:

}}}

2. Importare la chiave pubblica di Martin sul sistema:

  • wget -q "http://keyserver.ubuntu.com:11371/pks/lookup?op=get&search=0x0DE7276D5E0577F2" -O- | sudo apt-key add -

3. Quindi digitare

  • sudo apt-get update

per aggiornare la lista dei pacchetti.

4. I simboli dei pacchetti del debug hanno allegato il suffisso '-dbgsym', cosi' per installare i simboli di debug per il pacchetto 'yelp', digitare:

  • sudo apt-get install yelp-dbgsym
  • Adesso e' stata realizzata una ["Backtrace"].
  • Eseguire ["Valgrind"], se il programma crasha causa "Segmentation fault" o "Bus error".
  • A scelta, potrebbe venir chiesta una ["Strace"].

Referenze

Feisty Fawn 7.04

Questo passo descrive quanto detto in precedenza per Edgy anche per Feisty, aggiungere la seguente linea al file /etc/apt/sources.list:

}}}

Gutsy Gibbon 7.10

Come gia' esposto in precedenza, aggiungere la seguente linea in '/etc/apt/sources.list' :

}}}

Versioni di Ubuntu precedenti

Questa sezione riguarda le versioni che precedono Edgy 6.10.

  1. Contrllare se il pacchetto e' disponibile per la versione di debbugging. Generalmente, i pacchetti di debug saranno identificati con il suffisso -dbg

  2. Se non e' disponibile, e' possibile crearne uno in questo modo:

Da tenere a mente: se si vuole creare un pacchetto, assicurarsi di avere la linea deb-src in /etc/apt/sources.list

  1. Installare lo script seguente:
    sudo apt-get install devscripts fakeroot
  2. Scoprire quale pacchetto appartiene al vostro programma:
    dpkg --search <program> 
  3. Installare le dipendenze:
    sudo apt-get build-dep <package>
  4. Creare .deb per il debugging:
    export DEB_BUILD_OPTIONS="debug nostrip noopt"
    fakeroot apt-get source -b <package>
  5. Installare i necessari .deb (si troveranno nella cartella di lavoro, in caso di successo nella creazione):
    sudo debi <package>*.changes

Xorg server

Il server X server e' in grado di gestire i crash creando uno "scarico" (dump) lasciando la traccia in /var/log/Xorg.0.log. Questa traccia e' modificata dallo stesso segnale responsabile. Per ottenere un "normale" crash, cioe' che crei un core dump (ed un resoconto tramite apport), aggiungere questo nel file /etc/X11/xorg.conf:

Section "ServerFlags"
        Option "NoTrapSignals" "true"
EndSection

Ulteriori risorse


CategoryNuoviDocumenti