2013-03-19 3 views
0

У меня есть небольшая программа, которая пытается эмулировать чтение (нестандартного) заголовка пакета и его обработку.Ошибка Strange seg fault, gdb is unhelpful

Я получаю странную сегмы ошибки при запуске программы, на анализе с помощью GDB, я вижу, что код выполняется полностью и ТОГДА дать мне «0x00000000 in ??()».

Я до сих пор не видел этого вида ошибки и не знаю, что может вызвать его.

Я скомпилировал код, как gcc -g header.c -lcrypto -lssl

Вот код

#include<stdlib.h> 
#include<stdio.h> 
#include<string.h> 
#include"hash_list.c" 

void process(unsigned char header[48]); 

int main() 
{ 

    unsigned char header[48]; 
    unsigned short int responseCode_Fail = 255; 
    unsigned short int responseCode_Pass = 0; 
    unsigned short int packlen = 65000; 
    long long int packetnumber = 2345678; 

    memset(&header, 0, 96); 
    strcpy(header,"FILELST"); 
    memcpy(&header[8], &responseCode_Fail, sizeof(responseCode_Fail)); 
    memcpy(&header[10], &packlen, sizeof(packlen)); 
    memcpy(&header[16], &packetnumber, sizeof(packetnumber)); 

    unsigned char result[MD5_DIGEST_LENGTH]; 
    calcmd5("sample.txt", result); 
    memcpy(&header[32], &result, sizeof(result)); 

    process(header); 

    return 0; 
} 


void process(unsigned char header[48]) 
{ 
    unsigned short int responseCode; 
    unsigned short int packlen; 
    long long int packetnumber; 
    unsigned char md5hash[MD5_DIGEST_LENGTH]; 

    memcpy(&responseCode, &header[8], sizeof(responseCode)); 
    memcpy(&packlen, &header[10], sizeof(responseCode)); 
    memcpy(&packetnumber, &header[16], sizeof(packetnumber)); 
    memcpy(&md5hash, &header[32], sizeof(md5hash)); 
    printmd5(md5hash); 

    printf("CODE: %hu\n",responseCode); 
    printf("LEN: %hu\n",packlen); 
    printf("PNO: %lld\n",packetnumber); 
    if(strncmp(header, "LULZ?", 8) == 0) 
    { 
     printf("Recieved Peer query.\n"); 
    } 
    else if(strncmp(header, "LULZ.", 8) == 0) 
    { 
     printf("Recieved Peer query confirmation.\n"); 
    } 
    else if(strncmp(header, "FILELST", 8) == 0) 
    { 
     printf("Recieved File list\n"); 
    } 
    else if(strncmp(header, "DWNLOAD", 8) == 0) 
    { 
     printf("Recieved Download request.\n"); 
    } 
    else if(strncmp(header, "UPLOAD", 8) == 0) 
    { 
     printf("recieved upload from peer ?\n"); 
    } 
    else if(strncmp(header, "ERROR", 8) == 0) 
    { 
     printf("Recieved Error\n"); 
    } 
    else if(strncmp(header, "LIST", 8) == 0) 
    { 
     printf("Recieved Peer query for filelist.\n"); 
    } 

    return; 

} 

Это выход я получаю

4768bfdd77920fe0b4f25f173e568266 
CODE: 255 
LEN: 65000 
PNO: 2345678 
Recieved File list 
Segmentation fault (core dumped) 
+0

Вы строили с отладочной информацией? –

+0

Программа уже скомпилирована с флагом -g. @Quirliom См. Редактирование. – ffledgling

+3

'#include" hash_list.c "' - не делайте этого – teppic

ответ

5
unsigned char header[48]; 

... 

memset(&header, 0, 96); 

Это звучит неправильно.