Skip to main content

ab_riscv_primitives/instructions/v/
zvexx.rs

1//! ZveXx extension (Vector Extension for Embedded Processors, ELEN=64, integer-only)
2
3#[doc(hidden)]
4pub mod arith;
5#[doc(hidden)]
6pub mod carry;
7#[doc(hidden)]
8pub mod config;
9#[doc(hidden)]
10pub mod fixed_point;
11#[doc(hidden)]
12pub mod load;
13#[doc(hidden)]
14pub mod mask;
15#[doc(hidden)]
16pub mod muldiv;
17#[doc(hidden)]
18pub mod perm;
19#[doc(hidden)]
20pub mod reduction;
21#[doc(hidden)]
22pub mod store;
23#[doc(hidden)]
24pub mod widen_narrow;
25
26use crate::instructions::Instruction;
27use crate::instructions::v::Eew;
28use crate::instructions::v::zvexx::arith::ZveXxArithInstruction;
29use crate::instructions::v::zvexx::carry::ZveXxCarryInstruction;
30use crate::instructions::v::zvexx::config::ZveXxConfigInstruction;
31use crate::instructions::v::zvexx::fixed_point::ZveXxFixedPointInstruction;
32use crate::instructions::v::zvexx::load::{LoadStoreNreg, Nf, SegVmNf, ZveXxLoadInstruction};
33use crate::instructions::v::zvexx::mask::ZveXxMaskInstruction;
34use crate::instructions::v::zvexx::muldiv::ZveXxMulDivInstruction;
35use crate::instructions::v::zvexx::perm::ZveXxPermInstruction;
36use crate::instructions::v::zvexx::reduction::ZveXxReductionInstruction;
37use crate::instructions::v::zvexx::store::ZveXxStoreInstruction;
38use crate::instructions::v::zvexx::widen_narrow::ZveXxWidenNarrowInstruction;
39use crate::instructions::zicsr::ZicsrInstruction;
40use crate::registers::general_purpose::Register;
41use crate::registers::vector::VReg;
42use ab_riscv_macros::instruction;
43use core::fmt;
44
45/// RISC-V ZveXx instruction.
46///
47/// `X` is any legal value, according to the RISC-V specification, for example, Zve32x or Zve64x.
48/// The actual `ELEN` and `VLEN` values are configured at the execution side and do not impact
49/// decoded instructions.
50#[instruction(
51    inherit = [
52        ZveXxConfigInstruction,
53        ZveXxLoadInstruction,
54        ZveXxStoreInstruction,
55        ZveXxArithInstruction,
56        ZveXxCarryInstruction,
57        ZveXxMulDivInstruction,
58        ZveXxWidenNarrowInstruction,
59        ZveXxFixedPointInstruction,
60        ZveXxMaskInstruction,
61        ZveXxReductionInstruction,
62        ZveXxPermInstruction,
63        ZicsrInstruction,
64    ],
65)]
66#[derive(Debug, Clone, Copy, PartialEq, Eq)]
67pub enum ZveXxInstruction<Reg> {}
68
69#[instruction]
70impl<Reg> const Instruction for ZveXxInstruction<Reg>
71where
72    Reg: [const] Register,
73{
74    type Reg = Reg;
75
76    #[inline(always)]
77    fn try_decode(instruction: u32) -> Option<Self> {
78        None
79    }
80
81    #[inline(always)]
82    fn alignment() -> u8 {
83        align_of::<u32>() as u8
84    }
85
86    #[inline(always)]
87    fn size(&self) -> u8 {
88        size_of::<u32>() as u8
89    }
90}
91
92#[instruction]
93impl<Reg> fmt::Display for ZveXxInstruction<Reg>
94where
95    Reg: fmt::Display + Copy,
96{
97    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
98        match self {}
99    }
100}