mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-26 07:34:06 +00:00
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:
parent
f09733a876
commit
190144293d
18
test/LiveVar/Makefile
Normal file
18
test/LiveVar/Makefile
Normal 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
32
test/LiveVar/loops.ll
Normal 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
202
test/LiveVar/loops.out
Normal 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
30
test/LiveVar/phiuse.ll
Normal 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
143
test/LiveVar/phiuse.out
Normal 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
|
Loading…
x
Reference in New Issue
Block a user