Qiu Chaofan d0f9553ef5 [PowerPC] Enable fast-isel on AIX 64 subtarget
This patch basically enables fast-isel for AIX 64-bit subtarget
(previously enabled only for ELF 64). The initial motivation is to
introduce branch folding to AIX generated code for correct debug
behavior. I also saw some compiling time improvement in a few LLVM
test-suite benchmarks. (toast, dbms, cjpeg, burg, etc.)

Reviewed By: jsji

Differential Revision: https://reviews.llvm.org/D98844
2021-09-03 11:33:45 +08:00

77 lines
1.6 KiB
LLVM

; RUN: llc < %s -O0 -verify-machineinstrs -fast-isel-abort=1 -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 | FileCheck %s --check-prefix=PPC64
; RUN: llc < %s -O0 -verify-machineinstrs -fast-isel-abort=1 -mtriple=powerpc64-ibm-aix-xcoff -mcpu=pwr7 | FileCheck %s --check-prefix=PPC64
; zext
define i32 @zext_8_32(i8 %a) nounwind {
; PPC64: zext_8_32
%r = zext i8 %a to i32
; PPC64: clrlwi {{[0-9]+}}, {{[0-9]+}}, 24
ret i32 %r
}
define i32 @zext_16_32(i16 %a) nounwind {
; PPC64: zext_16_32
%r = zext i16 %a to i32
; PPC64: clrlwi {{[0-9]+}}, {{[0-9]+}}, 16
ret i32 %r
}
define i64 @zext_8_64(i8 %a) nounwind {
; PPC64: zext_8_64
%r = zext i8 %a to i64
; PPC64: clrldi {{[0-9]+}}, {{[0-9]+}}, 56
ret i64 %r
}
define i64 @zext_16_64(i16 %a) nounwind {
; PPC64: zext_16_64
%r = zext i16 %a to i64
; PPC64: clrldi {{[0-9]+}}, {{[0-9]+}}, 48
ret i64 %r
}
define i64 @zext_32_64(i32 %a) nounwind {
; PPC64: zext_32_64
%r = zext i32 %a to i64
; PPC64: clrldi {{[0-9]+}}, {{[0-9]+}}, 32
ret i64 %r
}
; sext
define i32 @sext_8_32(i8 %a) nounwind {
; PPC64: sext_8_32
%r = sext i8 %a to i32
; PPC64: extsb
ret i32 %r
}
define i32 @sext_16_32(i16 %a) nounwind {
; PPC64: sext_16_32
%r = sext i16 %a to i32
; PPC64: extsh
ret i32 %r
}
define i64 @sext_8_64(i8 %a) nounwind {
; PPC64: sext_8_64
%r = sext i8 %a to i64
; PPC64: extsb
ret i64 %r
}
define i64 @sext_16_64(i16 %a) nounwind {
; PPC64: sext_16_64
%r = sext i16 %a to i64
; PPC64: extsh
ret i64 %r
}
define i64 @sext_32_64(i32 %a) nounwind {
; PPC64: sext_32_64
%r = sext i32 %a to i64
; PPC64: extsw
ret i64 %r
}