39 releases
0.6.18 | Mar 16, 2024 |
---|---|
0.6.15 | Oct 11, 2023 |
0.6.13 | Jun 20, 2023 |
0.6.9 | Mar 23, 2023 |
0.1.4 | Oct 1, 2019 |
#23 in Unix APIs
5,074 downloads per month
Used in 8 crates
(7 directly)
1MB
9K
SLoC
syscalls
This is a low-level library for listing and invoking raw Linux system calls.
Features
- Provides a syscall enum for multiple architectures (see table below).
- Provides inlinable syscall functions for multiple architectures (see table below).
- Provides an
Errno
type for Rustic error handling. - Provides O(1) array-backed
SysnoSet
andSysnoMap
types.
Feature Flags
The features that are enabled by default include std
and serde
.
std
By default, std
support is enabled. If you wish to compile in a no_std
environment, use:
syscalls = { version = "0.6", default-features = false }
serde
Various types can be serialized with Serde. This can be enabled with:
syscalls = { version = "0.6", features = ["serde"] }
full
Enables all extra features.
all
Enables syscall tables for all architectures. If you don't need all
architectures, you can enable them individually with features like arm
, x86
,
powerpc
, etc. See the Architecture Support table below for a full list of
available architectures.
Architecture Support
The Enum column means that a Sysno
enum is implemented for this
architecture.
The Invoke column means that syscalls can be invoked for this architecture.
The Stable Rust? column means that syscall invocation only requires stable Rust. Some architectures require nightly Rust because inline assembly is not yet stabilized for all architectures.
Arch | Enum | Invoke | Stable Rust? |
---|---|---|---|
arm * |
✅ | ✅ | Yes ✅ |
aarch64 |
✅ | ✅ | Yes ✅ |
mips |
✅ | ✅ | No ❌ |
mips64 |
✅ | ✅ | No ❌ |
powerpc |
✅ | ✅ | No ❌ |
powerpc64 |
✅ | ✅ | No ❌ |
riscv32 |
✅ | ❌† | No ❌ |
riscv64 |
✅ | ✅ | Yes ✅ |
s390x |
✅ | ✅ | No ❌ |
sparc |
✅ | ❌ | N/A |
sparc64 |
✅ | ❌ | N/A |
x86 |
✅ | ✅ | Yes ✅ |
x86_64 |
✅ | ✅ | Yes ✅ |
* Includes ARM thumb mode support.
† Rust does not support riscv32 Linux targets, but syscall functions are implemented if you're feeling adventurous.
Updating the syscall list
Updates are pulled from the .tbl
files in the Linux source tree.
- Change the Linux version in
syscalls-gen/src/main.rs
to the latest version. Only update to the latest stable version (not release candidates). - Run
cd syscalls-gen && cargo run
. This will regenerate the syscall tables insrc/arch/
.
Dependencies
~0.3–1MB
~21K SLoC