-
Notifications
You must be signed in to change notification settings - Fork 11
Expand file tree
/
Copy patharray.zig
More file actions
65 lines (56 loc) · 2.11 KB
/
array.zig
File metadata and controls
65 lines (56 loc) · 2.11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
const std = @import("std");
const root = @import("root.zig");
const print = std.debug.print;
const testing = std.testing;
const allocator = root.allocator;
const libbpf = root.libbpf;
test "array" {
_ = libbpf.libbpf_set_print(root.dbg_printf);
const path = try allocator.dupeZ(u8, @import("@build_options").prog_array_path);
defer allocator.free(path);
const obj = libbpf.bpf_object__open(path);
if (obj == null) {
print("failed to open bpf object: {}\n", .{std.posix.errno(-1)});
return error.OPEN;
}
defer libbpf.bpf_object__close(obj);
var ret = libbpf.bpf_object__load(obj);
if (ret != 0) {
print("failed to load bpf object: {}\n", .{std.posix.errno(-1)});
return error.LOAD;
}
if (libbpf.bpf_object__next_program(obj, null)) |prog| {
const map = libbpf.bpf_object__next_map(obj, null).?;
// map[0] = 1
var k: u32 = 0;
var v: u32 = 1;
ret = libbpf.bpf_map__update_elem(map, &k, @sizeOf(@TypeOf(k)), &v, @sizeOf(@TypeOf(v)), 0);
if (ret != 0) {
print("failed update map element: {}\n", .{std.posix.errno(-1)});
return error.MAP_UPDATE;
}
// run bpf program
const fd = libbpf.bpf_program__fd(prog);
var buf: [32]u8 = undefined;
var attr = std.mem.zeroInit(libbpf.bpf_test_run_opts, .{
.sz = @sizeOf(libbpf.bpf_test_run_opts),
.data_in = &buf,
.data_size_in = 32,
.data_out = &buf,
});
ret = libbpf.bpf_prog_test_run_opts(fd, &attr);
if (ret != 0) {
print("failed run prog: {}\n", .{std.posix.errno(-1)});
return error.RUN;
}
try testing.expectEqual(@as(@TypeOf(attr.retval), 0), attr.retval);
// expect map[1] == 2
k = 1;
ret = libbpf.bpf_map__lookup_elem(map, &k, @sizeOf(@TypeOf(k)), &v, @sizeOf(@TypeOf(v)), 0);
if (ret != 0) {
print("failed loopup map element: {}\n", .{std.posix.errno(-1)});
return error.MAP_LOOKUP;
}
try testing.expectEqual(@as(@TypeOf(v), 2), v);
}
}