forked from Bananymous/banan-os
Kernel: Make sys_nanosleep interruptable by signals
This commit is contained in:
parent
deeb6d2756
commit
393ac33e3c
|
@ -616,10 +616,31 @@ namespace Kernel
|
||||||
{
|
{
|
||||||
LockGuard _(m_lock);
|
LockGuard _(m_lock);
|
||||||
validate_pointer_access(rqtp, sizeof(timespec));
|
validate_pointer_access(rqtp, sizeof(timespec));
|
||||||
|
if (rmtp)
|
||||||
validate_pointer_access(rmtp, sizeof(timespec));
|
validate_pointer_access(rmtp, sizeof(timespec));
|
||||||
}
|
}
|
||||||
// TODO: rmtp
|
|
||||||
SystemTimer::get().sleep(rqtp->tv_sec * 1000 + BAN::Math::div_round_up<uint64_t>(rqtp->tv_nsec, 1'000'000));
|
uint64_t sleep_ms = rqtp->tv_sec * 1000 + BAN::Math::div_round_up<uint64_t>(rqtp->tv_nsec, 1'000'000);
|
||||||
|
if (sleep_ms == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
uint64_t wake_time_ms = SystemTimer::get().ms_since_boot() + sleep_ms;
|
||||||
|
|
||||||
|
Scheduler::get().set_current_thread_sleeping(wake_time_ms);
|
||||||
|
|
||||||
|
uint64_t current_ms = SystemTimer::get().ms_since_boot();
|
||||||
|
|
||||||
|
if (current_ms < wake_time_ms)
|
||||||
|
{
|
||||||
|
if (rmtp)
|
||||||
|
{
|
||||||
|
uint64_t remaining_ms = wake_time_ms - current_ms;
|
||||||
|
rmtp->tv_sec = remaining_ms / 1000;
|
||||||
|
rmtp->tv_nsec = (remaining_ms % 1000) * 1'000'000;
|
||||||
|
}
|
||||||
|
return BAN::Error::from_errno(EINTR);
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue