summaryrefslogtreecommitdiff
path: root/progs
diff options
context:
space:
mode:
authorMaciej Żenczykowski <maze@google.com>2020-01-27 01:10:48 -0800
committerMaciej Żenczykowski <maze@google.com>2020-01-29 08:41:26 +0000
commit730a3860c284f81590625bba180079b982c1ef64 (patch)
tree28a36de09fae677c38b52abad531f550110bf71f /progs
parent3c057e6b7b48bc3c2c1ef04b3536ff8460933e97 (diff)
downloadbpf-730a3860c284f81590625bba180079b982c1ef64.tar.gz
refactor bpf_map_def into a single header file
Test: build, atest Signed-off-by: Maciej Żenczykowski <maze@google.com> Change-Id: Iafd6016f4f24cc8fa263939c67e1a096aa91b125
Diffstat (limited to 'progs')
-rw-r--r--progs/include/bpf_helpers.h22
-rw-r--r--progs/include/bpf_map_def.h47
2 files changed, 49 insertions, 20 deletions
diff --git a/progs/include/bpf_helpers.h b/progs/include/bpf_helpers.h
index 454db2d..825947f 100644
--- a/progs/include/bpf_helpers.h
+++ b/progs/include/bpf_helpers.h
@@ -4,6 +4,8 @@
#include <stdbool.h>
#include <stdint.h>
+#include "bpf_map_def.h"
+
/* place things in different elf sections */
#define SEC(NAME) __attribute__((section(NAME), used))
@@ -83,23 +85,3 @@ static int (*bpf_trace_printk)(const char* fmt, int fmt_size, ...) = (void*) BPF
static unsigned long long (*bpf_get_current_pid_tgid)(void) = (void*) BPF_FUNC_get_current_pid_tgid;
static unsigned long long (*bpf_get_current_uid_gid)(void) = (void*) BPF_FUNC_get_current_uid_gid;
static unsigned long long (*bpf_get_smp_processor_id)(void) = (void*) BPF_FUNC_get_smp_processor_id;
-
-/*
- * Map structure to be used by Android eBPF C programs. The Android eBPF loader
- * uses this structure from eBPF object to create maps at boot time.
- *
- * The eBPF C program should define structure in the maps section using
- * SEC("maps") otherwise it will be ignored by the eBPF loader.
- *
- * For example:
- * struct bpf_map_def SEC("maps") mymap { .type=... , .key_size=... }
- */
-struct bpf_map_def {
- unsigned int type;
- unsigned int key_size;
- unsigned int value_size;
- unsigned int max_entries;
- unsigned int map_flags;
- unsigned int pad1;
- unsigned int pad2;
-};
diff --git a/progs/include/bpf_map_def.h b/progs/include/bpf_map_def.h
new file mode 100644
index 0000000..86708fc
--- /dev/null
+++ b/progs/include/bpf_map_def.h
@@ -0,0 +1,47 @@
+/*
+ * Copyright (C) 2020 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#pragma once
+
+/* This file is separate because it's included both by eBPF programs (via include
+ * in bpf_helpers.h) and directly by the boot time bpfloader (Loader.cpp).
+ */
+
+#include <linux/bpf.h>
+
+/*
+ * Map structure to be used by Android eBPF C programs. The Android eBPF loader
+ * uses this structure from eBPF object to create maps at boot time.
+ *
+ * The eBPF C program should define structure in the maps section using
+ * SEC("maps") otherwise it will be ignored by the eBPF loader.
+ *
+ * For example:
+ * const struct bpf_map_def SEC("maps") mymap { .type=... , .key_size=... }
+ *
+ * See 'bpf_helpers.h' for helpful macros for eBPF program use.
+ */
+struct bpf_map_def {
+ enum bpf_map_type type;
+ unsigned int key_size;
+ unsigned int value_size;
+ unsigned int max_entries;
+ unsigned int map_flags;
+
+ // The following are not supported by the Android bpfloader:
+ // unsigned int inner_map_idx;
+ // unsigned int numa_node;
+};