Я столкнулся со странной проблемой в куске кода.
void app_ErrDesc(char *ps_logbuf, char *pc_buf_err_recno)
{
char *pc_logbuf_in;
char rec_num[10];
char *y = "|";
int i, j;
memset(rec_num, 0, sizeof(rec_num));
memset(pc_buf_err_recno, 0, LOGBUFF);
.....
.....
}
По какой-то причине первый вызов memset отправляет SIGSEGV. Что более странно, когда
внутри GDB одна и та же строка выполняется около 30 раз, хотя вызывается функция
только один раз и внутри петель нет! Вот часть сессии GDB.
7295 /*Point to logbuffer string*/
(gdb)
7292 memset(rec_num, 0, sizeof(rec_num));
(gdb)
7295 /*Point to logbuffer string*/
(gdb)
7292 memset(rec_num, 0, sizeof(rec_num));
(gdb) n
7295 /*Point to logbuffer string*/
(gdb)
7292 memset(rec_num, 0, sizeof(rec_num));
(gdb)
Программа получила сигнал SIGSEGV, ошибка сегментации.
Я также пытался запустить программу с помощью инструмента memcheck от valgrind, но не получил ничего значительного в приведенном выше фрагменте кода.
Файл, который я анализирую, содержит только одну запись.
Любые указатели приветствуются. Спасибо.