Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ARCv2 relocation failure #573

Open
BrunoASMauricio opened this issue Jul 31, 2023 · 2 comments
Open

ARCv2 relocation failure #573

BrunoASMauricio opened this issue Jul 31, 2023 · 2 comments

Comments

@BrunoASMauricio
Copy link

BrunoASMauricio commented Jul 31, 2023

While testing QEMU FPUv2 a GLibC test (test-fpucw-static) that didn't fail a few months ago, started failing with the most recent toolchain.

The issue seems to be because a relocation isn't completed with success.

The invocation line found by running make test t=math/test-fpucw-static inside glibc-build folder is:

$ arc-linux-gnu-gcc -o $GLIBC_BUILD_PATH/math/test-fpucw-static        \
                    -nostdlib                                          \
                    -nostartfiles                                      \
                    -static                                            \
                    $GLIBC_BUILD_PATH/csu/crt1.o                       \
                    $GLIBC_BUILD_PATH/csu/crti.o                       \
                    `arc-linux-gnu-gcc  --print-file-name=crtbeginT.o` \
                    $GLIBC_BUILD_PATH/math/test-fpucw-static.o         \
                    $GLIBC_BUILD_PATH/support/libsupport_nonshared.a   \
                    $GLIBC_BUILD_PATH/math/libm.a                      \
                    -Wl,--start-group                                  \
                      $GLIBC_BUILD_PATH/libc.a                         \
                      -lgcc                                            \
                      -lgcc_eh                                         \
                    -Wl,--end-group                                    \
                    `arc-linux-gnu-gcc --print-file-name=crtend.o`     \
                    $GLIBC_BUILD_PATH/csu/crtn.o

We can see with arc-linux-gnu-objdump -d -r that in libc.a the relocation is supposed to be

126:   0802 0000               bl      0       ;0 <__pthread_initialize_minimal>
                       126: R_ARC_S25W_PCREL_PLT       __pthread_initialize_minimal

Linking seems to fail as the final binary has:

112d2:       0802 0000               bl      0       ;112d0 <__libc_start_main+0x74>

The symbol in question here is:

// sysdeps/generic/ldsodefs.h

# define weak_function __attribute__ ((weak))
void __pthread_initialize_minimal (void) weak_function;
// csu/libc-start.c

void
__pthread_initialize_minimal (void)
{
  _init_routine (__libc_stack_end);  // <-- static void function
}

And the problematic usage:

// csu/libc-start.c

  if (__pthread_initialize_minimal != NULL)
    __pthread_initialize_minimal ();

Attachment:
comp.1.zip
comp.2.zip

$ cat comp.{1,2}.zip > comp.tar.xz
@claziss
Copy link
Contributor

claziss commented Aug 2, 2023

There are a number of R_ARC_GOTPC32 which are resolved to point to the first entry in the .got section. Here are the symbols in cause:

	__call_tls_dtors
	__mq_notify_fork_subprocess
	__nss_database_fork_prepare_parent
	__nss_database_fork_subprocess
	__pthread_initialize_minimal
	stderr
	__timer_fork_subprocess

All the above with the exception of stderr are weak undefined symbols. Needless to say the first location of .got is initialized with the value of stderr namely 00088398 D stderr.

One of the errors is seen bellow:

   112b0:       2730 7f82 0007 6b10     ld      r2,[pcl,0x76b10]        ;87dc0 <.got>
                        112b4: R_ARC_GOTPC32    __pthread_initialize_minimal
   112b8:       7a4b                    tst_s   r2,r2
   112ba:       1100 2002               ld      r2,[r17]
   112be:       2700 7f83 0007 5d48     add     r3,pcl,0x75d48  ;87004 <__stack_chk_guard>
                        112c2: R_ARC_PC32       __stack_chk_guard
   112c6:       4244                    ld_s    r2,[r2,0]
   112c8:       226c 01c2               bmskn   r2,r2,0x7
   112cc:       000a 0021               beq.d   10      ;112d6 <__libc_start_main+0x7a>
   112d0:       a340                    st_s    r2,[r3,0]
   112d2:       0802 0000               bl      0       ;112d0 <__libc_start_main+0x74>
                        112d2: R_ARC_S25W_PCREL_PLT     __pthread_initialize_minimal

The R_ARC_S25W_PCREL_PLT is correctly resolved to zero, as the __pthread_initialize_minimal symbol is undefined weak. However, the R_ARC_GOTPC32 is pointing to the first entry of .got section which is actually the entry for stderr. Thus, instead of returning zero in r2 register, it returns stderr value. Hence, the error.

@claziss
Copy link
Contributor

claziss commented Aug 3, 2023

A reduced test case:

#include <stddef.h>
#include <stdio.h>

# define weak_function __attribute__ ((weak))
void __pthread_initialize_minimal (void) weak_function;

extern void abort (void);

int main (void)
{
  if (stderr == NULL)
    abort ();
  if (__pthread_initialize_minimal != NULL)
    __pthread_initialize_minimal ();

  return 0;
}

@abrodkin abrodkin added the bug label Sep 10, 2023
@abrodkin abrodkin added this to the 2023.09 milestone Sep 10, 2023
@claziss claziss modified the milestones: 2023.09, 2024.03 Sep 11, 2023
@abrodkin abrodkin removed this from the 2024.06 milestone Jun 4, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants