在以下代碼中,BPF 程序tail_prog沒有從以下位置調用 tail main_prog:#include <linux/bpf.h>#include <bpf/bpf_helpers.h>struct bpf_map_def SEC("maps") jump_table = { .type = BPF_MAP_TYPE_PROG_ARRAY, .key_size = sizeof(__u32), .value_size = sizeof(__u32), .max_entries = 8,};SEC("xdp")int main_prog(struct xdp_md *ctx) { bpf_printk("Making tail call"); bpf_tail_call(ctx, &jump_table, 0); return XDP_PASS;}SEC("xdp_1")int tail_prog(struct xdp_md *ctx) { bpf_printk("Inside tail call"); return XDP_PASS;}char _license[] SEC("license") = "GPL";我觀察到只有 print inmain_prog被打印出來。我正在使用Cilium 的 eBPF Go 包加載 BPF 程序。這是加載程序和地圖的代碼:type BpfObjects struct { MainProg *ebpf.Program `ebpf:"main_prog"` TailProg *ebpf.Program `ebpf:"tail_prog"` JumpTable *ebpf.Map `ebpf:"jump_table"`} var objects BpfObjects spec, err := ebpf.LoadCollectionSpec("prog.o") if err != nil { log.Fatalln("ebpf.LoadCollectionSpec", err) } if err := spec.LoadAndAssign(&objects, nil); err != nil { log.Fatalln("ebpf.LoadAndAssign", err) } objects.JumpTable.Update(0, objects.TailProg.FD(), ebpf.UpdateAny)據(jù)此,跳轉表已從用戶空間初始化,這是我認為上面的最后一行應該做的。但是,我看不出那條線是否存在有任何區(qū)別。
1 回答

隔江千里
TA貢獻1906條經(jīng)驗 獲得超10個贊
我沒有查看Update函數(shù)返回的錯誤:Update can't marshal key: encoding int: binary.Write: invalid type int. 因此,程序數(shù)組映射沒有更新。我更改為以下內容:
err = objects.JumpTable.Update(uint32(0), uint32(objects.CopyHttpHostnameProg.FD()), ebpf.UpdateAny)
if err != nil {
println("Update", err.Error())
}
如果您0作為鍵傳遞,則鍵的大小為 8 個字節(jié),這就是您必須這樣做的原因uint32(0),這與映射的定義相匹配?,F(xiàn)在尾部調用成功了。
- 1 回答
- 0 關注
- 96 瀏覽
添加回答
舉報
0/150
提交
取消