1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
use super::{InlineAsmArch, InlineAsmType}; use rustc_macros::HashStable_Generic; use std::fmt; def_reg_class! { Hexagon HexagonInlineAsmRegClass { reg, } } impl HexagonInlineAsmRegClass { pub fn valid_modifiers(self, _arch: super::InlineAsmArch) -> &'static [char] { &[] } pub fn suggest_class(self, _arch: InlineAsmArch, _ty: InlineAsmType) -> Option<Self> { None } pub fn suggest_modifier( self, _arch: InlineAsmArch, _ty: InlineAsmType, ) -> Option<(char, &'static str)> { None } pub fn default_modifier(self, _arch: InlineAsmArch) -> Option<(char, &'static str)> { None } pub fn supported_types( self, _arch: InlineAsmArch, ) -> &'static [(InlineAsmType, Option<&'static str>)] { match self { Self::reg => types! { _: I8, I16, I32, F32; }, } } } def_regs! { Hexagon HexagonInlineAsmReg HexagonInlineAsmRegClass { r0: reg = ["r0"], r1: reg = ["r1"], r2: reg = ["r2"], r3: reg = ["r3"], r4: reg = ["r4"], r5: reg = ["r5"], r6: reg = ["r6"], r7: reg = ["r7"], r8: reg = ["r8"], r9: reg = ["r9"], r10: reg = ["r10"], r11: reg = ["r11"], r12: reg = ["r12"], r13: reg = ["r13"], r14: reg = ["r14"], r15: reg = ["r15"], r16: reg = ["r16"], r17: reg = ["r17"], r18: reg = ["r18"], r20: reg = ["r20"], r21: reg = ["r21"], r22: reg = ["r22"], r23: reg = ["r23"], r24: reg = ["r24"], r25: reg = ["r25"], r26: reg = ["r26"], r27: reg = ["r27"], r28: reg = ["r28"], #error = ["r19"] => "r19 is used internally by LLVM and cannot be used as an operand for inline asm", #error = ["r29", "sp"] => "the stack pointer cannot be used as an operand for inline asm", #error = ["r30", "fr"] => "the frame register cannot be used as an operand for inline asm", #error = ["r31", "lr"] => "the link register cannot be used as an operand for inline asm", } } impl HexagonInlineAsmReg { pub fn emit( self, out: &mut dyn fmt::Write, _arch: InlineAsmArch, _modifier: Option<char>, ) -> fmt::Result { out.write_str(self.name()) } pub fn overlapping_regs(self, mut _cb: impl FnMut(HexagonInlineAsmReg)) {} }