Regression tests for live-variable analysis on machine code

generated by llc.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1882 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Vikram S. Adve 2002-03-16 21:42:33 +00:00
parent f09733a876
commit 190144293d
5 changed files with 425 additions and 0 deletions

18
test/LiveVar/Makefile Normal file
View File

@ -0,0 +1,18 @@
# test/Regression/Assembler/Makefile
#
# This directory contains regression tests for the LLVM assembler program.
# These LLVM source file tests are just required to assembler properly to pass.
#
LEVEL = ../../..
include $(LEVEL)/test/Makefile.tests
TESTS := $(wildcard *.ll)
all:: $(addprefix Output/, $(TESTS:%.ll=%.out))
Output/%.out: %.ll $(LLC) Output/.dir
@echo "======== Testing live variables for $<"
$(LAS) < $< | $(LLC) -f -dlivevar i -o /dev/null 1> $@ 2>&1
diff $@ . > /dev/null 2>& 1 || \
( rm -f $@; $(FAILURE) $@ )

32
test/LiveVar/loops.ll Normal file
View File

@ -0,0 +1,32 @@
implementation
;; Test live variable analysis:
;; -- a simple nested loop
;; -- a function call with arguments and return value
int "LoopTest"(int %i, int %j)
begin
Start:
%j1 = add int 0, 0
br label %L1Header
L1Header:
%j2 = phi int [%j1, %Start], [%j3, %L2Done]
%i1 = add int 0, 0 ; %i1 = 0
br label %L2Body
L2Body:
%wl = phi int [%j, %L1Header], [%wl, %L2Body] ;; Useless PHI
%i2 = phi int [%i1, %L1Header], [%i3, %L2Body]
%i3 = add int %i2, 1
%L2Done = seteq int %i3, 10
br bool %L2Done, label %L2Done, label %L2Body
L2Done:
%j3 = add int %j2, %i3
%L1Done = seteq int %j3, 100
br bool %L1Done, label %L1Done, label %L1Header
L1Done:
%recurse = call int %LoopTest(int %j3, int %j3)
ret int %recurse
end

202
test/LiveVar/loops.out Normal file
View File

@ -0,0 +1,202 @@
Analysing live variables ...
For BB 0x4c6560(L1Done) :
Defs: 0x4c65a8(recurse) 0x726cf8
In: 0x4c6438(j3)
Out:
For BB 0x4c63f0(L2Done) :
Defs: 0x4c6438(j3) 0x4d8120 0x4ddf98 0x727280(PhiCp:)
In: 0x4d6478(i3) 0x5ab290(j2)
Out:
For BB 0x5ab450(L2Body) :
Defs: 0x4d6398(i2) 0x4d6478(i3) 0x5ab498(wl) 0x726f20 0x726ff8 0x7271c0
In: 0x727388(PhiCp:) 0x727490(PhiCp:)
Out:
For BB 0x4d82a0(L1Header) :
Defs: 0x5ab290(j2) 0x5ab370(i1) 0x727388(PhiCp:) 0x727490(PhiCp:)
In: 0x5414e0(j) 0x727280(PhiCp:)
Out:
For BB 0x501700(Start) :
Defs: 0x501748(j1) 0x727280(PhiCp:)
In:
Out:
After Backward Pass 0...
For BB L1Done:
In: 0x4c6438(j3)
Out:
For BB L2Done:
In: 0x4d6478(i3) 0x5ab290(j2)
Out: 0x4c6438(j3)
For BB L2Body:
In: 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Out: 0x4d6478(i3) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
For BB L1Header:
In: 0x5414e0(j) 0x727280(PhiCp:)
Out: 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
For BB Start:
In: 0x5414e0(j)
Out: 0x5414e0(j) 0x727280(PhiCp:)
After Backward Pass 1...
For BB L1Done:
In: 0x4c6438(j3)
Out:
For BB L2Done:
In: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2)
Out: 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
For BB L2Body:
In: 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Out: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
For BB L1Header:
In: 0x5414e0(j) 0x727280(PhiCp:)
Out: 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
For BB Start:
In: 0x5414e0(j)
Out: 0x5414e0(j) 0x727280(PhiCp:)
Live Variable Analysis complete!
======For BB Start: Live var sets for instructions======
Live var sets before/after instruction nop
Before: 0x5414e0(j) 0x727280(PhiCp:)
After : 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction ba %ccreg(val 0x0) %disp(label L1Header)
Before: 0x5414e0(j) 0x727280(PhiCp:)
After : 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction add %reg(val j1) %reg(23) %reg(val PhiCp:)*
Before: 0x501748(j1) 0x5414e0(j)
After : 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction add %reg(23) %reg(23) %reg(val j1)*
Before: 0x5414e0(j)
After : 0x501748(j1) 0x5414e0(j)
======For BB L1Header: Live var sets for instructions======
Live var sets before/after instruction nop
Before: 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
After : 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction ba %ccreg(val 0x0) %disp(label L2Body)
Before: 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
After : 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction add %reg(val i1) %reg(23) %reg(val PhiCp:)*
Before: 0x5414e0(j) 0x5ab290(j2) 0x5ab370(i1) 0x727388(PhiCp:)
After : 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction add %reg(val j) %reg(23) %reg(val PhiCp:)*
Before: 0x5414e0(j) 0x5ab290(j2) 0x5ab370(i1)
After : 0x5414e0(j) 0x5ab290(j2) 0x5ab370(i1) 0x727388(PhiCp:)
Live var sets before/after instruction add %reg(23) %reg(23) %reg(val i1)*
Before: 0x5414e0(j) 0x5ab290(j2)
After : 0x5414e0(j) 0x5ab290(j2) 0x5ab370(i1)
Live var sets before/after instruction add %reg(val PhiCp:) %reg(23) %reg(val j2)*
Before: 0x5414e0(j) 0x727280(PhiCp:)
After : 0x5414e0(j) 0x5ab290(j2)
======For BB L2Body: Live var sets for instructions======
Live var sets before/after instruction nop
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction ba %ccreg(val 0x0) %disp(label L2Body)
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction nop
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction be %ccreg(val 0x726ff8) %disp(label L2Done)
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x726ff8 0x727388(PhiCp:) 0x727490(PhiCp:)
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction add %reg(val i3) %reg(23) %reg(val PhiCp:)*
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x726ff8 0x727388(PhiCp:)
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x726ff8 0x727388(PhiCp:) 0x727490(PhiCp:)
Live var sets before/after instruction add %reg(val wl) %reg(23) %reg(val PhiCp:)*
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl) 0x726ff8
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x726ff8 0x727388(PhiCp:)
Live var sets before/after instruction subcc %reg(val i3) %reg(val 0x7271c0) %reg(23)* %ccreg(val 0x726ff8)*
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl) 0x7271c0
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl) 0x726ff8
Live var sets before/after instruction setsw 10 %reg(val 0x7271c0)*
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl)
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl) 0x7271c0
Live var sets before/after instruction add %reg(val i2) %reg(val 0x726f20) %reg(val i3)*
Before: 0x4d6398(i2) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl) 0x726f20
After : 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl)
Live var sets before/after instruction setsw 1 %reg(val 0x726f20)*
Before: 0x4d6398(i2) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl)
After : 0x4d6398(i2) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl) 0x726f20
Live var sets before/after instruction add %reg(val PhiCp:) %reg(23) %reg(val wl)*
Before: 0x4d6398(i2) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:)
After : 0x4d6398(i2) 0x5414e0(j) 0x5ab290(j2) 0x5ab498(wl)
Live var sets before/after instruction add %reg(val PhiCp:) %reg(23) %reg(val i2)*
Before: 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:) 0x727490(PhiCp:)
After : 0x4d6398(i2) 0x5414e0(j) 0x5ab290(j2) 0x727388(PhiCp:)
======For BB L2Done: Live var sets for instructions======
Live var sets before/after instruction nop
Before: 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
After : 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction ba %ccreg(val 0x0) %disp(label L1Header)
Before: 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
After : 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction nop
Before: 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
After : 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction be %ccreg(val 0x4ddf98) %disp(label L1Done)
Before: 0x4c6438(j3) 0x4ddf98 0x5414e0(j) 0x727280(PhiCp:)
After : 0x4c6438(j3) 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction add %reg(val j3) %reg(23) %reg(val PhiCp:)*
Before: 0x4c6438(j3) 0x4ddf98 0x5414e0(j)
After : 0x4c6438(j3) 0x4ddf98 0x5414e0(j) 0x727280(PhiCp:)
Live var sets before/after instruction subcc %reg(val j3) %reg(val 0x4d8120) %reg(23)* %ccreg(val 0x4ddf98)*
Before: 0x4c6438(j3) 0x4d8120 0x5414e0(j)
After : 0x4c6438(j3) 0x4ddf98 0x5414e0(j)
Live var sets before/after instruction setsw 100 %reg(val 0x4d8120)*
Before: 0x4c6438(j3) 0x5414e0(j)
After : 0x4c6438(j3) 0x4d8120 0x5414e0(j)
Live var sets before/after instruction add %reg(val j2) %reg(val i3) %reg(val j3)*
Before: 0x4d6478(i3) 0x5414e0(j) 0x5ab290(j2)
After : 0x4c6438(j3) 0x5414e0(j)
======For BB L1Done: Live var sets for instructions======
Live var sets before/after instruction nop
Before:
After :
Live var sets before/after instruction jmpl %reg(22)* 8 %reg(23) Implicit:0x4c65a8
Before: 0x4c65a8(recurse)
After :
Live var sets before/after instruction nop
Before: 0x4c65a8(recurse)
After : 0x4c65a8(recurse)
Live var sets before/after instruction call %disp(label LoopTest) Implicit:0x4c6438 0x4c6438 0x4c65a8* 0x726cf8*
Before: 0x4c6438(j3)
After : 0x4c65a8(recurse)

30
test/LiveVar/phiuse.ll Normal file
View File

@ -0,0 +1,30 @@
implementation
;; Test live variable analysis:
;; -- phi argument is also used as first class value
int "PhiTest"(int %i, int %j)
begin
Start:
%i1 = add int %i, %j
br label %L1Header
L1Header:
%i2 = phi int [%i1, %Start], [%i4, %L1Header]
%i3 = add int %i1, 0
%i4 = add int %i2, %i3
%L1Done = setgt int %i4, 10
br bool %L1Done, label %L1Done, label %L1Header
L1Done:
ret int %i4
end
int "main"()
begin
bb0:
%result = call int %PhiTest( int 9, int 17 )
ret int %result
end

143
test/LiveVar/phiuse.out Normal file
View File

@ -0,0 +1,143 @@
Analysing live variables ...
For BB 0x4d6510(L1Done) :
Defs:
In: 0x4d6398(i4)
Out:
For BB 0x5ab408(L1Header) :
Defs: 0x4c6528 0x4d6350(i3) 0x4d6398(i4) 0x4ddf50 0x5ab450(i2)
In: 0x4d8290(i1) 0x726c68(PhiCp:)
Out:
For BB 0x4d8248(Start) :
Defs: 0x4d8290(i1) 0x726c68(PhiCp:)
In: 0x4e4690(j) 0x501658(i)
Out:
After Backward Pass 0...
For BB L1Done:
In: 0x4d6398(i4)
Out:
For BB L1Header:
In: 0x4d8290(i1) 0x726c68(PhiCp:)
Out: 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
For BB Start:
In: 0x4e4690(j) 0x501658(i)
Out: 0x4d8290(i1) 0x726c68(PhiCp:)
After Backward Pass 1...
For BB L1Done:
In: 0x4d6398(i4)
Out:
For BB L1Header:
In: 0x4d8290(i1) 0x726c68(PhiCp:)
Out: 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
For BB Start:
In: 0x4e4690(j) 0x501658(i)
Out: 0x4d8290(i1) 0x726c68(PhiCp:)
Live Variable Analysis complete!
======For BB Start: Live var sets for instructions======
Live var sets before/after instruction nop
Before: 0x4d8290(i1) 0x726c68(PhiCp:)
After : 0x4d8290(i1) 0x726c68(PhiCp:)
Live var sets before/after instruction ba %ccreg(val 0x0) %disp(label L1Header)
Before: 0x4d8290(i1) 0x726c68(PhiCp:)
After : 0x4d8290(i1) 0x726c68(PhiCp:)
Live var sets before/after instruction add %reg(val i1) %reg(23) %reg(val PhiCp:)*
Before: 0x4d8290(i1)
After : 0x4d8290(i1) 0x726c68(PhiCp:)
Live var sets before/after instruction add %reg(val i) %reg(val j) %reg(val i1)*
Before: 0x4e4690(j) 0x501658(i)
After : 0x4d8290(i1)
======For BB L1Header: Live var sets for instructions======
Live var sets before/after instruction nop
Before: 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
After : 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
Live var sets before/after instruction ba %ccreg(val 0x0) %disp(label L1Header)
Before: 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
After : 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
Live var sets before/after instruction nop
Before: 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
After : 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
Live var sets before/after instruction bg %ccreg(val 0x4ddf50) %disp(label L1Done)
Before: 0x4d6398(i4) 0x4d8290(i1) 0x4ddf50 0x726c68(PhiCp:)
After : 0x4d6398(i4) 0x4d8290(i1) 0x726c68(PhiCp:)
Live var sets before/after instruction add %reg(val i4) %reg(23) %reg(val PhiCp:)*
Before: 0x4d6398(i4) 0x4d8290(i1) 0x4ddf50
After : 0x4d6398(i4) 0x4d8290(i1) 0x4ddf50 0x726c68(PhiCp:)
Live var sets before/after instruction subcc %reg(val i4) %reg(val 0x4c6528) %reg(23)* %ccreg(val 0x4ddf50)*
Before: 0x4c6528 0x4d6398(i4) 0x4d8290(i1)
After : 0x4d6398(i4) 0x4d8290(i1) 0x4ddf50
Live var sets before/after instruction setsw 10 %reg(val 0x4c6528)*
Before: 0x4d6398(i4) 0x4d8290(i1)
After : 0x4c6528 0x4d6398(i4) 0x4d8290(i1)
Live var sets before/after instruction add %reg(val i2) %reg(val i3) %reg(val i4)*
Before: 0x4d6350(i3) 0x4d8290(i1) 0x5ab450(i2)
After : 0x4d6398(i4) 0x4d8290(i1)
Live var sets before/after instruction add %reg(val i1) %reg(23) %reg(val i3)*
Before: 0x4d8290(i1) 0x5ab450(i2)
After : 0x4d6350(i3) 0x4d8290(i1) 0x5ab450(i2)
Live var sets before/after instruction add %reg(val PhiCp:) %reg(23) %reg(val i2)*
Before: 0x4d8290(i1) 0x726c68(PhiCp:)
After : 0x4d8290(i1) 0x5ab450(i2)
======For BB L1Done: Live var sets for instructions======
Live var sets before/after instruction nop
Before:
After :
Live var sets before/after instruction jmpl %reg(22)* 8 %reg(23) Implicit:0x4d6398
Before: 0x4d6398(i4)
After :
Analysing live variables ...
For BB 0x5ab498(bb0) :
Defs: 0x4daa90 0x4f2d68 0x4f2df8 0x501768(result)
In:
Out:
After Backward Pass 0...
For BB bb0:
In:
Out:
Live Variable Analysis complete!
======For BB bb0: Live var sets for instructions======
Live var sets before/after instruction nop
Before:
After :
Live var sets before/after instruction jmpl %reg(22)* 8 %reg(23) Implicit:0x501768
Before: 0x501768(result)
After :
Live var sets before/after instruction nop
Before: 0x501768(result)
After : 0x501768(result)
Live var sets before/after instruction call %disp(label PhiTest) Implicit:0x4f2d68 0x4f2df8 0x501768* 0x4daa90*
Before: 0x4f2d68 0x4f2df8
After : 0x501768(result)
Live var sets before/after instruction setsw 17 %reg(val 0x4f2df8)*
Before: 0x4f2d68
After : 0x4f2d68 0x4f2df8
Live var sets before/after instruction setsw 9 %reg(val 0x4f2d68)*
Before:
After : 0x4f2d68