Задать вопрос
@tugo

Как вытащить максимум полезного из дампа Google Breakpad?

К примеру,
- взял открытый проект QOwnNotes.
- подключил breakpad
- создал ошибку5f2961c6bb737655797016.png
- приложение упало, дамп сохранился. Натравил на него minidump_stackwalk и minidump_dump. В результате получились текстовые файлы результата работы.

В принципе, читая файл _stack.txt можно понять в чем дело:
результат работы minidump_stackwalk

Thread 0 (crashed)
 0  libQt5Widgets.so.5 + 0x308061
    rax = 0x00007ffe03827cf0   rdx = 0x0000000000000000
    rcx = 0x0000000003707e93   rbx = 0x00007ffe03828540
    rsi = 0x0000000000000000   rdi = 0x00007ffe03827cf0
    rbp = 0x00007ffe03827d30   rsp = 0x00007ffe03827c70
     r8 = 0x0000000000000053    r9 = 0x0000000000000000
    r10 = 0x2ce33e6c02ce33e7   r11 = 0x00007ffe03827880
    r12 = 0x000055948b476a90   r13 = 0x0000559489e408a0
    r14 = 0x000055948b471000   r15 = 0x00007ffe03827f10
    rip = 0x00007f7524f3f061
    Found by: given as instruction pointer in context
 1  QOwnNotes!QtPrivate::FunctorCall<QtPrivate::IndexesList<>, QtPrivate::List<>, void, void (MainWindow::*)()>::call(void (MainWindow::*)(), MainWindow*, void**) [qobjectdefs_impl.h : 152 + 0x5]
    rbp = 0x00007ffe03827d70   rsp = 0x00007ffe03827d40
    rip = 0x000055948758caad
    Found by: previous frame's frame pointer
 2  QOwnNotes!void QtPrivate::FunctionPointer<void (MainWindow::*)()>::call<QtPrivate::List<>, void>(void (MainWindow::*)(), MainWindow*, void**) [qobjectdefs_impl.h : 185 + 0x1b]
    rbp = 0x00007ffe03827da0   rsp = 0x00007ffe03827d80
    rip = 0x000055948758b253
    Found by: call frame info
 3  QOwnNotes!QtPrivate::QSlotObject<void (MainWindow::*)(), QtPrivate::List<>, void>::impl(int, QtPrivate::QSlotObjectBase*, QObject*, void**, bool*) [qobjectdefs_impl.h : 414 + 0x1f]
    rbp = 0x00007ffe03827df0   rsp = 0x00007ffe03827db0
    rip = 0x0000559487587d33
    Found by: call frame info
 4  libQt5Core.so.5 + 0x2aea36
    rbx = 0x00007ffe038284f0   rbp = 0x00007ffe03827f00
    rsp = 0x00007ffe03827e00   rip = 0x00007f752260ca36
    Found by: call frame info
 5  libQt5Core.so.5 + 0x2bb1d7
    rbp = 0x00007ffe03827fb0   rsp = 0x00007ffe03827f10
    rip = 0x00007f75226191d7
    Found by: previous frame's frame pointer
 6  libQt5Widgets.so.5 + 0x160f6c
    rbp = 0x00007ffe038281d0   rsp = 0x00007ffe03827fc0
    rip = 0x00007f7524d97f6c
    Found by: previous frame's frame pointer
 7  libQt5Widgets.so.5 + 0x168120
    rbp = 0x00007ffe038281d0   rsp = 0x00007ffe03827ff0



Хотя в данном случае место ошибки выбрано неудачно, т.к. и отладчик дает некрасивый вывод:
5f296475a4be4448470007.png
И ничего не понятно, где упало. Если вызовы без qt-шной магии, там более понятно. Даже видна строчка, где упало.

Что можно сделать с файлами вывода minidump_stackwalk и minidump_dump, чтобы было более понятно, что произошло? Зачем нужен minidump_dump?

Файлы дампа и его расшифровки лежат здесь https://yadi.sk/d/L4dMaKH8K-hRtg
  • Вопрос задан
  • 111 просмотров
Подписаться 1 Простой Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы