1; REQUIRES: arm-registered-target
2; REQUIRES: aarch64-registered-target
3; check .ll input
4; RUN: %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm \
5; RUN:    -fembed-bitcode=all -x ir %s -o - \
6; RUN:    | FileCheck %s
7; RUN: %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm \
8; RUN:    -fembed-bitcode=marker -x ir %s -o - \
9; RUN:    | FileCheck %s -check-prefix=CHECK-MARKER
10; RUN: %clang_cc1 -triple aarch64-unknown-linux-gnueabi -emit-llvm \
11; RUN:    -fembed-bitcode=all -x ir %s -o - \
12; RUN:    | FileCheck %s -check-prefix=CHECK-ELF
13
14; check .bc input
15; RUN: %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm-bc \
16; RUN:    -x ir %s -o %t.bc
17; RUN: %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm \
18; RUN:    -fembed-bitcode=all -x ir %t.bc -o - \
19; RUN:    | FileCheck %s
20; RUN: %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm \
21; RUN:    -fembed-bitcode=bitcode -x ir %t.bc -o - \
22; RUN:    | FileCheck %s -check-prefix=CHECK-ONLY-BITCODE
23; RUN: %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm \
24; RUN:    -fembed-bitcode=marker -x ir %t.bc -o - \
25; RUN:    | FileCheck %s -check-prefix=CHECK-MARKER
26
27; run through -fembed-bitcode twice and make sure it doesn't crash
28; RUN: %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm-bc \
29; RUN:    -fembed-bitcode=all -x ir %s -o - \
30; RUN: | %clang_cc1 -triple thumbv7-apple-ios8.0.0 -emit-llvm \
31; RUN:    -fembed-bitcode=all -x ir - -o /dev/null
32
33; check the magic number of bitcode at the beginning of the string
34; CHECK: @llvm.embedded.module = private constant
35; CHECK: c"\DE\C0\17\0B
36; CHECK: section "__LLVM,__bitcode"
37; CHECK: @llvm.cmdline = private constant
38; CHECK: section "__LLVM,__cmdline"
39
40; CHECK-ELF: @llvm.embedded.module
41; CHECK-ELF: section ".llvmbc"
42; CHECK-ELF: @llvm.cmdline
43; CHECK-ELF: section ".llvmcmd"
44
45; CHECK-ONLY-BITCODE: @llvm.embedded.module = private constant
46; CHECK-ONLY-BITCODE: c"\DE\C0\17\0B
47; CHECK-ONLY-BITCODE: section "__LLVM,__bitcode"
48; CHECK-ONLY-BITCODE-NOT: @llvm.cmdline = private constant
49; CHECK-ONLY-BITCODE-NOT: section "__LLVM,__cmdline"
50
51; CHECK-MARKER: @llvm.embedded.module
52; CHECK-MARKER: constant [0 x i8] zeroinitializer
53; CHECK-MARKER: section "__LLVM,__bitcode"
54; CHECK-MARKER: @llvm.cmdline
55; CHECK-MARKER: section "__LLVM,__cmdline"
56
57define i32 @f0() {
58  ret i32 0
59}
60