summaryrefslogtreecommitdiff
path: root/test/FrontendC/2010-05-18-asmsched.c
blob: ca7625f41f2b5ce1c6270a814cc0dc8c5e3d9f6e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// RUN: %llvmgcc %s -S -O3 -o - | llc -march=x86-64 -mtriple=x86_64-apple-darwin | FileCheck %s
// r9 used to be clobbered before its value was moved to r10.  7993104.

void foo(int x, int y) {
// CHECK: bar
// CHECK-NOT: {{, %r9$}}
// CHECK: movq  %r9,
// CHECK: movq  {{.*}}, %r9
// CHECK: bar
  register int lr9 asm("r9") = x;
  register int lr10 asm("r10") = y;
  int foo;
  asm volatile("bar" : "=r"(lr9) : "r"(lr9), "r"(lr10));
  foo = lr9;
  lr9 = x;
  lr10 = foo;
  asm volatile("bar" : "=r"(lr9) : "r"(lr9), "r"(lr10));
}