summaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
authorBob Wilson <bob.wilson@apple.com>2010-12-07 20:02:45 +0000
committerBob Wilson <bob.wilson@apple.com>2010-12-07 20:02:45 +0000
commitc4ba09da6064c61ff75890987d6e73a5fc7a6125 (patch)
tree98686f2fc1f93fbbc7e1bf4e365e3683073e2e59 /utils
parent9801b5c822bf475e859e3fe18b87dbb308b0e22c (diff)
downloadllvm-c4ba09da6064c61ff75890987d6e73a5fc7a6125.tar.gz
llvm-c4ba09da6064c61ff75890987d6e73a5fc7a6125.tar.bz2
llvm-c4ba09da6064c61ff75890987d6e73a5fc7a6125.tar.xz
Add new built-in operations for vmull and vmull_n
so they can be implemented without requiring clang builtins. Radar 8446238. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@121173 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rw-r--r--utils/TableGen/NeonEmitter.cpp18
-rw-r--r--utils/TableGen/NeonEmitter.h4
2 files changed, 22 insertions, 0 deletions
diff --git a/utils/TableGen/NeonEmitter.cpp b/utils/TableGen/NeonEmitter.cpp
index 3752db0f4d..7fdc1cacd6 100644
--- a/utils/TableGen/NeonEmitter.cpp
+++ b/utils/TableGen/NeonEmitter.cpp
@@ -508,6 +508,15 @@ static std::string GenMacroLocals(const std::string &proto, StringRef typestr) {
return s;
}
+// Use the vmovl builtin to sign-extend or zero-extend a vector.
+static std::string Extend(const std::string &proto, StringRef typestr,
+ const std::string &a) {
+ std::string s;
+ s = MangleName("vmovl", typestr, ClassS);
+ s += "(" + a + ")";
+ return s;
+}
+
static std::string Duplicate(unsigned nElts, StringRef typestr,
const std::string &a) {
std::string s;
@@ -587,6 +596,15 @@ static std::string GenOpString(OpKind op, const std::string &proto,
case OpMul:
s += "__a * __b;";
break;
+ case OpMullN:
+ s += Extend(proto, typestr, "__a") + " * " +
+ Extend(proto, typestr,
+ Duplicate(nElts << (int)quad, typestr, "__b")) + ";";
+ break;
+ case OpMull:
+ s += Extend(proto, typestr, "__a") + " * " +
+ Extend(proto, typestr, "__b") + ";";
+ break;
case OpMlaN:
s += "__a + (__b * " + Duplicate(nElts, typestr, "__c") + ");";
break;
diff --git a/utils/TableGen/NeonEmitter.h b/utils/TableGen/NeonEmitter.h
index 3d122ffbba..0ee856c26b 100644
--- a/utils/TableGen/NeonEmitter.h
+++ b/utils/TableGen/NeonEmitter.h
@@ -26,9 +26,11 @@ enum OpKind {
OpAdd,
OpSub,
OpMul,
+ OpMull,
OpMla,
OpMls,
OpMulN,
+ OpMullN,
OpMlaN,
OpMlsN,
OpMulLane,
@@ -79,9 +81,11 @@ namespace llvm {
OpMap["OP_ADD"] = OpAdd;
OpMap["OP_SUB"] = OpSub;
OpMap["OP_MUL"] = OpMul;
+ OpMap["OP_MULL"] = OpMull;
OpMap["OP_MLA"] = OpMla;
OpMap["OP_MLS"] = OpMls;
OpMap["OP_MUL_N"] = OpMulN;
+ OpMap["OP_MULL_N"]= OpMullN;
OpMap["OP_MLA_N"] = OpMlaN;
OpMap["OP_MLS_N"] = OpMlsN;
OpMap["OP_MUL_LN"]= OpMulLane;