ab_riscv_primitives/instructions/v/
zve64x.rs1#[doc(hidden)]
4pub mod arith;
5#[doc(hidden)]
6pub mod config;
7#[doc(hidden)]
8pub mod fixed_point;
9#[doc(hidden)]
10pub mod load;
11#[doc(hidden)]
12pub mod mask;
13#[doc(hidden)]
14pub mod muldiv;
15#[doc(hidden)]
16pub mod perm;
17#[doc(hidden)]
18pub mod reduction;
19#[doc(hidden)]
20pub mod store;
21#[doc(hidden)]
22pub mod widen_narrow;
23
24use crate::instructions::Instruction;
25use crate::instructions::v::Eew;
26use crate::instructions::v::zve64x::arith::Zve64xArithInstruction;
27use crate::instructions::v::zve64x::config::Zve64xConfigInstruction;
28use crate::instructions::v::zve64x::fixed_point::Zve64xFixedPointInstruction;
29use crate::instructions::v::zve64x::load::Zve64xLoadInstruction;
30use crate::instructions::v::zve64x::mask::Zve64xMaskInstruction;
31use crate::instructions::v::zve64x::muldiv::Zve64xMulDivInstruction;
32use crate::instructions::v::zve64x::perm::Zve64xPermInstruction;
33use crate::instructions::v::zve64x::reduction::Zve64xReductionInstruction;
34use crate::instructions::v::zve64x::store::Zve64xStoreInstruction;
35use crate::instructions::v::zve64x::widen_narrow::Zve64xWidenNarrowInstruction;
36use crate::instructions::zicsr::ZicsrInstruction;
37use crate::registers::general_purpose::Register;
38use crate::registers::vector::VReg;
39use ab_riscv_macros::instruction;
40use core::fmt;
41
42#[instruction(
44 inherit = [
45 Zve64xConfigInstruction,
46 Zve64xLoadInstruction,
47 Zve64xStoreInstruction,
48 Zve64xArithInstruction,
49 Zve64xMulDivInstruction,
50 Zve64xWidenNarrowInstruction,
51 Zve64xFixedPointInstruction,
52 Zve64xMaskInstruction,
53 Zve64xReductionInstruction,
54 Zve64xPermInstruction,
55 ZicsrInstruction,
56 ],
57)]
58#[derive(Debug, Clone, Copy, PartialEq, Eq)]
59pub enum Zve64xInstruction<Reg> {}
60
61#[instruction]
62impl<Reg> const Instruction for Zve64xInstruction<Reg>
63where
64 Reg: [const] Register,
65{
66 type Reg = Reg;
67
68 #[inline(always)]
69 fn try_decode(instruction: u32) -> Option<Self> {
70 None
71 }
72
73 #[inline(always)]
74 fn alignment() -> u8 {
75 align_of::<u32>() as u8
76 }
77
78 #[inline(always)]
79 fn size(&self) -> u8 {
80 size_of::<u32>() as u8
81 }
82}
83
84#[instruction]
85impl<Reg> fmt::Display for Zve64xInstruction<Reg>
86where
87 Reg: fmt::Display + Copy,
88{
89 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
90 match self {}
91 }
92}