Many tools, especially GDB, have been architected to execute on your development host while actually debugging code on a remote target. GDB can be used to interactively debug your target code or to perform a postmortem analysis of a core file generated by an application crash. We covered the details of application core dump analysis in Chapter 13.

15.2. Remote (Cross) Debugging

Cross-development tools were developed primarily to overcome the resource limitations of embedded platforms. A modest-size application compiled with symbolic debug information can easily exceed several megabytes. With cross-debugging, the heavy lifting can be done on your development host. When you invoke your cross-version of GDB on your development host, you pass it an ELF file compiled with symbolic debug information. On your target, there is no reason you can't strip[100] the ELF file of all unnecessary debugging info to keep the resulting image to its minimum size.

We introduced the readelf utility in Chapter 13. In Chapter 14, 'Kernel Debugging Techniques,' we used it to examine the debug information in an ELF file compiled with symbolic debugging information. Listing 15-1 contains the output of readelf for a relatively small web server application compiled for the ARM architecture.

Listing 15-1. ELF File Debug Info for Example Program

$ xscale_be-readelf -S websdemo

There are 39 section headers, starting at offset 0x3dfd0:

Section Headers:

[Nr] Name              Type        Addr     Off    Size   ES Flg Lk Inf Al

[ 0]                   NULL        00000000 000000 000000 00      0  0  0

[ 1] .interp           PROGBITS    00008154 000154 000013 00   A  0  0  1

[ 2] .note.ABI-tag     NOTE        00008168 000168 000020 00   A  0  0  4

[ 3] .note.numapolicy  NOTE        00008188 000188 000074 00   A  0  0  4

[ 4] .hash             HASH        000081fc 0001fc 00022c 04   A  5  0  4

[ 5] .dynsym           DYNSYM      00008428 000428 000460 10   A  6  1  4

[ 6] .dynstr           STRTAB      00008888 000888 000211 00   A  0  0  1

[ 7] .gnu.version      VERSYM      00008a9a 000a9a 00008c 02   A  5  0  2

[ 8] .gnu.version_r    VERNEED     00008b28 000b28 000020 00   A  6  1  4

[ 9] .rel.plt          REL         00008b48 000b48 000218 08   A  5 11  4

[10] .init             PROGBITS    00008d60 000d60 000018 00  AX  0  0  4

[11] .plt              PROGBITS    00008d78 000d78 000338 04  AX  0  0  4

[12] .text             PROGBITS    000090b0 0010b0 019fe4 00  AX  0  0  4

[13] .fini             PROGBITS    00023094 01b094 000018 00  AX  0  0  4

[14] .rodata           PROGBITS    000230b0 01b0b0 0023d0 00   A  0  0  8

[15] .ARM.extab        PROGBITS    00025480 01d480 000000 00   A  0  0  1

[16] .ARM.exidx        ARM_EXIDX   00025480 01d480 000008 00  AL 12  0  4

[17] .eh_frame_hdr     PROGBITS    00025488 01d488 00002c 00   A  0  0  4

[18] .eh_frame         PROGBITS    000254b4 01d4b4 00007c 00   A  0  0  4

[19] .init_array       INIT_ARRAY  0002d530 01d530 000004 00  WA  0  0  4

[20] .fini_array       FINI_ARRAY  0002d534 01d534 000004 00  WA  0  0  4

[21] .jcr              PROGBITS    0002d538 01d538 000004 00  WA  0  0  4

[22] .dynamic          DYNAMIC     0002d53c 01d53c 0000d0 08  WA  6  0  4

[23] .got              PROGBITS    0002d60c 01d60c 000118 04  WA  0  0  4

[24] .data             PROGBITS    0002d728 01d728 0003c0 00  WA  0  0  8

[25] .bss              NOBITS      0002dae8 01dae8 0001c8 00  WA  0  0  4

[26] .comment          PROGBITS    00000000 01dae8 000940 00      0  0  1

[27] .debug_aranges    PROGBITS    00000000 01e428 0004a0 00      0  0  8

[28] .debug_pubnames   PROGBITS    00000000 01e8c8 001aae 00      0  0  1

[29] .debug_info       PROGBITS    00000000 020376 013d27 00      0  0  1

[30] .debug_abbrev     PROGBITS    00000000 03409d 002ede 00      0  0  1

[31] .debug_line       PROGBITS    00000000 036f7b 0034a2 00      0  0  1

[32] .debug_frame      PROGBITS    00000000 03a420 003380 00      0  0  4

[33] .debug_str        PROGBITS    00000000 03d7a0 000679 00      0  0  1

[34] .note.gnu.arm.ide NOTE        00000000 03de19 00001c 00      0  0  1

[35] .debug_ranges     PROGBITS    00000000 03de35 000018 00      0  0  1

[36] .shstrtab         STRTAB      00000000 03de4d 000183 00      0  0  1

[37] .symtab           SYMTAB      00000000 03e5e8 004bd0 10     38 773 4

[38] .strtab           STRTAB      00000000 0431b8 0021bf 00      0  0  1

Key to Flags:

W (write), A (alloc), X (execute), M (merge), S (strings)

I (info), L (link order), G (group), x (unknown)

O (extra OS processing required) o (OS specific), p (processor specific)

$

You can see from Listing 15-1 that there are many sections containing debug information. There is also a .comment section that contains more than 2KB (0x940) of information that is not necessary for the application to function. The size of this example file, including debug information, is more than 275KB.

$ ls -l websdemo

-rwxrwxr-x 1 chris chris 283511 Nov 8 18:48 websdemo

If we strip this file using the strip utility, we can minimize its size to preserve resources on our target system. Listing 15-2 shows the results.

Listing 15-2. Strip Target Application

$ xscale_be-strip -s -R .comment -o websdemo-stripped websdemo

$ ls -l websdemo*

-rwxrwxr-x  1 chris chris 283491 Apr  9 09:19 websdemo

-rwxrwxr-x  1 chris chris 123156 Apr  9 09:21 websdemo-stripped

$

Here we strip both the symbolic debug information and the .comment section from the executable file. We specify the name of the stripped binary using the -o command line switch. You can see that the resulting size of the stripped binary is less than half of its original size. Of course, for larger applications, this space savings can be even more significant. A recent Linux kernel compiled with debug information was larger than 18MB. After stripping as in Listing 15-2, the resulting binary was slightly larger than 2MB!

For debugging in this fashion, you place the stripped version of the binary on your target system and keep a local unstripped copy on your development workstation containing symbolic information needed for debugging. You use gdbserver on your target board to provide an interface back to your development host where you run the full-blown version of GDB on your nonstripped binary.

15.2.1. gdbserver

Добавить отзыв
ВСЕ ОТЗЫВЫ О КНИГЕ В ИЗБРАННОЕ

0

Вы можете отметить интересные вам фрагменты текста, которые будут доступны по уникальной ссылке в адресной строке браузера.

Отметить Добавить цитату