diff options
author | Juergen Ributzka <juergen@apple.com> | 2014-09-22 21:08:53 +0000 |
---|---|---|
committer | Juergen Ributzka <juergen@apple.com> | 2014-09-22 21:08:53 +0000 |
commit | 27e959d7b2cf031cc942e5cce8b0583cd7dbd318 (patch) | |
tree | e462d3d1c91f5d7d0f40a1315fd54676b7769cc7 /llvm/lib/Target/AArch64/AArch64FastISel.cpp | |
parent | d15514a8bdc40886b5befed7f9f61e047bfd43f4 (diff) | |
download | bcm5719-llvm-27e959d7b2cf031cc942e5cce8b0583cd7dbd318.tar.gz bcm5719-llvm-27e959d7b2cf031cc942e5cce8b0583cd7dbd318.zip |
[FastISel][AArch64] Also allow folding of sign-/zero-extend and shift-left for booleans (i1).
Shift-left immediate with sign-/zero-extensions also works for boolean values.
Update the assert and the test cases to reflect that fact.
This should fix a bug found by Chad.
llvm-svn: 218275
Diffstat (limited to 'llvm/lib/Target/AArch64/AArch64FastISel.cpp')
-rw-r--r-- | llvm/lib/Target/AArch64/AArch64FastISel.cpp | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/llvm/lib/Target/AArch64/AArch64FastISel.cpp b/llvm/lib/Target/AArch64/AArch64FastISel.cpp index f09f6003289..5c2daa1fdbe 100644 --- a/llvm/lib/Target/AArch64/AArch64FastISel.cpp +++ b/llvm/lib/Target/AArch64/AArch64FastISel.cpp @@ -3453,8 +3453,9 @@ unsigned AArch64FastISel::emitLSL_ri(MVT RetVT, MVT SrcVT, unsigned Op0, bool IsZext) { assert(RetVT.SimpleTy >= SrcVT.SimpleTy && "Unexpected source/return type pair."); - assert((SrcVT == MVT::i8 || SrcVT == MVT::i16 || SrcVT == MVT::i32 || - SrcVT == MVT::i64) && "Unexpected source value type."); + assert((SrcVT == MVT::i1 || SrcVT == MVT::i8 || SrcVT == MVT::i16 || + SrcVT == MVT::i32 || SrcVT == MVT::i64) && + "Unexpected source value type."); assert((RetVT == MVT::i8 || RetVT == MVT::i16 || RetVT == MVT::i32 || RetVT == MVT::i64) && "Unexpected return value type."); |