1 // RUN: %clang_cc1 -triple riscv32 -emit-llvm -o - %s | FileCheck -check-prefix=EMPTY-ILP32 %s 2 // RUN: %clang_cc1 -triple riscv32 -emit-llvm -target-feature +f -target-feature +d -o - %s | FileCheck -check-prefix=EMPTY-ILP32D %s 3 // RUN: %clang_cc1 -triple riscv32 -target-abi ilp32 -emit-llvm -o - %s | FileCheck -check-prefix=ILP32 %s 4 // RUN: %clang_cc1 -triple riscv32 -target-feature +f -target-abi ilp32f -emit-llvm -o - %s | FileCheck -check-prefix=ILP32F %s 5 // RUN: %clang_cc1 -triple riscv32 -target-feature +d -target-feature +f -target-abi ilp32d -emit-llvm -o - %s | FileCheck -check-prefix=ILP32D %s 6 // RUN: %clang_cc1 -triple riscv64 -emit-llvm -o - %s | FileCheck -check-prefix=EMPTY-LP64 %s 7 // RUN: %clang_cc1 -triple riscv64 -target-feature +f -target-feature +d -emit-llvm -o - %s | FileCheck -check-prefix=EMPTY-LP64D %s 8 // RUN: %clang_cc1 -triple riscv64 -target-abi lp64 -emit-llvm -o - %s | FileCheck -check-prefix=LP64 %s 9 // RUN: %clang_cc1 -triple riscv64 -target-feature +f -target-abi lp64f -emit-llvm -o - %s | FileCheck -check-prefix=LP64F %s 10 // RUN: %clang_cc1 -triple riscv64 -target-feature +d -target-feature +f -target-abi lp64d -emit-llvm -o - %s | FileCheck -check-prefix=LP64D %s 11 12 // Test expected behavior when giving -target-cpu 13 // This cc1 test is similar to clang with -march=rv32ifd -mcpu=sifive-e31, default abi is ilp32d 14 // RUN: %clang_cc1 -triple riscv32 -emit-llvm -target-feature +f -target-feature +d -target-cpu sifive-e31 -o - %s | FileCheck -check-prefix=EMPTY-ILP32D %s 15 // This cc1 test is similar to clang with -march=rv64i -mcpu=sifive-u74, default abi is lp64 16 // RUN: %clang_cc1 -triple riscv64 -emit-llvm -o - -target-cpu sifive-u74 %s | FileCheck -check-prefix=EMPTY-LP64 %s 17 18 // EMPTY-ILP32: !{{[0-9]+}} = !{i32 1, !"target-abi", !"ilp32"} 19 // EMPTY-ILP32D: !{{[0-9]+}} = !{i32 1, !"target-abi", !"ilp32d"} 20 // ILP32: !{{[0-9]+}} = !{i32 1, !"target-abi", !"ilp32"} 21 // ILP32F: !{{[0-9]+}} = !{i32 1, !"target-abi", !"ilp32f"} 22 // ILP32D: !{{[0-9]+}} = !{i32 1, !"target-abi", !"ilp32d"} 23 24 // EMPTY-LP64: !{{[0-9]+}} = !{i32 1, !"target-abi", !"lp64"} 25 // EMPTY-LP64D: !{{[0-9]+}} = !{i32 1, !"target-abi", !"lp64d"} 26 // LP64: !{{[0-9]+}} = !{i32 1, !"target-abi", !"lp64"} 27 // LP64F: !{{[0-9]+}} = !{i32 1, !"target-abi", !"lp64f"} 28 // LP64D: !{{[0-9]+}} = !{i32 1, !"target-abi", !"lp64d"} 29