NAKAMURA Takumi | 512bd57 | 2015-12-15 22:19:00 +0000 | [diff] [blame] | 1 | // REQUIRES: x86-registered-target |
Krzysztof Parzyszek | 6c3b837 | 2015-12-15 19:14:24 +0000 | [diff] [blame] | 2 | |
Michael Zuckerman | 724d02a | 2015-12-15 14:35:51 +0000 | [diff] [blame] | 3 | // RUN: %clang_cc1 -triple x86_64-pc-win32 -fasm-blocks -emit-llvm %s -o - | FileCheck %s |
Michael Zuckerman | 229158c | 2015-12-15 14:04:18 +0000 | [diff] [blame] | 4 | class t1 { |
| 5 | public: |
| 6 | double a; |
| 7 | void runc(); |
| 8 | }; |
| 9 | |
| 10 | class t2 { |
| 11 | public: |
| 12 | double a; |
| 13 | void runc(); |
| 14 | }; |
| 15 | |
NAKAMURA Takumi | db87d5d | 2015-12-15 22:42:28 +0000 | [diff] [blame] | 16 | // CHECK: define void @"\01?runc@t2@@ |
Michael Zuckerman | 229158c | 2015-12-15 14:04:18 +0000 | [diff] [blame] | 17 | void t2::runc() { |
| 18 | double num = 0; |
| 19 | __asm { |
| 20 | mov rax,[this] |
NAKAMURA Takumi | db87d5d | 2015-12-15 22:42:28 +0000 | [diff] [blame] | 21 | // CHECK: [[THIS_ADDR_T2:%.+]] = alloca %class.t2* |
| 22 | // CHECK: [[THIS1_T2:%.+]] = load %class.t2*, %class.t2** [[THIS_ADDR_T2]], |
| 23 | // CHECK: call void asm sideeffect inteldialect "mov rax,qword ptr $1{{.*}}%class.t2* [[THIS1_T2]] |
Michael Zuckerman | 229158c | 2015-12-15 14:04:18 +0000 | [diff] [blame] | 24 | mov rbx,[rax] |
| 25 | mov num, rbx |
| 26 | }; |
| 27 | } |
| 28 | |
NAKAMURA Takumi | db87d5d | 2015-12-15 22:42:28 +0000 | [diff] [blame] | 29 | // CHECK: define void @"\01?runc@t1@@ |
Michael Zuckerman | 229158c | 2015-12-15 14:04:18 +0000 | [diff] [blame] | 30 | void t1::runc() { |
| 31 | double num = 0; |
| 32 | __asm { |
| 33 | mov rax,[this] |
NAKAMURA Takumi | db87d5d | 2015-12-15 22:42:28 +0000 | [diff] [blame] | 34 | // CHECK: [[THIS_ADDR_T1:%.+]] = alloca %class.t1* |
| 35 | // CHECK: [[THIS1_T1:%.+]] = load %class.t1*, %class.t1** [[THIS_ADDR_T1]], |
| 36 | // CHECK: call void asm sideeffect inteldialect "mov rax,qword ptr $1{{.*}}%class.t1* [[THIS1_T1]] |
Michael Zuckerman | 229158c | 2015-12-15 14:04:18 +0000 | [diff] [blame] | 37 | mov rbx,[rax] |
| 38 | mov num, rbx |
| 39 | }; |
| 40 | } |
| 41 | |
| 42 | struct s { |
| 43 | int a; |
NAKAMURA Takumi | db87d5d | 2015-12-15 22:42:28 +0000 | [diff] [blame] | 44 | // CHECK: define linkonce_odr void @"\01?func@s@@ |
Michael Zuckerman | 229158c | 2015-12-15 14:04:18 +0000 | [diff] [blame] | 45 | void func() { |
| 46 | __asm mov rax, [this] |
NAKAMURA Takumi | db87d5d | 2015-12-15 22:42:28 +0000 | [diff] [blame] | 47 | // CHECK: [[THIS_ADDR_S:%.+]] = alloca %struct.s* |
| 48 | // CHECK: [[THIS1_S:%.+]] = load %struct.s*, %struct.s** [[THIS_ADDR_S]], |
| 49 | // CHECK: call void asm sideeffect inteldialect "mov rax, qword ptr $0{{.*}}%struct.s* [[THIS1_S]] |
Michael Zuckerman | 229158c | 2015-12-15 14:04:18 +0000 | [diff] [blame] | 50 | } |
| 51 | } f3; |
| 52 | |
| 53 | int main() { |
| 54 | f3.func(); |
| 55 | f3.a=1; |
| 56 | return 0; |
| 57 | } |