<?xml version="1.0" encoding="utf-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
	<channel>
		<atom:link href="http://gentoo-zh.org/extern.php?action=feed&amp;tid=873&amp;type=rss" rel="self" type="application/rss+xml" />
		<title><![CDATA[Gentoo中文社区 / Gentoo伯克利子系统之七:静态跟踪点tracepoint]]></title>
		<link>http://www.gentoo-zh.org/viewtopic.php?id=873</link>
		<description><![CDATA[Gentoo伯克利子系统之七:静态跟踪点tracepoint 最近发表的帖子。]]></description>
		<lastBuildDate>Sat, 13 Jul 2024 03:59:42 +0000</lastBuildDate>
		<generator>FluxBB</generator>
		<item>
			<title><![CDATA[Gentoo伯克利子系统之七:静态跟踪点tracepoint]]></title>
			<link>http://www.gentoo-zh.org/viewtopic.php?pid=993#p993</link>
			<description><![CDATA[<p>在《linux-observability-with-bpf》中第4章节中的案例中，有一个tracepoint bpf_prog_load的实例，在我自己的云主机上，执行不通过。发现网上也有一些人遇到。针对该问题分析了一下具体的原因。 根本原因是：内核版本的问题。<br />下面是《linux-observability-with-bpf》中的一个示例程序：</p><br /><div class="codebox"><pre><code>from bcc import BPF
 
bpf_source = &quot;&quot;&quot;
int trace_bpf_prog_load(struct pt_regs *ctx) {
  char comm[16];
  bpf_get_current_comm(&amp;comm, sizeof(comm));
  bpf_trace_printk(&quot;%s is loading a BPF program&quot;, comm);
  return 0;
}
&quot;&quot;&quot;
 
bpf = BPF(text = bpf_source)
bpf.attach_tracepoint(tp = &quot;bpf:bpf_prog_load&quot;, fn_name = &quot;trace_bpf_prog_load&quot;)
bpf.trace_print()</code></pre></div><p>上面的程序在bpf_prog_load的函数中添加一个添加一个tracepoint点。通过下面的命令可以参考本操作系统支持tracepoint的函数。<br />1）通过下面目录中，查看是否有相关的events</p><p><span class="postimg"><img src="https://www.batsom.net/usr/uploads/2024/05/2661943399.png" alt="FluxBB bbcode 测试" /></span></p><p>2）通过bcc的相关命令行工具</p><p><span class="postimg"><img src="https://www.batsom.net/usr/uploads/2024/05/980936701.png" alt="FluxBB bbcode 测试" /></span></p><p>&#160; &#160; &#160; &#160; 通过是上面的两个命令查看，都没有相关bpf的tracepoint点。所有执行上面的命令会出现下面的错误信息。open(/sys/kernel/debug/tracing/events/bpf/bpf_prog_load/id): No such file or directory </p><p><span class="postimg"><img src="https://www.batsom.net/usr/uploads/2024/05/3778500137.png" alt="FluxBB bbcode 测试" /></span></p><p>&#160; &#160; &#160; &#160; 通过对内核中相关的文件进行分析， 在kernel/bpf/syscall.c文件中，我们可以看到其中提交的一个commit，去掉对bpf_prog_load的tracepoint，使用git show 4d220ed 显示下面的信息</p><br /><p><span class="postimg"><img src="https://www.batsom.net/usr/uploads/2024/05/3104620357.png" alt="FluxBB bbcode 测试" /></span></p><p><span class="postimg"><img src="https://www.batsom.net/usr/uploads/2024/05/3104620357.png" alt="FluxBB bbcode 测试" /></span><br />&#160; &#160; &#160; &#160; 通过上面的查看，是在内核4.18之后的内核删除了。commit的描述是在有可能导致内核的panic。为了测试tracepoint的使用，可以使用下面的代码进行验证。 </p><div class="codebox"><pre><code>from bcc import BPF
 
bpf_source = &quot;&quot;&quot;
int trace_net_dev_xmit(struct pt_regs *ctx) {
  char comm[16];
  bpf_get_current_comm(&amp;comm, sizeof(comm));
  bpf_trace_printk(&quot;%s is loading a BPF program&quot;, comm);
  return 0;
}
&quot;&quot;&quot;
 
bpf = BPF(text = bpf_source)
bpf.attach_tracepoint(tp = &quot;net:net_dev_xmit&quot;, fn_name = &quot;trace_net_dev_xmit&quot;)
bpf.trace_print()</code></pre></div>]]></description>
			<author><![CDATA[dummy@example.com (batsom)]]></author>
			<pubDate>Sat, 13 Jul 2024 03:59:42 +0000</pubDate>
			<guid>http://www.gentoo-zh.org/viewtopic.php?pid=993#p993</guid>
		</item>
	</channel>
</rss>
