#bpf #seccomp #assembly #filter #vm #cbpf

bpfvm

bpfvm 是一个小型的 BPF 虚拟机和 cBPF 令牌汇编器。它旨在在部署前测试 cBPF 功能,例如 seccomp BPF 过滤器。

3 个版本

0.1.2 2022 年 10 月 28 日
0.1.1 2022 年 10 月 28 日
0.1.0 2022 年 10 月 16 日

#316 in 测试

每月 21 次下载
用于 libpledge

ISC 许可证

48KB
996

bpfvm:cBPF '汇编器' 和虚拟机

bpfvm 是一个小型的 BPF 虚拟机和 cBPF 令牌汇编器。它旨在在部署前测试 cBPF 功能,例如 seccomp BPF 过滤器。

示例

// Simple BPF opcode list
//
#[test_log::test]
fn test_alu_mask() {
    let prog = vec![
        bpf_ld(Mode::ABS, 2*WORDS),
        bpf_stmt(libc::BPF_ALU | libc::BPF_AND | libc::BPF_K, 0xF0),
        bpf_ret(Src::Acc, 0),
    ];
    let mut vm = BpfVM::new(&prog).unwrap();

    let data = vec![0, 0, 0xFF, 0];
    let ret = vm.run(&data).unwrap();
    assert!(ret == 0xF0);

    let data = vec![0, 0, 0x80, 0];
    let ret = vm.run(&data).unwrap();
    assert!(ret == 0x80);
}

// With tokens and assembler...
//
#[test_log::test]
fn test_ld_gt_ret() {
    let asm = vec![
        Load(Mode::IMM, 99),
        Jump(JmpOp::JGT, 98, Some("ret_acc"), Some("ret999")),
        // Should skip this one
        Label("ret999"),
        Load(Mode::IMM, 999),
        Label("ret_acc"),
        Return(Src::Acc, 0),
    ];
    let prog = compile(&asm).unwrap();

    let mut vm = BpfVM::new(&prog).unwrap();
    let data = vec![];
    let ret = vm.run(&data).unwrap();
    assert!(ret == 99);
}

依赖项

~0.4–1MB
~21K SLoC