
This patch enables the following command line flags for RISC-V targets: + `-fcf-protection=branch` turns on forward-edge control-flow integrity conditioning + `-mcf-branch-label-scheme=unlabeled|func-sig` selects the label scheme used in the forward-edge CFI conditioning
95 lines
4.7 KiB
C
95 lines
4.7 KiB
C
// RUN: %clang --target=riscv32 -menable-experimental-extensions \
|
|
// RUN: -march=rv32i_zicfilp1p0 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=unlabeled -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,UNLABELED-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv32 -menable-experimental-extensions \
|
|
// RUN: -march=rv32i_zicfilp1p0 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=func-sig -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,FUNC-SIG-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv32 -menable-experimental-extensions \
|
|
// RUN: -march=rv32i_zicfilp1p0 -mcf-branch-label-scheme=unlabeled -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,UNLABELED-SCHEME-UNUSED %s
|
|
|
|
// RUN: %clang --target=riscv32 -menable-experimental-extensions \
|
|
// RUN: -march=rv32i_zicfilp1p0 -mcf-branch-label-scheme=func-sig -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,FUNC-SIG-SCHEME-UNUSED %s
|
|
|
|
// RUN: %clang --target=riscv32 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=unlabeled -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,UNLABELED-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv32 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=func-sig -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,FUNC-SIG-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv32 -mcf-branch-label-scheme=unlabeled -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,UNLABELED-SCHEME-UNUSED %s
|
|
|
|
// RUN: %clang --target=riscv32 -mcf-branch-label-scheme=func-sig -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,FUNC-SIG-SCHEME-UNUSED %s
|
|
|
|
// RUN: %clang --target=riscv64 -menable-experimental-extensions \
|
|
// RUN: -march=rv64i_zicfilp1p0 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=unlabeled -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,UNLABELED-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv64 -menable-experimental-extensions \
|
|
// RUN: -march=rv64i_zicfilp1p0 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=func-sig -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,FUNC-SIG-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv64 -menable-experimental-extensions \
|
|
// RUN: -march=rv64i_zicfilp1p0 -mcf-branch-label-scheme=unlabeled -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,UNLABELED-SCHEME-UNUSED %s
|
|
|
|
// RUN: %clang --target=riscv64 -menable-experimental-extensions \
|
|
// RUN: -march=rv64i_zicfilp1p0 -mcf-branch-label-scheme=func-sig -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,FUNC-SIG-SCHEME-UNUSED %s
|
|
|
|
// RUN: %clang --target=riscv64 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=unlabeled -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,UNLABELED-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv64 -fcf-protection=branch \
|
|
// RUN: -mcf-branch-label-scheme=func-sig -S -emit-llvm %s -o - | FileCheck \
|
|
// RUN: --check-prefixes=BRANCH-PROT-FLAG,FUNC-SIG-FLAG %s
|
|
|
|
// RUN: %clang --target=riscv64 -mcf-branch-label-scheme=unlabeled -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,UNLABELED-SCHEME-UNUSED %s
|
|
|
|
// RUN: %clang --target=riscv64 -mcf-branch-label-scheme=func-sig -S \
|
|
// RUN: -emit-llvm %s -o - 2>&1 | FileCheck \
|
|
// RUN: --check-prefixes=NO-FLAG,FUNC-SIG-SCHEME-UNUSED %s
|
|
|
|
// Default -mcf-branch-label-scheme is func-sig
|
|
// RUN: %clang --target=riscv32 -fcf-protection=branch -S -emit-llvm %s -o - \
|
|
// RUN: | FileCheck --check-prefixes=BRANCH-PROT-FLAG,FUNC-SIG-FLAG %s
|
|
|
|
// Default -mcf-branch-label-scheme is func-sig
|
|
// RUN: %clang --target=riscv64 -fcf-protection=branch -S -emit-llvm %s -o - \
|
|
// RUN: | FileCheck --check-prefixes=BRANCH-PROT-FLAG,FUNC-SIG-FLAG %s
|
|
|
|
// UNLABELED-SCHEME-UNUSED: warning: argument unused during compilation:
|
|
// UNLABELED-SCHEME-UNUSED-SAME: '-mcf-branch-label-scheme=unlabeled'
|
|
// FUNC-SIG-SCHEME-UNUSED: warning: argument unused during compilation:
|
|
// FUNC-SIG-SCHEME-UNUSED-SAME: '-mcf-branch-label-scheme=func-sig'
|
|
|
|
// BRANCH-PROT-FLAG-DAG: [[P_FLAG:![0-9]+]] = !{i32 8, !"cf-protection-branch", i32 1}
|
|
// UNLABELED-FLAG-DAG: [[S_FLAG:![0-9]+]] = !{i32 1, !"cf-branch-label-scheme", !"unlabeled"}
|
|
// FUNC-SIG-FLAG-DAG: [[S_FLAG:![0-9]+]] = !{i32 1, !"cf-branch-label-scheme", !"func-sig"}
|
|
// BRANCH-PROT-FLAG-DAG: !llvm.module.flags = !{{[{].*}}[[P_FLAG]]{{.*, }}[[S_FLAG]]{{(,.+)?[}]}}
|
|
// NO-FLAG-NOT: !{i32 8, !"cf-protection-branch", i32 1}
|
|
// NO-FLAG-NOT: !{i32 8, !"cf-branch-label-scheme", !"unlabeled"}
|
|
// NO-FLAG-NOT: !{i32 8, !"cf-branch-label-scheme", !"func-sig"}
|
|
|
|
int main() { return 0; }
|