summaryrefslogtreecommitdiffstats
path: root/include/uapi/linux/bpf.h
diff options
context:
space:
mode:
authorAlexei Starovoitov2016-02-02 07:39:54 +0100
committerDavid S. Miller2016-02-06 09:34:36 +0100
commita10423b87a7eae75da79ce80a8d9475047a674ee (patch)
tree2a8296c94fc90056e7a8d2b2dd3b31d4d3d73d5b /include/uapi/linux/bpf.h
parentbpf: introduce BPF_MAP_TYPE_PERCPU_HASH map (diff)
downloadkernel-qcow2-linux-a10423b87a7eae75da79ce80a8d9475047a674ee.tar.gz
kernel-qcow2-linux-a10423b87a7eae75da79ce80a8d9475047a674ee.tar.xz
kernel-qcow2-linux-a10423b87a7eae75da79ce80a8d9475047a674ee.zip
bpf: introduce BPF_MAP_TYPE_PERCPU_ARRAY map
Primary use case is a histogram array of latency where bpf program computes the latency of block requests or other events and stores histogram of latency into array of 64 elements. All cpus are constantly running, so normal increment is not accurate, bpf_xadd causes cache ping-pong and this per-cpu approach allows fastest collision-free counters. Signed-off-by: Alexei Starovoitov <ast@kernel.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/uapi/linux/bpf.h')
-rw-r--r--include/uapi/linux/bpf.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/include/uapi/linux/bpf.h b/include/uapi/linux/bpf.h
index 43ae40c8763e..2ee0fde1bf96 100644
--- a/include/uapi/linux/bpf.h
+++ b/include/uapi/linux/bpf.h
@@ -82,6 +82,7 @@ enum bpf_map_type {
BPF_MAP_TYPE_PROG_ARRAY,
BPF_MAP_TYPE_PERF_EVENT_ARRAY,
BPF_MAP_TYPE_PERCPU_HASH,
+ BPF_MAP_TYPE_PERCPU_ARRAY,
};
enum bpf_prog_type {