Mercurial > hg > Members > tobaru > cbc > CbC_llvm
view test/CodeGen/X86/movbe.ll @ 33:e4204d083e25
LLVM 3.5
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 12 Dec 2013 14:32:10 +0900 |
parents | 95c75e76d11b |
children | 54457678186b |
line wrap: on
line source
; RUN: llc -mtriple=x86_64-linux -mcpu=atom < %s | FileCheck %s ; RUN: llc -mtriple=x86_64-linux -mcpu=slm < %s | FileCheck %s -check-prefix=SLM declare i32 @llvm.bswap.i32(i32) nounwind readnone declare i64 @llvm.bswap.i64(i64) nounwind readnone define void @test1(i32* nocapture %x, i32 %y) nounwind { %bswap = call i32 @llvm.bswap.i32(i32 %y) store i32 %bswap, i32* %x, align 4 ret void ; CHECK-LABEL: test1: ; CHECK: movbel %esi, (%rdi) ; SLM-LABEL: test1: ; SLM: movbel %esi, (%rdi) } define i32 @test2(i32* %x) nounwind { %load = load i32* %x, align 4 %bswap = call i32 @llvm.bswap.i32(i32 %load) ret i32 %bswap ; CHECK-LABEL: test2: ; CHECK: movbel (%rdi), %eax ; SLM-LABEL: test2: ; SLM: movbel (%rdi), %eax } define void @test3(i64* %x, i64 %y) nounwind { %bswap = call i64 @llvm.bswap.i64(i64 %y) store i64 %bswap, i64* %x, align 8 ret void ; CHECK-LABEL: test3: ; CHECK: movbeq %rsi, (%rdi) ; SLM-LABEL: test3: ; SLM: movbeq %rsi, (%rdi) } define i64 @test4(i64* %x) nounwind { %load = load i64* %x, align 8 %bswap = call i64 @llvm.bswap.i64(i64 %load) ret i64 %bswap ; CHECK-LABEL: test4: ; CHECK: movbeq (%rdi), %rax ; SLM-LABEL: test4: ; SLM: movbeq (%rdi), %rax }