minimal_rt/rt.rs
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 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT License.
//! Architecture-independent runtime support.
#[cfg(minimal_rt)]
#[expect(clippy::missing_safety_doc)]
mod instead_of_builtins {
/// Implementation cribbed from compiler_builtins.
#[inline(always)]
unsafe fn copy_backward_bytes(mut dest: *mut u8, mut src: *const u8, n: usize) {
// SAFETY: The caller guarantees that the pointers and length are correct.
unsafe {
let dest_start = dest.sub(n);
while dest_start < dest {
dest = dest.sub(1);
src = src.sub(1);
*dest = *src;
}
}
}
unsafe extern "C" {
fn memcpy(dest: *mut u8, src: *const u8, n: usize) -> *mut u8;
}
/// Implementation cribbed from compiler_builtins.
// SAFETY: The minimal_rt_build crate ensures that when this code is compiled
// there is no libc for this to conflict with.
#[unsafe(no_mangle)]
unsafe extern "C" fn memmove(dest: *mut u8, src: *const u8, n: usize) -> *mut u8 {
let delta = (dest as usize).wrapping_sub(src as usize);
if delta >= n {
// SAFETY: We can copy forwards because either dest is far enough ahead of src,
// or src is ahead of dest (and delta overflowed).
unsafe {
memcpy(dest, src, n);
}
} else {
// SAFETY: dest and src must be copied backward due to src and dest.
unsafe {
let dest = dest.add(n);
let src = src.add(n);
copy_backward_bytes(dest, src, n);
}
}
dest
}
/// This implementation is cribbed from compiler_builtins. It would be nice to
/// use those implementation for all the above functions, but those require
/// nightly as these are not yet stabilized.
// SAFETY: The minimal_rt_build crate ensures that when this code is compiled
// there is no libc for this to conflict with.
#[unsafe(no_mangle)]
unsafe extern "C" fn bcmp(s1: *const u8, s2: *const u8, n: usize) -> i32 {
// SAFETY: The caller guarantees that the pointers and length are correct.
unsafe {
let mut i = 0;
while i < n {
let a = *s1.add(i);
let b = *s2.add(i);
if a != b {
return a as i32 - b as i32;
}
i += 1;
}
0
}
}
}