mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-05 13:26:55 +00:00
Add numeric extend, trunctate to mips fast-isel
Summary: Add numeric extend, trunctate to mips fast-isel Reactivates D4827 Test Plan: fpext.ll loadstoreconv.ll Reviewers: dsanders Subscribers: mcrosier Differential Revision: http://reviews.llvm.org/D5251 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218681 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
21
test/CodeGen/Mips/Fast-ISel/fpext.ll
Normal file
21
test/CodeGen/Mips/Fast-ISel/fpext.ll
Normal file
@@ -0,0 +1,21 @@
|
||||
; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort -mcpu=mips32r2 \
|
||||
; RUN: < %s | FileCheck %s
|
||||
; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort -mcpu=mips32 \
|
||||
; RUN: < %s | FileCheck %s
|
||||
|
||||
@f = global float 0x40147E6B80000000, align 4
|
||||
@d_f = common global double 0.000000e+00, align 8
|
||||
@.str = private unnamed_addr constant [6 x i8] c"%f \0A\00", align 1
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @dv() #0 {
|
||||
entry:
|
||||
%0 = load float* @f, align 4
|
||||
%conv = fpext float %0 to double
|
||||
; CHECK: cvt.d.s $f{{[0-9]+}}, $f{{[0-9]+}}
|
||||
store double %conv, double* @d_f, align 8
|
||||
ret void
|
||||
}
|
||||
|
||||
|
||||
attributes #1 = { nounwind }
|
179
test/CodeGen/Mips/Fast-ISel/loadstoreconv.ll
Normal file
179
test/CodeGen/Mips/Fast-ISel/loadstoreconv.ll
Normal file
@@ -0,0 +1,179 @@
|
||||
; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort -mcpu=mips32r2 \
|
||||
; RUN: < %s | FileCheck %s
|
||||
; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort -mcpu=mips32 \
|
||||
; RUN: < %s | FileCheck %s
|
||||
; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort -mcpu=mips32r2 \
|
||||
; RUN: < %s | FileCheck %s -check-prefix=mips32r2
|
||||
; RUN: llc -march=mipsel -relocation-model=pic -O0 -mips-fast-isel -fast-isel-abort -mcpu=mips32 \
|
||||
; RUN: < %s | FileCheck %s -check-prefix=mips32
|
||||
|
||||
@b2 = global i8 0, align 1
|
||||
@b1 = global i8 1, align 1
|
||||
@uc1 = global i8 0, align 1
|
||||
@uc2 = global i8 -1, align 1
|
||||
@sc1 = global i8 -128, align 1
|
||||
@sc2 = global i8 127, align 1
|
||||
@ss1 = global i16 -32768, align 2
|
||||
@ss2 = global i16 32767, align 2
|
||||
@us1 = global i16 0, align 2
|
||||
@us2 = global i16 -1, align 2
|
||||
@ssi = global i16 0, align 2
|
||||
@ssj = global i16 0, align 2
|
||||
@i = global i32 0, align 4
|
||||
@j = global i32 0, align 4
|
||||
@.str = private unnamed_addr constant [4 x i8] c"%i\0A\00", align 1
|
||||
@.str1 = private unnamed_addr constant [7 x i8] c"%i %i\0A\00", align 1
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z3b_iv() {
|
||||
entry:
|
||||
; CHECK-LABEL: .ent _Z3b_iv
|
||||
%0 = load i8* @b1, align 1
|
||||
%tobool = trunc i8 %0 to i1
|
||||
%frombool = zext i1 %tobool to i8
|
||||
store i8 %frombool, i8* @b2, align 1
|
||||
%1 = load i8* @b2, align 1
|
||||
%tobool1 = trunc i8 %1 to i1
|
||||
%conv = zext i1 %tobool1 to i32
|
||||
store i32 %conv, i32* @i, align 4
|
||||
; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; CHECK: andi $[[REG2:[0-9]+]], $[[REG1]], 1
|
||||
; CHECK: sb $[[REG2]], 0(${{[0-9]+}})
|
||||
|
||||
|
||||
|
||||
ret void
|
||||
; CHECK: .end _Z3b_iv
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z4uc_iv() {
|
||||
entry:
|
||||
; CHECK-LABEL: .ent _Z4uc_iv
|
||||
|
||||
%0 = load i8* @uc1, align 1
|
||||
%conv = zext i8 %0 to i32
|
||||
store i32 %conv, i32* @i, align 4
|
||||
%1 = load i8* @uc2, align 1
|
||||
%conv1 = zext i8 %1 to i32
|
||||
; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; CHECK: andi ${{[0-9]+}}, $[[REG1]], 255
|
||||
|
||||
store i32 %conv1, i32* @j, align 4
|
||||
ret void
|
||||
; CHECK: .end _Z4uc_iv
|
||||
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z4sc_iv() {
|
||||
entry:
|
||||
; mips32r2-LABEL: .ent _Z4sc_iv
|
||||
; mips32-LABEL: .ent _Z4sc_iv
|
||||
|
||||
%0 = load i8* @sc1, align 1
|
||||
%conv = sext i8 %0 to i32
|
||||
store i32 %conv, i32* @i, align 4
|
||||
%1 = load i8* @sc2, align 1
|
||||
%conv1 = sext i8 %1 to i32
|
||||
store i32 %conv1, i32* @j, align 4
|
||||
; mips32r2: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; mips32r2: seb ${{[0-9]+}}, $[[REG1]]
|
||||
; mips32: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; mips32: sll $[[REG2:[0-9]+]], $[[REG1]], 24
|
||||
; mips32: sra ${{[0-9]+}}, $[[REG2]], 24
|
||||
|
||||
ret void
|
||||
; CHECK: .end _Z4sc_iv
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z4us_iv() {
|
||||
entry:
|
||||
; CHECK-LABEL: .ent _Z4us_iv
|
||||
%0 = load i16* @us1, align 2
|
||||
%conv = zext i16 %0 to i32
|
||||
store i32 %conv, i32* @i, align 4
|
||||
%1 = load i16* @us2, align 2
|
||||
%conv1 = zext i16 %1 to i32
|
||||
store i32 %conv1, i32* @j, align 4
|
||||
ret void
|
||||
; CHECK: lhu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; CHECK: andi ${{[0-9]+}}, $[[REG1]], 65535
|
||||
; CHECK: .end _Z4us_iv
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z4ss_iv() {
|
||||
entry:
|
||||
; mips32r2-LABEL: .ent _Z4ss_iv
|
||||
; mips32=LABEL: .ent _Z4ss_iv
|
||||
|
||||
%0 = load i16* @ss1, align 2
|
||||
%conv = sext i16 %0 to i32
|
||||
store i32 %conv, i32* @i, align 4
|
||||
%1 = load i16* @ss2, align 2
|
||||
%conv1 = sext i16 %1 to i32
|
||||
store i32 %conv1, i32* @j, align 4
|
||||
; mips32r2: lhu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; mips32r2: seh ${{[0-9]+}}, $[[REG1]]
|
||||
; mips32: lhu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; mips32: sll $[[REG2:[0-9]+]], $[[REG1]], 16
|
||||
; mips32: sra ${{[0-9]+}}, $[[REG2]], 16
|
||||
|
||||
ret void
|
||||
; CHECK: .end _Z4ss_iv
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z4b_ssv() {
|
||||
entry:
|
||||
; CHECK-LABEL: .ent _Z4b_ssv
|
||||
%0 = load i8* @b2, align 1
|
||||
%tobool = trunc i8 %0 to i1
|
||||
%conv = zext i1 %tobool to i16
|
||||
store i16 %conv, i16* @ssi, align 2
|
||||
ret void
|
||||
; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; CHECK: andi ${{[0-9]+}}, $[[REG1]], 1
|
||||
; CHECK: .end _Z4b_ssv
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z5uc_ssv() {
|
||||
entry:
|
||||
; CHECK-LABEL: .ent _Z5uc_ssv
|
||||
%0 = load i8* @uc1, align 1
|
||||
%conv = zext i8 %0 to i16
|
||||
store i16 %conv, i16* @ssi, align 2
|
||||
%1 = load i8* @uc2, align 1
|
||||
%conv1 = zext i8 %1 to i16
|
||||
; CHECK: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; CHECK: andi ${{[0-9]+}}, $[[REG1]], 255
|
||||
|
||||
store i16 %conv1, i16* @ssj, align 2
|
||||
ret void
|
||||
; CHECK: .end _Z5uc_ssv
|
||||
}
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define void @_Z5sc_ssv() {
|
||||
entry:
|
||||
; mips32r2-LABEL: .ent _Z5sc_ssv
|
||||
; mips32-LABEL: .ent _Z5sc_ssv
|
||||
%0 = load i8* @sc1, align 1
|
||||
%conv = sext i8 %0 to i16
|
||||
store i16 %conv, i16* @ssi, align 2
|
||||
%1 = load i8* @sc2, align 1
|
||||
%conv1 = sext i8 %1 to i16
|
||||
store i16 %conv1, i16* @ssj, align 2
|
||||
; mips32r2: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; mips32r2: seb ${{[0-9]+}}, $[[REG1]]
|
||||
; mips32: lbu $[[REG1:[0-9]+]], 0(${{[0-9]+}})
|
||||
; mips32: sll $[[REG2:[0-9]+]], $[[REG1]], 24
|
||||
; mips32: sra ${{[0-9]+}}, $[[REG2]], 24
|
||||
|
||||
ret void
|
||||
; CHECK: .end _Z5sc_ssv
|
||||
}
|
||||
|
Reference in New Issue
Block a user