Сервер отлаживался под GDB 5.3. Когда сервер получил SIGSEGV GDB остановил выполнение сервера и с радостью мне сообщил, что по адресу 0x0 в функции ?? () возникла ошибка сегментации. На команду 'bt' GDB выдал пустой стэк. Обращался к разработчикам GDB с подробным описанием ошибки, указал им версию компилятора (gcc version egcs-2.91.66) и GDB, как они и просили, но они на отрез отказались помогать, требуя typescript файл и обвиняя, таким образом, меня, лживую морду, в фальсификации информации. =)))
Один программер из баг-рассылки подкинул интересную идею. Вот его письмо:
"I strongly suspect that this is caused by a zero function pointer call, and the example below indeed shows a regression with backtracing from zero function pointer calls between gdb-5.3 and gdb-6.0.
I am not familiar enough with the new frame code to propose a fix though, sorry.
pes@xxxx_7$ cat zerofun.c
void x()
{
void (*fp)() = 0;
fp();
}
int
main()
{
x();
return 0;
}
pes@xxxx_8$ gcc -g zerofun.c
pes@xxxx_9$ gdb-5.3 a.out
GNU gdb 5.3
Copyright 2002 Free Software Foundation, Inc.
GDB is free software, covered by the GNU General Public License, and you are welcome to change it and/or distribute copies of it under certain conditions. Type "show copying" to see the conditions.
There is absolutely no warranty for GDB. Type "show warranty" for details. This GDB was configured as "i686-pc-linux-gnu"...
(gdb) r
Starting program: ..../a.out
Program received signal SIGSEGV, Segmentation fault.
0x00000000 in ?? ()
(gdb) bt
#0 0x00000000 in ?? ()
#1 0x08048306 in x () at zerofun.c:4
#2 0x0804831d in main () at zerofun.c:9
#3 0x420158d4 in __libc_start_main () from /lib/i686/libc.so.6
(gdb) q
The program is running. Exit anyway? (y or n) y
pes@xxxx_10$ gdb-6.0 a.out
GNU gdb 6.0
Copyright 2003 Free Software Foundation, Inc.
GDB is free software, covered by the GNU General Public License, and you are welcome to change it and/or distribute copies of it under certain conditions. Type "show copying" to see the conditions.
There is absolutely no warranty for GDB. Type "show warranty" for details. This GDB was configured as "i686-pc-linux-gnu"...
(gdb) r
Starting program: ..../a.out
Program received signal SIGSEGV, Segmentation fault.
0x00000000 in ?? ()
(gdb) bt
#0 0x00000000 in ?? ()
(gdb) q
The program is running. Exit anyway? (y or n) y"
В кратце, проблема заключается в вызове функции по нулевому указателю. В сервере как раз есть динамически подключаемая бибилотека. Очень вероятно, что ошибка идет из серверной функции, возвращающей адреса требуемых функций из динамической библиотеки.
Но проблема возникла как раз в 5.3, а не в 6.0.
Кто что думает по этому поводу. Когда ошибка возникнет в следующий раз, я опять не получу никакой информации. А это грозит отправкой большого булыжника в мой огород скоростным рейсом.
Спасибо.
Ответ на:
комментарий
от Murr
Ответ на:
комментарий
от Murr
Ответ на:
Re
от Debugger
Ответ на:
Re
от Debugger
Ответ на:
Re
от Debugger
Ответ на:
комментарий
от Lestat
Ответ на:
комментарий
от Lestat
Вы не можете добавлять комментарии в эту тему. Тема перемещена в архив.
Похожие темы
- Форум Вопрос о GDB (2004)
- Форум gdb уходит в background (2005)
- Форум gdb vs proftpd (2003)
- Форум как увидеть src код с ошибкой при отладке? (2002)
- Форум [pidgin] Ошибка (2008)
- Форум «GDB и разделяемые библиотеки» или «пустой стэк в GDB возвращается». (2003)
- Форум Нет символов в core-файлах (2006)
- Форум gkrellm2 | linux-2.6.12 (2005)
- Форум dlopen: Segmentation fault (2007)
- Форум xsane запускается только под рутом (2007)