Подготовка к отладке на QEMU

Чтобы подготовить условия для отладки с использованием GDB-сервера ядра KasperskyOS на QEMU, нужно выполнить следующие шаги:

  1. Проверить, что в составе KasperskyOS Community Edition есть версия ядра с GDB-сервером.

    Для это нужно убедиться в наличии файла libexec/aarch64-kos/kos-qemu-gdbstub в составе KasperskyOS Community Edition.

  2. Добавить параметр GDBSTUB_KERNEL в список параметров CMake-команды build_kos_qemu_image().

    Этот параметр включает в решение ядро с GDB-сервером.

    Пример:

    build_kos_qemu_image(kos-qemu-image

    GDBSTUB_KERNEL

    ...

    QEMU_FLAGS "${QEMU_FLAGS}")

  3. Создать файл .gdbinit, чтобы не вызывать вручную начальные GDB-команды при каждом запуске отладчика GDB. (Файл .gdbinit нужно сохранить в директории, где будет запускаться отладчик GDB.)

    Пример:

    # Задать путь для поиска динамических библиотек с отладочными символами из

    # состава KasperskyOS Community Edition

    set sysroot /opt/KasperskyOS-Community-Edition-<version>/sysroot-aarch64-kos

    # Задать дополнительные пути для поиска динамических библиотек с отладочными

    # символами

    set solib-search-path /home/user/example/build/lib1:/home/user/example/build/lib2

    # Настроить управление потоками исполнения (опционально)

    # Отладчик GDB может работать в режиме all-stop или non-stop. В первом режиме

    # отладчик GDB считает, что при остановке потока исполнения, контекст которого

    # находится в фокусе отладки, останавливаются все остальные потоки исполнения,

    # о которых известно отладчику GDB. Во втором режиме отладчик GDB считает, что

    # все потоки, кроме остановленного, продолжают исполняться. Режим all-stop

    # применяется отладчиком GDB по умолчанию, и GDB-сервер ядра дает возможность

    # использовать только этот режим. Чтобы изменить заданные по умолчанию параметры

    # управления потоками исполнения в режиме all-stop, нужно использовать GDB-команды

    # set scheduler-locking и set schedule-multiple.

    # В этом примере первая GDB-команда указывает отладчику GDB, что при возобновлении

    # исполнения потока, контекст которого находится в фокусе отладки (например,

    # GDB-командами continue, step, next), нужно возобновить исполнение остальных потоков.

    # Вторая GDB-команда указывает отладчику GDB, что при возобновлении исполнения потока,

    # контекст которого находится в фокусе отладки, нужно возобновить исполнение всех

    # потоков, входящих в процессы всех программ, для которых выполняется отладка.

    set scheduler-locking off

    set schedule-multiple on

    # Подключить отладчик GDB к GDB-серверу ядра

    # GDB-сервер ядра взаимодействует с отладчиком GDB по расширенному протоколу,

    # и QEMU предоставляет доступ к GDB-серверу ядра через TCP-сокет.

    target extended-remote localhost:1234

В начало