29 lines
788 B
LLVM
29 lines
788 B
LLVM
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
||
|
; RUN: llc < %s -mtriple=i686-linux | FileCheck %s --check-prefix=X86
|
||
|
; RUN: llc < %s -mtriple=x86_64-linux | FileCheck %s --check-prefix=X64
|
||
|
|
||
|
define i32 @main() nounwind {
|
||
|
; X86-LABEL: main:
|
||
|
; X86: # %bb.0: # %entry
|
||
|
; X86-NEXT: pushl %eax
|
||
|
; X86-NEXT: movl $1, (%esp)
|
||
|
; X86-NEXT: movl $1, %eax
|
||
|
; X86-NEXT: popl %ecx
|
||
|
; X86-NEXT: retl
|
||
|
;
|
||
|
; X64-LABEL: main:
|
||
|
; X64: # %bb.0: # %entry
|
||
|
; X64-NEXT: movl $1, -{{[0-9]+}}(%rsp)
|
||
|
; X64-NEXT: movl $1, %eax
|
||
|
; X64-NEXT: retq
|
||
|
entry:
|
||
|
%a = alloca i32, align 4
|
||
|
store i32 1, i32* %a, align 4
|
||
|
%0 = load i32, i32* %a, align 4
|
||
|
%or = or i32 1, %0
|
||
|
%and = and i32 1, %or
|
||
|
%rem = urem i32 %and, 1
|
||
|
%add = add i32 %rem, 1
|
||
|
ret i32 %add
|
||
|
}
|