summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@intel.com>2018-06-05 21:54:35 +0000
committerCraig Topper <craig.topper@intel.com>2018-06-05 21:54:35 +0000
commit11899b04a4ffe362cf4b09a8b2b944cb1b16a8fc (patch)
treea8fac5355ab04d0d989d9388d47318b8ab709d99
parentc4c6b548c5bdd8ca20ff31e061e1370f1c0a4de8 (diff)
downloadbcm5719-llvm-11899b04a4ffe362cf4b09a8b2b944cb1b16a8fc.tar.gz
bcm5719-llvm-11899b04a4ffe362cf4b09a8b2b944cb1b16a8fc.zip
[X86] Make __builtin_ia32_vec_ext_v2si require ICE for its index argument. Add warnings for out of range indices for __builtin_ia32_vec_ext_v2si, __builtin_ia32_vec_ext_v4hi, and __builtin_ia32_vec_set_v4hi.
These should take a constant value for an index and that constant should be a valid element number. llvm-svn: 334051
-rw-r--r--clang/include/clang/Basic/BuiltinsX86.def2
-rw-r--r--clang/lib/Sema/SemaChecking.cpp7
2 files changed, 8 insertions, 1 deletions
diff --git a/clang/include/clang/Basic/BuiltinsX86.def b/clang/include/clang/Basic/BuiltinsX86.def
index 6f7ecaf28cc..0657354bd53 100644
--- a/clang/include/clang/Basic/BuiltinsX86.def
+++ b/clang/include/clang/Basic/BuiltinsX86.def
@@ -142,7 +142,7 @@ TARGET_BUILTIN(__builtin_ia32_movntq, "vV1LLi*V1LLi", "n", "mmx")
TARGET_BUILTIN(__builtin_ia32_vec_init_v2si, "V2iii", "nc", "mmx")
TARGET_BUILTIN(__builtin_ia32_vec_init_v4hi, "V4sssss", "nc", "mmx")
TARGET_BUILTIN(__builtin_ia32_vec_init_v8qi, "V8ccccccccc", "nc", "mmx")
-TARGET_BUILTIN(__builtin_ia32_vec_ext_v2si, "iV2ii", "nc", "mmx")
+TARGET_BUILTIN(__builtin_ia32_vec_ext_v2si, "iV2iIi", "nc", "mmx")
// MMX2 (MMX+SSE) intrinsics
TARGET_BUILTIN(__builtin_ia32_cvtpi2ps, "V4fV4fV2i", "nc", "mmx,sse")
diff --git a/clang/lib/Sema/SemaChecking.cpp b/clang/lib/Sema/SemaChecking.cpp
index 7b9975e6abf..643c103c8a3 100644
--- a/clang/lib/Sema/SemaChecking.cpp
+++ b/clang/lib/Sema/SemaChecking.cpp
@@ -2555,7 +2555,14 @@ bool Sema::CheckX86BuiltinFunctionCall(unsigned BuiltinID, CallExpr *TheCall) {
case X86::BI_mm_prefetch:
i = 1; l = 0; u = 7;
break;
+ case X86::BI__builtin_ia32_vec_ext_v2si:
+ i = 1; l = 0; u = 1;
+ break;
+ case X86::BI__builtin_ia32_vec_ext_v4hi:
+ i = 1; l = 0; u = 3;
+ break;
case X86::BI__builtin_ia32_sha1rnds4:
+ case X86::BI__builtin_ia32_vec_set_v4hi:
i = 2; l = 0; u = 3;
break;
case X86::BI__builtin_ia32_vpermil2pd:
OpenPOWER on IntegriCloud