!172 [sync] PR-171: sync from openEuler-24.03-LTS-SP1

From: @openeuler-sync-bot 
Reviewed-by: @bigclouds99, @supercharge 
Signed-off-by: @supercharge
This commit is contained in:
openeuler-ci-bot 2025-04-07 12:28:45 +00:00 committed by Gitee
commit bf0e5f163b
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
2 changed files with 85 additions and 8 deletions

72
add-sw_64-support.patch Normal file
View File

@ -0,0 +1,72 @@
From 93391a6f90774d4e6ee3d21972ef937eb183067c Mon Sep 17 00:00:00 2001
From: Super User <root@localhost.localdomain>
Date: Fri, 14 Mar 2025 17:31:35 +0800
Subject: [PATCH] add sw_64 support
---
src/bpf_tracing.h | 35 +++++++++++++++++++++++++++++++++++
1 file changed, 35 insertions(+)
diff --git a/src/bpf_tracing.h b/src/bpf_tracing.h
index 6fb3d0f..ba30c3f 100644
--- a/src/bpf_tracing.h
+++ b/src/bpf_tracing.h
@@ -35,6 +35,9 @@
#elif defined(__TARGET_ARCH_loongarch)
#define bpf_target_loongarch
#define bpf_target_defined
+#elif defined(__TARGET_ARCH_sw_64)
+ #define bpf_target_sw64
+ #define bpf_target_defined
#else
/* Fall back to what the compiler says */
@@ -68,6 +71,9 @@
#elif defined(__loongarch__)
#define bpf_target_loongarch
#define bpf_target_defined
+#elif defined(__sw_64__)
+ #define bpf_target_sw64
+ #define bpf_target_defined
#endif /* no compiler target */
#endif
@@ -442,6 +448,35 @@ struct pt_regs___arm64 {
#define __PT_SP_REG regs[3]
#define __PT_IP_REG csr_era
+#elif defined(bpf_target_sw64)
+
+/* sw64 provides struct user_pt_regs instead of struct pt_regs to userspace */
+struct pt_regs;
+#define PT_REGS_SW64 const volatile struct user_pt_regs
+#define PT_REGS_PARM1(x) (((PT_REGS_SW64 *)(x))->regs[16])
+#define PT_REGS_PARM2(x) (((PT_REGS_SW64 *)(x))->regs[17])
+#define PT_REGS_PARM3(x) (((PT_REGS_SW64 *)(x))->regs[18])
+#define PT_REGS_PARM4(x) (((PT_REGS_SW64 *)(x))->regs[19])
+#define PT_REGS_PARM5(x) (((PT_REGS_SW64 *)(x))->regs[20])
+#define PT_REGS_RET(x) (((PT_REGS_SW64 *)(x))->regs[26])
+/* Works only with CONFIG_FRAME_POINTER */
+#define PT_REGS_FP(x) (((PT_REGS_SW64 *)(x))->regs[15])
+#define PT_REGS_RC(x) (((PT_REGS_SW64 *)(x))->regs[0])
+#define PT_REGS_SP(x) (((PT_REGS_SW64 *)(x))->regs[30])
+#define PT_REGS_IP(x) (((PT_REGS_SW64 *)(x))->pc)
+
+#define PT_REGS_PARM1_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[16])
+#define PT_REGS_PARM2_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[17])
+#define PT_REGS_PARM3_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[18])
+#define PT_REGS_PARM4_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[19])
+#define PT_REGS_PARM5_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[20])
+#define PT_REGS_RET_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[26])
+#define PT_REGS_FP_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[15])
+#define PT_REGS_RC_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[0])
+#define PT_REGS_SP_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), regs[30])
+#define PT_REGS_IP_CORE(x) BPF_CORE_READ((PT_REGS_SW64 *)(x), pc)
+
+
#endif
#if defined(bpf_target_defined)
--
2.43.0

View File

@ -4,7 +4,7 @@
Name: %{githubname}
Version: %{githubver}
Release: 7
Release: 8
Summary: Libbpf library
License: LGPLv2 or BSD
@ -22,12 +22,14 @@ Patch0005: backport-libbpf-Avoid-uninitialized-value-in-BPF_CORE_READ_BI.pa
Patch0006: backport-libbpf-Add-NULL-checks-to-bpf_object__prev_map,next_.patch
Patch0007: backport-libbpf-Apply-map_set_def_max_entries-for-inner_maps-.patch
Patch0008: backport-libbpf-Dont-take-direct-pointers-into-BTF-data-from-.patch
Patch0009: backport-libbpf-Do-not-resolve-size-on-duplicate-FUNCs.patch
Patch0010: backport-libbpf-Fix-bpf_object__open_skeleton-s-mishandling-o.patch
Patch0011: backport-libbpf-Fix-segfault-due-to-libelf-functions-not-sett.patch
Patch0012: backport-libbpf-Fixed-getting-wrong-return-address-on-arm64-a.patch
Patch0013: backport-libbpf-fix-sym_is_subprog-logic-for-weak-global-subp.patch
Patch0014: backport-libbpf-move-global-data-mmap-ing-into-bpf_object__lo.patch
Patch0009: add-sw_64-support.patch
Patch0010: backport-libbpf-Do-not-resolve-size-on-duplicate-FUNCs.patch
Patch0011: backport-libbpf-Fix-bpf_object__open_skeleton-s-mishandling-o.patch
Patch0012: backport-libbpf-Fix-segfault-due-to-libelf-functions-not-sett.patch
Patch0013: backport-libbpf-Fixed-getting-wrong-return-address-on-arm64-a.patch
Patch0014: backport-libbpf-fix-sym_is_subprog-logic-for-weak-global-subp.patch
Patch0015: backport-libbpf-move-global-data-mmap-ing-into-bpf_object__lo.patch
# This package supersedes libbpf from kernel-tools,
# which has default Epoch: 0. By having Epoch: 1
@ -80,7 +82,7 @@ developing applications that use %{name}
%{_libdir}/libbpf.a
%changelog
* Fri Mar 14 2025 zhangmingyi <zhangmingyi5@huawei.com> 2:1.2.2-7
* Fri Mar 14 2025 zhangmingyi <zhangmingyi5@huawei.com> 2:1.2.2-8
- backport patch from upstream:
backport-libbpf-Do-not-resolve-size-on-duplicate-FUNCs.patch
backport-libbpf-Fix-bpf_object__open_skeleton-s-mishandling-o.patch
@ -89,6 +91,9 @@ developing applications that use %{name}
backport-libbpf-fix-sym_is_subprog-logic-for-weak-global-subp.patch
backport-libbpf-move-global-data-mmap-ing-into-bpf_object__lo.patch
* Fri Mar 14 2025 mahailiang <mahailiang@uniontech.com> 2:1.2.2-7
- add sw_64 support
* Mon Dec 23 2024 zhangmingyi <zhangmingyi5@huawei.com> 2:1.2.2-6
- backport patch from upstream:
backport-libbpf-Dont-take-direct-pointers-into-BTF-data-from-.patch