mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-06 05:33:28 +00:00
Fix this test cases to use parameter attributes for its parameter and
result types. These tests are checking for sext behavior and it won't happen unless requested with the parameter attribute. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32828 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
52ab904ee5
commit
2233361a83
@ -1,183 +1,180 @@
|
|||||||
;test all the shifted and signextending adds and subs with and without consts
|
;test all the shifted and signextending adds and subs with and without consts
|
||||||
|
;
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep ' addl' |wc -l |grep 2 &&
|
; RUN: llvm-as < %s | llc -march=alpha -o %t.s -f &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep ' addq' |wc -l |grep 2 &&
|
; RUN: grep ' addl' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep ' subl' |wc -l |grep 2 &&
|
; RUN: grep ' addq' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep ' subq' |wc -l |grep 1 &&
|
; RUN: grep ' subl' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 'lda $0,-100($16)' |wc -l |grep 1 &&
|
; RUN: grep ' subq' %t.s | wc -l | grep 1 &&
|
||||||
|
;
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's4addl' |wc -l |grep 2 &&
|
; RUN: grep 'lda $0,-100($16)' %t.s | wc -l | grep 1 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's8addl' |wc -l |grep 2 &&
|
; RUN: grep 's4addl' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's4addq' |wc -l |grep 2 &&
|
; RUN: grep 's8addl' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's8addq' |wc -l |grep 2 &&
|
; RUN: grep 's4addq' %t.s | wc -l | grep 2 &&
|
||||||
|
; RUN: grep 's8addq' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's4subl' |wc -l |grep 2 &&
|
;
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's8subl' |wc -l |grep 2 &&
|
; RUN: grep 's4subl' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's4subq' |wc -l |grep 2 &&
|
; RUN: grep 's8subl' %t.s | wc -l | grep 2 &&
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep 's8subq' |wc -l |grep 2
|
; RUN: grep 's4subq' %t.s | wc -l | grep 2 &&
|
||||||
|
; RUN: grep 's8subq' %t.s | wc -l | grep 2
|
||||||
|
|
||||||
implementation ; Functions:
|
implementation ; Functions:
|
||||||
|
|
||||||
int %al(int %x, int %y) {
|
define i32 @sext %al(i32 @sext %x.s, i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.3 = add int %y, %x
|
%tmp.3.s = add i32 %y.s, %x.s ; <i32> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
int %ali(int %x) {
|
define i32 @sext %ali(i32 @sext %x.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.3 = add int 100, %x
|
%tmp.3.s = add i32 100, %x.s ; <i32> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %aq(long %x, long %y) {
|
define i64 @sext %aq(i64 @sext %x.s, i64 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.3 = add long %y, %x
|
%tmp.3.s = add i64 %y.s, %x.s ; <i64> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
|
||||||
long %aqi(long %x) {
|
|
||||||
entry:
|
|
||||||
%tmp.3 = add long 100, %x
|
|
||||||
ret long %tmp.3
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int %sl(int %x, int %y) {
|
define i64 %aqi(i64 %x.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.3 = sub int %y, %x
|
%tmp.3.s = add i64 100, %x.s ; <i64> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
int %sli(int %x) {
|
define i32 @sext %sl(i32 @sext %x.s, i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.3 = sub int %x, 100
|
%tmp.3.s = sub i32 %y.s, %x.s ; <i32> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %sq(long %x, long %y) {
|
define i32 @sext %sli(i32 @sext %x.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.3 = sub long %y, %x
|
%tmp.3.s = sub i32 %x.s, 100 ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
|
||||||
long %sqi(long %x) {
|
|
||||||
entry:
|
|
||||||
%tmp.3 = sub long %x, 100
|
|
||||||
ret long %tmp.3
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define i64 %sq(i64 %x.s, i64 %y.s) {
|
||||||
|
|
||||||
int %a4l(int %x, int %y) {
|
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 2
|
%tmp.3.s = sub i64 %y.s, %x.s ; <i64> [#uses=1]
|
||||||
%tmp.3 = add int %tmp.1, %x
|
ret i64 %tmp.3.s
|
||||||
ret int %tmp.3
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int %a8l(int %x, int %y) {
|
define i64 %sqi(i64 %x.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 3
|
%tmp.3.s = sub i64 %x.s, 100 ; <i64> [#uses=1]
|
||||||
%tmp.3 = add int %tmp.1, %x
|
ret i64 %tmp.3.s
|
||||||
ret int %tmp.3
|
|
||||||
}
|
}
|
||||||
|
|
||||||
long %a4q(long %x, long %y) {
|
define i32 @sext %a4l(i32 @sext %x.s, i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 2
|
%tmp.1.s = shl i32 %y.s, i8 2 ; <i32> [#uses=1]
|
||||||
%tmp.3 = add long %tmp.1, %x
|
%tmp.3.s = add i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %a8q(long %x, long %y) {
|
define i32 @sext %a8l(i32 @sext %x.s, i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 3
|
%tmp.1.s = shl i32 %y.s, i8 3 ; <i32> [#uses=1]
|
||||||
%tmp.3 = add long %tmp.1, %x
|
%tmp.3.s = add i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
int %a4li(int %y) {
|
define i64 %a4q(i64 %x.s, i64 %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 2
|
%tmp.1.s = shl i64 %y.s, i8 2 ; <i64> [#uses=1]
|
||||||
%tmp.3 = add int 100, %tmp.1
|
%tmp.3.s = add i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
int %a8li(int %y) {
|
define i64 %a8q(i64 %x.s, i64 %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 3
|
%tmp.1.s = shl i64 %y.s, i8 3 ; <i64> [#uses=1]
|
||||||
%tmp.3 = add int 100, %tmp.1
|
%tmp.3.s = add i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %a4qi(long %y) {
|
define i32 @sext %a4li(i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 2
|
%tmp.1.s = shl i32 %y.s, i8 2 ; <i32> [#uses=1]
|
||||||
%tmp.3 = add long 100, %tmp.1
|
%tmp.3.s = add i32 100, %tmp.1.s ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %a8qi(long %y) {
|
define i32 @sext %a8li(i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 3
|
%tmp.1.s = shl i32 %y.s, i8 3 ; <i32> [#uses=1]
|
||||||
%tmp.3 = add long 100, %tmp.1
|
%tmp.3.s = add i32 100, %tmp.1.s ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define i64 %a4qi(i64 %y.s) {
|
||||||
|
|
||||||
|
|
||||||
int %s4l(int %x, int %y) {
|
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 2
|
%tmp.1.s = shl i64 %y.s, i8 2 ; <i64> [#uses=1]
|
||||||
%tmp.3 = sub int %tmp.1, %x
|
%tmp.3.s = add i64 100, %tmp.1.s ; <i64> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
int %s8l(int %x, int %y) {
|
define i64 %a8qi(i64 %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 3
|
%tmp.1.s = shl i64 %y.s, i8 3 ; <i64> [#uses=1]
|
||||||
%tmp.3 = sub int %tmp.1, %x
|
%tmp.3.s = add i64 100, %tmp.1.s ; <i64> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %s4q(long %x, long %y) {
|
define i32 @sext %s4l(i32 @sext %x.s, i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 2
|
%tmp.1.s = shl i32 %y.s, i8 2 ; <i32> [#uses=1]
|
||||||
%tmp.3 = sub long %tmp.1, %x
|
%tmp.3.s = sub i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %s8q(long %x, long %y) {
|
define i32 @sext %s8l(i32 @sext %x.s, i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 3
|
%tmp.1.s = shl i32 %y.s, i8 3 ; <i32> [#uses=1]
|
||||||
%tmp.3 = sub long %tmp.1, %x
|
%tmp.3.s = sub i32 %tmp.1.s, %x.s ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
int %s4li(int %y) {
|
define i64 %s4q(i64 %x.s, i64 %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 2
|
%tmp.1.s = shl i64 %y.s, i8 2 ; <i64> [#uses=1]
|
||||||
%tmp.3 = sub int %tmp.1, 100
|
%tmp.3.s = sub i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
int %s8li(int %y) {
|
define i64 %s8q(i64 %x.s, i64 %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl int %y, ubyte 3
|
%tmp.1.s = shl i64 %y.s, i8 3 ; <i64> [#uses=1]
|
||||||
%tmp.3 = sub int %tmp.1, 100
|
%tmp.3.s = sub i64 %tmp.1.s, %x.s ; <i64> [#uses=1]
|
||||||
ret int %tmp.3
|
ret i64 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %s4qi(long %y) {
|
define i32 @sext %s4li(i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 2
|
%tmp.1.s = shl i32 %y.s, i8 2 ; <i32> [#uses=1]
|
||||||
%tmp.3 = sub long %tmp.1, 100
|
%tmp.3.s = sub i32 %tmp.1.s, 100 ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
long %s8qi(long %y) {
|
define i32 @sext %s8li(i32 @sext %y.s) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = shl long %y, ubyte 3
|
%tmp.1.s = shl i32 %y.s, i8 3 ; <i32> [#uses=1]
|
||||||
%tmp.3 = sub long %tmp.1, 100
|
%tmp.3.s = sub i32 %tmp.1.s, 100 ; <i32> [#uses=1]
|
||||||
ret long %tmp.3
|
ret i32 %tmp.3.s
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define i64 %s4qi(i64 %y.s) {
|
||||||
|
entry:
|
||||||
|
%tmp.1.s = shl i64 %y.s, i8 2 ; <i64> [#uses=1]
|
||||||
|
%tmp.3.s = sub i64 %tmp.1.s, 100 ; <i64> [#uses=1]
|
||||||
|
ret i64 %tmp.3.s
|
||||||
|
}
|
||||||
|
|
||||||
|
define i64 %s8qi(i64 %y.s) {
|
||||||
|
entry:
|
||||||
|
%tmp.1.s = shl i64 %y.s, i8 3 ; <i64> [#uses=1]
|
||||||
|
%tmp.3.s = sub i64 %tmp.1.s, 100 ; <i64> [#uses=1]
|
||||||
|
ret i64 %tmp.3.s
|
||||||
|
}
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
; Make sure this testcase codegens to the ctpop instruction
|
; Make sure this testcase codegens to the ctpop instruction
|
||||||
; RUN: llvm-upgrade < %s | llvm-as | llc -march=alpha | grep -i 'subl $16,1,$0'
|
; RUN: llvm-as < %s | llc -march=alpha | grep -i 'subl $16,1,$0'
|
||||||
|
|
||||||
implementation ; Functions:
|
implementation ; Functions:
|
||||||
|
|
||||||
int %foo(int %x) {
|
define i32 @sext %foo(i32 @sext %x) {
|
||||||
entry:
|
entry:
|
||||||
%tmp.1 = add int %x, -1 ; <int> [#uses=1]
|
%tmp.1 = add i32 %x, -1 ; <int> [#uses=1]
|
||||||
ret int %tmp.1
|
ret i32 %tmp.1
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user