gdb - загрузить модуль ядра для удаленной отладки

Ubuntu 14.04 LTS:

peter@peterubuntu0:$ insmod mymodule
peter@peterubuntu0:/sys/module/mymodule/sections$ cat .text .data .bss
0x0000000000000000
0x0000000000000000
0x0000000000000000

Так как мне сказать GDB, где мой модуль загружен на целевой машине, когда я отлаживаю удаленно? Я использую только смещения (так что 0x64 или 64 десятичных для.text тогда?)?

peter@peterubuntu0:~$ objdump mymodule.ko --section-headers

mymodule.ko:     file format elf64-x86-64

Sections:
Idx Name          Size      VMA               LMA               File off  Algn
  0 .note.gnu.build-id 00000024  0000000000000000  0000000000000000  00000040  2**2
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  1 .text         0000b345  0000000000000000  0000000000000000  00000064  2**0
                  CONTENTS, ALLOC, LOAD, RELOC, READONLY, CODE
 12 .data         000001e4  0000000000000000  0000000000000000  00012620  2**5
                  CONTENTS, ALLOC, LOAD, RELOC, DATA, LINK_ONCE_DISCARD
 15 .bss          00000014  0000000000000000  0000000000000000  00012a80  2**3
                  ALLOC

2 ответа

Решение

Добавьте файл.gdbinit в ваш домашний каталог. Gdb получает этот файл при запуске. В этом файле вы можете определить макросы для GDB, а также можете выполнять обычные команды оболочки.

 #gdb implementation of the linux lsmod
 define gdblsmod
        set $current = modules.next
        set $offset =  ((int)&((struct module *)0).list)
    printf "Module\tAddress\n"

    while($current.next != modules.next)
                printf "%s\t%p\n",  \
                        ((struct module *) (((void *) ($current)) - $offset ) )->name ,\
                        ((struct module *) (((void *) ($current)) - $offset ) )->module_core
                set $current = $current.next
        end
end

Этот макрос печатает адреса текстовых разделов для всех загруженных в данный момент модулей. Откройте консоль GDB и введите gdblsmod использовать это. Вы можете поместить туда также команды GDB, например:

set serial baud 115200

если вы отлаживаете удаленно через последовательный порт.

Я обнаружил, что, когда целью является другой xubuntu, также выполняются следующие работы для получения текстовых адресов:

(gdb) monitor lsmod
Module                  Size  modstruct     Used by
iptable_mangle         16384  0xffffffffc0f57040    1  (Live) 0xffffffffc0f55000 [ ]
...

тогда вы можете использовать в другом месте документированные команды, чтобы сказать GDB смещение

(gdb) add-symbol-file mymodule 0xmymoduleaddress
Другие вопросы по тегам