mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-27 03:16:07 +00:00

This relands commit 13dd65b3a1a3ac049b5f3a9712059f7c61649bea. The original commit contained a test, which failed when compiled for a MACH-O target. This patch changes the test to run for x86_64-linux instead of `%itanium_abi_triple`, to avoid having invalid syntax for MACH-O sections. The patch itself does not care about section attribute syntax and a x86 backend does not even need to be included in the build. Differential Revision: https://reviews.llvm.org/D102693
51 lines
1.3 KiB
C++
51 lines
1.3 KiB
C++
// RUN: %clang_cc1 -triple x86_64-linux -emit-llvm -o - %s | FileCheck %s --check-prefix=LLVM
|
|
// RUN: %clang_cc1 -triple x86_64-linux -S -o - %s | FileCheck %s --check-prefix=ASM
|
|
// Actually, any ELF target would do
|
|
// REQUIRES: x86_64-linux
|
|
|
|
#pragma clang section bss = "B$$" data = "d@t@" rodata = "r0d@t@"
|
|
|
|
const int a = 1;
|
|
const int *f() { return &a; }
|
|
|
|
int init();
|
|
const int b = init();
|
|
|
|
int c = 2;
|
|
|
|
int d = init();
|
|
|
|
int e;
|
|
|
|
// LLVM: @_ZL1a = internal constant i32 1, align 4 #[[#A:]]
|
|
// LLVM: @_ZL1b = internal global i32 0, align 4 #[[#A]]
|
|
// LLVM: @c = {{.*}}global i32 2, align 4 #[[#A]]
|
|
// LLVM: @d = {{.*}}global i32 0, align 4 #[[#A]]
|
|
// LLVM: @e = {{.*}}global i32 0, align 4 #[[#A]]
|
|
|
|
// LLVM: attributes #[[#A]] = { "bss-section"="B$$" "data-section"="d@t@" "rodata-section"="r0d@t@" }
|
|
|
|
// ASM: .section "r0d@t@","a",@progbits
|
|
// ASM-NOT: .section
|
|
// ASM-LABEL: _ZL1a:
|
|
// ASM-NEXT: .long 1
|
|
|
|
// ASM: .section "B$$","aw",@nobits
|
|
// ASM-NOT: .section
|
|
// ASM-LABEL: _ZL1b:
|
|
// ASM-NEXT: .long 0
|
|
|
|
// ASM: .section "d@t@","aw",@progbits
|
|
// ASM-NOT: .section
|
|
// ASM-LABEL: c:
|
|
// ASM: .long 2
|
|
|
|
// ASM: .section "B$$","aw",@nobits
|
|
// ASM-NOT: .section
|
|
// ASM-LABEL: d:
|
|
// ASM: .long 0
|
|
|
|
// ASM-NOT: .section
|
|
// ASM-LABEL: e:
|
|
// ASM .long 0
|