Доступен релиз отладчика 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).


Источник: http://www.opennet.ru/opennews/art.shtml?num=45291