2

XDP BPF プログラムのテストを実行しようとしています。BPF プログラムはbpf_xdp_adjust_meta()ヘルパーを使用して、メタデータを調整します。

私は試した:

  1. 走るbpf_prog_test_run()
  2. 走る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 を返します。

ノート

プログラムは、実際のネットワーク インターフェイスのフック ポイントに正常に接続され、意図したとおりに実行されました。テスト用に、プログラムをフック ポイントに接続するコードを上記のコードに置き換えただけです。

4

1 に答える 1