syscall-alt

Crates.iosyscall-alt
lib.rssyscall-alt
version0.0.14
sourcesrc
created_at2016-09-14 12:05:31.232407
updated_at2017-05-24 10:03:07.652987
descriptionsyscall-alt
homepagehttps://github.com/lemonrock/syscall-alt
repositoryhttps://github.com/lemonrock/syscall-alt.git
max_upload_size
id6487
size878,216
Raphael Cohn (raphaelcohn)

documentation

https://github.com/lemonrock/syscall-alt/blob/master/README.md

README

[](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.

Commit count: 37

cargo fmt