-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathingress_bpfeb.go
137 lines (117 loc) · 3.26 KB
/
ingress_bpfeb.go
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
// Code generated by bpf2go; DO NOT EDIT.
//go:build arm64be || armbe || mips || mips64 || mips64p32 || ppc64 || s390 || s390x || sparc || sparc64
// +build arm64be armbe mips mips64 mips64p32 ppc64 s390 s390x sparc sparc64
package main
import (
"bytes"
_ "embed"
"fmt"
"io"
"github.com/cilium/ebpf"
)
type ingressSeg6localKey struct {
Base struct {
Prefixlen uint32
Data [0]uint8
}
Prefix struct{ In6U struct{ U6Addr8 [16]uint8 } }
Pad [12]uint8
}
type ingressSeg6localVal struct {
Action uint32
Attr struct{ Vrftable uint32 }
}
// loadIngress returns the embedded CollectionSpec for ingress.
func loadIngress() (*ebpf.CollectionSpec, error) {
reader := bytes.NewReader(_IngressBytes)
spec, err := ebpf.LoadCollectionSpecFromReader(reader)
if err != nil {
return nil, fmt.Errorf("can't load ingress: %w", err)
}
return spec, err
}
// loadIngressObjects loads ingress and converts it into a struct.
//
// The following types are suitable as obj argument:
//
// *ingressObjects
// *ingressPrograms
// *ingressMaps
//
// See ebpf.CollectionSpec.LoadAndAssign documentation for details.
func loadIngressObjects(obj interface{}, opts *ebpf.CollectionOptions) error {
spec, err := loadIngress()
if err != nil {
return err
}
return spec.LoadAndAssign(obj, opts)
}
// ingressSpecs contains maps and programs before they are loaded into the kernel.
//
// It can be passed ebpf.CollectionSpec.Assign.
type ingressSpecs struct {
ingressProgramSpecs
ingressMapSpecs
}
// ingressSpecs contains programs before they are loaded into the kernel.
//
// It can be passed ebpf.CollectionSpec.Assign.
type ingressProgramSpecs struct {
IngressMain *ebpf.ProgramSpec `ebpf:"ingress_main"`
}
// ingressMapSpecs contains maps before they are loaded into the kernel.
//
// It can be passed ebpf.CollectionSpec.Assign.
type ingressMapSpecs struct {
Vrftable2ifindex *ebpf.MapSpec `ebpf:"vrftable2ifindex"`
ZebraSeg6localMap *ebpf.MapSpec `ebpf:"zebra_seg6local_map"`
}
// ingressObjects contains all objects after they have been loaded into the kernel.
//
// It can be passed to loadIngressObjects or ebpf.CollectionSpec.LoadAndAssign.
type ingressObjects struct {
ingressPrograms
ingressMaps
}
func (o *ingressObjects) Close() error {
return _IngressClose(
&o.ingressPrograms,
&o.ingressMaps,
)
}
// ingressMaps contains all maps after they have been loaded into the kernel.
//
// It can be passed to loadIngressObjects or ebpf.CollectionSpec.LoadAndAssign.
type ingressMaps struct {
Vrftable2ifindex *ebpf.Map `ebpf:"vrftable2ifindex"`
ZebraSeg6localMap *ebpf.Map `ebpf:"zebra_seg6local_map"`
}
func (m *ingressMaps) Close() error {
return _IngressClose(
m.Vrftable2ifindex,
m.ZebraSeg6localMap,
)
}
// ingressPrograms contains all programs after they have been loaded into the kernel.
//
// It can be passed to loadIngressObjects or ebpf.CollectionSpec.LoadAndAssign.
type ingressPrograms struct {
IngressMain *ebpf.Program `ebpf:"ingress_main"`
}
func (p *ingressPrograms) Close() error {
return _IngressClose(
p.IngressMain,
)
}
func _IngressClose(closers ...io.Closer) error {
for _, closer := range closers {
if err := closer.Close(); err != nil {
return err
}
}
return nil
}
// Do not access this directly.
//
//go:embed ingress_bpfeb.o
var _IngressBytes []byte