llvm-6502/test/CodeGen/ARM
Bob Wilson 626613d5e8 Recognize sign/zero-extended constant BUILD_VECTORs for VMULL operations.
We need to check if the individual vector elements are sign/zero-extended
values.  For now this only handles constants values.  Radar 8687140.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@120034 91177308-0d34-0410-b5e6-96231b3b80d8
2010-11-23 19:38:38 +00:00
..
2006-11-10-CycleInDAG.ll
2007-01-19-InfiniteLoop.ll Fix test. 2010-11-03 18:21:33 +00:00
2007-03-07-CombinerCrash.ll
2007-03-13-InstrSched.ll
2007-03-21-JoinIntervalsCrash.ll
2007-03-26-RegScavengerAssert.ll Correct bogus module triple specifications. 2010-08-30 10:48:29 +00:00
2007-03-27-RegScavengerAssert.ll
2007-03-30-RegScavengerAssert.ll
2007-04-02-RegScavengerAssert.ll
2007-04-03-PEIBug.ll
2007-04-03-UndefinedSymbol.ll
2007-04-30-CombinerCrash.ll
2007-05-03-BadPostIndexedLd.ll
2007-05-07-jumptoentry.ll
2007-05-07-tailmerge-1.ll
2007-05-09-tailmerge-2.ll
2007-05-14-InlineAsmCstCrash.ll
2007-05-14-RegScavengerAssert.ll
2007-05-22-tailmerge-3.ll
2007-05-23-BadPreIndexedStore.ll
2007-05-31-RegScavengerInfiniteLoop.ll Correct bogus module triple specifications. 2010-08-30 10:48:29 +00:00
2007-08-15-ReuseBug.ll
2008-02-04-LocalRegAllocBug.ll
2008-02-29-RegAllocLocal.ll
2008-03-05-SxtInRegBug.ll
2008-03-07-RegScavengerAssert.ll
2008-04-04-ScavengerAssert.ll
2008-04-10-ScavengerAssert.ll
2008-04-11-PHIofImpDef.ll
2008-05-19-LiveIntervalsBug.ll
2008-05-19-ScavengerAssert.ll
2008-07-17-Fdiv.ll
2008-07-24-CodeGenPrepCrash.ll
2008-08-07-AsmPrintBug.ll
2008-09-14-CoalescerBug.ll
2008-09-17-CoalescerBug.ll
2008-11-18-ScavengerAssert.ll
2009-02-16-SpillerBug.ll
2009-02-22-SoftenFloatVaArg.ll
2009-02-27-SpillerBug.ll
2009-03-07-SpillerBug.ll
2009-03-09-AddrModeBug.ll
2009-04-06-AsmModifier.ll
2009-04-08-AggregateAddr.ll
2009-04-08-FloatUndef.ll
2009-04-08-FREM.ll
2009-04-09-RegScavengerAsm.ll
2009-05-05-DAGCombineBug.ll
2009-05-07-RegAllocLocal.ll
2009-05-11-CodePlacementCrash.ll
2009-05-18-InlineAsmMem.ll
2009-06-02-ISelCrash.ll
2009-06-04-MissingLiveIn.ll
2009-06-12-RegScavengerAssert.ll
2009-06-15-RegScavengerAssert.ll
2009-06-19-RegScavengerAssert.ll
2009-06-22-CoalescerBug.ll
2009-06-30-RegScavengerAssert2.ll
2009-06-30-RegScavengerAssert3.ll
2009-06-30-RegScavengerAssert4.ll
2009-06-30-RegScavengerAssert5.ll
2009-06-30-RegScavengerAssert.ll
2009-07-01-CommuteBug.ll
2009-07-09-asm-p-constraint.ll
2009-07-18-RewriterBug.ll
2009-07-22-ScavengerAssert.ll Remove arm_apcscc from the test files. It is the default and doing this 2010-06-17 15:18:27 +00:00
2009-07-22-SchedulerAssert.ll
2009-07-29-VFP3Registers.ll
2009-08-02-RegScavengerAssert-Neon.ll
2009-08-04-RegScavengerAssert-2.ll
2009-08-04-RegScavengerAssert.ll
2009-08-15-RegScavenger-EarlyClobber.ll
2009-08-15-RegScavengerAssert.ll
2009-08-21-PostRAKill2.ll
2009-08-21-PostRAKill3.ll
2009-08-21-PostRAKill.ll
2009-08-23-linkerprivate.ll
2009-08-26-ScalarToVector.ll
2009-08-27-ScalarToVector.ll
2009-08-29-ExtractEltf32.ll
2009-08-29-TooLongSplat.ll
2009-08-31-LSDA-Name.ll
2009-08-31-TwoRegShuffle.ll
2009-09-09-AllOnes.ll
2009-09-09-fpcmp-ole.ll
2009-09-10-postdec.ll
2009-09-13-InvalidSubreg.ll
2009-09-13-InvalidSuperReg.ll
2009-09-20-LiveIntervalsBug.ll
2009-09-21-LiveVariablesBug.ll
2009-09-22-LiveVariablesBug.ll
2009-09-23-LiveVariablesBug.ll
2009-09-24-spill-align.ll
2009-09-27-CoalescerBug.ll
2009-09-28-LdStOptiBug.ll User proper libcall names & condcodes while compiling for ARM EABI. 2010-09-28 21:39:26 +00:00
2009-10-02-NEONSubregsBug.ll
2009-10-21-InvalidFNeg.ll
2009-10-27-double-align.ll
2009-10-30.ll
2009-11-01-NeonMoves.ll
2009-11-02-NegativeLane.ll
2009-11-07-SubRegAsmPrinting.ll
2009-11-13-CoalescerCrash.ll
2009-11-13-ScavengerAssert2.ll
2009-11-13-ScavengerAssert.ll
2009-11-13-VRRewriterCrash.ll
2009-11-30-LiveVariablesBug.ll
2009-12-02-vtrn-undef.ll
2010-03-04-eabi-fp-spill.ll
2010-03-04-stm-undef-addr.ll
2010-03-18-ldm-rtrn.ll
2010-04-07-DbgValueOtherTargets.ll
2010-04-09-NeonSelect.ll
2010-04-13-v2f64SplitArg.ll
2010-04-14-SplitVector.ll
2010-04-15-ScavengerDebugValue.ll
2010-05-14-IllegalType.ll
2010-05-17-DAGCombineAssert.ll
2010-05-17-FastAllocCrash.ll
2010-05-18-LocalAllocCrash.ll
2010-05-18-PostIndexBug.ll
2010-05-19-Shuffles.ll
2010-05-20-NEONSpillCrash.ll Add alignment arguments to all the NEON load/store intrinsics. 2010-08-27 17:13:24 +00:00
2010-05-21-BuildVector.ll Add alignment arguments to all the NEON load/store intrinsics. 2010-08-27 17:13:24 +00:00
2010-06-11-vmovdrr-bitcast.ll Add alignment arguments to all the NEON load/store intrinsics. 2010-08-27 17:13:24 +00:00
2010-06-21-LdStMultipleBug.ll
2010-06-21-nondarwin-tc.ll
2010-06-25-Thumb2ITInvalidIterator.ll
2010-06-28-DAGCombineUndef.ll
2010-06-29-PartialRedefFastAlloc.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
2010-06-29-SubregImpDefs.ll
2010-07-26-GlobalMerge.ll
2010-08-04-EHCrash.ll
2010-09-17-vmovrrd-combine.ll Add target-specific DAG combiner for BUILD_VECTOR and VMOVRRD. An i64 2010-09-17 22:59:05 +00:00
2010-09-21-OptCmpBug.ll OptimizeCompareInstr should avoid iterating pass the beginning of the MBB when the 'and' instruction is after the comparison. 2010-09-21 23:49:07 +00:00
2010-09-29-mc-asm-header-test.ll Tiny patch for proof-of-concept cleanup of ARMAsmPrinter::EmitStartOfAsmFile() 2010-09-30 02:45:56 +00:00
2010-10-19-mc-elf-objheader.ll Revert 118422 in search of bot verdancy. 2010-11-08 19:17:22 +00:00
2010-10-25-ifcvt-ldm.ll Rewrite stack callee saved spills and restores to use push/pop instructions. 2010-11-18 19:40:05 +00:00
2010-11-15-SpillEarlyClobber.ll Fix PR8612 in the standard spiller, take two. 2010-11-16 00:40:59 +00:00
2010-11-17-DAGCombineShiftBug.ll Fix bug in DAGCombiner for ARM that was trying to do a ShiftCombine on illegal types (vector should be split first). 2010-11-18 22:06:46 +00:00
addrmode.ll
aliases.ll
align.ll Increase ARM APCS preferred alignment for i64 and f64 from 32 bits to 64 bits. 2010-09-29 17:54:10 +00:00
alloca.ll
argaddr.ll
arguments2.ll
arguments3.ll
arguments4.ll
arguments5.ll
arguments6.ll
arguments7.ll
arguments8.ll
arguments_f64_backfill.ll
arguments-nosplit-double.ll
arguments-nosplit-i64.ll
arguments.ll - Add TargetInstrInfo::getOperandLatency() to compute operand latencies. This 2010-10-06 06:27:31 +00:00
arm-and-tst-peephole.ll Remove ARM isel hacks that fold large immediates into a pair of add, sub, and, 2010-11-17 20:13:28 +00:00
arm-asm.ll
arm-frameaddr.ll
arm-negative-stride.ll
arm-returnaddr.ll
armv4.ll
bfc.ll
bfi.ll Update tests to handle MC-inst instruction printing of shift operations. The 2010-09-17 21:58:46 +00:00
bfx.ll
bic.ll
bits.ll FileCheck-ize 2010-09-17 21:46:16 +00:00
bx_fold.ll
call_nolink.ll
call-tc.ll
call.ll
carry.ll
clz.ll FileCheck-ize a few tests. 2010-10-22 21:55:03 +00:00
code-placement.ll Explicitly disable CGP critical edge splitting for this test so it won't break 2010-09-27 18:43:43 +00:00
compare-call.ll
constants.ll tidy up 2010-10-22 23:46:04 +00:00
crash-O0.ll
crash.ll Simplify test and move into a generic "crash" ll file. 2010-10-09 00:29:04 +00:00
cse-libcalls.ll
ctors_dtors.ll
ctz.ll
dg.exp
div.ll These tests are looking for library function names that 2010-11-17 21:57:32 +00:00
dyn-stackalloc.ll
extloadi1.ll
fabss.ll Re-commit 117518 and 117519 now that ARM MC test failures are out of the way. 2010-10-28 06:47:08 +00:00
fadds.ll Re-commit 117518 and 117519 now that ARM MC test failures are out of the way. 2010-10-28 06:47:08 +00:00
fast-isel.ll Recommit this change and remove the failing part of the test - it didn't 2010-11-15 21:11:06 +00:00
fcopysign.ll
fdivs.ll Re-commit 117518 and 117519 now that ARM MC test failures are out of the way. 2010-10-28 06:47:08 +00:00
fixunsdfdi.ll
flag-crash.ll
fmacs.ll Add some missing isel predicates on def : pat patterns to avoid generating VFP vmla / vmls (they cause stalls). Disabling them in isel is properly not a right solution, I'll look into a proper solution next. 2010-11-12 20:32:20 +00:00
fmdrr-fmrrd.ll
fmscs.ll Add some missing isel predicates on def : pat patterns to avoid generating VFP vmla / vmls (they cause stalls). Disabling them in isel is properly not a right solution, I'll look into a proper solution next. 2010-11-12 20:32:20 +00:00
fmuls.ll Re-commit 117518 and 117519 now that ARM MC test failures are out of the way. 2010-10-28 06:47:08 +00:00
fnegs.ll
fnmacs.ll Add some missing isel predicates on def : pat patterns to avoid generating VFP vmla / vmls (they cause stalls). Disabling them in isel is properly not a right solution, I'll look into a proper solution next. 2010-11-12 20:32:20 +00:00
fnmscs.ll Add some missing isel predicates on def : pat patterns to avoid generating VFP vmla / vmls (they cause stalls). Disabling them in isel is properly not a right solution, I'll look into a proper solution next. 2010-11-12 20:32:20 +00:00
fnmul.ll
fnmuls.ll Fix an unnecessary XFAIL 2010-09-02 20:19:24 +00:00
formal.ll
fp16.ll
fp_convert.ll
fp.ll tweak test to check instructions rather than relying on the comment string 2010-09-17 20:21:03 +00:00
fparith.ll
fpcmp_ueq.ll These tests are looking for library function names that 2010-11-17 21:57:32 +00:00
fpcmp-opt.ll
fpcmp.ll
fpconsts.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
fpconv.ll These tests are looking for library function names that 2010-11-17 21:57:32 +00:00
fpmem.ll
fpow.ll
fpowi.ll Correct bogus module triple specifications. 2010-08-30 10:48:29 +00:00
fptoint.ll
fsubs.ll
global-merge.ll Change ARMGlobalMerge to keep BSS globals in separate pools. 2010-11-17 21:25:39 +00:00
globals.ll
hardfloat_neon.ll
hello.ll Fix epilogue codegen to avoid leaving the stack pointer in an invalid 2010-11-22 18:12:04 +00:00
hidden-vis-2.ll
hidden-vis-3.ll
hidden-vis.ll
iabs.ll
ifcvt1.ll
ifcvt2.ll
ifcvt3.ll
ifcvt4.ll
ifcvt5.ll
ifcvt6.ll
ifcvt7.ll
ifcvt8.ll
ifcvt9.ll
ifcvt10.ll Two sets of changes. Sorry they are intermingled. 2010-11-03 00:45:17 +00:00
ifcvt11.ll Two sets of changes. Sorry they are intermingled. 2010-11-03 00:45:17 +00:00
illegal-vector-bitcast.ll
imm.ll
indirectbr.ll
inlineasm2.ll
inlineasm3.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
inlineasm-imm-arm.ll
inlineasm.ll
insn-sched1.ll
ispositive.ll Update tests to handle MC-inst instruction printing of shift operations. The 2010-09-17 21:58:46 +00:00
large-stack.ll
ldm.ll
ldr_ext.ll
ldr_frame.ll
ldr_post.ll
ldr_pre.ll
ldr.ll
ldrd.ll
load.ll
long_shift.ll When we look at instructions to convert to setting the 's' flag, we need to look 2010-11-01 20:41:43 +00:00
long-setcc.ll
long.ll tweak test to check instructions rather than relying on the comment string 2010-09-17 20:27:26 +00:00
lsr-code-insertion.ll Revert r114340 (improvements in Darwin function prologue/epilogue), as it broke 2010-11-02 17:35:25 +00:00
lsr-on-unrolled-loops.ll Add some missing isel predicates on def : pat patterns to avoid generating VFP vmla / vmls (they cause stalls). Disabling them in isel is properly not a right solution, I'll look into a proper solution next. 2010-11-12 20:32:20 +00:00
lsr-scale-addr-mode.ll
machine-cse-cmp.ll
mem.ll
memcpy-inline.ll
memfunc.ll
mls.ll
movt-movw-global.ll
movt.ll
mul_const.ll Update tests to handle MC-inst instruction printing of shift operations. The 2010-09-17 21:58:46 +00:00
mul.ll
mulhi.ll
mult-alt-generic-arm.ll Inline asm mult-alt constraint tests. 2010-11-02 23:01:44 +00:00
mvn.ll
neon_arith1.ll
neon_ld1.ll
neon_ld2.ll
neon_minmax.ll
pack.ll Remove duplicate test. 2010-10-22 22:04:28 +00:00
pr3502.ll
prefetch.ll Fix @llvm.prefetch isel. Selecting between pld / pldw using the first immediate rw. There is currently no intrinsic that matches to pli. 2010-11-04 05:19:35 +00:00
private.ll
reg_sequence.ll Two sets of changes. Sorry they are intermingled. 2010-11-03 00:45:17 +00:00
ret0.ll
ret_arg1.ll
ret_arg2.ll
ret_arg3.ll
ret_arg4.ll
ret_arg5.ll
ret_f32_arg2.ll
ret_f32_arg5.ll
ret_f64_arg2.ll
ret_f64_arg_reg_split.ll
ret_f64_arg_split.ll
ret_f64_arg_stack.ll
ret_i64_arg2.ll
ret_i64_arg3.ll
ret_i64_arg_split.ll
ret_i128_arg2.ll
ret_void.ll
rev.ll FileCheck-ize a few tests. 2010-10-22 21:55:03 +00:00
sbfx.ll
section.ll
select_xform.ll Remove ARM isel hacks that fold large immediates into a pair of add, sub, and, 2010-11-17 20:13:28 +00:00
select-imm.ll Add conditional move of large immediate. 2010-11-13 02:25:14 +00:00
select.ll These tests are looking for library function names that 2010-11-17 21:57:32 +00:00
shifter_operand.ll Re-commit 117518 and 117519 now that ARM MC test failures are out of the way. 2010-10-28 06:47:08 +00:00
smul.ll
spill-q.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
stack-frame.ll
stm.ll Teach the (non-MC) instruction printer to use the cannonical names for push/pop, 2010-09-17 22:36:38 +00:00
str_post.ll
str_pre-2.ll Rewrite stack callee saved spills and restores to use push/pop instructions. 2010-11-18 19:40:05 +00:00
str_pre.ll
str_trunc.ll
sub.ll
sxt_rot.ll
t2-imm.ll Fix borken test 2010-08-30 23:41:49 +00:00
tail-opts.ll
thread_pointer.ll
tls1.ll
tls2.ll
tls3.ll
trap.ll
trunc_ldr.ll
truncstore-dag-combine.ll
tst_teq.ll
uint64tof64.ll
unaligned_load_store.ll Add a command line option "-arm-strict-align" to disallow unaligned memory 2010-09-28 04:09:35 +00:00
unord.ll
uxt_rot.ll
uxtb.ll
va_arg.ll
vaba.ll Replace NEON vabdl, vaba, and vabal intrinsics with combinations of the 2010-09-03 01:35:08 +00:00
vabd.ll Replace NEON vabdl, vaba, and vabal intrinsics with combinations of the 2010-09-03 01:35:08 +00:00
vabs.ll
vadd.ll Remove NEON vaddl, vaddw, vsubl, and vsubw intrinsics. Instead, use llvm 2010-08-29 05:57:34 +00:00
vargs_align.ll
vargs.ll
vbits.ll Add codegen and encoding support for the immediate form of vbic. 2010-11-05 19:27:46 +00:00
vbsl.ll
vceq.ll Add support for ARM's specialized vector-compare-against-zero instructions. 2010-11-08 23:21:22 +00:00
vcge.ll Add support for ARM's specialized vector-compare-against-zero instructions. 2010-11-08 23:21:22 +00:00
vcgt.ll Add support for ARM's specialized vector-compare-against-zero instructions. 2010-11-08 23:21:22 +00:00
vcnt.ll
vcombine.ll
vcvt.ll
vdup.ll
vext.ll
vfcmp.ll
vfp.ll
vget_lane.ll Add codegen patterns for VST1-lane instructions. Radar 8599955. 2010-11-03 16:24:53 +00:00
vhadd.ll
vhsub.ll
vicmp.ll
vld1.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
vld2.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
vld3.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
vld4.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
vldlane.ll Add codegen patterns for VST1-lane instructions. Radar 8599955. 2010-11-03 16:24:53 +00:00
vminmax.ll
vmla.ll Remove DAG combiner patch to fold vector splats. Instcombiner does it now. 2010-10-29 22:03:02 +00:00
vmls.ll Remove NEON vmull, vmlal, and vmlsl intrinsics, replacing them with multiply, 2010-09-01 23:50:19 +00:00
vmov.ll NEON does not support truncating vector stores. Radar 8598391. 2010-11-01 18:31:39 +00:00
vmul.ll Recognize sign/zero-extended constant BUILD_VECTORs for VMULL operations. 2010-11-23 19:38:38 +00:00
vneg.ll
vpadal.ll
vpadd.ll
vpminmax.ll
vqadd.ll
vqdmul.ll
vqshl.ll Merge a bunch of NEON tests into larger files so they run faster. 2009-10-09 20:20:54 +00:00
vqshrn.ll
vqsub.ll
vrec.ll
vrev.ll SelectionDAG shuffle nodes do not allow operands with different numbers of 2010-10-27 20:38:28 +00:00
vshift.ll
vshiftins.ll
vshl.ll
vshll.ll
vshrn.ll
vsra.ll
vst1.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
vst2.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
vst3.ll Set alignment operand for NEON VST instructions. 2010-09-23 23:42:37 +00:00
vst4.ll Change register allocation order for ARM VFP and NEON registers to put the 2010-10-08 06:15:13 +00:00
vstlane.ll Add codegen patterns for VST1-lane instructions. Radar 8599955. 2010-11-03 16:24:53 +00:00
vsub.ll Remove NEON vaddl, vaddw, vsubl, and vsubw intrinsics. Instead, use llvm 2010-08-29 05:57:34 +00:00
vtbl.ll
vtrn.ll
vuzp.ll
vzip.ll
weak2.ll
weak.ll