C 使用linux内核模块发送UDP数据包而不使用套接字

C 使用linux内核模块发送UDP数据包而不使用套接字,c,linux,sockets,linux-kernel,kernel-module,C,Linux,Sockets,Linux Kernel,Kernel Module,我正在编写一个内核模块来创建一个IP数据包。现在我想发送这个包,但还没有为它的传输创建任何套接字 有没有办法在内核例程的帮助下直接发送它 由于我跟踪了用于数据包传输的linux内核代码,在net/core/dev.c中定义了一个名为dev\u hard\u start\u xmit()的函数。我们能用它吗 实际上我不想使用套接字。在内核中发送UDP数据包不需要套接字,只需要分配一个skb,自己构造IP头和UDP头,最后通过dev_queue_xmit()发送出去 我也在做同样的过程,但在传输过程

我正在编写一个内核模块来创建一个IP数据包。现在我想发送这个包,但还没有为它的传输创建任何套接字

有没有办法在内核例程的帮助下直接发送它

由于我跟踪了用于数据包传输的linux内核代码,在net/core/dev.c中定义了一个名为dev\u hard\u start\u xmit()的函数。我们能用它吗


实际上我不想使用套接字。

在内核中发送UDP数据包不需要套接字,只需要分配一个skb,自己构造IP头和UDP头,最后通过dev_queue_xmit()发送出去


我也在做同样的过程,但在传输过程中,系统变得有点慢。为什么会发生这种情况我无法找到…请帮忙???我也有同样的问题。你从哪里得到开发结构?@Gaurav可能,要么开发人员已经知道,要么git从查找到路由表。传输速度非常慢。比使用原始套接字低。这是什么原因?任何想法。。
skb = alloc_skb(len, GFP_ATOMIC);
if (!skb)
        return;

skb_put(skb, len);

skb_push(skb, sizeof(*udph));
skb_reset_transport_header(skb);
udph = udp_hdr(skb);
udph->source = htons(....);
udph->dest = htons(...);
udph->len = htons(udp_len);
udph->check = 0;
udph->check = csum_tcpudp_magic(local_ip,
                                remote_ip,
                                udp_len, IPPROTO_UDP,
                                csum_partial(udph, udp_len, 0));

if (udph->check == 0)
        udph->check = CSUM_MANGLED_0;

skb_push(skb, sizeof(*iph));
skb_reset_network_header(skb);
iph = ip_hdr(skb);

/* iph->version = 4; iph->ihl = 5; */
put_unaligned(0x45, (unsigned char *)iph);
iph->tos      = 0;
put_unaligned(htons(ip_len), &(iph->tot_len));
iph->id       = htons(atomic_inc_return(&ip_ident));
iph->frag_off = 0;
iph->ttl      = 64;
iph->protocol = IPPROTO_UDP;
iph->check    = 0;
put_unaligned(local_ip, &(iph->saddr));
put_unaligned(remote_ip, &(iph->daddr));
iph->check    = ip_fast_csum((unsigned char *)iph, iph->ihl);

eth = (struct ethhdr *) skb_push(skb, ETH_HLEN);
skb_reset_mac_header(skb);
skb->protocol = eth->h_proto = htons(ETH_P_IP);
memcpy(eth->h_source, dev->dev_addr, ETH_ALEN);
memcpy(eth->h_dest, remote_mac, ETH_ALEN);

skb->dev = dev;


dev_queue_xmit(skb);