[llvm] r208620 - Add support bswap16 to/from memory compiling to rev16 on ARM/Thumb

Louis Gerbarg lgg at apple.com
Mon May 12 15:21:08 PDT 2014


Committed r208638.

Louis

On May 12, 2014, at 3:12 PM, Louis Gerbarg <lgg at apple.com> wrote:

> I’ll submit something in sec.
> 
> Louis
> 
> On May 12, 2014, at 3:09 PM, Reid Kleckner <rnk at google.com> wrote:
> 
>> This test fails on Windows:
>> http://bb.pgr.jp/builders/ninja-x64-msvc-RA-centos6/builds/2682
>> 
>> The Windows target is thumb-only.  You need to add a triple.
>> 
>> 
>> On Mon, May 12, 2014 at 12:53 PM, Louis Gerbarg <lgg at apple.com> wrote:
>> Author: louis
>> Date: Mon May 12 14:53:52 2014
>> New Revision: 208620
>> 
>> URL: http://llvm.org/viewvc/llvm-project?rev=208620&view=rev
>> Log:
>> Add support bswap16 to/from memory compiling to rev16 on ARM/Thumb
>> 
>> The current patterns for REV16 misses mostn __builtin_bswap16() due to
>> legalization promoting the operands to from load/stores toi32s and then
>> truncing/extending them. This patch adds new patterns that catch the resultant
>> DAGs and codegens them to rev16 instructions. Tests included.
>> 
>> rdar://15353652
>> 
>> Added:
>>     llvm/trunk/test/CodeGen/ARM/bswap16.ll
>> Modified:
>>     llvm/trunk/lib/Target/ARM/ARMInstrInfo.td
>>     llvm/trunk/lib/Target/ARM/ARMInstrThumb.td
>> 
>> Modified: llvm/trunk/lib/Target/ARM/ARMInstrInfo.td
>> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/ARMInstrInfo.td?rev=208620&r1=208619&r2=208620&view=diff
>> ==============================================================================
>> --- llvm/trunk/lib/Target/ARM/ARMInstrInfo.td (original)
>> +++ llvm/trunk/lib/Target/ARM/ARMInstrInfo.td Mon May 12 14:53:52 2014
>> @@ -4122,6 +4122,11 @@ def REV16 : AMiscA1I<0b01101011, 0b1011,
>>                 Requires<[IsARM, HasV6]>,
>>             Sched<[WriteALU]>;
>> 
>> +def : ARMV6Pat<(srl (bswap (extloadi16 addrmode3:$addr)), (i32 16)),
>> +              (REV16 (LDRH addrmode3:$addr))>;
>> +def : ARMV6Pat<(truncstorei16 (srl (bswap GPR:$Rn), (i32 16)), addrmode3:$addr),
>> +               (STRH (REV16 GPR:$Rn), addrmode3:$addr)>;
>> +
>>  let AddedComplexity = 5 in
>>  def REVSH : AMiscA1I<0b01101111, 0b1011, (outs GPR:$Rd), (ins GPR:$Rm),
>>                 IIC_iUNAr, "revsh", "\t$Rd, $Rm",
>> 
>> Modified: llvm/trunk/lib/Target/ARM/ARMInstrThumb.td
>> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/ARMInstrThumb.td?rev=208620&r1=208619&r2=208620&view=diff
>> ==============================================================================
>> --- llvm/trunk/lib/Target/ARM/ARMInstrThumb.td (original)
>> +++ llvm/trunk/lib/Target/ARM/ARMInstrThumb.td Mon May 12 14:53:52 2014
>> @@ -1308,6 +1308,18 @@ def : T1Pat<(addc   tGPR:$lhs, imm8_255_
>>  def : T1Pat<(subc   tGPR:$lhs, tGPR:$rhs),
>>              (tSUBrr tGPR:$lhs, tGPR:$rhs)>;
>> 
>> +// Bswap 16 with load/store
>> +def : T1Pat<(srl (bswap (extloadi16 t_addrmode_rrs2:$addr)), (i32 16)),
>> +            (tREV16 (tLDRHr t_addrmode_rrs2:$addr))>;
>> +def : T1Pat<(srl (bswap (extloadi16 t_addrmode_is2:$addr)), (i32 16)),
>> +            (tREV16 (tLDRHi t_addrmode_is2:$addr))>;
>> +def : T1Pat<(truncstorei16 (srl (bswap tGPR:$Rn), (i32 16)),
>> +                           t_addrmode_rrs2:$addr),
>> +            (tSTRHr (tREV16 tGPR:$Rn), t_addrmode_rrs2:$addr)>;
>> +def : T1Pat<(truncstorei16 (srl (bswap tGPR:$Rn), (i32 16)),
>> +                           t_addrmode_is2:$addr),
>> +            (tSTRHi(tREV16 tGPR:$Rn), t_addrmode_is2:$addr)>;
>> +
>>  // ConstantPool
>>  def : T1Pat<(ARMWrapper  tconstpool  :$dst), (tLEApcrel tconstpool  :$dst)>;
>> 
>> 
>> Added: llvm/trunk/test/CodeGen/ARM/bswap16.ll
>> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/ARM/bswap16.ll?rev=208620&view=auto
>> ==============================================================================
>> --- llvm/trunk/test/CodeGen/ARM/bswap16.ll (added)
>> +++ llvm/trunk/test/CodeGen/ARM/bswap16.ll Mon May 12 14:53:52 2014
>> @@ -0,0 +1,42 @@
>> +; RUN: llc -march=arm  -mattr=v6 < %s | FileCheck %s
>> +; RUN: llc -march=thumb  -mattr=v6 < %s | FileCheck %s
>> +
>> +
>> +define void @test1(i16* nocapture %data) {
>> +entry:
>> +  %0 = load i16* %data, align 2
>> +  %1 = tail call i16 @llvm.bswap.i16(i16 %0)
>> +  store i16 %1, i16* %data, align 2
>> +  ret void
>> +
>> +  ; CHECK-LABEL: test1:
>> +  ; CHECK: ldrh r[[R1:[0-9]+]], [r0]
>> +  ; CHECK: rev16 r[[R1]], r[[R1]]
>> +  ; CHECK: strh r[[R1]], [r0]
>> +}
>> +
>> +
>> +define void @test2(i16* nocapture %data, i16 zeroext %in) {
>> +entry:
>> +  %0 = tail call i16 @llvm.bswap.i16(i16 %in)
>> +  store i16 %0, i16* %data, align 2
>> +  ret void
>> +
>> +  ; CHECK-LABEL: test2:
>> +  ; CHECK: rev16 r[[R1:[0-9]+]], r1
>> +  ; CHECK: strh r[[R1]], [r0]
>> +}
>> +
>> +
>> +define i16 @test3(i16* nocapture %data) {
>> +entry:
>> +  %0 = load i16* %data, align 2
>> +  %1 = tail call i16 @llvm.bswap.i16(i16 %0)
>> +  ret i16 %1
>> +
>> +  ; CHECK-LABEL: test3:
>> +  ; CHECK: ldrh r[[R0:[0-9]+]], [r0]
>> +  ; CHECK: rev16 r[[R0]], r0
>> +}
>> +
>> +declare i16 @llvm.bswap.i16(i16)
>> 
>> 
>> _______________________________________________
>> llvm-commits mailing list
>> llvm-commits at cs.uiuc.edu
>> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
>> 
> 
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20140512/c103e8bb/attachment.html>


More information about the llvm-commits mailing list