Информационные технологииStfw.Ru 🔍
🕛

Выпуск отладчика GDB 7.12

Доступен релиз отладчика GDB 7.12, поддерживающего отладку на уровне исходных текстов для широкого спектра языков программирования ..., Доступен релиз отладчика GDB 7.12, поддерживающего
Доступен релиз отладчика GDB 7.12, поддерживающего отладку на уровне исходных текстов для широкого спектра языков программирования (Ada, C, C++, Objective-C, Pascal, Go и т.д.) на различных аппаратных (i386, amd64, ARM, Power, Sparc и т.д.) и программных платформах (GNU/Linux, Unix, Windows, macOS).
Ключевые улучшения:
По умолчанию для сборки применён компилятор C++. Возможность сборки компилятором Си сохранена, но требуется указание опции "--disable-build-with-cxx". В будущем будет оставлена только возможность сборки компилятором С++;
Реализована поддержка отладки программ, написанных на языке Rust;
Добавлена новая целевая платформа Andes NDS32 (nds32*-*-elf);
В средствах отладки программ на языке Фортран добавлена поддержка массивов и структур с полями на основе динамических типов;
Улучшения, связанные с Python API, в том числе добавлена функция $_as_string(val) для преобразования значения в строковое представление и расширена поддержка точек останова (в объекты gdb.Breakpoint добавлен атрибут "pending", реализованы новые события
gdb.breakpoint_created, gdb.breakpoint_modified и
gdb.breakpoint_deleted);
В команде 'x' обеспечена возможность указания отрицательного счётчика повторов для изучения содержимого памяти в обратную сторону, относительно текущего адреса, например:
(gdb) bt
#0 Func1 (n=42, p=0x40061c "hogehoge") at main.cpp:4
#1 0x400580 in main (argc=1, argv=0x7fffffffe5c8) at main.cpp:8
(gdb) x/-5i 0x0000000000400580
0x40056a :
mov
%edi,-0x4(%rbp)
0x40056d :
mov
%rsi,-0x10(%rbp)
0x400571 :
mov
$0x40061c,%esi
0x400576 :
mov
$0x2a,%edi
0x40057b :
callq 0x400536
В случае краха (SIGSEGV) из-за блокировки выхода за границы буфера средствами Intel MPX теперь показывается тип переполнения, границы буфера и область куда был совершён выход;
Program received signal SIGSEGV, Segmentation fault
Upper bound violation while accessing address 0x7fffffffc3b3
Bounds: [lower = 0x7fffffffc390, upper = 0x7fffffffc3a3]
0x0000000000400d7c in upper () at i386-mpx-sigsegv.c:68
В команде "catch syscall" обеспечена возможность извлечения группы связанных системных вызовов при указании префикса 'group:' или 'g:';
В GDBserver добавлена возможность записи btrace без необходимости поддержания активного соединения с GDB, для платформ s390-linux,
s390x-linux, powerpc64-linux и powerpc64le-linux добавлена поддержка обычных и быстрых точек трассировки;
Новые команды:
skip -file file
skip -gfile file-glob-pattern
skip -function function
skip -rfunction regular-expression (обобщённый вариант команды skip с поддержкой масок в именах файлов и регулярных выражений для имён функций);
maint info line-table REGEXP (показывает содержимое внутренней структуры line-table);
maint selftest (запускает любой вкомпилированный unit-тест)
new-ui INTERP TTY (запускает новый экземпляр интерфейса пользователя, используя указанный в поле INTERP интерпретатор и файл TTY для ввода/вывода);
Удалена поддержка протоколов и систем мониторинга ПЗУ:
target m32rsdi (удалённая отладка M32R поверх SDI);
target mips
(протокол удалённой отладки MIPS);
target pmon
(PMON ROM monitor)
target ddb
(DDB-вариант PMON для Vr4300 от компании NEC);
target rockhopper (вариант PMON для RockHopper от компании NEC);
target lsi
(вариант PMO от LSI).

Также по теме:
Каталог лучших, бесплатных программ.