llvm/clang/test/CodeGenCXX/clang-sections-1.cpp

// 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-registered-target

#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