asmkit/x86/features/SMX.rs
1use crate::x86::assembler::*;
2use crate::x86::operands::*;
3use super::super::opcodes::*;
4use crate::core::emitter::*;
5use crate::core::operand::*;
6
7/// A dummy operand that represents no register. Here just for simplicity.
8const NOREG: Operand = Operand::new();
9
10/// `GETSEC`.
11///
12/// Supported operand variants:
13///
14/// ```text
15/// +---+----------+
16/// | # | Operands |
17/// +---+----------+
18/// | 1 | (none) |
19/// +---+----------+
20/// ```
21pub trait GetsecEmitter {
22 fn getsec(&mut self);
23}
24
25impl<'a> GetsecEmitter for Assembler<'a> {
26 fn getsec(&mut self) {
27 self.emit(GETSEC, &NOREG, &NOREG, &NOREG, &NOREG);
28 }
29}
30
31
32impl<'a> Assembler<'a> {
33 /// `GETSEC`.
34 ///
35 /// Supported operand variants:
36 ///
37 /// ```text
38 /// +---+----------+
39 /// | # | Operands |
40 /// +---+----------+
41 /// | 1 | (none) |
42 /// +---+----------+
43 /// ```
44 #[inline]
45 pub fn getsec(&mut self)
46 where Assembler<'a>: GetsecEmitter {
47 <Self as GetsecEmitter>::getsec(self);
48 }
49}