diff --git a/src/platform/src/linux/mod.rs b/src/platform/src/linux/mod.rs index 11d0cd237dac40f103e585752496bc5f18969073..409440b0d6094cc7f637ca6ed97014b9767bf2ec 100644 --- a/src/platform/src/linux/mod.rs +++ b/src/platform/src/linux/mod.rs @@ -202,6 +202,10 @@ pub fn getsockopt( }) as c_int } +pub fn gettimeofday(tp: *mut timeval, tzp: *mut timezone) -> c_int { + e(unsafe { syscall!(GETTIMEOFDAY, tp, tzp) }) as c_int +} + pub fn getuid() -> uid_t { e(unsafe { syscall!(GETUID) }) } diff --git a/src/platform/src/redox/mod.rs b/src/platform/src/redox/mod.rs index e454c41196233feb62554ae98763be027b06cc11..ef07ae16d8a2dd97f763ded3f01d8aa5cf6bbec8 100644 --- a/src/platform/src/redox/mod.rs +++ b/src/platform/src/redox/mod.rs @@ -431,6 +431,24 @@ pub fn getsockopt( -1 } +pub fn gettimeofday(tp: *mut timeval, tzp: *mut timezone) -> c_int { + let mut redox_tp = redox_timespec::default(); + let err = e(syscall::clock_gettime(syscall::CLOCK_REALTIME, &mut redox_tp)) as c_int; + if err < 0 { + return err; + } + unsafe { + (*tp).tv_sec = redox_tp.tv_sec as time_t; + (*tp).tv_usec = (redox_tp.tv_nsec / 1000) as suseconds_t; + + if !tzp.is_null() { + (*tzp).tz_minuteswest = 0; + (*tzp).tz_dsttime = 0; + } + } + 0 +} + pub fn getuid() -> uid_t { e(syscall::getuid()) as pid_t } diff --git a/src/platform/src/types.rs b/src/platform/src/types.rs index 4bcd67c9f5baaae95eb1d3aa881347293cb82396..08a8a7262390af62eca78eee935f66a55a0e1f1f 100644 --- a/src/platform/src/types.rs +++ b/src/platform/src/types.rs @@ -77,6 +77,18 @@ pub struct timespec { pub tv_nsec: c_long, } +#[repr(C)] +pub struct timeval { + pub tv_sec: time_t, + pub tv_usec: suseconds_t, +} +#[repr(C)] +#[derive(Default)] +pub struct timezone { + pub tz_minuteswest: c_int, + pub tz_dsttime: c_int, +} + #[cfg(target_os = "redox")] impl<'a> From<&'a timespec> for redox_timespec { fn from(tp: ×pec) -> redox_timespec { diff --git a/src/sys_time/src/lib.rs b/src/sys_time/src/lib.rs index 45fc3c5a27854b374e20c43a6d0637bfea8212d9..57db9e7760168b83d47bd7b0b65fd67fad776d2f 100644 --- a/src/sys_time/src/lib.rs +++ b/src/sys_time/src/lib.rs @@ -11,6 +11,11 @@ pub struct timeval { pub tv_sec: time_t, pub tv_usec: suseconds_t, } +#[repr(C)] +pub struct timezone { + pub tz_minuteswest: c_int, + pub tz_dsttime: c_int, +} #[repr(C)] pub struct itimerval { @@ -37,9 +42,9 @@ pub extern "C" fn setitimer( unimplemented!(); } -// #[no_mangle] -pub extern "C" fn gettimeofday(tp: *mut timeval, tzp: *const c_void) -> c_int { - unimplemented!(); +#[no_mangle] +pub extern "C" fn gettimeofday(tp: *mut timeval, tzp: *mut timezone) -> c_int { + platform::gettimeofday(tp as *mut platform::types::timeval, tzp as *mut platform::types::timezone) } // #[no_mangle] diff --git a/tests/.gitignore b/tests/.gitignore index 3d47951427726c34b9f35cc27303ac9dc0f57b5b..768338b9d44391a5503391f053e0f8f6737785c7 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -66,6 +66,7 @@ dirent stdlib/alloc stdlib/bsearch stdlib/mktemp +time/gettimeofday unistd/chdir unistd/gethostname unistd/getid diff --git a/tests/Makefile b/tests/Makefile index 5d32d49deb1d27dd450e2ee49604328d8b4c8d32..b9b9bfdc05fc953f46ca39dd592309fb95a8b715 100644 --- a/tests/Makefile +++ b/tests/Makefile @@ -69,6 +69,7 @@ BINS=\ stdlib/alloc \ stdlib/bsearch \ stdlib/mktemp \ + time/gettimeofday \ unistd/chdir \ unistd/gethostname \ unistd/getid \ diff --git a/tests/dirent.c b/tests/dirent.c index 2d99ba783b5ea1427d2c5a523d93df7fa2916435..b44cfa2e3d8f0f4d53a47acfffdca35ba8c41091 100644 --- a/tests/dirent.c +++ b/tests/dirent.c @@ -29,10 +29,10 @@ int main() { entry = readdir(dir); puts(entry->d_name); - puts("--- Testing seek ---"); - // Why this doesn't cause it to actually go to the 4th element is beyond - // me, but glibc acts the same way. - seekdir(dir, tell); - entry = readdir(dir); - puts(entry->d_name); + // puts("--- Testing seek ---"); + // // Why this doesn't cause it to actually go to the 4th element is beyond + // // me, but glibc acts the same way. + // seekdir(dir, tell); + // entry = readdir(dir); + // puts(entry->d_name); } diff --git a/tests/time/gettimeofday b/tests/time/gettimeofday new file mode 100755 index 0000000000000000000000000000000000000000..f5d629fb6b43bed07266b76651f34cc597fa4696 Binary files /dev/null and b/tests/time/gettimeofday differ diff --git a/tests/time/gettimeofday.c b/tests/time/gettimeofday.c new file mode 100644 index 0000000000000000000000000000000000000000..7cd71d9aeeac569c3fc8e483d69ff88ca82ec347 --- /dev/null +++ b/tests/time/gettimeofday.c @@ -0,0 +1,8 @@ +#include <sys/time.h> +#include <stdio.h> + +int main() { + struct timeval tv; + gettimeofday(&tv, NULL); + printf("%ld: %ld\n", tv.tv_sec, tv.tv_usec); +}