-1

OSPF パケットを手動で生成する必要があるプロジェクトに取り組んでいます。現在、OSPF チェックサムを正しく取得するのに問題があります。Auth データを計算から除外する必要があることを読みましたが、そうしているにもかかわらず、それを機能させることができません。同じ関数を使用して IP ヘッダーのチェックサムを生成し、それが機能するため、チェックサムの生成に使用されている関数が正しいことはわかっています。

*C プログラミングが下手で申し訳ありません。C は私のメイン言語ではありません。

void generateHello(unsigned char* packet_return,unsigned char* buff,unsigned short *ospf_packet){
ospf_packet = (unsigned short*) malloc(14*sizeof(unsigned short));

//OSPF Version 
packet_return[34] = 0x02;

//Message Type - Hello
packet_return[35] = 0x01;

//Packet Length
packet_return[36] = 0x00;
packet_return[37] = 0x2c;

//Source OSPF Router (IP)
packet_return[38]=local_ip[0];
packet_return[39]=local_ip[1];
packet_return[40]=local_ip[2];
packet_return[41]=local_ip[3];

//Area 

packet_return[42]=0x00;
packet_return[43]=0x00;
packet_return[44]=0x00;
packet_return[45]=0x01;

//ADD CHECKSUM

packet_return[46]=0x00;
packet_return[47]=0x00;

//Auth Type
packet_return[48]=0x00;
packet_return[49]=0x00;

//Auth Data
packet_return[50]=0x00;
packet_return[51]=0x00;
packet_return[52]=0x00;
packet_return[53]=0x00;
packet_return[54]=0x00;
packet_return[55]=0x00;
packet_return[56]=0x00;
packet_return[57]=0x00;

//Network Mask
packet_return[58]=0xff;
packet_return[59]=0xff;
packet_return[60]=0xff;
packet_return[61]=0x00;

//Hello Interval
packet_return[62]=0x00;
packet_return[63]=0x0a;

//Multi-Topology Routing
packet_return[64]=0x12;

//Router Priority
packet_return[65]=0x01;

//Router Dead Interval 
packet_return[66]=0x00;
packet_return[67]=0x00;
packet_return[68]=0x00;
packet_return[69]=0x28;

//Designated Router
packet_return[70]=0x00;
packet_return[71]=0x00;
packet_return[72]=0x00;
packet_return[73]=0x00;

//Backup designated router
packet_return[74]=0x00;
packet_return[75]=0x00;
packet_return[76]=0x00;
packet_return[77]=0x00;

//Checksum
packet_return[78]=0x00;
packet_return[79]=0x00;

//LLS Data Length
packet_return[80]=0x00;
packet_return[81]=0x03;

//Type
packet_return[82]=0x00;
packet_return[83]=0x01;

//Length
packet_return[84]=0x00;
packet_return[85]=0x04;

//Options - LSDB Resynchronization
packet_return[86]=0x00;
packet_return[87]=0x00;
packet_return[88]=0x00;
packet_return[89]=0x01;


int i;
int j;
for(i=0,j=34;i<48;i++,j+=2)
{
    ospf_packet[i]= htons(((packet_return[j] << 8) | packet_return[j+1])); 
}


unsigned short ck_sum = in_cksum(ospf_packet,sizeof(unsigned short)*14);
printf("CHECKSUM OSPF - %.4x \n", ck_sum);

packet_return[46]=ck_sum & 0xff;
packet_return[47]=(ck_sum >> 8) & 0xff;
}
4

1 に答える 1

2

structまず、多くの配列オフセットで__attribute__((packed))はなく、定数またはより良いものを使用してください。

第二に、これは怪しいように見えます:

for(i=0,j=34;i<48;i++,j+=2)
{
    ospf_packet[i]= htons(((packet_return[j] << 8) | packet_return[j+1])); 
}

ospf_packetmalloc. _ それでも、あなたはそれに 48 個の署名のないショート パンツを書き込んでいます。これにより、未定義の動作が発生します。

また、おそらく配線順でpacket_returnあるように見えます。char *次に、それがすべてワイヤーオーダーのショートであると仮定して読み上げています(私が推測する限りでは問題ありません)。次に、ワイヤーオーダーからホストオーダーに変換します(そうです)-そうすべきでntohsはないと思いますhtons(はい、知っています彼らは同じことをします)。なぜこれを行っているのかはまったく明らかではありません。

最後に、認証フィールドを除く OSPF パケット全体で OSPF チェックサムが計算されます。

RFC2328から

    Checksum
        The standard IP 16-bit one's complement checksum of the
        entire OSPF packet, excluding the 64-bit authentication
        field.  This checksum is calculated as part of the
        appropriate authentication procedure; for some OSPF
        authentication types, the checksum calculation is omitted.
        See Section D.4 for details.

コードがパケット全体で合計される理由や、認証フィールドが省略されている理由がすぐにはわかりません。

于 2014-11-09T20:37:04.017 に答える