Home | History | Annotate | Download | only in pseudo
      1 # RUN: llc -O0  %s -o - -march=avr | FileCheck %s
      2 
      3 # This test checks the expansion of the 16-bit 'LDDWRdPtrQ' pseudo instruction.
      4 #
      5 # This test ensures that the pseudo expander can correctly handle the case
      6 # where we are expanding a 16-bit LDD instruction where the source and
      7 # destination registers are the same.
      8 #
      9 # The instruction itself is earlyclobber and so ISel will never produce an
     10 # instruction like this, but the stack slot loading can and will.
     11 
     12 --- |
     13   target triple = "avr--"
     14   define void @test_lddwrdptrq() {
     15   entry:
     16     ret void
     17   }
     18 ...
     19 
     20 ---
     21 name:            test_lddwrdptrq
     22 tracksRegLiveness: true
     23 body: |
     24   bb.0.entry:
     25 
     26     ; CHECK-LABEL: test_lddwrdptrq
     27 
     28     ; CHECK:      ldd [[SCRATCH:r[0-9]+]], Z+10
     29     ; CHECK-NEXT: push [[SCRATCH]]
     30     ; CHECK-NEXT: ldd [[SCRATCH]], Z+11
     31     ; CHECK-NEXT: mov r31, [[SCRATCH]]
     32     ; CHECK-NEXT: pop r30
     33 
     34     early-clobber $r31r30 = LDDWRdPtrQ undef $r31r30, 10
     35 ...
     36