From 7ad9a03ff794a8e190f52e44688c9a89a3bfb213 Mon Sep 17 00:00:00 2001 From: Lokathor Date: Thu, 20 Oct 2022 15:32:05 -0600 Subject: [PATCH] unfortunately, the BX trick is unsound in the presence of a double-inline, so we can't use it. --- src/asm_runtime.rs | 26 -------------------------- src/mmio.rs | 4 ++-- 2 files changed, 2 insertions(+), 28 deletions(-) diff --git a/src/asm_runtime.rs b/src/asm_runtime.rs index d1e4e4b..dd9cffe 100644 --- a/src/asm_runtime.rs +++ b/src/asm_runtime.rs @@ -1018,29 +1018,3 @@ core::arch::global_asm! { }, options(raw), } - -/// This does a `bx` directly to [`__aeabi_memcpy4`], instead of doing a `bl` to -/// the symbol and having the linker generate a stub function. -/// -/// This saves only 6 cycles, but there's no real harm in it other than it being -/// a pain in the butt to manually indirect like this. -/// -/// In the future we probably want to allow users to call this, but for now it's -/// fine to just have it internally for the one place we're manually using it. -#[inline] -#[allow(non_snake_case)] -pub(crate) unsafe fn bx__aeabi_memcpy4( - dest: *mut u8, src: *const u8, byte_count: usize, -) { - let f: unsafe extern "C" fn(*mut u8, *const u8, usize) = __aeabi_memcpy4; - core::arch::asm!("bx r3", - inout("r0") dest => _, - inout("r1") src => _, - inout("r2") byte_count => _, - inout("r3") f => _, - out("r12") _, - // CAUTION: this doesn't allow `lr` to be altered in the ASM block, so it - // doesn't work for the general C ABI, but since we've implemented the - // specific function ourselves we know that `lr` won't be trashed. - ) -} diff --git a/src/mmio.rs b/src/mmio.rs index 6364bde..9342bbc 100644 --- a/src/mmio.rs +++ b/src/mmio.rs @@ -265,11 +265,11 @@ macro_rules! make_me_a_screenblock_addr { /// Overwrites the entire screenblock with the data provided. pub fn write_words(self, words: &[u32; Self::WORD_COUNT]) { - use crate::prelude::bx__aeabi_memcpy4; + use crate::prelude::__aeabi_memcpy4; let dest: *mut u32 = self.block.as_ptr() as *mut u32; let src: *const u32 = words.as_ptr(); let byte_count = size_of::<[u32; Self::WORD_COUNT]>(); - unsafe { bx__aeabi_memcpy4(dest.cast(), src.cast(), byte_count) }; + unsafe { __aeabi_memcpy4(dest.cast(), src.cast(), byte_count) }; } } }