Mercurial > hg > CbC > CbC_llvm
comparison test/CodeGen/X86/2008-09-18-inline-asm-2.ll @ 95:afa8332a0e37 LLVM3.8
LLVM 3.8
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 13 Oct 2015 17:48:58 +0900 |
parents | 54457678186b |
children | 803732b1fca8 |
comparison
equal
deleted
inserted
replaced
84:f3e34b893a5f | 95:afa8332a0e37 |
---|---|
30 target triple = "i386-apple-darwin8" | 30 target triple = "i386-apple-darwin8" |
31 %struct.foo = type { i32, i32, i8* } | 31 %struct.foo = type { i32, i32, i8* } |
32 | 32 |
33 define i32 @get(%struct.foo* %c, i8* %state) nounwind { | 33 define i32 @get(%struct.foo* %c, i8* %state) nounwind { |
34 entry: | 34 entry: |
35 %0 = getelementptr %struct.foo* %c, i32 0, i32 0 ; <i32*> [#uses=2] | 35 %0 = getelementptr %struct.foo, %struct.foo* %c, i32 0, i32 0 ; <i32*> [#uses=2] |
36 %1 = getelementptr %struct.foo* %c, i32 0, i32 1 ; <i32*> [#uses=2] | 36 %1 = getelementptr %struct.foo, %struct.foo* %c, i32 0, i32 1 ; <i32*> [#uses=2] |
37 %2 = getelementptr %struct.foo* %c, i32 0, i32 2 ; <i8**> [#uses=2] | 37 %2 = getelementptr %struct.foo, %struct.foo* %c, i32 0, i32 2 ; <i8**> [#uses=2] |
38 %3 = load i32* %0, align 4 ; <i32> [#uses=1] | 38 %3 = load i32, i32* %0, align 4 ; <i32> [#uses=1] |
39 %4 = load i32* %1, align 4 ; <i32> [#uses=1] | 39 %4 = load i32, i32* %1, align 4 ; <i32> [#uses=1] |
40 %5 = load i8* %state, align 1 ; <i8> [#uses=1] | 40 %5 = load i8, i8* %state, align 1 ; <i8> [#uses=1] |
41 %asmtmp = tail call { i32, i32, i32, i32 } asm sideeffect "#1st=$0 $1 2nd=$1 $2 3rd=$2 $4 5th=$4 $3=4th 1$0 1%eXx 5$4 5%eXx 6th=$5", "=&r,=r,=r,=*m,=&q,=*imr,1,2,*m,5,~{dirflag},~{fpsr},~{flags},~{cx}"(i8** %2, i8* %state, i32 %3, i32 %4, i8** %2, i8 %5) nounwind ; <{ i32, i32, i32, i32 }> [#uses=3] | 41 %asmtmp = tail call { i32, i32, i32, i32 } asm sideeffect "#1st=$0 $1 2nd=$1 $2 3rd=$2 $4 5th=$4 $3=4th 1$0 1%eXx 5$4 5%eXx 6th=$5", "=&r,=r,=r,=*m,=&q,=*imr,1,2,*m,5,~{dirflag},~{fpsr},~{flags},~{cx}"(i8** %2, i8* %state, i32 %3, i32 %4, i8** %2, i8 %5) nounwind ; <{ i32, i32, i32, i32 }> [#uses=3] |
42 %asmresult = extractvalue { i32, i32, i32, i32 } %asmtmp, 0 ; <i32> [#uses=1] | 42 %asmresult = extractvalue { i32, i32, i32, i32 } %asmtmp, 0 ; <i32> [#uses=1] |
43 %asmresult1 = extractvalue { i32, i32, i32, i32 } %asmtmp, 1 ; <i32> [#uses=1] | 43 %asmresult1 = extractvalue { i32, i32, i32, i32 } %asmtmp, 1 ; <i32> [#uses=1] |
44 store i32 %asmresult1, i32* %0 | 44 store i32 %asmresult1, i32* %0 |
45 %asmresult2 = extractvalue { i32, i32, i32, i32 } %asmtmp, 2 ; <i32> [#uses=1] | 45 %asmresult2 = extractvalue { i32, i32, i32, i32 } %asmtmp, 2 ; <i32> [#uses=1] |