Summary: Weak symbols are supposed to have the semantics that they can be overriden by a strong (i.e. global) definition. This wasn't being respected by the LTO pass because we simply used the first definition that was available. This patch fixes that logic by doing a first pass over the symbols to check for strong resolutions that could override a weak one. A lot of fake linker logic is ending up in the linker wrapper. If there were an option to handle this in `lld` it would be a lot cleaner, but unfortunately supporting NVPTX is a big restriction as their binaries require the `nvlink` tool.
34 lines
722 B
C
34 lines
722 B
C
// RUN: %libomptarget-compile-generic -DA -c -o %t-a.o
|
|
// RUN: %libomptarget-compile-generic -DB -c -o %t-b.o
|
|
// RUN: %libomptarget-compile-generic %t-a.o %t-b.o && \
|
|
// RUN: %libomptarget-run-generic | %fcheck-generic
|
|
|
|
#if defined(A)
|
|
__attribute__((weak)) int x = 999;
|
|
#pragma omp declare target to(x)
|
|
#elif defined(B)
|
|
int x = 42;
|
|
#pragma omp declare target to(x)
|
|
__attribute__((weak)) int y = 42;
|
|
#pragma omp declare target to(y)
|
|
#else
|
|
|
|
#include <stdio.h>
|
|
|
|
extern int x;
|
|
#pragma omp declare target to(x)
|
|
extern int y;
|
|
#pragma omp declare target to(y)
|
|
|
|
int main() {
|
|
x = 0;
|
|
|
|
#pragma omp target update from(x)
|
|
#pragma omp target update from(y)
|
|
|
|
// CHECK: PASS
|
|
if (x == 42 && y == 42)
|
|
printf("PASS\n");
|
|
}
|
|
#endif
|