Skip to content

Commit

Permalink
Merge pull request rust-lang#3942 from randomPoison/trusty-patch
Browse files Browse the repository at this point in the history
Add Trusty OS support
  • Loading branch information
tgross35 authored Nov 6, 2024
2 parents f3152ef + b348da8 commit 94c7cae
Show file tree
Hide file tree
Showing 3 changed files with 156 additions and 0 deletions.
49 changes: 49 additions & 0 deletions libc-test/semver/trusty.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
AT_PAGESZ
CLOCK_REALTIME
MAP_FAILED
PROT_READ
PROT_WRITE
STDERR_FILENO
STDOUT_FILENO
calloc
clockid_t
clock_gettime
close
c_char
c_int
c_int16_t
c_int32_t
c_int64_t
c_int8_t
c_long
c_longlong
c_schar
c_short
c_uchar
c_uint
c_uint16_t
c_uint32_t
c_uint64_t
c_uint8_t
c_ulong
c_ulonglong
c_ushort
c_void
free
getauxval
iovec
malloc
memalign
mmap
munmap
nanosleep
off_t
posix_memalign
realloc
size_t
ssize_t
strlen
timespec
time_t
write
writev
6 changes: 6 additions & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,12 @@ cfg_if! {

mod teeos;
pub use teeos::*;
} else if #[cfg(target_os = "trusty")] {
mod fixed_width_ints;
pub use fixed_width_ints::*;

mod trusty;
pub use trusty::*;
} else if #[cfg(all(target_env = "sgx", target_vendor = "fortanix"))] {
mod fixed_width_ints;
pub use fixed_width_ints::*;
Expand Down
101 changes: 101 additions & 0 deletions src/trusty.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
pub use core::ffi::c_void;

pub type size_t = usize;
pub type ssize_t = isize;

pub type off_t = i64;

cfg_if! {
if #[cfg(any(target_arch = "aarch64", target_arch = "arm"))] {
pub type c_char = u8;
} else if #[cfg(target_arch = "x86_64")] {
pub type c_char = i8;
}
}

pub type c_schar = i8;
pub type c_uchar = u8;
pub type c_short = i16;
pub type c_ushort = u16;
pub type c_int = i32;
pub type c_uint = u32;

cfg_if! {
if #[cfg(target_pointer_width = "32")] {
pub type c_long = i32;
pub type c_ulong = u32;
} else if #[cfg(target_pointer_width = "64")] {
pub type c_long = i64;
pub type c_ulong = u64;
}
}

pub type c_longlong = i64;
pub type c_ulonglong = u64;

pub type c_uint8_t = u8;
pub type c_uint16_t = u16;
pub type c_uint32_t = u32;
pub type c_uint64_t = u64;

pub type c_int8_t = i8;
pub type c_int16_t = i16;
pub type c_int32_t = i32;
pub type c_int64_t = i64;

pub type c_float = f32;
pub type c_double = f64;

pub type time_t = c_long;

pub type clockid_t = c_int;

s! {
pub struct iovec {
pub iov_base: *mut ::c_void,
pub iov_len: ::size_t,
}

pub struct timespec {
pub tv_sec: time_t,
pub tv_nsec: c_long,
}
}

pub const PROT_READ: i32 = 1;
pub const PROT_WRITE: i32 = 2;

// Trusty only supports `CLOCK_BOOTTIME`.
pub const CLOCK_BOOTTIME: clockid_t = 7;

pub const STDOUT_FILENO: ::c_int = 1;
pub const STDERR_FILENO: ::c_int = 2;

pub const AT_PAGESZ: ::c_ulong = 6;

pub const MAP_FAILED: *mut ::c_void = !0 as *mut ::c_void;

extern "C" {
pub fn calloc(nobj: size_t, size: size_t) -> *mut c_void;
pub fn malloc(size: size_t) -> *mut c_void;
pub fn realloc(p: *mut c_void, size: size_t) -> *mut c_void;
pub fn free(p: *mut c_void);
pub fn memalign(align: ::size_t, size: ::size_t) -> *mut ::c_void;
pub fn posix_memalign(memptr: *mut *mut ::c_void, align: ::size_t, size: ::size_t) -> ::c_int;
pub fn write(fd: ::c_int, buf: *const ::c_void, count: ::size_t) -> ::ssize_t;
pub fn writev(fd: ::c_int, iov: *const ::iovec, iovcnt: ::c_int) -> ::ssize_t;
pub fn close(fd: ::c_int) -> ::c_int;
pub fn strlen(cs: *const c_char) -> size_t;
pub fn getauxval(type_: c_ulong) -> c_ulong;
pub fn mmap(
addr: *mut ::c_void,
len: ::size_t,
prot: ::c_int,
flags: ::c_int,
fd: ::c_int,
offset: off_t,
) -> *mut ::c_void;
pub fn munmap(addr: *mut ::c_void, len: ::size_t) -> ::c_int;
pub fn clock_gettime(clk_id: ::clockid_t, tp: *mut ::timespec) -> ::c_int;
pub fn nanosleep(rqtp: *const ::timespec, rmtp: *mut ::timespec) -> ::c_int;
}

0 comments on commit 94c7cae

Please sign in to comment.