]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
libsframe: testsuite: fix PR libsframe/33140
authorIndu Bhagat <indu.bhagat@oracle.com>
Fri, 11 Jul 2025 16:39:24 +0000 (09:39 -0700)
committerIndu Bhagat <indu.bhagat@oracle.com>
Fri, 11 Jul 2025 17:29:54 +0000 (10:29 -0700)
Commit 0d4d5a2633f missed some necessary adjustments to the testcase
after rebase.  SFrame FDE function start address data is now an offset
in PCREL encoding; reflect with a new flag SFRAME_F_FDE_START_ADDR_PCREL
in the header.

Adjust the newly added testcase.

PR libsframe/33140 SFrame test failures on x86-64

libsframe/testsuite/
* libsframe.find/plt-findfre-2.c: Adjust for the new FDE func
start addr encoding.

libsframe/testsuite/libsframe.find/plt-findfre-2.c

index 195a05b24bd3d2dd3d1b0af39c924d0ea3363b22..00a5b2ab07652a57f2696de18cecea9cb36bd23d 100644 (file)
@@ -48,7 +48,11 @@ add_plt0_fde (sframe_encoder_ctx *ectx, uint32_t plt_vaddr,
 
   unsigned char finfo = sframe_fde_create_func_info (SFRAME_FRE_TYPE_ADDR1,
                                                     SFRAME_FDE_TYPE_PCINC);
-  int32_t func_start_addr = plt_vaddr - sframe_vaddr;
+  uint32_t offsetof_fde_in_sec
+    = sframe_encoder_get_offsetof_fde_start_addr (ectx, idx, NULL);
+
+  int32_t func_start_addr = (plt_vaddr
+                            - (sframe_vaddr + offsetof_fde_in_sec));
 
   /* 1 PCINC-type FDE for 1 plt0 entry of 32 bytes.  */
   int err = sframe_encoder_add_funcdesc_v2 (ectx, func_start_addr,
@@ -77,7 +81,11 @@ add_pltn_fde (sframe_encoder_ctx *ectx, uint32_t plt_vaddr,
 
   unsigned char finfo = sframe_fde_create_func_info (SFRAME_FRE_TYPE_ADDR1,
                                                     SFRAME_FDE_TYPE_PCMASK);
-  int32_t func_start_addr = plt_vaddr - sframe_vaddr;
+  uint32_t offsetof_fde_in_sec
+    = sframe_encoder_get_offsetof_fde_start_addr (ectx, idx, NULL);
+
+  int32_t func_start_addr = (plt_vaddr
+                            - (sframe_vaddr + offsetof_fde_in_sec));
 
   /* 1 PCMASK-type FDE for 5 pltN entries of 32 bytes each.  */
   int err = sframe_encoder_add_funcdesc_v2 (ectx, func_start_addr,
@@ -117,7 +125,8 @@ void test_plt_findfre (const char suffix, const uint32_t plt_vaddr,
     }                                                                  \
     while (0)
 
-  ectx = sframe_encode (SFRAME_VERSION, 0, SFRAME_ABI_S390X_ENDIAN_BIG,
+  ectx = sframe_encode (SFRAME_VERSION, SFRAME_F_FDE_FUNC_START_PCREL,
+                       SFRAME_ABI_S390X_ENDIAN_BIG,
                        SFRAME_CFA_FIXED_FP_INVALID,
                        SFRAME_CFA_FIXED_RA_INVALID,
                        &err);