Documentation ¶
Index ¶
Constants ¶
View Source
const ( XdpProgramInterface = "bpfman.io.xdpprogramcontroller/interface" TcProgramInterface = "bpfman.io.tcprogramcontroller/interface" TracepointProgramTracepoint = "bpfman.io.tracepointprogramcontroller/tracepoint" KprobeProgramFunction = "bpfman.io.kprobeprogramcontroller/function" UprobeProgramTarget = "bpfman.io.uprobeprogramcontroller/target" UprobeContainerPid = "bpfman.io.uprobeprogramcontroller/containerpid" UprobeNoContainersOnNode = "bpfman.io.uprobeprogramcontroller/nocontainersonnode" FentryProgramFunction = "bpfman.io.fentryprogramcontroller/function" FexitProgramFunction = "bpfman.io.fexitprogramcontroller/function" K8sHostLabel = "kubernetes.io/hostname" DiscoveredLabel = "bpfman.io/discoveredProgram" IdAnnotation = "bpfman.io/ProgramId" UuidMetadataKey = "bpfman.io/uuid" ProgramNameKey = "bpfman.io/ProgramName" BpfmanNs = "bpfman" BpfmanOperatorName = "bpfman-operator" BpfmanDsName = "bpfman-daemon" BpfmanConfigName = "bpfman-config" BpfmanCsiDriverName = "csi.bpfman.io" BpfmanRestrictedSccName = "bpfman-restricted" BpfmanContainerName = "bpfman" BpfmanAgentContainerName = "bpfman-agent" BpfmanDaemonManifestPath = "./config/bpfman-deployment/daemonset.yaml" BpfmanCsiDriverPath = "./config/bpfman-deployment/csidriverinfo.yaml" BpfmanRestrictedSCCPath = "./config/openshift/restricted-scc.yaml" BpfmanMapFs = "/run/bpfman/fs/maps" DefaultType = "tcp" DefaultPath = "/run/bpfman-sock/bpfman.sock" DefaultPort = 50051 DefaultEnabled = true // BpfProgramOwner is the name of the object that owns the BpfProgram // object. In the case of a *Program, it will be the name of the *Program // object. In the case of a BpfApplication, it will be the name of the // BpfApplication object. BpfProgramOwner = "bpfman.io/ownedByProgram" // AppProgramId is an identifier that is used to identify individual // programs that are part of a given BpfApplication object. *Programs have // an AppProgramId of "". AppProgramId = "bpfman.io/appProgramId" // BpfProgramAttachPoint is the attach point for a given BpfProgram. BpfProgramAttachPoint = "bpfman.io/bpfProgramAttachPoint" )
View Source
const ( // BpfmanOperatorFinalizer is the finalizer that holds a *Program from // deletion until cleanup can be performed. BpfmanOperatorFinalizer = "bpfman.io.operator/finalizer" // XdpProgramControllerFinalizer is the finalizer that holds an Xdp BpfProgram // object from deletion until cleanup can be performed. XdpProgramControllerFinalizer = "bpfman.io.xdpprogramcontroller/finalizer" // TcProgramControllerFinalizer is the finalizer that holds an Tc BpfProgram // object from deletion until cleanup can be performed. TcProgramControllerFinalizer = "bpfman.io.tcprogramcontroller/finalizer" // TracepointProgramControllerFinalizer is the finalizer that holds an Tracepoint // BpfProgram object from deletion until cleanup can be performed. TracepointProgramControllerFinalizer = "bpfman.io.tracepointprogramcontroller/finalizer" // KprobeProgramControllerFinalizer is the finalizer that holds a Kprobe // BpfProgram object from deletion until cleanup can be performed. KprobeProgramControllerFinalizer = "bpfman.io.kprobeprogramcontroller/finalizer" // UprobeProgramControllerFinalizer is the finalizer that holds a Uprobe // BpfProgram object from deletion until cleanup can be performed. UprobeProgramControllerFinalizer = "bpfman.io.uprobeprogramcontroller/finalizer" // FentryProgramControllerFinalizer is the finalizer that holds a Fentry // BpfProgram object from deletion until cleanup can be performed. FentryProgramControllerFinalizer = "bpfman.io.fentryprogramcontroller/finalizer" // FexitProgramControllerFinalizer is the finalizer that holds a Fexit // BpfProgram object from deletion until cleanup can be performed. FexitProgramControllerFinalizer = "bpfman.io.fexitprogramcontroller/finalizer" // BpfApplicationFinalizer is the finalizer that holds a BpfApplication BpfApplicationControllerFinalizer = "bpfman.io.bpfapplicationcontroller/finalizer" )
View Source
const ApplicationString = "application"
View Source
const FentryString = "fentry"
View Source
const FexitString = "fexit"
View Source
const UprobeString = "uprobe"
Define a constant strings for Uprobe, Fentry and Fexit. Uprobe has the same kernel ProgramType as Kprobe, and Fentry and Fexit both have the Tracing ProgramType, so we can't use the ProgramType String() method above.
Variables ¶
This section is empty.
Functions ¶
func BpfProgramNodePredicate ¶
Only reconcile if a bpfprogram has been created for a controller's node.
func BpfProgramTypePredicate ¶
Only reconcile if a bpfprogram has been created for the controller's program type.
func DiscoveredBpfProgramPredicate ¶
Only reconcile if a bpfprogram has been created for a controller's node.
func StatusChangedPredicate ¶
Types ¶
type ProgramType ¶
type ProgramType int32
Must match the kernel's `bpf_prog_type` enum. https://elixir.bootlin.com/linux/v6.4.4/source/include/uapi/linux/bpf.h#L948
const ( Unspec ProgramType = iota SocketFilter Kprobe Tc SchedAct Tracepoint Xdp PerfEvent CgroupSkb CgroupSock LwtIn LwtOut LwtXmit SockOps SkSkb CgroupDevice SkMsg RawTracepoint CgroupSockAddr LwtSeg6Local LircMode2 SkReuseport FlowDissector CgroupSysctl RawTracepointWritable CgroupSockopt Tracing StructOps Ext Lsm SkLookup Syscall )
func FromString ¶
func FromString(p string) (*ProgramType, error)
func (ProgramType) String ¶
func (p ProgramType) String() string
func (ProgramType) Uint32 ¶
func (p ProgramType) Uint32() *uint32
type ReconcileResult ¶
type ReconcileResult uint8
const ( // No changes were made to k8s objects, and rescheduling another reconcile // is not necessary. The calling code may continue reconciling other // programs in it's list. Unchanged ReconcileResult = 0 // Changes were made to k8s objects that we know will trigger another // reconcile. Calling code should stop reconciling additional programs and // return immediately to avoid multiple concurrent reconcile threads. Updated ReconcileResult = 1 // A retry should be scheduled. This should only be used when "Updated" // doesn't apply, but we want to trigger another reconcile anyway. For // example, there was a transient error. The calling code may continue // reconciling other programs in it's list. Requeue ReconcileResult = 2 )
func (ReconcileResult) String ¶
func (r ReconcileResult) String() string
Click to show internal directories.
Click to hide internal directories.