2012-11-12 14:42:51 +08:00
|
|
|
// RUN: %clang_cc1 -triple i386-apple-darwin9 -verify %s
|
|
|
|
// <rdar://problem/12415959>
|
|
|
|
|
|
|
|
typedef unsigned int u_int32_t;
|
|
|
|
typedef u_int32_t uint32_t;
|
|
|
|
|
|
|
|
typedef unsigned long long u_int64_t;
|
|
|
|
typedef u_int64_t uint64_t;
|
|
|
|
|
2013-03-23 05:33:46 +08:00
|
|
|
int func1() {
|
2012-11-13 05:13:35 +08:00
|
|
|
// Error out if size is > 32-bits.
|
2012-11-12 14:42:51 +08:00
|
|
|
uint32_t msr = 0x8b;
|
|
|
|
uint64_t val = 0;
|
|
|
|
__asm__ volatile("wrmsr"
|
|
|
|
:
|
|
|
|
: "c" (msr),
|
|
|
|
"a" ((val & 0xFFFFFFFFUL)), // expected-error {{invalid input size for constraint 'a'}}
|
|
|
|
"d" (((val >> 32) & 0xFFFFFFFFUL)));
|
2012-11-13 05:13:35 +08:00
|
|
|
|
|
|
|
// Don't error out if the size of the destination is <= 32 bits.
|
|
|
|
unsigned char data;
|
|
|
|
unsigned int port;
|
|
|
|
__asm__ volatile("outb %0, %w1" : : "a" (data), "Nd" (port)); // No error expected.
|
2012-11-12 14:42:51 +08:00
|
|
|
}
|