about summary refs log tree commit diff
path: root/library/std/src/sys/pal/uefi/thread.rs
blob: e1e66eaca1ba3465648902352759b52725290959 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
use super::unsupported;
use crate::ffi::CStr;
use crate::io;
use crate::num::NonZero;
use crate::ptr::NonNull;
use crate::time::Duration;

pub struct Thread(!);

pub const DEFAULT_MIN_STACK_SIZE: usize = 64 * 1024;

impl Thread {
    // unsafe: see thread::Builder::spawn_unchecked for safety requirements
    pub unsafe fn new(
        _stack: usize,
        _name: Option<&str>,
        _p: Box<dyn FnOnce()>,
    ) -> io::Result<Thread> {
        unsupported()
    }

    pub fn yield_now() {
        // do nothing
    }

    pub fn set_name(_name: &CStr) {
        // nope
    }

    pub fn sleep(dur: Duration) {
        let boot_services: NonNull<r_efi::efi::BootServices> =
            crate::os::uefi::env::boot_services().expect("can't sleep").cast();
        let mut dur_ms = dur.as_micros();
        // ceil up to the nearest microsecond
        if dur.subsec_nanos() % 1000 > 0 {
            dur_ms += 1;
        }

        while dur_ms > 0 {
            let ms = crate::cmp::min(dur_ms, usize::MAX as u128);
            let _ = unsafe { ((*boot_services.as_ptr()).stall)(ms as usize) };
            dur_ms -= ms;
        }
    }

    pub fn join(self) {
        self.0
    }
}

pub fn available_parallelism() -> io::Result<NonZero<usize>> {
    // UEFI is single threaded
    Ok(NonZero::new(1).unwrap())
}