diff options
| -rw-r--r-- | clang/lib/Basic/Targets.cpp | 12 | ||||
| -rw-r--r-- | clang/test/CodeGen/arm-target-attr.c | 19 | 
2 files changed, 30 insertions, 1 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp index 605f73802af..bb8d81858ad 100644 --- a/clang/lib/Basic/Targets.cpp +++ b/clang/lib/Basic/Targets.cpp @@ -5438,7 +5438,17 @@ public:        if (Feature[0] == '+')          Features[Feature.drop_front(1)] = true; -    return TargetInfo::initFeatureMap(Features, Diags, CPU, FeaturesVec); +    // Convert user-provided arm and thumb GNU target attributes to +    // [-|+]thumb-mode target features respectively. +    std::vector<std::string> UpdatedFeaturesVec(FeaturesVec); +    for (auto &Feature : UpdatedFeaturesVec) { +      if (Feature.compare("+arm") == 0) +        Feature = "-thumb-mode"; +      else if (Feature.compare("+thumb") == 0) +        Feature = "+thumb-mode"; +    } + +    return TargetInfo::initFeatureMap(Features, Diags, CPU, UpdatedFeaturesVec);    }    bool handleTargetFeatures(std::vector<std::string> &Features, diff --git a/clang/test/CodeGen/arm-target-attr.c b/clang/test/CodeGen/arm-target-attr.c new file mode 100644 index 00000000000..42fe8d15aaf --- /dev/null +++ b/clang/test/CodeGen/arm-target-attr.c @@ -0,0 +1,19 @@ +// RUN: %clang_cc1 -triple thumb-apple-darwin -emit-llvm -o - %s | FileCheck --check-prefix CHECKPOS %s +// RUN: %clang_cc1 -triple thumb-apple-darwin -emit-llvm -o - %s | FileCheck --check-prefix CHECKNEG %s +// RUN: %clang_cc1 -triple arm-apple-darwin -emit-llvm -o - %s | FileCheck --check-prefix CHECKPOS %s +// RUN: %clang_cc1 -triple arm-apple-darwin -emit-llvm -o - %s | FileCheck --check-prefix CHECKNEG %s + +__attribute__((target("arm"))) void test_target_arm() { +  // CHECKPOS: define void @test_target_arm() [[ARM_ATTRS:#[0-9]+]] +  // CHECKNEG: define void @test_target_arm() [[ARM_ATTRS:#[0-9]+]] +} + +__attribute__((target("thumb"))) void test_target_thumb() { +  // CHECKPOS: define void @test_target_thumb() [[THUMB_ATTRS:#[0-9]+]] +  // CHECKNEG: define void @test_target_thumb() [[THUMB_ATTRS:#[0-9]+]] +} + +// CHECKPOS: attributes [[ARM_ATTRS]] = { {{.*}} "target-features"="{{.*}}-thumb-mode{{.*}}" +// CHECKPOS: attributes [[THUMB_ATTRS]] = { {{.*}} "target-features"="{{.*}}+thumb-mode{{.*}}" +// CHECKNEG-NOT: attributes [[ARM_ATTRS]] = { {{.*}} "target-features"="{{.*}}+thumb-mode{{.*}}" +// CHECKNEG-NOT: attributes [[THUMB_ATTRS]] = { {{.*}} "target-features"="{{.*}}-thumb-mode{{.*}}"  | 

