18c2ecf20Sopenharmony_ci/* Copyright (c) 2015 PLUMgrid, http://plumgrid.com 28c2ecf20Sopenharmony_ci * 38c2ecf20Sopenharmony_ci * This program is free software; you can redistribute it and/or 48c2ecf20Sopenharmony_ci * modify it under the terms of version 2 of the GNU General Public 58c2ecf20Sopenharmony_ci * License as published by the Free Software Foundation. 68c2ecf20Sopenharmony_ci */ 78c2ecf20Sopenharmony_ci#include <linux/ptrace.h> 88c2ecf20Sopenharmony_ci#include <linux/version.h> 98c2ecf20Sopenharmony_ci#include <uapi/linux/bpf.h> 108c2ecf20Sopenharmony_ci#include <bpf/bpf_helpers.h> 118c2ecf20Sopenharmony_ci#include <bpf/bpf_tracing.h> 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_cistruct pair { 148c2ecf20Sopenharmony_ci u64 val; 158c2ecf20Sopenharmony_ci u64 ip; 168c2ecf20Sopenharmony_ci}; 178c2ecf20Sopenharmony_ci 188c2ecf20Sopenharmony_cistruct { 198c2ecf20Sopenharmony_ci __uint(type, BPF_MAP_TYPE_HASH); 208c2ecf20Sopenharmony_ci __type(key, long); 218c2ecf20Sopenharmony_ci __type(value, struct pair); 228c2ecf20Sopenharmony_ci __uint(max_entries, 1000000); 238c2ecf20Sopenharmony_ci} my_map SEC(".maps"); 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci/* kprobe is NOT a stable ABI. If kernel internals change this bpf+kprobe 268c2ecf20Sopenharmony_ci * example will no longer be meaningful 278c2ecf20Sopenharmony_ci */ 288c2ecf20Sopenharmony_ciSEC("kprobe/kmem_cache_free") 298c2ecf20Sopenharmony_ciint bpf_prog1(struct pt_regs *ctx) 308c2ecf20Sopenharmony_ci{ 318c2ecf20Sopenharmony_ci long ptr = PT_REGS_PARM2(ctx); 328c2ecf20Sopenharmony_ci 338c2ecf20Sopenharmony_ci bpf_map_delete_elem(&my_map, &ptr); 348c2ecf20Sopenharmony_ci return 0; 358c2ecf20Sopenharmony_ci} 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_ciSEC("kretprobe/kmem_cache_alloc_node") 388c2ecf20Sopenharmony_ciint bpf_prog2(struct pt_regs *ctx) 398c2ecf20Sopenharmony_ci{ 408c2ecf20Sopenharmony_ci long ptr = PT_REGS_RC(ctx); 418c2ecf20Sopenharmony_ci long ip = 0; 428c2ecf20Sopenharmony_ci 438c2ecf20Sopenharmony_ci /* get ip address of kmem_cache_alloc_node() caller */ 448c2ecf20Sopenharmony_ci BPF_KRETPROBE_READ_RET_IP(ip, ctx); 458c2ecf20Sopenharmony_ci 468c2ecf20Sopenharmony_ci struct pair v = { 478c2ecf20Sopenharmony_ci .val = bpf_ktime_get_ns(), 488c2ecf20Sopenharmony_ci .ip = ip, 498c2ecf20Sopenharmony_ci }; 508c2ecf20Sopenharmony_ci 518c2ecf20Sopenharmony_ci bpf_map_update_elem(&my_map, &ptr, &v, BPF_ANY); 528c2ecf20Sopenharmony_ci return 0; 538c2ecf20Sopenharmony_ci} 548c2ecf20Sopenharmony_cichar _license[] SEC("license") = "GPL"; 558c2ecf20Sopenharmony_ciu32 _version SEC("version") = LINUX_VERSION_CODE; 56