use crate::backend::reg::{
ArgReg, FromAsm, RetReg, SyscallNumber, ToAsm as _, A0, A1, A2, A3, A4, A5, R0,
};
use core::arch::asm;
#[inline]
pub(in crate::backend) unsafe fn syscall0_readonly(nr: SyscallNumber) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
lateout("$7" ) err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags, readonly)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall1(nr: SyscallNumber<'_>, a0: ArgReg<'_, A0>) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
lateout("$7" ) err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall1_readonly(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
lateout("$7" ) err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags, readonly)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall1_noreturn(nr: SyscallNumber<'_>, a0: ArgReg<'_, A0>) -> ! {
asm!(
"syscall",
"teq $0,$0",
in("$2" ) nr.to_asm(),
in("$4" ) a0.to_asm(),
options(nostack, noreturn)
)
}
#[inline]
pub(in crate::backend) unsafe fn syscall2(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
lateout("$7" ) err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall2_readonly(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
lateout("$7" ) err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags, readonly)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall3(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
lateout("$7" ) err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall3_readonly(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
lateout("$7" ) err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags, readonly)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall4(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
a3: ArgReg<'_, A3>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
inlateout("$7" ) a3.to_asm() => err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall4_readonly(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
a3: ArgReg<'_, A3>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
inlateout("$7" ) a3.to_asm() => err,
lateout("$8" ) _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags, readonly)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall5(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
a3: ArgReg<'_, A3>,
a4: ArgReg<'_, A4>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
inlateout("$7" ) a3.to_asm() => err,
inlateout("$8" ) a4.to_asm() => _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall5_readonly(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
a3: ArgReg<'_, A3>,
a4: ArgReg<'_, A4>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
inlateout("$7" ) a3.to_asm() => err,
inlateout("$8" ) a4.to_asm() => _,
lateout("$9" ) _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags, readonly)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall6(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
a3: ArgReg<'_, A3>,
a4: ArgReg<'_, A4>,
a5: ArgReg<'_, A5>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
inlateout("$7" ) a3.to_asm() => err,
inlateout("$8" ) a4.to_asm() => _,
inlateout("$9" ) a5.to_asm() => _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}
#[inline]
pub(in crate::backend) unsafe fn syscall6_readonly(
nr: SyscallNumber<'_>,
a0: ArgReg<'_, A0>,
a1: ArgReg<'_, A1>,
a2: ArgReg<'_, A2>,
a3: ArgReg<'_, A3>,
a4: ArgReg<'_, A4>,
a5: ArgReg<'_, A5>,
) -> RetReg<R0> {
let x0;
let err: usize;
asm!(
"syscall",
inlateout("$2" ) nr.to_asm() => x0,
in("$4" ) a0.to_asm(),
in("$5" ) a1.to_asm(),
in("$6" ) a2.to_asm(),
inlateout("$7" ) a3.to_asm() => err,
inlateout("$8" ) a4.to_asm() => _,
inlateout("$9" ) a5.to_asm() => _,
lateout("$10" ) _,
lateout("$11" ) _,
lateout("$12" ) _,
lateout("$13" ) _,
lateout("$14" ) _,
lateout("$15" ) _,
lateout("$24" ) _,
lateout("$25" ) _,
options(nostack, preserves_flags, readonly)
);
FromAsm::from_asm(if err != 0 {
(x0 as usize).wrapping_neg() as *mut _
} else {
x0
})
}