|  |  | @ -8,7 +8,7 @@ use aya::{programs::FExit, Btf}; | 
			
		
	
		
		
			
				
					
					|  |  |  | {%- when "uprobe", "uretprobe" -%} |  |  |  | {%- when "uprobe", "uretprobe" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::UProbe; |  |  |  | use aya::programs::UProbe; | 
			
		
	
		
		
			
				
					
					|  |  |  | {%- when "sock_ops" -%} |  |  |  | {%- when "sock_ops" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::SockOps; |  |  |  | use aya::programs::{SockOps, links::CgroupAttachMode}; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | {%- when "sk_msg" -%} |  |  |  | {%- when "sk_msg" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::maps::SockHash; |  |  |  | use aya::maps::SockHash; | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::SkMsg; |  |  |  | use aya::programs::SkMsg; | 
			
		
	
	
		
		
			
				
					|  |  | @ -19,11 +19,11 @@ use aya::programs::{Xdp, XdpFlags}; | 
			
		
	
		
		
			
				
					
					|  |  |  | {%- when "classifier" -%} |  |  |  | {%- when "classifier" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::{tc, SchedClassifier, TcAttachType}; |  |  |  | use aya::programs::{tc, SchedClassifier, TcAttachType}; | 
			
		
	
		
		
			
				
					
					|  |  |  | {%- when "cgroup_skb" -%} |  |  |  | {%- when "cgroup_skb" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::{CgroupSkb, CgroupSkbAttachType}; |  |  |  | use aya::programs::{CgroupSkb, CgroupSkbAttachType, links::CgroupAttachMode}; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | {%- when "cgroup_sysctl" -%} |  |  |  | {%- when "cgroup_sysctl" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::CgroupSysctl; |  |  |  | use aya::programs::{CgroupSysctl, links::CgroupAttachMode}; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | {%- when "cgroup_sockopt" -%} |  |  |  | {%- when "cgroup_sockopt" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::CgroupSockopt; |  |  |  | use aya::programs::{CgroupSockopt, links::CgroupAttachMode}; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | {%- when "tracepoint" -%} |  |  |  | {%- when "tracepoint" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::TracePoint; |  |  |  | use aya::programs::TracePoint; | 
			
		
	
		
		
			
				
					
					|  |  |  | {%- when "lsm" -%} |  |  |  | {%- when "lsm" -%} | 
			
		
	
	
		
		
			
				
					|  |  | @ -39,8 +39,8 @@ use aya::programs::SocketFilter; | 
			
		
	
		
		
			
				
					
					|  |  |  | {%- when "raw_tracepoint" -%} |  |  |  | {%- when "raw_tracepoint" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::programs::RawTracePoint; |  |  |  | use aya::programs::RawTracePoint; | 
			
		
	
		
		
			
				
					
					|  |  |  | {%- endcase %} |  |  |  | {%- endcase %} | 
			
		
	
		
		
			
				
					
					|  |  |  | use aya::{include_bytes_aligned, Bpf}; |  |  |  | use aya::{include_bytes_aligned, Ebpf}; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | use aya_log::BpfLogger; |  |  |  | use aya_log::EbpfLogger; | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | {% if program_types_with_opts contains program_type -%} |  |  |  | {% if program_types_with_opts contains program_type -%} | 
			
		
	
		
		
			
				
					
					|  |  |  | use clap::Parser; |  |  |  | use clap::Parser; | 
			
		
	
		
		
			
				
					
					|  |  |  | {% endif -%} |  |  |  | {% endif -%} | 
			
		
	
	
		
		
			
				
					|  |  | @ -86,51 +86,51 @@ async fn main() -> Result<(), anyhow::Error> { | 
			
		
	
		
		
			
				
					
					|  |  |  |     // like to specify the eBPF program at runtime rather than at compile-time, you can
 |  |  |  |     // like to specify the eBPF program at runtime rather than at compile-time, you can
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     // reach for `Bpf::load_file` instead.
 |  |  |  |     // reach for `Bpf::load_file` instead.
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     #[cfg(debug_assertions)] |  |  |  |     #[cfg(debug_assertions)] | 
			
		
	
		
		
			
				
					
					|  |  |  |     let mut bpf = Bpf::load(include_bytes_aligned!( |  |  |  |     let mut ebpf = Ebpf::load(include_bytes_aligned!( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         "../../target/bpfel-unknown-none/debug/{{project-name}}" |  |  |  |         "../../target/bpfel-unknown-none/debug/{{project-name}}" | 
			
		
	
		
		
			
				
					
					|  |  |  |     ))?; |  |  |  |     ))?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     #[cfg(not(debug_assertions))] |  |  |  |     #[cfg(not(debug_assertions))] | 
			
		
	
		
		
			
				
					
					|  |  |  |     let mut bpf = Bpf::load(include_bytes_aligned!( |  |  |  |     let mut ebpf = Ebpf::load(include_bytes_aligned!( | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         "../../target/bpfel-unknown-none/release/{{project-name}}" |  |  |  |         "../../target/bpfel-unknown-none/release/{{project-name}}" | 
			
		
	
		
		
			
				
					
					|  |  |  |     ))?; |  |  |  |     ))?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     if let Err(e) = BpfLogger::init(&mut bpf) { |  |  |  |     if let Err(e) = EbpfLogger::init(&mut ebpf) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         // This can happen if you remove all log statements from your eBPF program.
 |  |  |  |         // This can happen if you remove all log statements from your eBPF program.
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         warn!("failed to initialize eBPF logger: {}", e); |  |  |  |         warn!("failed to initialize eBPF logger: {}", e); | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     {% case program_type -%} |  |  |  |     {% case program_type -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "kprobe", "kretprobe" -%} |  |  |  |     {%- when "kprobe", "kretprobe" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut KProbe = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut KProbe = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach("{{kprobe}}", 0)?; |  |  |  |     program.attach("{{kprobe}}", 0)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "fentry" -%} |  |  |  |     {%- when "fentry" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let btf = Btf::from_sys_fs()?; |  |  |  |     let btf = Btf::from_sys_fs()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut FEntry = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut FEntry = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load("{{fn_name}}", &btf)?; |  |  |  |     program.load("{{fn_name}}", &btf)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach()?; |  |  |  |     program.attach()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "fexit" -%} |  |  |  |     {%- when "fexit" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let btf = Btf::from_sys_fs()?; |  |  |  |     let btf = Btf::from_sys_fs()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut FExit = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut FExit = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load("{{fn_name}}", &btf)?; |  |  |  |     program.load("{{fn_name}}", &btf)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach()?; |  |  |  |     program.attach()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "uprobe", "uretprobe" -%} |  |  |  |     {%- when "uprobe", "uretprobe" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut UProbe = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut UProbe = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach(Some("{{uprobe_fn_name}}"), 0, "{{uprobe_target}}", opt.pid)?; |  |  |  |     program.attach(Some("{{uprobe_fn_name}}"), 0, "{{uprobe_target}}", opt.pid)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "sock_ops" -%} |  |  |  |     {%- when "sock_ops" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut SockOps = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut SockOps = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; |  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach(cgroup)?; |  |  |  |     program.attach(cgroup, CgroupAttachMode::default())?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     {%- when "sk_msg" -%} |  |  |  |     {%- when "sk_msg" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let sock_map: SockHash::<_, SockKey> = bpf.map("{{sock_map}}").unwrap().try_into()?; |  |  |  |     let sock_map: SockHash::<_, SockKey> = ebpf.map("{{sock_map}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     let map_fd = sock_map.fd().try_clone()?; |  |  |  |     let map_fd = sock_map.fd().try_clone()?; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     let prog: &mut SkMsg = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let prog: &mut SkMsg = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     prog.load()?; |  |  |  |     prog.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     prog.attach(&map_fd)?; |  |  |  |     prog.attach(&map_fd)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     // insert sockets to the map using sock_map.insert here, or from a sock_ops program
 |  |  |  |     // insert sockets to the map using sock_map.insert here, or from a sock_ops program
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "xdp" -%} |  |  |  |     {%- when "xdp" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut Xdp = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut Xdp = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach(&opt.iface, XdpFlags::default()) |  |  |  |     program.attach(&opt.iface, XdpFlags::default()) | 
			
		
	
		
		
			
				
					
					|  |  |  |         .context("failed to attach the XDP program with default flags - try changing XdpFlags::default() to XdpFlags::SKB_MODE")?; |  |  |  |         .context("failed to attach the XDP program with default flags - try changing XdpFlags::default() to XdpFlags::SKB_MODE")?; | 
			
		
	
	
		
		
			
				
					|  |  | @ -138,49 +138,49 @@ async fn main() -> Result<(), anyhow::Error> { | 
			
		
	
		
		
			
				
					
					|  |  |  |     // error adding clsact to the interface if it is already added is harmless
 |  |  |  |     // error adding clsact to the interface if it is already added is harmless
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     // the full cleanup can be done with 'sudo tc qdisc del dev eth0 clsact'.
 |  |  |  |     // the full cleanup can be done with 'sudo tc qdisc del dev eth0 clsact'.
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     let _ = tc::qdisc_add_clsact(&opt.iface); |  |  |  |     let _ = tc::qdisc_add_clsact(&opt.iface); | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut SchedClassifier = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut SchedClassifier = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach(&opt.iface, TcAttachType::{{direction}})?; |  |  |  |     program.attach(&opt.iface, TcAttachType::{{direction}})?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "cgroup_skb" -%} |  |  |  |     {%- when "cgroup_skb" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut CgroupSkb = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut CgroupSkb = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; |  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach(cgroup, CgroupSkbAttachType::{{direction}})?; |  |  |  |     program.attach(cgroup, CgroupSkbAttachType::{{direction}}, CgroupAttachMode::default())?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     {%- when "tracepoint" -%} |  |  |  |     {%- when "tracepoint" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut TracePoint = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut TracePoint = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach("{{tracepoint_category}}", "{{tracepoint_name}}")?; |  |  |  |     program.attach("{{tracepoint_category}}", "{{tracepoint_name}}")?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "lsm" -%} |  |  |  |     {%- when "lsm" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let btf = Btf::from_sys_fs()?; |  |  |  |     let btf = Btf::from_sys_fs()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut Lsm = bpf.program_mut("{{lsm_hook}}").unwrap().try_into()?; |  |  |  |     let program: &mut Lsm = ebpf.program_mut("{{lsm_hook}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load("{{lsm_hook}}", &btf)?; |  |  |  |     program.load("{{lsm_hook}}", &btf)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach()?; |  |  |  |     program.attach()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "tp_btf" -%} |  |  |  |     {%- when "tp_btf" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let btf = Btf::from_sys_fs()?; |  |  |  |     let btf = Btf::from_sys_fs()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut BtfTracePoint = bpf.program_mut("{{tracepoint_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut BtfTracePoint = ebpf.program_mut("{{tracepoint_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load("{{tracepoint_name}}", &btf)?; |  |  |  |     program.load("{{tracepoint_name}}", &btf)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach()?; |  |  |  |     program.attach()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "socket_filter" -%} |  |  |  |     {%- when "socket_filter" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let client = TcpStream::connect("127.0.0.1:1234")?; |  |  |  |     let client = TcpStream::connect("127.0.0.1:1234")?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     let prog: &mut SocketFilter = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let prog: &mut SocketFilter = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     prog.load()?; |  |  |  |     prog.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     prog.attach(client)?; |  |  |  |     prog.attach(client)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "cgroup_sysctl" -%} |  |  |  |     {%- when "cgroup_sysctl" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut CgroupSysctl = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut CgroupSysctl = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; |  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach(cgroup)?; |  |  |  |     program.attach(cgroup, CgroupAttachMode::default())?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     {%- when "cgroup_sockopt" -%} |  |  |  |     {%- when "cgroup_sockopt" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut CgroupSockopt = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut CgroupSockopt = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; |  |  |  |     let cgroup = std::fs::File::open(opt.cgroup_path)?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach(cgroup)?; |  |  |  |     program.attach(cgroup, CgroupAttachMode::default())?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     {%- when "perf_event" -%} |  |  |  |     {%- when "perf_event" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     // This will raise scheduled events on each CPU at 1 HZ, triggered by the kernel based
 |  |  |  |     // This will raise scheduled events on each CPU at 1 HZ, triggered by the kernel based
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     // on clock ticks.
 |  |  |  |     // on clock ticks.
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut PerfEvent = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut PerfEvent = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     for cpu in online_cpus()? { |  |  |  |     for cpu in online_cpus().map_err(|(_, error)| error)? { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         program.attach( |  |  |  |         program.attach( | 
			
		
	
		
		
			
				
					
					|  |  |  |             perf_event::PerfTypeId::Software, |  |  |  |             perf_event::PerfTypeId::Software, | 
			
		
	
		
		
			
				
					
					|  |  |  |             perf_event::perf_sw_ids::PERF_COUNT_SW_CPU_CLOCK as u64, |  |  |  |             perf_event::perf_sw_ids::PERF_COUNT_SW_CPU_CLOCK as u64, | 
			
		
	
	
		
		
			
				
					|  |  | @ -190,7 +190,7 @@ async fn main() -> Result<(), anyhow::Error> { | 
			
		
	
		
		
			
				
					
					|  |  |  |         )?; |  |  |  |         )?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- when "raw_tracepoint" -%} |  |  |  |     {%- when "raw_tracepoint" -%} | 
			
		
	
		
		
			
				
					
					|  |  |  |     let program: &mut RawTracePoint = bpf.program_mut("{{crate_name}}").unwrap().try_into()?; |  |  |  |     let program: &mut RawTracePoint = ebpf.program_mut("{{crate_name}}").unwrap().try_into()?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     program.load()?; |  |  |  |     program.load()?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     program.attach("{{tracepoint_name}}")?; |  |  |  |     program.attach("{{tracepoint_name}}")?; | 
			
		
	
		
		
			
				
					
					|  |  |  |     {%- endcase %} |  |  |  |     {%- endcase %} | 
			
		
	
	
		
		
			
				
					|  |  | 
 |