13 releases

Uses old Rust 2015

0.0.14 May 24, 2017
0.0.13 May 24, 2017
0.0.12 Apr 25, 2017
0.0.11 Oct 1, 2016
0.0.10 Sep 19, 2016

#259 in Unix APIs

Download history 35/week @ 2022-11-27 55/week @ 2022-12-04 77/week @ 2022-12-11 76/week @ 2022-12-18 44/week @ 2022-12-25 21/week @ 2023-01-01 69/week @ 2023-01-08 25/week @ 2023-01-15 78/week @ 2023-01-22 111/week @ 2023-01-29 60/week @ 2023-02-05 68/week @ 2023-02-12 179/week @ 2023-02-19 9/week @ 2023-02-26 71/week @ 2023-03-05 19/week @ 2023-03-12

304 downloads per month
Used in 21 crates (7 directly)

MIT license

1MB
13K SLoC

[](This file is part of syscall-alt. It is subject to the license terms in the COPYRIGHT file found in the top-level directory of this distribution and at https://raw.githubusercontent.com/lemonrock/syscall-alt/master/COPYRIGHT. No part of syscall-alt, including this file, may be copied, modified, propagated, or distributed except according to the terms contained in the COPYRIGHT file.) [](Copyright © 2016 The developers of syscall-alt. See the COPYRIGHT file in the top-level directory of this distribution and at https://raw.githubusercontent.com/lemonrock/syscall-alt/master/COPYRIGHT.)

syscall-alt

syscall-alt is a rust crate that provides inline assembler (asm! macro) definitions of syscalls for some Linux platforms. It also includes:-

  • An enum defining common Linux syscalls;
  • Some minor wrapper logic to make straightforward to work with syscalls.
  • Correct Syscall / Posix error codes ('E'), eg EINVAL
    • Linux:-
      • These differ slightly on MIPS and PowerPC
      • MIPS64 is the same as MIPS
      • PowerPC64 is the same as PowerPC
      • PowerPC is nearly identical to x86_64 bar EDEADLOCK:-
        • PowerPC is the only platform on which EDEADLOCK != EDEADLK (so watch out when using match)
      • MIPS is very different to x86_64
        • But it has exactly the same set of E numbers
  • SYS call numbers and E numbers are available for every arch, eg if you want to know them for arm, but are compiled for x86_64, they are available
    • Watch out if using EDEADLOCK, EDEADLCK, ENOTSUP and EOPNOTSUPP; these vary in definition and value, sometimes being missing, sometimes being equal
    • Take a little care with EWOULDBLOCK and EAGAIN; all current platforms make EWOULDBLOCK the same as EAGAIN, but this isn't required by POSIX
  • A windows stub, which contains EAGAIN, etc, as defined on Windows (but no syscall numbers)

The code is very much 'early-days', so expect breaking changes.

This crate is #[!no_std], and does not require the std library or the libc crate

TODO

Licensing

The license for this project is AGPL.

No runtime deps