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