我有 net_device
,它实现了 ndo_start_xmit
函数。
当调用ndo_start_xmit
函数时,我有一个包含IP数据包的skb
。我需要使用 IP+UDP
header 公开数据包并将其发送回路由系统。
问题是,当我调用 dst_input(skb)
或 dst_output(skb)
时,我会捕获 NULL
指针取消引用错误。看来我不能使用这个函数将封装的数据包推送到网络堆栈中。
解决办法是什么?
最佳答案
数据包传输期间(从驱动程序到网络链路)
将数据从套接字缓冲区 (skb->data) 复制到驱动程序内核缓冲区(在 hard_start_xmit 函数内)。
数据包接收期间(从网络链接到驱动程序)
创建skb缓冲区。将数据从驱动程序内核缓冲区复制到套接字缓冲区,并使用netif_rx()函数移交给内核网络堆栈。
关于networking - 将SKB推送到网络堆栈,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18486992/