llvm-project/bolt/test/X86/instrumentation-eh_frame_hdr.cpp
Elvina Yakubova 6678f602c2 [BOLT][test] Fix cross-compilation tests after D151920
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
2023-09-08 00:05:39 +03:00

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(); }