#![allow(non_camel_case_types)] // SPARC registers #[repr(C)] #[derive(PartialEq, Debug, Clone, Copy)] #[allow(clippy::upper_case_acronyms)] pub enum RegisterSPARC { INVALID = 0, F0 = 1, F1 = 2, F2 = 3, F3 = 4, F4 = 5, F5 = 6, F6 = 7, F7 = 8, F8 = 9, F9 = 10, F10 = 11, F11 = 12, F12 = 13, F13 = 14, F14 = 15, F15 = 16, F16 = 17, F17 = 18, F18 = 19, F19 = 20, F20 = 21, F21 = 22, F22 = 23, F23 = 24, F24 = 25, F25 = 26, F26 = 27, F27 = 28, F28 = 29, F29 = 30, F30 = 31, F31 = 32, F32 = 33, F34 = 34, F36 = 35, F38 = 36, F40 = 37, F42 = 38, F44 = 39, F46 = 40, F48 = 41, F50 = 42, F52 = 43, F54 = 44, F56 = 45, F58 = 46, F60 = 47, F62 = 48, FCC0 = 49, FCC1 = 50, FCC2 = 51, FCC3 = 52, G0 = 53, G1 = 54, G2 = 55, G3 = 56, G4 = 57, G5 = 58, G6 = 59, G7 = 60, I0 = 61, I1 = 62, I2 = 63, I3 = 64, I4 = 65, I5 = 66, FP = 67, I7 = 68, ICC = 69, L0 = 70, L1 = 71, L2 = 72, L3 = 73, L4 = 74, L5 = 75, L6 = 76, L7 = 77, O0 = 78, O1 = 79, O2 = 80, O3 = 81, O4 = 82, O5 = 83, SP = 84, O7 = 85, Y = 86, XCC = 87, PC = 88, ENDING = 89, } impl RegisterSPARC { // alias registers // (assoc) O6 = 84, // (assoc) I6 = 67, pub const O6: RegisterSPARC = RegisterSPARC::SP; pub const I6: RegisterSPARC = RegisterSPARC::FP; } impl From for i32 { fn from(r: RegisterSPARC) -> Self { r as i32 } } #[repr(i32)] #[derive(Debug, Copy, Clone, PartialEq, Eq)] pub enum Sparc32CpuModel { UC_CPU_SPARC32_FUJITSU_MB86904 = 0, UC_CPU_SPARC32_FUJITSU_MB86907, UC_CPU_SPARC32_TI_MICROSPARC_I, UC_CPU_SPARC32_TI_MICROSPARC_II, UC_CPU_SPARC32_TI_MICROSPARC_IIEP, UC_CPU_SPARC32_TI_SUPERSPARC_40, UC_CPU_SPARC32_TI_SUPERSPARC_50, UC_CPU_SPARC32_TI_SUPERSPARC_51, UC_CPU_SPARC32_TI_SUPERSPARC_60, UC_CPU_SPARC32_TI_SUPERSPARC_61, UC_CPU_SPARC32_TI_SUPERSPARC_II, UC_CPU_SPARC32_LEON2, UC_CPU_SPARC32_LEON3, } impl From for i32 { fn from(value: Sparc32CpuModel) -> Self { value as i32 } } impl From<&Sparc32CpuModel> for i32 { fn from(value: &Sparc32CpuModel) -> Self { (*value) as i32 } } #[repr(i32)] #[derive(Debug, Copy, Clone, PartialEq, Eq)] pub enum Sparc64CpuModel { UC_CPU_SPARC64_FUJITSU = 0, UC_CPU_SPARC64_FUJITSU_III, UC_CPU_SPARC64_FUJITSU_IV, UC_CPU_SPARC64_FUJITSU_V, UC_CPU_SPARC64_TI_ULTRASPARC_I, UC_CPU_SPARC64_TI_ULTRASPARC_II, UC_CPU_SPARC64_TI_ULTRASPARC_III, UC_CPU_SPARC64_TI_ULTRASPARC_IIE, UC_CPU_SPARC64_SUN_ULTRASPARC_III, UC_CPU_SPARC64_SUN_ULTRASPARC_III_CU, UC_CPU_SPARC64_SUN_ULTRASPARC_IIII, UC_CPU_SPARC64_SUN_ULTRASPARC_IV, UC_CPU_SPARC64_SUN_ULTRASPARC_IV_PLUS, UC_CPU_SPARC64_SUN_ULTRASPARC_IIII_PLUS, UC_CPU_SPARC64_SUN_ULTRASPARC_T1, UC_CPU_SPARC64_SUN_ULTRASPARC_T2, UC_CPU_SPARC64_NEC_ULTRASPARC_I, } impl From for i32 { fn from(value: Sparc64CpuModel) -> Self { value as i32 } } impl From<&Sparc64CpuModel> for i32 { fn from(value: &Sparc64CpuModel) -> Self { (*value) as i32 } }