-
-
Notifications
You must be signed in to change notification settings - Fork 51
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Heap Management? #83
Comments
It's not. Though if you'd like to submit an allocation impl that'd be neat. |
I wonder, is there any ARM-compatible allocator crates around already? I am pretty new to Rust, but I am really surprised that such basic thing as a generic memory allocation needs to be reinvented for each embedded system. |
There might be some for more modern embedded devices. The major issues i can think of are:
That said, I have not been doing GBA programming much lately, and i have not tried very hard to come up with a good plan, so you might think of something good just by putting your mind to it. |
I've done some research and made a small working prototype of heap manager over the top of standard libc malloc/free methods. Currently I'm too shy to share the full project code (still polishing it), but the allocator piece looks like the following: // _sbrk implementation:
// C reference: https://github.com/eblot/newlib/blob/master/libgloss/epiphany/sbrk.c
static mut HEAP_END: *mut u8 = core::ptr::null_mut();
#[no_mangle]
pub extern "C" fn _sbrk(incr: i32) -> *mut u8 {
unsafe {
if HEAP_END == core::ptr::null_mut() {
HEAP_END = 0x03000000 as *mut u8;
}
let prev_heap_end = HEAP_END;
HEAP_END = HEAP_END.offset(incr as isize);
return prev_heap_end;
}
}
// Custom allocator:
struct EwramAllocator;
#[link(name = "c")]
extern {
fn malloc(_size: usize) -> *mut u8;
fn free(ptr: *mut u8);
}
unsafe impl GlobalAlloc for EwramAllocator {
unsafe fn alloc(&self, layout: Layout) -> *mut u8 {
return malloc(layout.size());
}
unsafe fn dealloc(&self, ptr: *mut u8, _layout: Layout) {
free(ptr);
}
}
#[global_allocator]
static A: EwramAllocator = EwramAllocator;
#[alloc_error_handler]
fn error_handler(_: core::alloc::Layout) -> ! {
loop {}
} I had some experience with C, but I am very new to the Rust itself - I wonder, what issues it may case? I tried boxing/unboxing, manual allocating, etc, seems to work, at least for memory allocation. |
I'll try to look at this later, but for now I'll give a ping to @ketsuban |
I have a few concerns.
I wrote my own allocator implementation a while back, principally based on the one used in |
Well, I've done small refactoring of /// These variables are defined in the linker script.
extern "C" {
static __ewram_start: usize;
static __ewram_top: usize;
}
/// Pointer to the current heap counter, used by _sbrk:
pub static mut HEAP_CURRENT: *mut u8 = core::ptr::null_mut();
/// _sbrk implementation for GBA.
/// C reference: https://github.com/eblot/newlib/blob/master/libgloss/epiphany/sbrk.c
#[no_mangle]
pub unsafe extern "C" fn _sbrk(incr: i32) -> *mut u8 {
let heap_start = (&__ewram_start as *const usize) as *mut u8;
let heap_top = (&__ewram_top as *const usize) as *mut u8;
if HEAP_CURRENT == core::ptr::null_mut() {
HEAP_CURRENT = heap_start;
}
if HEAP_CURRENT >= heap_top {
return (0 as *mut u8).offset(-1);
}
let prev_heap_end = HEAP_CURRENT;
HEAP_CURRENT = HEAP_CURRENT.offset(incr as isize);
return prev_heap_end;
} External variables are defined in the linker script:
But what about alignment - that is a real issue... As far as I know, Edit: Possible solution would be allocating enough space for size + alignment and padding excessive bytes. |
Someone pointed me at https://github.com/ivmai/bdwgc/ as a GC that could potentially be used in a very low memory situation so i'm just putting it here as a reminder link. EDIT: rust crate form: https://github.com/raviqqe/bdwgc-alloc/, and by same author there's also https://github.com/ivmai/tinygc |
That's definitely interesting, would take a look. |
I see no sign of dynamic allocation in source files and all examples are compiled with
no_std
flag, causing no built-in allocator. So how heap memory is managed in this crate?The text was updated successfully, but these errors were encountered: