mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 08:06:08 +00:00

Fix tests that are failing in cross-compilation after D151920 (https://lab.llvm.org/buildbot/#/builders/221/builds/17715): - instrumentation-ind-call, basic-instrumentation: add -mno-outline-atomics flag to runtime lib - bolt-address-translation-internal-call, internal-call-instrument: add %cflags - meta-merge-fdata: restrict to x86_64 Reviewed By: Amir Differential Revision: https://reviews.llvm.org/D159094
41 lines
1.3 KiB
C++
41 lines
1.3 KiB
C++
// This test checks that .eh_frame_hdr address is in bounds of the last LOAD
|
|
// end address i.e. the section address is smaller then the LOAD end address.
|
|
|
|
// REQUIRES: system-linux,bolt-runtime,target=x86_64{{.*}}
|
|
|
|
// RUN: %clangxx %cxxflags -static -Wl,-q %s -o %t.exe -Wl,--entry=_start
|
|
// RUN: llvm-bolt %t.exe -o %t.instr -instrument \
|
|
// RUN: --instrumentation-file=%t.fdata -instrumentation-sleep-time=1
|
|
// RUN: (llvm-readelf -SW %t.instr | grep -v bolt; llvm-readelf -lW %t.instr | \
|
|
// RUN: grep LOAD | tail -n 1) | FileCheck %s
|
|
|
|
// CHECK: {{.*}} .eh_frame_hdr PROGBITS [[#%x, EH_ADDR:]]
|
|
// CHECK: LOAD 0x[[#%x, LD_OFFSET:]] 0x[[#%x, LD_VADDR:]] 0x[[#%x, LD_FSIZE:]]
|
|
// CHECK-SAME: 0x[[#%x, LD_MEMSIZE:]]
|
|
//
|
|
// If .eh_frame_hdr address bigger then last LOAD segment end address test would
|
|
// fail with overflow error, otherwise the result of the expression is 0 that
|
|
// could be found on this line e.g. in LOAD align field.
|
|
// CHECK-SAME: [[#LD_VADDR + LD_MEMSIZE - max(LD_VADDR + LD_MEMSIZE,EH_ADDR)]]
|
|
|
|
#include <cstdio>
|
|
#include <stdexcept>
|
|
|
|
void foo() { throw std::runtime_error("Exception from foo()"); }
|
|
|
|
void bar() { foo(); }
|
|
|
|
int main() {
|
|
try {
|
|
bar();
|
|
} catch (const std::exception &e) {
|
|
printf("Exception caught: %s\n", e.what());
|
|
}
|
|
}
|
|
|
|
extern "C" {
|
|
void _start();
|
|
}
|
|
|
|
void _start() { main(); }
|