2020-02-20 09:19:48 +00:00
|
|
|
//@ only-x86_64
|
|
|
|
//@ compile-flags: -C target-feature=+avx2
|
|
|
|
|
2021-12-10 00:15:33 +00:00
|
|
|
use std::arch::asm;
|
2020-02-20 09:19:48 +00:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut foo = 0;
|
|
|
|
let mut bar = 0;
|
|
|
|
unsafe {
|
|
|
|
// Bad register/register class
|
|
|
|
|
|
|
|
asm!("{}", in(foo) foo);
|
|
|
|
//~^ ERROR invalid register class `foo`: unknown register class
|
|
|
|
asm!("", in("foo") foo);
|
|
|
|
//~^ ERROR invalid register `foo`: unknown register
|
|
|
|
asm!("{:z}", in(reg) foo);
|
|
|
|
//~^ ERROR invalid asm template modifier for this register class
|
|
|
|
asm!("{:r}", in(xmm_reg) foo);
|
|
|
|
//~^ ERROR invalid asm template modifier for this register class
|
|
|
|
asm!("{:a}", const 0);
|
|
|
|
//~^ ERROR asm template modifiers are not allowed for `const` arguments
|
|
|
|
asm!("{:a}", sym main);
|
|
|
|
//~^ ERROR asm template modifiers are not allowed for `sym` arguments
|
|
|
|
asm!("", in("ebp") foo);
|
|
|
|
//~^ ERROR invalid register `ebp`: the frame pointer cannot be used as an operand
|
|
|
|
asm!("", in("rsp") foo);
|
|
|
|
//~^ ERROR invalid register `rsp`: the stack pointer cannot be used as an operand
|
|
|
|
asm!("", in("ip") foo);
|
|
|
|
//~^ ERROR invalid register `ip`: the instruction pointer cannot be used as an operand
|
|
|
|
|
2021-06-17 20:00:52 +00:00
|
|
|
asm!("", in("st(2)") foo);
|
|
|
|
//~^ ERROR register class `x87_reg` can only be used as a clobber, not as an input or output
|
2022-04-14 12:07:36 +00:00
|
|
|
//~| ERROR `i32` cannot be used with this register class
|
2021-06-17 20:00:52 +00:00
|
|
|
asm!("", in("mm0") foo);
|
|
|
|
//~^ ERROR register class `mmx_reg` can only be used as a clobber, not as an input or output
|
2022-04-14 12:07:36 +00:00
|
|
|
//~| ERROR `i32` cannot be used with this register class
|
2022-04-06 19:41:12 +00:00
|
|
|
asm!("", in("k0") foo);
|
|
|
|
//~^ ERROR register class `kreg0` can only be used as a clobber, not as an input or output
|
2022-04-14 12:07:36 +00:00
|
|
|
//~| ERROR `i32` cannot be used with this register class
|
2021-06-17 20:00:52 +00:00
|
|
|
asm!("", out("st(2)") _);
|
|
|
|
asm!("", out("mm0") _);
|
|
|
|
asm!("{}", in(x87_reg) foo);
|
|
|
|
//~^ ERROR register class `x87_reg` can only be used as a clobber, not as an input or output
|
2022-04-14 12:07:36 +00:00
|
|
|
//~| ERROR `i32` cannot be used with this register class
|
2021-06-17 20:00:52 +00:00
|
|
|
asm!("{}", in(mmx_reg) foo);
|
|
|
|
//~^ ERROR register class `mmx_reg` can only be used as a clobber, not as an input or output
|
2022-04-14 12:07:36 +00:00
|
|
|
//~| ERROR `i32` cannot be used with this register class
|
2021-06-17 20:00:52 +00:00
|
|
|
asm!("{}", out(x87_reg) _);
|
|
|
|
//~^ ERROR register class `x87_reg` can only be used as a clobber, not as an input or output
|
|
|
|
asm!("{}", out(mmx_reg) _);
|
|
|
|
//~^ ERROR register class `mmx_reg` can only be used as a clobber, not as an input or output
|
|
|
|
|
2020-02-20 09:19:48 +00:00
|
|
|
// Explicit register conflicts
|
|
|
|
// (except in/lateout which don't conflict)
|
|
|
|
|
|
|
|
asm!("", in("eax") foo, in("al") bar);
|
2023-11-28 10:25:22 +00:00
|
|
|
//~^ ERROR register `al` conflicts with register `eax`
|
2022-04-14 12:07:36 +00:00
|
|
|
//~| ERROR `i32` cannot be used with this register class
|
2020-02-20 09:19:48 +00:00
|
|
|
asm!("", in("rax") foo, out("rax") bar);
|
2023-11-28 10:25:22 +00:00
|
|
|
//~^ ERROR register `rax` conflicts with register `rax`
|
2020-02-20 09:19:48 +00:00
|
|
|
asm!("", in("al") foo, lateout("al") bar);
|
2022-04-14 12:07:36 +00:00
|
|
|
//~^ ERROR `i32` cannot be used with this register class
|
|
|
|
//~| ERROR `i32` cannot be used with this register class
|
2020-02-20 09:19:48 +00:00
|
|
|
asm!("", in("xmm0") foo, in("ymm0") bar);
|
|
|
|
//~^ ERROR register `ymm0` conflicts with register `xmm0`
|
|
|
|
asm!("", in("xmm0") foo, out("ymm0") bar);
|
|
|
|
//~^ ERROR register `ymm0` conflicts with register `xmm0`
|
|
|
|
asm!("", in("xmm0") foo, lateout("ymm0") bar);
|
|
|
|
}
|
|
|
|
}
|