Skip to main content

asmkit/x86/features/
PREFETCHI.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/// `PREFETCHIT0`.
11///
12/// Supported operand variants:
13///
14/// ```text
15/// +---+----------+
16/// | # | Operands |
17/// +---+----------+
18/// | 1 | Mem      |
19/// +---+----------+
20/// ```
21pub trait Prefetchit0Emitter<A> {
22    fn prefetchit0(&mut self, op0: A);
23}
24
25impl<'a> Prefetchit0Emitter<Mem> for Assembler<'a> {
26    fn prefetchit0(&mut self, op0: Mem) {
27        self.emit(PREFETCHIT0M, op0.as_operand(), &NOREG, &NOREG, &NOREG);
28    }
29}
30
31/// `PREFETCHIT1`.
32///
33/// Supported operand variants:
34///
35/// ```text
36/// +---+----------+
37/// | # | Operands |
38/// +---+----------+
39/// | 1 | Mem      |
40/// +---+----------+
41/// ```
42pub trait Prefetchit1Emitter<A> {
43    fn prefetchit1(&mut self, op0: A);
44}
45
46impl<'a> Prefetchit1Emitter<Mem> for Assembler<'a> {
47    fn prefetchit1(&mut self, op0: Mem) {
48        self.emit(PREFETCHIT1M, op0.as_operand(), &NOREG, &NOREG, &NOREG);
49    }
50}
51
52
53impl<'a> Assembler<'a> {
54    /// `PREFETCHIT0`.
55    ///
56    /// Supported operand variants:
57    ///
58    /// ```text
59    /// +---+----------+
60    /// | # | Operands |
61    /// +---+----------+
62    /// | 1 | Mem      |
63    /// +---+----------+
64    /// ```
65    #[inline]
66    pub fn prefetchit0<A>(&mut self, op0: A)
67    where Assembler<'a>: Prefetchit0Emitter<A> {
68        <Self as Prefetchit0Emitter<A>>::prefetchit0(self, op0);
69    }
70    /// `PREFETCHIT1`.
71    ///
72    /// Supported operand variants:
73    ///
74    /// ```text
75    /// +---+----------+
76    /// | # | Operands |
77    /// +---+----------+
78    /// | 1 | Mem      |
79    /// +---+----------+
80    /// ```
81    #[inline]
82    pub fn prefetchit1<A>(&mut self, op0: A)
83    where Assembler<'a>: Prefetchit1Emitter<A> {
84        <Self as Prefetchit1Emitter<A>>::prefetchit1(self, op0);
85    }
86}