Compiler projects using llvm
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=m68k-linux-gnu -verify-machineinstrs | FileCheck %s
define i32 @A(i32 %Size) {
; CHECK-LABEL: A:
; CHECK:         .cfi_startproc
; CHECK-NEXT:  ; %bb.0:
; CHECK-NEXT:    move.l %a6, -(%sp)
; CHECK-NEXT:    .cfi_def_cfa_offset -8
; CHECK-NEXT:    .cfi_offset %a6, -8
; CHECK-NEXT:    move.l %sp, %a6
; CHECK-NEXT:    .cfi_def_cfa_register %a6
; CHECK-NEXT:    move.l %sp, %d0
; CHECK-NEXT:    and.l #-128, %d0
; CHECK-NEXT:    move.l %d0, %sp
; CHECK-NEXT:    suba.l #128, %sp
; CHECK-NEXT:    move.l %sp, %a4
; CHECK-NEXT:    movem.l %a4, (116,%a4) ; 8-byte Folded Spill
; CHECK-NEXT:    move.l (8,%a6), %d1
; CHECK-NEXT:    add.l #7, %d1
; CHECK-NEXT:    and.l #-8, %d1
; CHECK-NEXT:    move.l %sp, %d0
; CHECK-NEXT:    sub.l %d1, %d0
; CHECK-NEXT:    and.l #-128, %d0
; CHECK-NEXT:    move.l %d0, %sp
; CHECK-NEXT:    movem.l (116,%a4), %a4 ; 8-byte Folded Reload
; CHECK-NEXT:    move.l %a6, %sp
; CHECK-NEXT:    move.l (%sp)+, %a6
; CHECK-NEXT:    rts
  %A = alloca i8, i32 %Size, align 128
  %A_addr = ptrtoint i8* %A to i32
  ret i32 %A_addr
}