Проблема программирования сокетов ipv6 + udp - PullRequest
1 голос
/ 04 июля 2019

Я написал код для генерации пакетов ipv6 + UDP, я столкнулся с sendto() сбрасывает " sendto fail: недопустимый аргумент" , однако с небольшими изменениями тот же код работает для ipv4 + udp. Может ли кто-нибудь помочь мне определить проблему, которую я потерял?

    //create a socket
//int s = socket (AF_INET6, SOCK_RAW, IPPROTO_RAW);
int s = socket (AF_INET6, SOCK_RAW, IPPROTO_UDP);
if(s == -1)
{
    perror("System Error: Failed to create raw socket");
    exit(1);
}
    int one=0;
const int *val = &one;

if(setsockopt(s, 41, IP_HDRINCL, val, sizeof(one)) < 0)
{
    perror("setsockopt() error");
    exit(-1);
}

iph  = (struct ip6_hdr*) datagram;
udph = (struct udphdr *) (datagram + sizeof (struct ip6_hdr));
uint32_t tot_pkts = config->num_pkts ;
while(tot_pkts)
{
    //if(send(s, (void*) iph, ntohs(iph->ip6_plen), 0 ) < 0)
    //if (sendto (s, (char*) udph, ntohs(iph->ip6_plen),  0, (struct sockaddr *) (&sin6), sizeof (sin6)) < 0)
    if (sendto (s, (char*) datagram, (ntohs(iph->ip6_plen) + sizeof(struct ip6_hdr)),  0, (struct sockaddr *) (&sin6), sizeof (sin6)) < 0){
        printf("Length ip:%d \n",ntohs(iph->ip6_plen));
        perror("sendto failed ");
    }
    else
    {
        printf("Sending ...Length ip:%d udp:%d\n", ntohs(iph->ip6_plen),ntohs(udph->len));
    }
    tot_pkts--;
}

1 Ответ

2 голосов
/ 04 июля 2019
 if(setsockopt(s, 41, IP_HDRINCL, val, sizeof(one)) < 0)

IP_HDRINCL не работает с IPv6, но только с IPv4. В Linux вы можете использовать IPV6_HDRINCL (в сочетании с IPPROTO_IPV6 в setsockopt).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...