XDP BPF プログラムのテストを実行しようとしています。BPF プログラムはbpf_xdp_adjust_meta()
ヘルパーを使用して、メタデータを調整します。
私は試した:
- 走る
bpf_prog_test_run()
- 走る
bpf_prog_test_run_xattr()
1.bpf_prog_test_run()
(bpf プログラムのデバッグ メッセージを初めて試したとき、data_meta フィールドの調整に失敗したことがわかりました。)現在、data_meta を調整できますが、iph.ihl
フィールドは明らかに 5 に設定されていません。
2.bpf_prog_test_xattr()
これは常に -1 を返すので、何かが失敗しました。
コード
パケット:
struct ipv4_packet pkt_v4 = {
.eth.h_proto = __bpf_constant_htons(ETH_P_IP),
.iph.ihl = 5,
.iph.daddr = __bpf_constant_htonl(33554442),
.iph.saddr = __bpf_constant_htonl(50331658),
.iph.protocol = IPPROTO_TCP,
.iph.tot_len = __bpf_constant_htons(MAGIC_BYTES),
.tcp.urg_ptr = 123,
.tcp.doff = 5,
};
テスト属性:
__u32 size, retval, duration;
char data_out[128];
struct xdp_md ctx_in, ctx_out;
struct bpf_prog_test_run_attr test_attr = {
.prog_fd = prog_fd,
.repeat = 100,
.data_in = &pkt_v4,
.data_size_in = sizeof(&pkt_v4),
.data_out = &data_out,
.data_size_out = sizeof(data_out),
.ctx_in = &ctx_in,
.ctx_size_in = sizeof(ctx_in),
.ctx_out = &ctx_out,
.ctx_size_out = sizeof(ctx_out),
.retval = &retval,
.duration = &duration,
};
テストの実行:
bpf_prog_test_run(main_prog_fd, 1, &pkt_v4, sizeof(pkt_v4), &data_out, &size, &retval, &duration)
->iph.ihl
フィールドは 0 です。
bpf_prog_test_run_xattr(&test_attr)
-> -1 を返します。
ノート
プログラムは、実際のネットワーク インターフェイスのフック ポイントに正常に接続され、意図したとおりに実行されました。テスト用に、プログラムをフック ポイントに接続するコードを上記のコードに置き換えただけです。