【C语言】linux内核generic_xdp_tx

一、中文注释

/* 在执行通用XDP时,我们必须绕过qdisc层和网络挖掘点,* 以匹配驱动内XDP的行为。*/
void generic_xdp_tx(struct sk_buff *skb, struct bpf_prog *xdp_prog)
{struct net_device *dev = skb->dev; // 获取skb对应的网络设备struct netdev_queue *txq; // 声明网络设备发送队列bool free_skb = true; // 初始化一个标志位,用于标记是否需要释放skbint cpu, rc; // 声明CPU核心号和返回码变量txq = netdev_pick_tx(dev, skb, NULL); // 选择用于发送的队列cpu = smp_processor_id(); // 获取当前CPU核心的IDHARD_TX_LOCK(dev, txq, cpu); // 对选定的发送队列加锁if (!netif_xmit_stopped(txq)) { // 检查发送队列是否被停止rc = netdev_start_xmit(skb, dev, txq, 0); // 开始发送数据包if (dev_xmit_complete(rc)) // 如果发送完成,则不释放skbfree_skb = false;}HARD_TX_UNLOCK(dev, txq); // 解锁发送队列if (free_skb) { // 如果标志位为true,则释放skbtrace_xdp_exception(dev, xdp_prog, XDP_TX); // 记录XDP传输异常kfree_skb(skb); // 释放skb}
}
EXPORT_SYMBOL_GPL(generic_xdp_tx); // 导出该符号,GPL协议的模块可以使用这个函数

这个函数`generic_xdp_tx`用于通用XDP处理的数据包发送。代码里包含了一系列网络层的操作和逻辑判断。它在锁定CPU和筛选适当的网络发送队列之后,尝试发送数据包,如果发送成功,则记录结果,否则将数据包内存释放。

二、XDP

在 Linux 内核 4.9 版本中,XDP 指的是 eXpress Data Path。XDP 是一种高性能、可编程的网络数据路径,它允许用户态程序直接处理在网络设备驱动程序层收到的包,提供了一种脱离内核网络栈处理数据包的方法。通过XDP,可以在内核中运行的 eBPF (extended Berkeley Packet Filter) 程序,以决定包应该被丢弃、传递到常规的内核网络栈,还是直接转发到另一个接口。
XDP可以用于多种场景,比如DDoS攻击防御、高速包路由、负载均衡等,它通过允许包在被内核完全处理之前就被处理,来显著减少数据包处理的延迟和CPU占用。这使得XDP尤其适合那些需要非常低延迟和高吞吐量的场合。
在函数`generic_xdp_tx`中,XDP是用来处理网络数据包,并且在某些情况下,该函数在发送数据包前会绕过正常的内核网络队列调度(qdisc layer)和监视点(network taps)。这通常是当在驱动内部使用XDP时要实现的行为。而在这个函数中,我们可以看到涉及到skb(Socket Buffer)的发送逻辑,以及可能的异常记录和资源清理。这是在软件层面实现了类似硬件加速XDP的行为,因此被称为"通用XDP"(generic XDP)。

三、中文讲解

这段代码是 Linux 内核网络子系统的一部分,它实现了通用 XDP (eXpress Data Path) 传输的功能。在不支持驱动程序级别 XDP 的网络设备上,当你需要处理 XDP 程序的发送行为时,可以使用这个函数。下面是对这段代码的详细解释:
1. 函数签名 void generic_xdp_tx(struct sk_buff *skb, struct bpf_prog *xdp_prog):这个函数接收两个参数:`skb`(Socket Buffer,网络数据包的内核表示)和 xdp_prog(与 XDP 程序相关联的 BPF 程序)。
2. struct net_device *dev = skb->dev;:从 skb 中提取关联的网络设备,这个设备表示数据包将要发送的目的地网络接口。
3. struct netdev_queue *txq;:定义一个指向 netdev_queue 的指针,表示网络设备的发送队列。
4. bool free_skb = true;:定义一个布尔变量用来标记是否应该释放 skb,初始设置为 true,表示默认情况下(如果发送失败)需要释放 skb。
5. txq = netdev_pick_tx(dev, skb, NULL);:选择一个合适的发送队列来处理 skb。如果无法选择队列,可能会返回 NULL。
6. cpu = smp_processor_id();:获取当前 CPU 的 ID,用于确定发送数据包的 CPU。
7. HARD_TX_LOCK(dev, txq, cpu);:获取发送路径上的锁定,确保数据包发送的临界区保护。
8. if (!netif_xmit_stopped(txq)) {:检查是否队列已经停止发送。如果没有停止,就尝试发送数据包。
9. rc = netdev_start_xmit(skb, dev, txq, 0);:调用 netdev_start_xmit 函数发送数据包。
10. if (dev_xmit_complete(rc)):判断发送函数返回的结果是否表示发送完毕。如果 dev_xmit_complete(rc) 返回 true,则代表数据包已经成功发送,并且不需要释放 skb。
11. HARD_TX_UNLOCK(dev, txq);:释放之前获得的锁。
12. if (free_skb) {:如果之前没有发送成功,或者发送函数指示我们需要自行释放 skb。
13. trace_xdp_exception(dev, xdp_prog, XDP_TX);:如果有需要,记录 XDP 异常事件(这个调用可能与监控和调试相关)。
14. kfree_skb(skb);:释放 skb 资源,避免内存泄漏。
15. EXPORT_SYMBOL_GPL(generic_xdp_tx);:导出 generic_xdp_tx 函数,使其可以被模块使用,同时指明该函数受 GPL 许可证保护。
需要注意的是,这段代码需要在 Linux 内核的上下文中执行,并且需要相应的内核编程知识和经验。内核版本不同,细节上可能会有所差异。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/715317.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面试高频率问答题目

索引: 主键索引:表的id (唯一 且 不能为空) 唯一索引:表User 假设有account 字段 ,用户名不重复 (唯一 可以为空) 复合索引:where() 的条件 用户名,密码 …

MySQL:函数

提醒: 设定下面的语句是在数据库名为 db_book里执行的。 创建user_info表 注意:pwd为密码字段,这里使用了VARCHAR(128)类型,为了后面方便对比,开发项目里一般使用char(32),SQL语句里使用MD5加密函数 USE db…

【博图TIA-Api】通过Excel自动新建文件夹和导入FB块

【博图TIA-Api】通过Excel自动新建文件夹和导入FB块 说明思路准备获取Excel表格内文件名和FB块名等信息新建文件夹部分筛分获取的文件夹数据,去掉重复内容创建文件夹 导入FB块导出FB块的xml文件查找需要放置的文件夹导入块 说明 续上一篇文章,这次是根据…

多线程 --- [ 线程池、线程安全、其他常见的锁 ]

目录 1. 线程池 模块一:线程的封装 模块二:线程池的封装 模块三:互斥量的封装 (RAII风格) 模块四:任务的封装 模块五:日志的封装 模块六:时间的封装 模块六:主函数 模块七&#xff1a…

备战蓝桥杯---状态压缩DP进阶题1

我们来看一看一道比较难的问题(十分十分的巧妙): 显然我们应该一行一行放,又竖的会对下一行产生影响,我们令横着放为0,竖着放的上方为1. 对于下一行,前一行放1的下面为0,但是会出现…

【Redis | 第九篇】一篇文章看懂Redis持久化机制

文章目录 9.一篇文章看懂Redis持久化机制9.1Redis的两种持久化机制9.1.1为什么有持久化? 9.2RDB机制9.2.1介绍9.2.2触发机制(1)save命令触发(2)bgsave命令触发(3)自动触发 9.2.3执行流程9.2.4优…

C++知识点总结(22):模拟算法真题 ★★★★☆《卡牌游戏》《移动距离》

一、卡牌游戏 1. 审题 题目描述 A , B , C A,B,C A,B,C 三人在玩一个卡牌游戏,规则如下: 游戏开始时, 3 3 3 人分别会得到若干张手牌, 每张牌上写着 a,b,c 中某一个字母。手牌的顺序严格按照输入顺序排列&#xff0c…

前端【技术类】资源学习网站整理(那些年的小网站)

学习网站整理 值得分享的视频博主:学习网站链接 百度首页的资源收藏里的截图(排列顺序没有任何意义,随性而已~),可根据我标注的关键词百度搜索到这些网站呀,本篇末尾会一一列出来,供大家学习呀 …

彻底搞懂回溯算法(例题详解)

目录 什么是回溯算法: 子集问题: 子集问题II(元素可重复但不可复选): 组合问题: 组合问题II(元素可重复但不可复选): 排列问题: 排列问题II(元素可重复但不可复选): 什么是回溯算法: 「回溯是递归的副产品&…

最小生成树---Kruskal算法

最小生成树定义: 给定一张边带权的无向图 G(V,E),其中 V 表示图中点的集合,E 表示图中边的集合。 由 V 中的全部 n 个顶点和 E 中 n−1 条边构成的无向连通子图被称为 G 的一棵生成树,其中边的权值之和最小的生成树被称为无向图 G…

leetcode hot100 每日温度

在本题中,我们是通过单调栈来解决的,因为我们采用了栈的数据结构,并且,栈内存储的元素是单调的。 本题我们考虑,将气温数组元素的下标存入栈中,首先初始化要把0放入,0是下标的意思。然后我们拿…

华为HCIP Datacom H12-821 卷4

1.单选题 下面哪些策略或工具不能够应用于 OSPF: A、access-list B、prefix-list C、route- Policy D、as-path filter 正确答案: D 解析: as-path-filter命令用来创建AS路径过滤器,OSPF属于IGP协议,不涉及到AS号。 2.单选题…

【python基础学习05课_for循环以及双重for循环】

FOR循环 一、认识循环-while 1、循环条件不能超出列表长度 当i 1&#xff0c;while i < len(lst1) 时&#xff0c;i 3后, 打印print&#xff08;lst[3]&#xff09;小宋老师&#xff0c; 继续1, i 4, 4不小于 len(lst1)&#xff0c;打破循环。 2、循环条件超出列表长度报错…

JMeter元件和采样器一览

Apache JMeter是一个强大的开源负载测试工具&#xff0c;用于性能和功能测试。JMeter提供了丰富的元件和采样器&#xff0c;使得它能够模拟复杂的测试场景和高并发的用户请求。以下是JMeter中常用的一些元件和采样器的介绍和讲解&#xff1a; 测试计划元件 测试计划&#xff0…

latex报错I was expecting a `,‘ or a `}‘的解决办法

解决办法——经过检查在ref22后面缺少一个逗号 总结 当你在使用LaTeX时遇到“I was expecting a , or a }”这样的错误&#xff0c;这通常意味着LaTeX在解析你的代码时&#xff0c;预期在某个位置看到一个逗号&#xff08;,&#xff09;或一个大括号&#xff08;}&#xff09;…

每日一题 2369

2369. 检查数组是否存在有效划分 题目描述&#xff1a; 给你一个下标从 0 开始的整数数组 nums &#xff0c;你必须将数组划分为一个或多个 连续 子数组。 如果获得的这些子数组中每个都能满足下述条件 之一 &#xff0c;则可以称其为数组的一种 有效 划分&#xff1a; 子数…

PTA 1010 一元多项式求导

1010 一元多项式求导 (25分) C/C - 知乎 (zhihu.com) #include<stdio.h> int main(){ int x,n; scanf("%d %d",&x,&n); if(n0)printf("%d %d",0,0); //n0 说明是常数&#xff0c;不需要求导 else printf("%d %…

STM32 串口通信

串口发原理 在stm32每个串口内部有发送寄存器和发送移位寄存器。 当调用HAL_UART_Transmit 时&#xff0c;cpu会将发送的数据放入发送寄存器中。发送移位寄存器会将数据转换成电平的高低&#xff0c;从TX发出。 1、轮询模式配置、发送与接收 轮询模式时cpu会不断检测发送数…

嵌入式中汇编语言的基本实现

大家好&#xff0c;今天给大家分享&#xff0c;GNU汇编的语法。 第一&#xff1a;汇编简介 GNU 汇编语法适用于所有的架构&#xff0c;并不是 ARM 独享的&#xff0c;GNU 汇编由一系列的语句组成&#xff0c; 每行一条语句&#xff0c;每条语句有三个可选部分&#xff0c;如下…

小白学视觉 | 详解遗传算法 GA(Python实现代码)

本文来源公众号“小白学视觉”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;详解遗传算法 GA&#xff08;Python实现代码&#xff09; 转自&#xff1a;机器之心 英文&#xff1a;www.analyticsvidhya.com/blog/2017/07/introduc…