162306a36Sopenharmony_ci/* Copyright (c) 2015 PLUMgrid, http://plumgrid.com 262306a36Sopenharmony_ci * 362306a36Sopenharmony_ci * This program is free software; you can redistribute it and/or 462306a36Sopenharmony_ci * modify it under the terms of version 2 of the GNU General Public 562306a36Sopenharmony_ci * License as published by the Free Software Foundation. 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci#include "vmlinux.h" 862306a36Sopenharmony_ci#include <linux/version.h> 962306a36Sopenharmony_ci#include <bpf/bpf_helpers.h> 1062306a36Sopenharmony_ci#include <bpf/bpf_tracing.h> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_cistruct pair { 1362306a36Sopenharmony_ci u64 val; 1462306a36Sopenharmony_ci u64 ip; 1562306a36Sopenharmony_ci}; 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_cistruct { 1862306a36Sopenharmony_ci __uint(type, BPF_MAP_TYPE_HASH); 1962306a36Sopenharmony_ci __type(key, long); 2062306a36Sopenharmony_ci __type(value, struct pair); 2162306a36Sopenharmony_ci __uint(max_entries, 1000000); 2262306a36Sopenharmony_ci} my_map SEC(".maps"); 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci/* kprobe is NOT a stable ABI. If kernel internals change this bpf+kprobe 2562306a36Sopenharmony_ci * example will no longer be meaningful 2662306a36Sopenharmony_ci */ 2762306a36Sopenharmony_ciSEC("kprobe/kmem_cache_free") 2862306a36Sopenharmony_ciint bpf_prog1(struct pt_regs *ctx) 2962306a36Sopenharmony_ci{ 3062306a36Sopenharmony_ci long ptr = PT_REGS_PARM2(ctx); 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_ci bpf_map_delete_elem(&my_map, &ptr); 3362306a36Sopenharmony_ci return 0; 3462306a36Sopenharmony_ci} 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ciSEC("kretprobe/kmem_cache_alloc_node") 3762306a36Sopenharmony_ciint bpf_prog2(struct pt_regs *ctx) 3862306a36Sopenharmony_ci{ 3962306a36Sopenharmony_ci long ptr = PT_REGS_RC(ctx); 4062306a36Sopenharmony_ci long ip = 0; 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci /* get ip address of kmem_cache_alloc_node() caller */ 4362306a36Sopenharmony_ci BPF_KRETPROBE_READ_RET_IP(ip, ctx); 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci struct pair v = { 4662306a36Sopenharmony_ci .val = bpf_ktime_get_ns(), 4762306a36Sopenharmony_ci .ip = ip, 4862306a36Sopenharmony_ci }; 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_ci bpf_map_update_elem(&my_map, &ptr, &v, BPF_ANY); 5162306a36Sopenharmony_ci return 0; 5262306a36Sopenharmony_ci} 5362306a36Sopenharmony_cichar _license[] SEC("license") = "GPL"; 5462306a36Sopenharmony_ciu32 _version SEC("version") = LINUX_VERSION_CODE; 55