mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-26 00:56:38 +11:00
fix
This commit is contained in:
parent
433fad15a1
commit
a3de583d40
1 changed files with 25 additions and 2 deletions
|
@ -53,7 +53,6 @@ static __IWRAM_ALLOC: BlockAllocator = unsafe {
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(any(test, feature = "testing"))]
|
#[cfg(any(test, feature = "testing"))]
|
||||||
#[cfg(test)]
|
|
||||||
pub(crate) unsafe fn number_of_blocks() -> u32 {
|
pub(crate) unsafe fn number_of_blocks() -> u32 {
|
||||||
GLOBAL_ALLOC.number_of_blocks()
|
GLOBAL_ALLOC.number_of_blocks()
|
||||||
}
|
}
|
||||||
|
@ -74,7 +73,7 @@ fn iwram_data_end() -> usize {
|
||||||
|
|
||||||
// TODO: This seems completely wrong, but without the &, rust generates
|
// TODO: This seems completely wrong, but without the &, rust generates
|
||||||
// a double dereference :/. Maybe a bug in nightly?
|
// a double dereference :/. Maybe a bug in nightly?
|
||||||
(unsafe { &__iwram_data_end }) as *const _ as usize
|
(unsafe { &__iwram_data_end }) as *const _ as usize + 0x200
|
||||||
}
|
}
|
||||||
|
|
||||||
fn data_end() -> usize {
|
fn data_end() -> usize {
|
||||||
|
@ -171,4 +170,28 @@ mod test {
|
||||||
"data end should be smaller than 0x0203_0000"
|
"data end should be smaller than 0x0203_0000"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test_case]
|
||||||
|
fn should_return_data_end_somewhere_in_iwram(_gba: &mut crate::Gba) {
|
||||||
|
let data_end = iwram_data_end();
|
||||||
|
|
||||||
|
assert!(
|
||||||
|
(0x0300_0000..0x0300_8000).contains(&data_end),
|
||||||
|
"iwram data end should be in iwram, instead was {}",
|
||||||
|
data_end
|
||||||
|
);
|
||||||
|
crate::println!("data end was {:#010X}", data_end);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test_case]
|
||||||
|
fn allocate_to_iwram_works(_gba: &mut crate::Gba) {
|
||||||
|
let a = Box::new_in(1, IWRAM_ALLOC);
|
||||||
|
let p = &*a as *const i32;
|
||||||
|
let addr = p as usize;
|
||||||
|
assert!(
|
||||||
|
(0x0300_0000..0x0300_8000).contains(&addr),
|
||||||
|
"address of allocation should be within iwram, instead at {:?}",
|
||||||
|
p
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue