Chad Rosier | 48a05b9 | 2012-08-08 21:15:52 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 %s -triple x86_64-apple-darwin10 -O0 -fms-extensions -fenable-experimental-ms-inline-asm -w -emit-llvm -o - | FileCheck %s |
Chad Rosier | b64f310 | 2012-08-08 20:37:31 +0000 | [diff] [blame] | 2 | |
| 3 | void t1() { |
| 4 | // CHECK: @t1 |
Chad Rosier | 74896e0 | 2012-08-10 00:00:34 +0000 | [diff] [blame] | 5 | // CHECK: call void asm sideeffect "", "~{dirflag},~{fpsr},~{flags}"() nounwind ia_nsdialect |
Chad Rosier | b64f310 | 2012-08-08 20:37:31 +0000 | [diff] [blame] | 6 | // CHECK: ret void |
| 7 | __asm {} |
| 8 | } |
Chad Rosier | 265f538 | 2012-08-13 20:32:07 +0000 | [diff] [blame] | 9 | |
| 10 | void t2() { |
| 11 | // CHECK: @t2 |
| 12 | // CHECK: call void asm sideeffect "nop\0Anop\0Anop", "~{dirflag},~{fpsr},~{flags}"() nounwind ia_nsdialect |
| 13 | // CHECK: ret void |
| 14 | __asm nop |
| 15 | __asm nop |
| 16 | __asm nop |
| 17 | } |
| 18 | |
| 19 | void t3() { |
| 20 | // CHECK: @t3 |
| 21 | // CHECK: call void asm sideeffect "nop\0Anop\0Anop", "~{dirflag},~{fpsr},~{flags}"() nounwind ia_nsdialect |
| 22 | // CHECK: ret void |
| 23 | __asm nop __asm nop __asm nop |
| 24 | } |
| 25 | |
| 26 | void t4(void) { |
| 27 | // CHECK: @t4 |
| 28 | // CHECK: call void asm sideeffect "mov ebx, eax\0Amov ecx, ebx", "~{dirflag},~{fpsr},~{flags}"() nounwind ia_nsdialect |
| 29 | // CHECK: ret void |
| 30 | __asm mov ebx, eax |
| 31 | __asm mov ecx, ebx |
| 32 | } |
| 33 | |
| 34 | void t5(void) { |
| 35 | // CHECK: @t5 |
| 36 | // CHECK: call void asm sideeffect "mov ebx, eax\0Amov ecx, ebx", "~{dirflag},~{fpsr},~{flags}"() nounwind ia_nsdialect |
| 37 | // CHECK: ret void |
| 38 | __asm mov ebx, eax __asm mov ecx, ebx |
| 39 | } |
| 40 | |