本文主要是介绍6.16 CO-RE(Compile Once – Run Everywhere)使用手册(二,处理内核改动和功能检测),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
写在前面
BPF_CORE_READ()宏系列是BPF CO-RE的核心,但在使用BPF CO-RE构建实用BPF应用程序时,还有更多内容需要考虑。
BPF应用程序必须处理的一个非常常见的问题是执行功能检测的需要。即检测特定主机内核是否支持某些新的可选功能,BPF应用程序可以利用这些功能来获取更多信息或提高效率。然而,如果内核不支持这些功能,BPF应用程序宁愿回退到支持旧内核的代码,而不是直接失败。
BPF CO-RE提供了一系列不同的机制来满足这些需求。当然,这些机制并非仅限于功能检测的使用场景,但我会以功能检测为主要用例来描述它们。
一,bpf_core_field_exists()
bpf_core_field_exists()允许检查给定的内核类型是否包含指定的字段。在内核功能检测的上下文中,如果某个所需的内核功能是通过向内核类型添加特定字段来实现的,那么可以使用直接的bpf_core_field_exists()检查来检测该功能。
作为一个具体的例子,检测内核是否支持基于perf的BPF程序类型(tracepoints、kprobes、uprobes)的BPF cookie(在此提交中添加)的一种方法是:
union bpf_attr *attr = ... /* 可以是NULL */; if (bpf_core_field_exists(attr->link_create.perf_event.bpf_cookie)) {
/* bpf_cookie 受支持 */
} else {
/* bpf_cookie 不受支持 */
}
上面的示例假设BPF程序有一个类型为union bpf_attr *的变量。它可以是NULL,实际上并不重要,因为指针本身从未被读取,
这篇关于6.16 CO-RE(Compile Once – Run Everywhere)使用手册(二,处理内核改动和功能检测)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!