eBPF编程与BCC工具实践指南

1、修改 hello - map.py,使 eBPF 代码能被多个系统调用触发。例如,openat() 通常用于打开文件,write() 用于向文件写入数据。可以先将 hello eBPF 程序附加到多个系统调用的 kprobe 上。然后尝试为不同的系统调用编写 hello eBPF 程序的修改版本,证明可以从多个不同的程序访问同一个映射。

可以按照以下步骤操作:

  1. 先将 hello eBPF 程序附加到多个系统调用(如 openat() write() )的 kprobe 上。
  2. 为不同的系统调用编写 hello eBPF 程序的修改版本。
  3. 在这些不同版本的程序中访问同一个映射,以此证明可以从多个不同程序访问同一映射。

2、BCC的RAW_TRACEPOINT_PROBE宏有什么作用?如何在hello - tail.py中使用该宏来简化原始跟踪点的附加操作?

BCC的`RAW_TRACEPOINT_PROBE`宏能简化原始跟踪点的附加操作,它会告知用户空间的BCC代码自动将其附加到指定的跟踪点。在`hello-tail.py`中使用该宏简化操作的方法如下:

- 用`RAW_TRACEPOINT_PROBE(sys_enter)`替换`hello()`函数的定义;
- 从Python代码中移除显式的附加调用`b.attach_raw_tracepoint()`;

这样BCC会自动创建附加,程序的运行效果与之前相同,体现了BCC宏的便捷性。

3、请解释以下两条 ip link 命令的作用:$ ip link set dev eth0 xdp obj hello.bpf.o sec xdp;$ ip link set dev eth0 xdp off

  • 第一个命令用于将标记为 xdp 节的 eBPF 程序从 hello.bpf.o 对象中读取出来,并将其附加到 eth0 网络接口;
  • 第二个命令用于从 eth0 网络接口移除已附加的 XDP 程序。

4、运行一个BCC示例程序。在程序运行时,使用第二个终端窗口,通过bpftool检查已加载的程序。你还可以使用bpftool prog dump命令查看这些程序的字节码和机器码版本。

  • 按照描述,先运行BCC示例程序
  • 在其运行期间,打开第二个终端窗口
  • 使用 bpftool 检查已加载程序
  • 使用 bpftool prog dump 命令查看程序的字节码和机器码版本

5、运行指定目录下的hello - tail.py程序,在其运行时查看它加载的程序。你还可以使用bpftool prog dump xlated命令查看字节码指令。

可按以下步骤操作:

  1. 运行指定目录下的 hello-tail.py 程序;
  2. 在程序运行时,使用 bpftool prog list 查看它加载的程序;
  3. 使用 bpftool prog dump xlated 查看字节码指令。

6、在XDP程序中返回0值对应XDP_ABORTED,会让内核中止对数据包的进一步处理。若修改程序返回0并将其附加到虚拟机的eth0接口,所有网络数据包会怎样?是否可以在容器内运行该程序,使XDP程序附加到仅影响该容器而非整个虚拟机的虚拟以太网接口?请给出相关示例链接。

在XDP程序里返回 0 值意味着 XDP_ABORTED ,会使内核停止处理数据包。
若将返回 0 的程序附加到虚拟机 eth0 接口,所有网络数据包会被丢弃。
可在容器内运行程序,让XDP程序关联到只影响容器的虚拟以太网接口,示例见 GitHub仓库

7、运行该示例程序的两个实例,这样会有两个名为config的映射。若运行bpftool map dump name config,输出将包含这两个不同映射的信息及其内容。在strace下运行此命令,并通过系统调用输出来跟踪不同文件描述符的使用情况。你能看出它在哪里检索映射信息,又在哪里检索存储在其中的键值对吗?

  • 可以根据系统调用判断信息检索位置。
  • 在查找映射时:
  • 使用 BPF_MAP_GET_NEXT_ID 获取下一个映
内容概要:本文详细记录了对一个Android ARM64静态ELF文件中字符串加密机制的逆向分析过程。该ELF文件的所有字符串均被加密,无法通过常规strings命令或IDA直接识别。作者通过分析发现,加密字符串存储在.rodata段,其解密所需信息(包括密文地址、长度和16位密钥)保存在.data.rel.ro段的40字节描述符中。核心解密函数sub_10F408采用自反的双pass流密码算法,结合固定密钥KEY_TERM(由.data段24字节数据计算得出),实现字节级非线性、位置长度相关的加密。文章还复现了完整的Python解密脚本,并揭示了该保护机制的本质为代码混淆而非强加密,最终成功批量解密全部956条字符串,暴露程序真实行为,如shell命令模板、设备标识篡改、网络重置等操作。此外,文中还提及未启用的自定义壳框架及其反dump设计。; 适合人群:具备逆向工程基础的安全研究人员、二进制分析人员及对ELF保护技术感兴趣的开发者。; 使用场景及目标:①学习ELF二进制中字符串加密的典型实现方式逆向突破口;②掌握从结构识别、函数追踪到算法还原的完整逆向流程;③理解“绑定二进制”的完整性校验设计及其局限性;④实践编写IDAPython脚本自动化提取解密敏感数据。; 阅读建议:此资源以实战案例驱动,不仅展示技术细节,更强调逆向思维验证方法,建议读者结合IDA调试环境,逐步跟随文中步骤进行动态分析算法验证,深入理解每一步的推理依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值