| ; RUN: llc -mattr=avr6,sram < %s -mtriple=avr -verify-machineinstrs | FileCheck %s |
| |
| define i8 @load8(ptr %x) { |
| ; CHECK-LABEL: load8: |
| ; CHECK: ld r24, {{[XYZ]}} |
| %1 = load i8, ptr %x |
| ret i8 %1 |
| } |
| |
| define i16 @load16(ptr %x) { |
| ; CHECK-LABEL: load16: |
| ; CHECK: ld r24, [[PTR:[YZ]]] |
| ; CHECK: ldd r25, [[PTR]]+1 |
| %1 = load i16, ptr %x |
| ret i16 %1 |
| } |
| |
| define i8 @load8disp(ptr %x) { |
| ; CHECK-LABEL: load8disp: |
| ; CHECK: ldd r24, {{[YZ]}}+63 |
| %1 = getelementptr inbounds i8, ptr %x, i64 63 |
| %2 = load i8, ptr %1 |
| ret i8 %2 |
| } |
| |
| define i8 @load8nodisp(ptr %x) { |
| ; CHECK-LABEL: load8nodisp: |
| ; CHECK: movw r26, r24 |
| ; CHECK: subi r26, 192 |
| ; CHECK: sbci r27, 255 |
| ; CHECK: ld r24, {{[XYZ]}} |
| %1 = getelementptr inbounds i8, ptr %x, i64 64 |
| %2 = load i8, ptr %1 |
| ret i8 %2 |
| } |
| |
| define i16 @load16disp(ptr %x) { |
| ; CHECK-LABEL: load16disp: |
| ; CHECK: ldd r24, [[PTR:[YZ]]]+62 |
| ; CHECK: ldd r25, [[PTR]]+63 |
| %1 = getelementptr inbounds i16, ptr %x, i64 31 |
| %2 = load i16, ptr %1 |
| ret i16 %2 |
| } |
| |
| define i16 @load16nodisp(ptr %x) { |
| ; CHECK-LABEL: load16nodisp: |
| ; CHECK: subi r24, 192 |
| ; CHECK: sbci r25, 255 |
| ; CHECK: movw r30, r24 |
| ; CHECK: ld r24, [[PTR:[YZ]]] |
| ; CHECK: ldd r25, [[PTR]]+1 |
| %1 = getelementptr inbounds i16, ptr %x, i64 32 |
| %2 = load i16, ptr %1 |
| ret i16 %2 |
| } |
| |
| define i8 @load8postinc(ptr %x, i8 %y) { |
| ; CHECK-LABEL: load8postinc: |
| ; CHECK: ld {{.*}}, {{[XYZ]}}+ |
| entry: |
| %tobool6 = icmp eq i8 %y, 0 |
| br i1 %tobool6, label %while.end, label %while.body |
| while.body: ; preds = %entry, %while.body |
| %r.09 = phi i8 [ %add, %while.body ], [ 0, %entry ] |
| %y.addr.08 = phi i8 [ %dec, %while.body ], [ %y, %entry ] |
| %x.addr.07 = phi ptr [ %incdec.ptr, %while.body ], [ %x, %entry ] |
| %dec = add i8 %y.addr.08, -1 |
| %incdec.ptr = getelementptr inbounds i8, ptr %x.addr.07, i16 1 |
| %0 = load i8, ptr %x.addr.07 |
| %add = add i8 %0, %r.09 |
| %tobool = icmp eq i8 %dec, 0 |
| br i1 %tobool, label %while.end, label %while.body |
| while.end: ; preds = %while.body, %entry |
| %r.0.lcssa = phi i8 [ 0, %entry ], [ %add, %while.body ] |
| ret i8 %r.0.lcssa |
| } |
| |
| define i16 @load16postinc(ptr %x, i16 %y) { |
| ; CHECK-LABEL: load16postinc: |
| ; CHECK: ld {{.*}}, {{[XYZ]}}+ |
| ; CHECK: ld {{.*}}, {{[XYZ]}}+ |
| entry: |
| %tobool2 = icmp eq i16 %y, 0 |
| br i1 %tobool2, label %while.end, label %while.body |
| while.body: ; preds = %entry, %while.body |
| %r.05 = phi i16 [ %add, %while.body ], [ 0, %entry ] |
| %y.addr.04 = phi i16 [ %dec, %while.body ], [ %y, %entry ] |
| %x.addr.03 = phi ptr [ %incdec.ptr, %while.body ], [ %x, %entry ] |
| %dec = add nsw i16 %y.addr.04, -1 |
| %incdec.ptr = getelementptr inbounds i16, ptr %x.addr.03, i16 1 |
| %0 = load i16, ptr %x.addr.03 |
| %add = add nsw i16 %0, %r.05 |
| %tobool = icmp eq i16 %dec, 0 |
| br i1 %tobool, label %while.end, label %while.body |
| while.end: ; preds = %while.body, %entry |
| %r.0.lcssa = phi i16 [ 0, %entry ], [ %add, %while.body ] |
| ret i16 %r.0.lcssa |
| } |
| |
| define i8 @load8predec(ptr %x, i8 %y) { |
| ; CHECK-LABEL: load8predec: |
| ; CHECK: ld {{.*}}, -{{[XYZ]}} |
| entry: |
| %tobool6 = icmp eq i8 %y, 0 |
| br i1 %tobool6, label %while.end, label %while.body |
| while.body: ; preds = %entry, %while.body |
| %r.09 = phi i8 [ %add, %while.body ], [ 0, %entry ] |
| %y.addr.08 = phi i8 [ %dec, %while.body ], [ %y, %entry ] |
| %x.addr.07 = phi ptr [ %incdec.ptr, %while.body ], [ %x, %entry ] |
| %dec = add i8 %y.addr.08, -1 |
| %incdec.ptr = getelementptr inbounds i8, ptr %x.addr.07, i16 -1 |
| %0 = load i8, ptr %incdec.ptr |
| %add = add i8 %0, %r.09 |
| %tobool = icmp eq i8 %dec, 0 |
| br i1 %tobool, label %while.end, label %while.body |
| while.end: ; preds = %while.body, %entry |
| %r.0.lcssa = phi i8 [ 0, %entry ], [ %add, %while.body ] |
| ret i8 %r.0.lcssa |
| } |
| |
| define i16 @load16predec(ptr %x, i16 %y) { |
| ; CHECK-LABEL: load16predec: |
| ; CHECK: ld {{.*}}, -{{[XYZ]}} |
| ; CHECK: ld {{.*}}, -{{[XYZ]}} |
| entry: |
| %tobool2 = icmp eq i16 %y, 0 |
| br i1 %tobool2, label %while.end, label %while.body |
| while.body: ; preds = %entry, %while.body |
| %r.05 = phi i16 [ %add, %while.body ], [ 0, %entry ] |
| %y.addr.04 = phi i16 [ %dec, %while.body ], [ %y, %entry ] |
| %x.addr.03 = phi ptr [ %incdec.ptr, %while.body ], [ %x, %entry ] |
| %dec = add nsw i16 %y.addr.04, -1 |
| %incdec.ptr = getelementptr inbounds i16, ptr %x.addr.03, i16 -1 |
| %0 = load i16, ptr %incdec.ptr |
| %add = add nsw i16 %0, %r.05 |
| %tobool = icmp eq i16 %dec, 0 |
| br i1 %tobool, label %while.end, label %while.body |
| while.end: ; preds = %while.body, %entry |
| %r.0.lcssa = phi i16 [ 0, %entry ], [ %add, %while.body ] |
| ret i16 %r.0.lcssa |
| } |
| |
| define ptr addrspace(1) @load16_postinc_progmem(ptr addrspace(1) readonly %0) { |
| ; CHECK-LABEL: load16_postinc_progmem: |
| ; CHECK: movw r30, [[REG0:r[0-9]+]] |
| ; CHECK: lpm [[REG1:r[0-9]+]], Z+ |
| ; CHECK: lpm [[REG1:r[0-9]+]], Z |
| ; CHECK: call foo |
| ; CHECK: adiw [[REG0:r[0-9]+]], 2 |
| %2 = load i16, ptr addrspace(1) %0, align 1 |
| tail call addrspace(1) void @foo(i16 %2) |
| %3 = getelementptr inbounds i16, ptr addrspace(1) %0, i16 1 |
| ret ptr addrspace(1) %3 |
| } |
| |
| declare void @foo(i16) |