Blame SOURCES/0050-bpf-add-support-for-jited_ksyms-and-jited_func_lens-.patch

b484ca
From d1f90bcdc7cf95cf442321f18452d0367e80b7d5 Mon Sep 17 00:00:00 2001
b484ca
From: "Dmitry V. Levin" <ldv@altlinux.org>
b484ca
Date: Tue, 12 Mar 2019 11:17:20 +0000
b484ca
Subject: [PATCH] bpf: add support for *jited_ksyms and *jited_func_lens fields
b484ca
 in struct bpf_prog_info
b484ca
b484ca
* bpf_attr.h (struct bpf_prog_info_struct): Add nr_jited_ksyms,
b484ca
nr_jited_func_lens, jited_ksyms, and jited_func_lens fields.
b484ca
* bpf.c (struct obj_get_info_saved): Likewise.
b484ca
(print_bpf_prog_info): Decode these fields introduced by Linux commits
b484ca
v4.18-rc1~114^2~148^2~3^2~6 and v4.18-rc1~114^2~148^2~3^2~2.
b484ca
* tests/bpf-obj_get_info_by_fd.c (main): Update expected output.
b484ca
---
b484ca
 bpf.c                          | 40 ++++++++++++++++++++++++++++++++++++++++
b484ca
 bpf_attr.h                     |  6 +++++-
b484ca
 tests/bpf-obj_get_info_by_fd.c | 21 +++++++++++++++++++++
b484ca
 3 files changed, 66 insertions(+), 1 deletion(-)
b484ca
b484ca
Index: strace-4.24/bpf.c
b484ca
===================================================================
b484ca
--- strace-4.24.orig/bpf.c	2020-01-28 00:15:59.919446522 +0100
b484ca
+++ strace-4.24/bpf.c	2020-01-28 00:16:27.823183735 +0100
b484ca
@@ -427,6 +427,11 @@
b484ca
 	uint32_t jited_prog_len;
b484ca
 	uint32_t xlated_prog_len;
b484ca
 	uint32_t nr_map_ids;
b484ca
+
b484ca
+	uint32_t nr_jited_ksyms;
b484ca
+	uint32_t nr_jited_func_lens;
b484ca
+	uint64_t jited_ksyms;
b484ca
+	uint64_t jited_func_lens;
b484ca
 };
b484ca
 
b484ca
 static void
b484ca
@@ -497,6 +502,10 @@
b484ca
 		saved->jited_prog_len = info.jited_prog_len;
b484ca
 		saved->xlated_prog_len = info.xlated_prog_len;
b484ca
 		saved->nr_map_ids = info.nr_map_ids;
b484ca
+		saved->nr_jited_ksyms = info.nr_jited_ksyms;
b484ca
+		saved->nr_jited_func_lens = info.nr_jited_func_lens;
b484ca
+		saved->jited_ksyms = info.jited_ksyms;
b484ca
+		saved->jited_func_lens = info.jited_func_lens;
b484ca
 
b484ca
 		return;
b484ca
 	}
b484ca
@@ -559,6 +568,37 @@
b484ca
 	PRINT_FIELD_DEV(", ", info, netns_dev);
b484ca
 	PRINT_FIELD_U(", ", info, netns_ino);
b484ca
 
b484ca
+	/*
b484ca
+	 * The next four fields were introduced by Linux commits
b484ca
+	 * v4.18-rc1~114^2~148^2~3^2~6 and v4.18-rc1~114^2~148^2~3^2~2.
b484ca
+	 */
b484ca
+	if (len <= offsetof(struct bpf_prog_info_struct, nr_jited_ksyms))
b484ca
+		goto print_bpf_prog_info_end;
b484ca
+
b484ca
+	tprints(", nr_jited_ksyms=");
b484ca
+	if (saved->nr_jited_ksyms != info.nr_jited_ksyms)
b484ca
+		tprintf("%" PRIu32 " => ", saved->nr_jited_ksyms);
b484ca
+	tprintf("%" PRIu32, info.nr_jited_ksyms);
b484ca
+
b484ca
+	tprints(", nr_jited_func_lens=");
b484ca
+	if (saved->nr_jited_func_lens != info.nr_jited_func_lens)
b484ca
+		tprintf("%" PRIu32 " => ", saved->nr_jited_func_lens);
b484ca
+	tprintf("%" PRIu32, info.nr_jited_func_lens);
b484ca
+
b484ca
+	tprints(", jited_ksyms=");
b484ca
+	if (saved->jited_ksyms != info.jited_ksyms) {
b484ca
+		printaddr64(saved->jited_ksyms);
b484ca
+		tprints(" => ");
b484ca
+	}
b484ca
+	printaddr64(info.jited_ksyms);
b484ca
+
b484ca
+	tprints(", jited_func_lens=");
b484ca
+	if (saved->jited_func_lens != info.jited_func_lens) {
b484ca
+		printaddr64(saved->jited_func_lens);
b484ca
+		tprints(" => ");
b484ca
+	}
b484ca
+	printaddr64(info.jited_func_lens);
b484ca
+
b484ca
 	decode_attr_extra_data(tcp, info_buf, size, bpf_prog_info_struct_size);
b484ca
 
b484ca
 print_bpf_prog_info_end:
b484ca
Index: strace-4.24/bpf_attr.h
b484ca
===================================================================
b484ca
--- strace-4.24.orig/bpf_attr.h	2020-01-28 00:15:59.919446522 +0100
b484ca
+++ strace-4.24/bpf_attr.h	2020-01-28 00:16:27.823183735 +0100
b484ca
@@ -272,10 +272,14 @@
b484ca
 	 */
b484ca
 	uint64_t ATTRIBUTE_ALIGNED(8) netns_dev; /* skip check */
b484ca
 	uint64_t ATTRIBUTE_ALIGNED(8) netns_ino; /* skip check */
b484ca
+	uint32_t nr_jited_ksyms;
b484ca
+	uint32_t nr_jited_func_lens;
b484ca
+	uint64_t ATTRIBUTE_ALIGNED(8) jited_ksyms;
b484ca
+	uint64_t ATTRIBUTE_ALIGNED(8) jited_func_lens;
b484ca
 };
b484ca
 
b484ca
 # define bpf_prog_info_struct_size \
b484ca
 	sizeof(struct bpf_prog_info_struct)
b484ca
-# define expected_bpf_prog_info_struct_size 104
b484ca
+# define expected_bpf_prog_info_struct_size 128
b484ca
 
b484ca
 #endif /* !STRACE_BPF_ATTR_H */
b484ca
Index: strace-4.24/tests/bpf-obj_get_info_by_fd.c
b484ca
===================================================================
b484ca
--- strace-4.24.orig/tests/bpf-obj_get_info_by_fd.c	2020-01-28 00:15:59.920446513 +0100
b484ca
+++ strace-4.24/tests/bpf-obj_get_info_by_fd.c	2020-01-28 00:16:27.823183735 +0100
b484ca
@@ -358,6 +358,8 @@
b484ca
 	memset(prog_info, 0, PROG_INFO_SZ);
b484ca
 	for (unsigned int i = 0; i < 4; i++) {
b484ca
 		prog_info->jited_prog_len = 0;
b484ca
+		prog_info->nr_jited_ksyms = 0;
b484ca
+		prog_info->nr_jited_func_lens = 0;
b484ca
 		memset(prog_info + 1, 0, PROG_INFO_SZ - sizeof(*prog_info));
b484ca
 		switch (i) {
b484ca
 		case 1:
b484ca
@@ -485,6 +487,25 @@
b484ca
 		    offsetof(struct bpf_prog_info_struct, netns_ino))
b484ca
 			printf(", netns_ino=%" PRIu64, prog_info->netns_ino);
b484ca
 
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, nr_jited_ksyms)) {
b484ca
+			printf(", nr_jited_ksyms=0");
b484ca
+			if (prog_info->nr_jited_ksyms)
b484ca
+				printf(" => %u", prog_info->nr_jited_ksyms);
b484ca
+		}
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, nr_jited_func_lens)) {
b484ca
+			printf(", nr_jited_func_lens=0");
b484ca
+			if (prog_info->nr_jited_func_lens)
b484ca
+				printf(" => %u", prog_info->nr_jited_func_lens);
b484ca
+		}
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, jited_ksyms))
b484ca
+			printf(", jited_ksyms=NULL");
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, jited_func_lens))
b484ca
+			printf(", jited_func_lens=NULL");
b484ca
+
b484ca
 		printf("}");
b484ca
 # else /* !VERBOSE */
b484ca
 		printf("%p", prog_info);
b484ca
Index: strace-4.24/tests-m32/bpf-obj_get_info_by_fd.c
b484ca
===================================================================
b484ca
--- strace-4.24.orig/tests-m32/bpf-obj_get_info_by_fd.c	2020-01-28 00:16:14.855305862 +0100
b484ca
+++ strace-4.24/tests-m32/bpf-obj_get_info_by_fd.c	2020-01-28 00:16:37.300094485 +0100
b484ca
@@ -358,6 +358,8 @@
b484ca
 	memset(prog_info, 0, PROG_INFO_SZ);
b484ca
 	for (unsigned int i = 0; i < 4; i++) {
b484ca
 		prog_info->jited_prog_len = 0;
b484ca
+		prog_info->nr_jited_ksyms = 0;
b484ca
+		prog_info->nr_jited_func_lens = 0;
b484ca
 		memset(prog_info + 1, 0, PROG_INFO_SZ - sizeof(*prog_info));
b484ca
 		switch (i) {
b484ca
 		case 1:
b484ca
@@ -485,6 +487,25 @@
b484ca
 		    offsetof(struct bpf_prog_info_struct, netns_ino))
b484ca
 			printf(", netns_ino=%" PRIu64, prog_info->netns_ino);
b484ca
 
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, nr_jited_ksyms)) {
b484ca
+			printf(", nr_jited_ksyms=0");
b484ca
+			if (prog_info->nr_jited_ksyms)
b484ca
+				printf(" => %u", prog_info->nr_jited_ksyms);
b484ca
+		}
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, nr_jited_func_lens)) {
b484ca
+			printf(", nr_jited_func_lens=0");
b484ca
+			if (prog_info->nr_jited_func_lens)
b484ca
+				printf(" => %u", prog_info->nr_jited_func_lens);
b484ca
+		}
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, jited_ksyms))
b484ca
+			printf(", jited_ksyms=NULL");
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, jited_func_lens))
b484ca
+			printf(", jited_func_lens=NULL");
b484ca
+
b484ca
 		printf("}");
b484ca
 # else /* !VERBOSE */
b484ca
 		printf("%p", prog_info);
b484ca
Index: strace-4.24/tests-mx32/bpf-obj_get_info_by_fd.c
b484ca
===================================================================
b484ca
--- strace-4.24.orig/tests-mx32/bpf-obj_get_info_by_fd.c	2020-01-28 00:16:23.096228252 +0100
b484ca
+++ strace-4.24/tests-mx32/bpf-obj_get_info_by_fd.c	2020-01-28 00:16:34.082124791 +0100
b484ca
@@ -358,6 +358,8 @@
b484ca
 	memset(prog_info, 0, PROG_INFO_SZ);
b484ca
 	for (unsigned int i = 0; i < 4; i++) {
b484ca
 		prog_info->jited_prog_len = 0;
b484ca
+		prog_info->nr_jited_ksyms = 0;
b484ca
+		prog_info->nr_jited_func_lens = 0;
b484ca
 		memset(prog_info + 1, 0, PROG_INFO_SZ - sizeof(*prog_info));
b484ca
 		switch (i) {
b484ca
 		case 1:
b484ca
@@ -485,6 +487,25 @@
b484ca
 		    offsetof(struct bpf_prog_info_struct, netns_ino))
b484ca
 			printf(", netns_ino=%" PRIu64, prog_info->netns_ino);
b484ca
 
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, nr_jited_ksyms)) {
b484ca
+			printf(", nr_jited_ksyms=0");
b484ca
+			if (prog_info->nr_jited_ksyms)
b484ca
+				printf(" => %u", prog_info->nr_jited_ksyms);
b484ca
+		}
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, nr_jited_func_lens)) {
b484ca
+			printf(", nr_jited_func_lens=0");
b484ca
+			if (prog_info->nr_jited_func_lens)
b484ca
+				printf(" => %u", prog_info->nr_jited_func_lens);
b484ca
+		}
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, jited_ksyms))
b484ca
+			printf(", jited_ksyms=NULL");
b484ca
+		if (bpf_prog_get_info_attr.info_len >
b484ca
+		    offsetof(struct bpf_prog_info_struct, jited_func_lens))
b484ca
+			printf(", jited_func_lens=NULL");
b484ca
+
b484ca
 		printf("}");
b484ca
 # else /* !VERBOSE */
b484ca
 		printf("%p", prog_info);