From 3789e206f3ac0a73cf3fe6caa5ab2d00bddb67d1 Mon Sep 17 00:00:00 2001 From: Lokathor Date: Wed, 14 Nov 2018 19:47:56 -0700 Subject: [PATCH] VolatilePtr should be testing safe now --- src/core_extras.rs | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/src/core_extras.rs b/src/core_extras.rs index ef9aed2..8322574 100644 --- a/src/core_extras.rs +++ b/src/core_extras.rs @@ -5,7 +5,7 @@ /// /// Accessing the GBA's IO registers and video ram and specific other places on /// **must** be done with volatile operations. Having this wrapper makes that -/// more clear for all the global const values into IO registers. +/// more clear for all the const value IO registers. #[derive(Debug, Clone, Copy, Hash, PartialEq, Eq, PartialOrd, Ord)] #[repr(transparent)] pub struct VolatilePtr(pub *mut T); @@ -25,7 +25,14 @@ impl VolatilePtr { /// This method adds absolutely no additional safety, so all safety concerns /// for a normal raw pointer volatile read apply. pub unsafe fn read(&self) -> T { - core::ptr::read_volatile(self.0) + #[cfg(not(test))] + { + core::ptr::read_volatile(self.0) + } + #[cfg(test)] + { + core::mem::zeroed::() + } } /// Performs a volatile write. @@ -35,7 +42,14 @@ impl VolatilePtr { /// This method adds absolutely no additional safety, so all safety concerns /// for a normal raw pointer volatile write apply. pub unsafe fn write(&self, data: T) { - core::ptr::write_volatile(self.0, data); + #[cfg(not(test))] + { + core::ptr::write_volatile(self.0, data); + } + #[cfg(test)] + { + drop(data) + } } /// Offsets this address by the amount given. @@ -45,6 +59,13 @@ impl VolatilePtr { /// This is a standard offset, so all safety concerns of a normal raw pointer /// offset apply. pub unsafe fn offset(self, count: isize) -> Self { - VolatilePtr(self.0.offset(count)) + #[cfg(not(test))] + { + VolatilePtr(self.0.offset(count)) + } + #[cfg(test)] + { + VolatilePtr(self.0.wrapping_offset(count)) + } } }