Skip to main content

rustc_target/asm/
mips.rs

1use std::fmt;
2
3use rustc_span::Symbol;
4
5use super::{InlineAsmArch, InlineAsmType, ModifierInfo};
6
7#[allow(non_camel_case_types)]
pub enum MipsInlineAsmRegClass { reg, freg, }
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::marker::Copy for MipsInlineAsmRegClass { }
#[automatically_derived]
#[doc(hidden)]
#[allow(non_camel_case_types)]
unsafe impl ::core::clone::TrivialClone for MipsInlineAsmRegClass { }
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::clone::Clone for MipsInlineAsmRegClass {
    #[inline]
    fn clone(&self) -> MipsInlineAsmRegClass { *self }
}
const _: () =
    {
        impl<__E: ::rustc_span::SpanEncoder> ::rustc_serialize::Encodable<__E>
            for MipsInlineAsmRegClass {
            fn encode(&self, __encoder: &mut __E) {
                let disc =
                    match *self {
                        MipsInlineAsmRegClass::reg => { 0usize }
                        MipsInlineAsmRegClass::freg => { 1usize }
                    };
                ::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
                match *self {
                    MipsInlineAsmRegClass::reg => {}
                    MipsInlineAsmRegClass::freg => {}
                }
            }
        }
    };
const _: () =
    {
        impl<__D: ::rustc_span::SpanDecoder> ::rustc_serialize::Decodable<__D>
            for MipsInlineAsmRegClass {
            fn decode(__decoder: &mut __D) -> Self {
                match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
                    {
                    0usize => { MipsInlineAsmRegClass::reg }
                    1usize => { MipsInlineAsmRegClass::freg }
                    n => {
                        ::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `MipsInlineAsmRegClass`, expected 0..2, actual {0}",
                                n));
                    }
                }
            }
        }
    };
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::fmt::Debug for MipsInlineAsmRegClass {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::write_str(f,
            match self {
                MipsInlineAsmRegClass::reg => "reg",
                MipsInlineAsmRegClass::freg => "freg",
            })
    }
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::Eq for MipsInlineAsmRegClass {
    #[inline]
    #[doc(hidden)]
    #[coverage(off)]
    fn assert_receiver_is_total_eq(&self) {}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::marker::StructuralPartialEq for MipsInlineAsmRegClass { }
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialEq for MipsInlineAsmRegClass {
    #[inline]
    fn eq(&self, other: &MipsInlineAsmRegClass) -> bool {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        __self_discr == __arg1_discr
    }
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialOrd for MipsInlineAsmRegClass {
    #[inline]
    fn partial_cmp(&self, other: &MipsInlineAsmRegClass)
        -> ::core::option::Option<::core::cmp::Ordering> {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        ::core::cmp::PartialOrd::partial_cmp(&__self_discr, &__arg1_discr)
    }
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::hash::Hash for MipsInlineAsmRegClass {
    #[inline]
    fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        ::core::hash::Hash::hash(&__self_discr, state)
    }
}
const _: () =
    {
        impl<__CTX> ::rustc_data_structures::stable_hasher::HashStable<__CTX>
            for MipsInlineAsmRegClass where __CTX: crate::HashStableContext {
            #[inline]
            fn hash_stable(&self, __hcx: &mut __CTX,
                __hasher:
                    &mut ::rustc_data_structures::stable_hasher::StableHasher) {
                ::std::mem::discriminant(self).hash_stable(__hcx, __hasher);
                match *self {
                    MipsInlineAsmRegClass::reg => {}
                    MipsInlineAsmRegClass::freg => {}
                }
            }
        }
    };
impl MipsInlineAsmRegClass {
    pub fn name(self) -> rustc_span::Symbol {
        match self {
            Self::reg => rustc_span::sym::reg,
            Self::freg => rustc_span::sym::freg,
        }
    }
    pub fn parse(name: rustc_span::Symbol)
        -> Result<Self, &'static [rustc_span::Symbol]> {
        match name {
            rustc_span::sym::reg => Ok(Self::reg),
            rustc_span::sym::freg => Ok(Self::freg),
            _ => Err(&[rustc_span::sym::reg, rustc_span::sym::freg]),
        }
    }
}
pub(super) fn regclass_map()
    ->
        rustc_data_structures::fx::FxHashMap<super::InlineAsmRegClass,
        rustc_data_structures::fx::FxIndexSet<super::InlineAsmReg>> {
    use rustc_data_structures::fx::FxHashMap;
    use rustc_data_structures::fx::FxIndexSet;
    use super::InlineAsmRegClass;
    let mut map = FxHashMap::default();
    map.insert(InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg),
        FxIndexSet::default());
    map.insert(InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg),
        FxIndexSet::default());
    map
}def_reg_class! {
8    Mips MipsInlineAsmRegClass {
9        reg,
10        freg,
11    }
12}
13
14impl MipsInlineAsmRegClass {
15    pub fn valid_modifiers(self, _arch: super::InlineAsmArch) -> &'static [char] {
16        &[]
17    }
18
19    pub fn suggest_class(self, _arch: InlineAsmArch, _ty: InlineAsmType) -> Option<Self> {
20        None
21    }
22
23    pub fn suggest_modifier(
24        self,
25        _arch: InlineAsmArch,
26        _ty: InlineAsmType,
27    ) -> Option<ModifierInfo> {
28        None
29    }
30
31    pub fn default_modifier(self, _arch: InlineAsmArch) -> Option<ModifierInfo> {
32        None
33    }
34
35    pub fn supported_types(
36        self,
37        arch: InlineAsmArch,
38    ) -> &'static [(InlineAsmType, Option<Symbol>)] {
39        match (self, arch) {
40            (Self::reg, InlineAsmArch::Mips64) => {
    use super::InlineAsmType::*;
    &[(I8, None), (I16, None), (I32, None), (I64, None), (F32, None),
                (F64, None)]
}types! { _: I8, I16, I32, I64, F32, F64; },
41            (Self::reg, _) => {
    use super::InlineAsmType::*;
    &[(I8, None), (I16, None), (I32, None), (F32, None)]
}types! { _: I8, I16, I32, F32; },
42            (Self::freg, _) => {
    use super::InlineAsmType::*;
    &[(F32, None), (F64, None)]
}types! { _: F32, F64; },
43        }
44    }
45}
46
47// The reserved registers are somewhat taken from
48// <https://github.com/llvm/llvm-project/blob/deb8f8bcf31540c657716ea5242183b0792702a1/llvm/lib/Target/Mips/MipsRegisterInfo.cpp#L150>.
49#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
pub enum MipsInlineAsmReg {
    r2,
    r3,
    r4,
    r5,
    r6,
    r7,
    r8,
    r9,
    r10,
    r11,
    r12,
    r13,
    r14,
    r15,
    r16,
    r17,
    r18,
    r19,
    r20,
    r21,
    r22,
    r23,
    r24,
    r25,
    f0,
    f1,
    f2,
    f3,
    f4,
    f5,
    f6,
    f7,
    f8,
    f9,
    f10,
    f11,
    f12,
    f13,
    f14,
    f15,
    f16,
    f17,
    f18,
    f19,
    f20,
    f21,
    f22,
    f23,
    f24,
    f25,
    f26,
    f27,
    f28,
    f29,
    f30,
    f31,
}
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::marker::Copy for MipsInlineAsmReg { }
#[automatically_derived]
#[doc(hidden)]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
unsafe impl ::core::clone::TrivialClone for MipsInlineAsmReg { }
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::clone::Clone for MipsInlineAsmReg {
    #[inline]
    fn clone(&self) -> MipsInlineAsmReg { *self }
}
const _: () =
    {
        impl<__E: ::rustc_span::SpanEncoder> ::rustc_serialize::Encodable<__E>
            for MipsInlineAsmReg {
            fn encode(&self, __encoder: &mut __E) {
                let disc =
                    match *self {
                        MipsInlineAsmReg::r2 => { 0usize }
                        MipsInlineAsmReg::r3 => { 1usize }
                        MipsInlineAsmReg::r4 => { 2usize }
                        MipsInlineAsmReg::r5 => { 3usize }
                        MipsInlineAsmReg::r6 => { 4usize }
                        MipsInlineAsmReg::r7 => { 5usize }
                        MipsInlineAsmReg::r8 => { 6usize }
                        MipsInlineAsmReg::r9 => { 7usize }
                        MipsInlineAsmReg::r10 => { 8usize }
                        MipsInlineAsmReg::r11 => { 9usize }
                        MipsInlineAsmReg::r12 => { 10usize }
                        MipsInlineAsmReg::r13 => { 11usize }
                        MipsInlineAsmReg::r14 => { 12usize }
                        MipsInlineAsmReg::r15 => { 13usize }
                        MipsInlineAsmReg::r16 => { 14usize }
                        MipsInlineAsmReg::r17 => { 15usize }
                        MipsInlineAsmReg::r18 => { 16usize }
                        MipsInlineAsmReg::r19 => { 17usize }
                        MipsInlineAsmReg::r20 => { 18usize }
                        MipsInlineAsmReg::r21 => { 19usize }
                        MipsInlineAsmReg::r22 => { 20usize }
                        MipsInlineAsmReg::r23 => { 21usize }
                        MipsInlineAsmReg::r24 => { 22usize }
                        MipsInlineAsmReg::r25 => { 23usize }
                        MipsInlineAsmReg::f0 => { 24usize }
                        MipsInlineAsmReg::f1 => { 25usize }
                        MipsInlineAsmReg::f2 => { 26usize }
                        MipsInlineAsmReg::f3 => { 27usize }
                        MipsInlineAsmReg::f4 => { 28usize }
                        MipsInlineAsmReg::f5 => { 29usize }
                        MipsInlineAsmReg::f6 => { 30usize }
                        MipsInlineAsmReg::f7 => { 31usize }
                        MipsInlineAsmReg::f8 => { 32usize }
                        MipsInlineAsmReg::f9 => { 33usize }
                        MipsInlineAsmReg::f10 => { 34usize }
                        MipsInlineAsmReg::f11 => { 35usize }
                        MipsInlineAsmReg::f12 => { 36usize }
                        MipsInlineAsmReg::f13 => { 37usize }
                        MipsInlineAsmReg::f14 => { 38usize }
                        MipsInlineAsmReg::f15 => { 39usize }
                        MipsInlineAsmReg::f16 => { 40usize }
                        MipsInlineAsmReg::f17 => { 41usize }
                        MipsInlineAsmReg::f18 => { 42usize }
                        MipsInlineAsmReg::f19 => { 43usize }
                        MipsInlineAsmReg::f20 => { 44usize }
                        MipsInlineAsmReg::f21 => { 45usize }
                        MipsInlineAsmReg::f22 => { 46usize }
                        MipsInlineAsmReg::f23 => { 47usize }
                        MipsInlineAsmReg::f24 => { 48usize }
                        MipsInlineAsmReg::f25 => { 49usize }
                        MipsInlineAsmReg::f26 => { 50usize }
                        MipsInlineAsmReg::f27 => { 51usize }
                        MipsInlineAsmReg::f28 => { 52usize }
                        MipsInlineAsmReg::f29 => { 53usize }
                        MipsInlineAsmReg::f30 => { 54usize }
                        MipsInlineAsmReg::f31 => { 55usize }
                    };
                ::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
                match *self {
                    MipsInlineAsmReg::r2 => {}
                    MipsInlineAsmReg::r3 => {}
                    MipsInlineAsmReg::r4 => {}
                    MipsInlineAsmReg::r5 => {}
                    MipsInlineAsmReg::r6 => {}
                    MipsInlineAsmReg::r7 => {}
                    MipsInlineAsmReg::r8 => {}
                    MipsInlineAsmReg::r9 => {}
                    MipsInlineAsmReg::r10 => {}
                    MipsInlineAsmReg::r11 => {}
                    MipsInlineAsmReg::r12 => {}
                    MipsInlineAsmReg::r13 => {}
                    MipsInlineAsmReg::r14 => {}
                    MipsInlineAsmReg::r15 => {}
                    MipsInlineAsmReg::r16 => {}
                    MipsInlineAsmReg::r17 => {}
                    MipsInlineAsmReg::r18 => {}
                    MipsInlineAsmReg::r19 => {}
                    MipsInlineAsmReg::r20 => {}
                    MipsInlineAsmReg::r21 => {}
                    MipsInlineAsmReg::r22 => {}
                    MipsInlineAsmReg::r23 => {}
                    MipsInlineAsmReg::r24 => {}
                    MipsInlineAsmReg::r25 => {}
                    MipsInlineAsmReg::f0 => {}
                    MipsInlineAsmReg::f1 => {}
                    MipsInlineAsmReg::f2 => {}
                    MipsInlineAsmReg::f3 => {}
                    MipsInlineAsmReg::f4 => {}
                    MipsInlineAsmReg::f5 => {}
                    MipsInlineAsmReg::f6 => {}
                    MipsInlineAsmReg::f7 => {}
                    MipsInlineAsmReg::f8 => {}
                    MipsInlineAsmReg::f9 => {}
                    MipsInlineAsmReg::f10 => {}
                    MipsInlineAsmReg::f11 => {}
                    MipsInlineAsmReg::f12 => {}
                    MipsInlineAsmReg::f13 => {}
                    MipsInlineAsmReg::f14 => {}
                    MipsInlineAsmReg::f15 => {}
                    MipsInlineAsmReg::f16 => {}
                    MipsInlineAsmReg::f17 => {}
                    MipsInlineAsmReg::f18 => {}
                    MipsInlineAsmReg::f19 => {}
                    MipsInlineAsmReg::f20 => {}
                    MipsInlineAsmReg::f21 => {}
                    MipsInlineAsmReg::f22 => {}
                    MipsInlineAsmReg::f23 => {}
                    MipsInlineAsmReg::f24 => {}
                    MipsInlineAsmReg::f25 => {}
                    MipsInlineAsmReg::f26 => {}
                    MipsInlineAsmReg::f27 => {}
                    MipsInlineAsmReg::f28 => {}
                    MipsInlineAsmReg::f29 => {}
                    MipsInlineAsmReg::f30 => {}
                    MipsInlineAsmReg::f31 => {}
                }
            }
        }
    };
const _: () =
    {
        impl<__D: ::rustc_span::SpanDecoder> ::rustc_serialize::Decodable<__D>
            for MipsInlineAsmReg {
            fn decode(__decoder: &mut __D) -> Self {
                match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
                    {
                    0usize => { MipsInlineAsmReg::r2 }
                    1usize => { MipsInlineAsmReg::r3 }
                    2usize => { MipsInlineAsmReg::r4 }
                    3usize => { MipsInlineAsmReg::r5 }
                    4usize => { MipsInlineAsmReg::r6 }
                    5usize => { MipsInlineAsmReg::r7 }
                    6usize => { MipsInlineAsmReg::r8 }
                    7usize => { MipsInlineAsmReg::r9 }
                    8usize => { MipsInlineAsmReg::r10 }
                    9usize => { MipsInlineAsmReg::r11 }
                    10usize => { MipsInlineAsmReg::r12 }
                    11usize => { MipsInlineAsmReg::r13 }
                    12usize => { MipsInlineAsmReg::r14 }
                    13usize => { MipsInlineAsmReg::r15 }
                    14usize => { MipsInlineAsmReg::r16 }
                    15usize => { MipsInlineAsmReg::r17 }
                    16usize => { MipsInlineAsmReg::r18 }
                    17usize => { MipsInlineAsmReg::r19 }
                    18usize => { MipsInlineAsmReg::r20 }
                    19usize => { MipsInlineAsmReg::r21 }
                    20usize => { MipsInlineAsmReg::r22 }
                    21usize => { MipsInlineAsmReg::r23 }
                    22usize => { MipsInlineAsmReg::r24 }
                    23usize => { MipsInlineAsmReg::r25 }
                    24usize => { MipsInlineAsmReg::f0 }
                    25usize => { MipsInlineAsmReg::f1 }
                    26usize => { MipsInlineAsmReg::f2 }
                    27usize => { MipsInlineAsmReg::f3 }
                    28usize => { MipsInlineAsmReg::f4 }
                    29usize => { MipsInlineAsmReg::f5 }
                    30usize => { MipsInlineAsmReg::f6 }
                    31usize => { MipsInlineAsmReg::f7 }
                    32usize => { MipsInlineAsmReg::f8 }
                    33usize => { MipsInlineAsmReg::f9 }
                    34usize => { MipsInlineAsmReg::f10 }
                    35usize => { MipsInlineAsmReg::f11 }
                    36usize => { MipsInlineAsmReg::f12 }
                    37usize => { MipsInlineAsmReg::f13 }
                    38usize => { MipsInlineAsmReg::f14 }
                    39usize => { MipsInlineAsmReg::f15 }
                    40usize => { MipsInlineAsmReg::f16 }
                    41usize => { MipsInlineAsmReg::f17 }
                    42usize => { MipsInlineAsmReg::f18 }
                    43usize => { MipsInlineAsmReg::f19 }
                    44usize => { MipsInlineAsmReg::f20 }
                    45usize => { MipsInlineAsmReg::f21 }
                    46usize => { MipsInlineAsmReg::f22 }
                    47usize => { MipsInlineAsmReg::f23 }
                    48usize => { MipsInlineAsmReg::f24 }
                    49usize => { MipsInlineAsmReg::f25 }
                    50usize => { MipsInlineAsmReg::f26 }
                    51usize => { MipsInlineAsmReg::f27 }
                    52usize => { MipsInlineAsmReg::f28 }
                    53usize => { MipsInlineAsmReg::f29 }
                    54usize => { MipsInlineAsmReg::f30 }
                    55usize => { MipsInlineAsmReg::f31 }
                    n => {
                        ::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `MipsInlineAsmReg`, expected 0..56, actual {0}",
                                n));
                    }
                }
            }
        }
    };
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::fmt::Debug for MipsInlineAsmReg {
    #[inline]
    fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
        ::core::fmt::Formatter::write_str(f,
            match self {
                MipsInlineAsmReg::r2 => "r2",
                MipsInlineAsmReg::r3 => "r3",
                MipsInlineAsmReg::r4 => "r4",
                MipsInlineAsmReg::r5 => "r5",
                MipsInlineAsmReg::r6 => "r6",
                MipsInlineAsmReg::r7 => "r7",
                MipsInlineAsmReg::r8 => "r8",
                MipsInlineAsmReg::r9 => "r9",
                MipsInlineAsmReg::r10 => "r10",
                MipsInlineAsmReg::r11 => "r11",
                MipsInlineAsmReg::r12 => "r12",
                MipsInlineAsmReg::r13 => "r13",
                MipsInlineAsmReg::r14 => "r14",
                MipsInlineAsmReg::r15 => "r15",
                MipsInlineAsmReg::r16 => "r16",
                MipsInlineAsmReg::r17 => "r17",
                MipsInlineAsmReg::r18 => "r18",
                MipsInlineAsmReg::r19 => "r19",
                MipsInlineAsmReg::r20 => "r20",
                MipsInlineAsmReg::r21 => "r21",
                MipsInlineAsmReg::r22 => "r22",
                MipsInlineAsmReg::r23 => "r23",
                MipsInlineAsmReg::r24 => "r24",
                MipsInlineAsmReg::r25 => "r25",
                MipsInlineAsmReg::f0 => "f0",
                MipsInlineAsmReg::f1 => "f1",
                MipsInlineAsmReg::f2 => "f2",
                MipsInlineAsmReg::f3 => "f3",
                MipsInlineAsmReg::f4 => "f4",
                MipsInlineAsmReg::f5 => "f5",
                MipsInlineAsmReg::f6 => "f6",
                MipsInlineAsmReg::f7 => "f7",
                MipsInlineAsmReg::f8 => "f8",
                MipsInlineAsmReg::f9 => "f9",
                MipsInlineAsmReg::f10 => "f10",
                MipsInlineAsmReg::f11 => "f11",
                MipsInlineAsmReg::f12 => "f12",
                MipsInlineAsmReg::f13 => "f13",
                MipsInlineAsmReg::f14 => "f14",
                MipsInlineAsmReg::f15 => "f15",
                MipsInlineAsmReg::f16 => "f16",
                MipsInlineAsmReg::f17 => "f17",
                MipsInlineAsmReg::f18 => "f18",
                MipsInlineAsmReg::f19 => "f19",
                MipsInlineAsmReg::f20 => "f20",
                MipsInlineAsmReg::f21 => "f21",
                MipsInlineAsmReg::f22 => "f22",
                MipsInlineAsmReg::f23 => "f23",
                MipsInlineAsmReg::f24 => "f24",
                MipsInlineAsmReg::f25 => "f25",
                MipsInlineAsmReg::f26 => "f26",
                MipsInlineAsmReg::f27 => "f27",
                MipsInlineAsmReg::f28 => "f28",
                MipsInlineAsmReg::f29 => "f29",
                MipsInlineAsmReg::f30 => "f30",
                MipsInlineAsmReg::f31 => "f31",
            })
    }
}
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::cmp::Eq for MipsInlineAsmReg {
    #[inline]
    #[doc(hidden)]
    #[coverage(off)]
    fn assert_receiver_is_total_eq(&self) {}
}
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::marker::StructuralPartialEq for MipsInlineAsmReg { }
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialEq for MipsInlineAsmReg {
    #[inline]
    fn eq(&self, other: &MipsInlineAsmReg) -> bool {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        __self_discr == __arg1_discr
    }
}
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialOrd for MipsInlineAsmReg {
    #[inline]
    fn partial_cmp(&self, other: &MipsInlineAsmReg)
        -> ::core::option::Option<::core::cmp::Ordering> {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        let __arg1_discr = ::core::intrinsics::discriminant_value(other);
        ::core::cmp::PartialOrd::partial_cmp(&__self_discr, &__arg1_discr)
    }
}
#[automatically_derived]
#[allow(unreachable_code)]
#[allow(non_camel_case_types)]
impl ::core::hash::Hash for MipsInlineAsmReg {
    #[inline]
    fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) {
        let __self_discr = ::core::intrinsics::discriminant_value(self);
        ::core::hash::Hash::hash(&__self_discr, state)
    }
}
const _: () =
    {
        impl<__CTX> ::rustc_data_structures::stable_hasher::HashStable<__CTX>
            for MipsInlineAsmReg where __CTX: crate::HashStableContext {
            #[inline]
            fn hash_stable(&self, __hcx: &mut __CTX,
                __hasher:
                    &mut ::rustc_data_structures::stable_hasher::StableHasher) {
                ::std::mem::discriminant(self).hash_stable(__hcx, __hasher);
                match *self {
                    MipsInlineAsmReg::r2 => {}
                    MipsInlineAsmReg::r3 => {}
                    MipsInlineAsmReg::r4 => {}
                    MipsInlineAsmReg::r5 => {}
                    MipsInlineAsmReg::r6 => {}
                    MipsInlineAsmReg::r7 => {}
                    MipsInlineAsmReg::r8 => {}
                    MipsInlineAsmReg::r9 => {}
                    MipsInlineAsmReg::r10 => {}
                    MipsInlineAsmReg::r11 => {}
                    MipsInlineAsmReg::r12 => {}
                    MipsInlineAsmReg::r13 => {}
                    MipsInlineAsmReg::r14 => {}
                    MipsInlineAsmReg::r15 => {}
                    MipsInlineAsmReg::r16 => {}
                    MipsInlineAsmReg::r17 => {}
                    MipsInlineAsmReg::r18 => {}
                    MipsInlineAsmReg::r19 => {}
                    MipsInlineAsmReg::r20 => {}
                    MipsInlineAsmReg::r21 => {}
                    MipsInlineAsmReg::r22 => {}
                    MipsInlineAsmReg::r23 => {}
                    MipsInlineAsmReg::r24 => {}
                    MipsInlineAsmReg::r25 => {}
                    MipsInlineAsmReg::f0 => {}
                    MipsInlineAsmReg::f1 => {}
                    MipsInlineAsmReg::f2 => {}
                    MipsInlineAsmReg::f3 => {}
                    MipsInlineAsmReg::f4 => {}
                    MipsInlineAsmReg::f5 => {}
                    MipsInlineAsmReg::f6 => {}
                    MipsInlineAsmReg::f7 => {}
                    MipsInlineAsmReg::f8 => {}
                    MipsInlineAsmReg::f9 => {}
                    MipsInlineAsmReg::f10 => {}
                    MipsInlineAsmReg::f11 => {}
                    MipsInlineAsmReg::f12 => {}
                    MipsInlineAsmReg::f13 => {}
                    MipsInlineAsmReg::f14 => {}
                    MipsInlineAsmReg::f15 => {}
                    MipsInlineAsmReg::f16 => {}
                    MipsInlineAsmReg::f17 => {}
                    MipsInlineAsmReg::f18 => {}
                    MipsInlineAsmReg::f19 => {}
                    MipsInlineAsmReg::f20 => {}
                    MipsInlineAsmReg::f21 => {}
                    MipsInlineAsmReg::f22 => {}
                    MipsInlineAsmReg::f23 => {}
                    MipsInlineAsmReg::f24 => {}
                    MipsInlineAsmReg::f25 => {}
                    MipsInlineAsmReg::f26 => {}
                    MipsInlineAsmReg::f27 => {}
                    MipsInlineAsmReg::f28 => {}
                    MipsInlineAsmReg::f29 => {}
                    MipsInlineAsmReg::f30 => {}
                    MipsInlineAsmReg::f31 => {}
                }
            }
        }
    };
impl MipsInlineAsmReg {
    pub fn name(self) -> &'static str {
        match self {
            Self::r2 => "$2",
            Self::r3 => "$3",
            Self::r4 => "$4",
            Self::r5 => "$5",
            Self::r6 => "$6",
            Self::r7 => "$7",
            Self::r8 => "$8",
            Self::r9 => "$9",
            Self::r10 => "$10",
            Self::r11 => "$11",
            Self::r12 => "$12",
            Self::r13 => "$13",
            Self::r14 => "$14",
            Self::r15 => "$15",
            Self::r16 => "$16",
            Self::r17 => "$17",
            Self::r18 => "$18",
            Self::r19 => "$19",
            Self::r20 => "$20",
            Self::r21 => "$21",
            Self::r22 => "$22",
            Self::r23 => "$23",
            Self::r24 => "$24",
            Self::r25 => "$25",
            Self::f0 => "$f0",
            Self::f1 => "$f1",
            Self::f2 => "$f2",
            Self::f3 => "$f3",
            Self::f4 => "$f4",
            Self::f5 => "$f5",
            Self::f6 => "$f6",
            Self::f7 => "$f7",
            Self::f8 => "$f8",
            Self::f9 => "$f9",
            Self::f10 => "$f10",
            Self::f11 => "$f11",
            Self::f12 => "$f12",
            Self::f13 => "$f13",
            Self::f14 => "$f14",
            Self::f15 => "$f15",
            Self::f16 => "$f16",
            Self::f17 => "$f17",
            Self::f18 => "$f18",
            Self::f19 => "$f19",
            Self::f20 => "$f20",
            Self::f21 => "$f21",
            Self::f22 => "$f22",
            Self::f23 => "$f23",
            Self::f24 => "$f24",
            Self::f25 => "$f25",
            Self::f26 => "$f26",
            Self::f27 => "$f27",
            Self::f28 => "$f28",
            Self::f29 => "$f29",
            Self::f30 => "$f30",
            Self::f31 => "$f31",
        }
    }
    pub fn reg_class(self) -> MipsInlineAsmRegClass {
        match self {
            Self::r2 => MipsInlineAsmRegClass::reg,
            Self::r3 => MipsInlineAsmRegClass::reg,
            Self::r4 => MipsInlineAsmRegClass::reg,
            Self::r5 => MipsInlineAsmRegClass::reg,
            Self::r6 => MipsInlineAsmRegClass::reg,
            Self::r7 => MipsInlineAsmRegClass::reg,
            Self::r8 => MipsInlineAsmRegClass::reg,
            Self::r9 => MipsInlineAsmRegClass::reg,
            Self::r10 => MipsInlineAsmRegClass::reg,
            Self::r11 => MipsInlineAsmRegClass::reg,
            Self::r12 => MipsInlineAsmRegClass::reg,
            Self::r13 => MipsInlineAsmRegClass::reg,
            Self::r14 => MipsInlineAsmRegClass::reg,
            Self::r15 => MipsInlineAsmRegClass::reg,
            Self::r16 => MipsInlineAsmRegClass::reg,
            Self::r17 => MipsInlineAsmRegClass::reg,
            Self::r18 => MipsInlineAsmRegClass::reg,
            Self::r19 => MipsInlineAsmRegClass::reg,
            Self::r20 => MipsInlineAsmRegClass::reg,
            Self::r21 => MipsInlineAsmRegClass::reg,
            Self::r22 => MipsInlineAsmRegClass::reg,
            Self::r23 => MipsInlineAsmRegClass::reg,
            Self::r24 => MipsInlineAsmRegClass::reg,
            Self::r25 => MipsInlineAsmRegClass::reg,
            Self::f0 => MipsInlineAsmRegClass::freg,
            Self::f1 => MipsInlineAsmRegClass::freg,
            Self::f2 => MipsInlineAsmRegClass::freg,
            Self::f3 => MipsInlineAsmRegClass::freg,
            Self::f4 => MipsInlineAsmRegClass::freg,
            Self::f5 => MipsInlineAsmRegClass::freg,
            Self::f6 => MipsInlineAsmRegClass::freg,
            Self::f7 => MipsInlineAsmRegClass::freg,
            Self::f8 => MipsInlineAsmRegClass::freg,
            Self::f9 => MipsInlineAsmRegClass::freg,
            Self::f10 => MipsInlineAsmRegClass::freg,
            Self::f11 => MipsInlineAsmRegClass::freg,
            Self::f12 => MipsInlineAsmRegClass::freg,
            Self::f13 => MipsInlineAsmRegClass::freg,
            Self::f14 => MipsInlineAsmRegClass::freg,
            Self::f15 => MipsInlineAsmRegClass::freg,
            Self::f16 => MipsInlineAsmRegClass::freg,
            Self::f17 => MipsInlineAsmRegClass::freg,
            Self::f18 => MipsInlineAsmRegClass::freg,
            Self::f19 => MipsInlineAsmRegClass::freg,
            Self::f20 => MipsInlineAsmRegClass::freg,
            Self::f21 => MipsInlineAsmRegClass::freg,
            Self::f22 => MipsInlineAsmRegClass::freg,
            Self::f23 => MipsInlineAsmRegClass::freg,
            Self::f24 => MipsInlineAsmRegClass::freg,
            Self::f25 => MipsInlineAsmRegClass::freg,
            Self::f26 => MipsInlineAsmRegClass::freg,
            Self::f27 => MipsInlineAsmRegClass::freg,
            Self::f28 => MipsInlineAsmRegClass::freg,
            Self::f29 => MipsInlineAsmRegClass::freg,
            Self::f30 => MipsInlineAsmRegClass::freg,
            Self::f31 => MipsInlineAsmRegClass::freg,
        }
    }
    pub fn parse(name: &str) -> Result<Self, &'static str> {
        match name {
            "$2" => Ok(Self::r2),
            "$3" => Ok(Self::r3),
            "$4" => Ok(Self::r4),
            "$5" => Ok(Self::r5),
            "$6" => Ok(Self::r6),
            "$7" => Ok(Self::r7),
            "$8" => Ok(Self::r8),
            "$9" => Ok(Self::r9),
            "$10" => Ok(Self::r10),
            "$11" => Ok(Self::r11),
            "$12" => Ok(Self::r12),
            "$13" => Ok(Self::r13),
            "$14" => Ok(Self::r14),
            "$15" => Ok(Self::r15),
            "$16" => Ok(Self::r16),
            "$17" => Ok(Self::r17),
            "$18" => Ok(Self::r18),
            "$19" => Ok(Self::r19),
            "$20" => Ok(Self::r20),
            "$21" => Ok(Self::r21),
            "$22" => Ok(Self::r22),
            "$23" => Ok(Self::r23),
            "$24" => Ok(Self::r24),
            "$25" => Ok(Self::r25),
            "$f0" => Ok(Self::f0),
            "$f1" => Ok(Self::f1),
            "$f2" => Ok(Self::f2),
            "$f3" => Ok(Self::f3),
            "$f4" => Ok(Self::f4),
            "$f5" => Ok(Self::f5),
            "$f6" => Ok(Self::f6),
            "$f7" => Ok(Self::f7),
            "$f8" => Ok(Self::f8),
            "$f9" => Ok(Self::f9),
            "$f10" => Ok(Self::f10),
            "$f11" => Ok(Self::f11),
            "$f12" => Ok(Self::f12),
            "$f13" => Ok(Self::f13),
            "$f14" => Ok(Self::f14),
            "$f15" => Ok(Self::f15),
            "$f16" => Ok(Self::f16),
            "$f17" => Ok(Self::f17),
            "$f18" => Ok(Self::f18),
            "$f19" => Ok(Self::f19),
            "$f20" => Ok(Self::f20),
            "$f21" => Ok(Self::f21),
            "$f22" => Ok(Self::f22),
            "$f23" => Ok(Self::f23),
            "$f24" => Ok(Self::f24),
            "$f25" => Ok(Self::f25),
            "$f26" => Ok(Self::f26),
            "$f27" => Ok(Self::f27),
            "$f28" => Ok(Self::f28),
            "$f29" => Ok(Self::f29),
            "$f30" => Ok(Self::f30),
            "$f31" => Ok(Self::f31),
            "$0" =>
                Err("constant zero cannot be used as an operand for inline asm"),
            "$1" => Err("reserved for assembler (Assembler Temp)"),
            "$26" =>
                Err("OS-reserved register cannot be used as an operand for inline asm"),
            "$27" =>
                Err("OS-reserved register cannot be used as an operand for inline asm"),
            "$28" =>
                Err("the global pointer cannot be used as an operand for inline asm"),
            "$29" =>
                Err("the stack pointer cannot be used as an operand for inline asm"),
            "$30" =>
                Err("the frame pointer cannot be used as an operand for inline asm"),
            "$31" =>
                Err("the return address register cannot be used as an operand for inline asm"),
            _ => Err("unknown register"),
        }
    }
    pub fn validate(self, _arch: super::InlineAsmArch,
        _reloc_model: crate::spec::RelocModel,
        _target_features: &rustc_data_structures::fx::FxIndexSet<Symbol>,
        _target: &crate::spec::Target, _is_clobber: bool)
        -> Result<(), &'static str> {
        match self {
            Self::r2 => { Ok(()) }
            Self::r3 => { Ok(()) }
            Self::r4 => { Ok(()) }
            Self::r5 => { Ok(()) }
            Self::r6 => { Ok(()) }
            Self::r7 => { Ok(()) }
            Self::r8 => { Ok(()) }
            Self::r9 => { Ok(()) }
            Self::r10 => { Ok(()) }
            Self::r11 => { Ok(()) }
            Self::r12 => { Ok(()) }
            Self::r13 => { Ok(()) }
            Self::r14 => { Ok(()) }
            Self::r15 => { Ok(()) }
            Self::r16 => { Ok(()) }
            Self::r17 => { Ok(()) }
            Self::r18 => { Ok(()) }
            Self::r19 => { Ok(()) }
            Self::r20 => { Ok(()) }
            Self::r21 => { Ok(()) }
            Self::r22 => { Ok(()) }
            Self::r23 => { Ok(()) }
            Self::r24 => { Ok(()) }
            Self::r25 => { Ok(()) }
            Self::f0 => { Ok(()) }
            Self::f1 => { Ok(()) }
            Self::f2 => { Ok(()) }
            Self::f3 => { Ok(()) }
            Self::f4 => { Ok(()) }
            Self::f5 => { Ok(()) }
            Self::f6 => { Ok(()) }
            Self::f7 => { Ok(()) }
            Self::f8 => { Ok(()) }
            Self::f9 => { Ok(()) }
            Self::f10 => { Ok(()) }
            Self::f11 => { Ok(()) }
            Self::f12 => { Ok(()) }
            Self::f13 => { Ok(()) }
            Self::f14 => { Ok(()) }
            Self::f15 => { Ok(()) }
            Self::f16 => { Ok(()) }
            Self::f17 => { Ok(()) }
            Self::f18 => { Ok(()) }
            Self::f19 => { Ok(()) }
            Self::f20 => { Ok(()) }
            Self::f21 => { Ok(()) }
            Self::f22 => { Ok(()) }
            Self::f23 => { Ok(()) }
            Self::f24 => { Ok(()) }
            Self::f25 => { Ok(()) }
            Self::f26 => { Ok(()) }
            Self::f27 => { Ok(()) }
            Self::f28 => { Ok(()) }
            Self::f29 => { Ok(()) }
            Self::f30 => { Ok(()) }
            Self::f31 => { Ok(()) }
        }
    }
}
pub(super) fn fill_reg_map(_arch: super::InlineAsmArch,
    _reloc_model: crate::spec::RelocModel,
    _target_features: &rustc_data_structures::fx::FxIndexSet<Symbol>,
    _target: &crate::spec::Target,
    _map:
        &mut rustc_data_structures::fx::FxHashMap<super::InlineAsmRegClass,
        rustc_data_structures::fx::FxIndexSet<super::InlineAsmReg>>) {
    #[allow(unused_imports)]
    use super::{InlineAsmReg, InlineAsmRegClass};
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r2));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r3));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r4));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r5));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r6));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r7));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r8));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r9));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r10));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r11));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r12));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r13));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r14));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r15));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r16));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r17));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r18));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r19));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r20));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r21));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r22));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r23));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r24));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::reg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::r25));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f0));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f1));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f2));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f3));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f4));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f5));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f6));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f7));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f8));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f9));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f10));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f11));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f12));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f13));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f14));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f15));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f16));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f17));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f18));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f19));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f20));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f21));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f22));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f23));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f24));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f25));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f26));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f27));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f28));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f29));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f30));
        }
    }
    if true {
        if let Some(set) =
                _map.get_mut(&InlineAsmRegClass::Mips(MipsInlineAsmRegClass::freg))
            {
            set.insert(InlineAsmReg::Mips(MipsInlineAsmReg::f31));
        }
    }
}def_regs! {
50    Mips MipsInlineAsmReg MipsInlineAsmRegClass {
51        r2: reg = ["$2"],
52        r3: reg = ["$3"],
53        r4: reg = ["$4"],
54        r5: reg = ["$5"],
55        r6: reg = ["$6"],
56        r7: reg = ["$7"],
57        // FIXME: Reserve $t0, $t1 if in mips16 mode.
58        r8: reg = ["$8"],
59        r9: reg = ["$9"],
60        r10: reg = ["$10"],
61        r11: reg = ["$11"],
62        r12: reg = ["$12"],
63        r13: reg = ["$13"],
64        r14: reg = ["$14"],
65        r15: reg = ["$15"],
66        r16: reg = ["$16"],
67        r17: reg = ["$17"],
68        r18: reg = ["$18"],
69        r19: reg = ["$19"],
70        r20: reg = ["$20"],
71        r21: reg = ["$21"],
72        r22: reg = ["$22"],
73        r23: reg = ["$23"],
74        r24: reg = ["$24"],
75        r25: reg = ["$25"],
76        f0: freg = ["$f0"],
77        f1: freg = ["$f1"],
78        f2: freg = ["$f2"],
79        f3: freg = ["$f3"],
80        f4: freg = ["$f4"],
81        f5: freg = ["$f5"],
82        f6: freg = ["$f6"],
83        f7: freg = ["$f7"],
84        f8: freg = ["$f8"],
85        f9: freg = ["$f9"],
86        f10: freg = ["$f10"],
87        f11: freg = ["$f11"],
88        f12: freg = ["$f12"],
89        f13: freg = ["$f13"],
90        f14: freg = ["$f14"],
91        f15: freg = ["$f15"],
92        f16: freg = ["$f16"],
93        f17: freg = ["$f17"],
94        f18: freg = ["$f18"],
95        f19: freg = ["$f19"],
96        f20: freg = ["$f20"],
97        f21: freg = ["$f21"],
98        f22: freg = ["$f22"],
99        f23: freg = ["$f23"],
100        f24: freg = ["$f24"],
101        f25: freg = ["$f25"],
102        f26: freg = ["$f26"],
103        f27: freg = ["$f27"],
104        f28: freg = ["$f28"],
105        f29: freg = ["$f29"],
106        f30: freg = ["$f30"],
107        f31: freg = ["$f31"],
108        #error = ["$0"] =>
109            "constant zero cannot be used as an operand for inline asm",
110        #error = ["$1"] =>
111            "reserved for assembler (Assembler Temp)",
112        #error = ["$26"] =>
113            "OS-reserved register cannot be used as an operand for inline asm",
114        #error = ["$27"] =>
115            "OS-reserved register cannot be used as an operand for inline asm",
116        #error = ["$28"] =>
117            "the global pointer cannot be used as an operand for inline asm",
118        #error = ["$29"] =>
119            "the stack pointer cannot be used as an operand for inline asm",
120        #error = ["$30"] =>
121            "the frame pointer cannot be used as an operand for inline asm",
122        #error = ["$31"] =>
123            "the return address register cannot be used as an operand for inline asm",
124    }
125}
126
127impl MipsInlineAsmReg {
128    pub fn emit(
129        self,
130        out: &mut dyn fmt::Write,
131        _arch: InlineAsmArch,
132        _modifier: Option<char>,
133    ) -> fmt::Result {
134        out.write_str(self.name())
135    }
136}