1
0
Fork 0

Rename Stack::top() to Stack::base(), which is correct.

Fixes #25.
This commit is contained in:
whitequark 2016-08-11 23:18:36 +00:00 committed by edef
parent 7d5075edc2
commit b79e7c0a9b
6 changed files with 10 additions and 10 deletions

View File

@ -84,7 +84,7 @@ pub unsafe fn init(stack: &Stack, f: unsafe extern "C" fn(usize) -> !) -> StackP
*sp.0 = val *sp.0 = val
} }
let mut sp = StackPointer(stack.top() as *mut usize); let mut sp = StackPointer(stack.base() as *mut usize);
push(&mut sp, 0xdead0cfa); // CFA slot push(&mut sp, 0xdead0cfa); // CFA slot
push(&mut sp, f as usize); // function push(&mut sp, f as usize); // function
push(&mut sp, trampoline_1 as usize); push(&mut sp, trampoline_1 as usize);
@ -96,7 +96,7 @@ pub unsafe fn init(stack: &Stack, f: unsafe extern "C" fn(usize) -> !) -> StackP
pub unsafe fn swap(arg: usize, old_sp: &mut StackPointer, new_sp: &StackPointer, pub unsafe fn swap(arg: usize, old_sp: &mut StackPointer, new_sp: &StackPointer,
new_stack: &Stack) -> usize { new_stack: &Stack) -> usize {
// Address of the topmost CFA stack slot. // Address of the topmost CFA stack slot.
let new_cfa = (new_stack.top() as *mut usize).offset(-1); let new_cfa = (new_stack.base() as *mut usize).offset(-1);
#[naked] #[naked]
unsafe extern "C" fn trampoline() { unsafe extern "C" fn trampoline() {

View File

@ -85,7 +85,7 @@ pub unsafe fn init(stack: &Stack, f: unsafe extern "C" fn(usize) -> !) -> StackP
*sp.0 = val *sp.0 = val
} }
let mut sp = StackPointer(stack.top() as *mut usize); let mut sp = StackPointer(stack.base() as *mut usize);
push(&mut sp, 0xdeaddeaddead0cfa); // CFA slot push(&mut sp, 0xdeaddeaddead0cfa); // CFA slot
push(&mut sp, 0 as usize); // alignment push(&mut sp, 0 as usize); // alignment
push(&mut sp, f as usize); // function push(&mut sp, f as usize); // function
@ -98,7 +98,7 @@ pub unsafe fn init(stack: &Stack, f: unsafe extern "C" fn(usize) -> !) -> StackP
pub unsafe fn swap(arg: usize, old_sp: &mut StackPointer, new_sp: &StackPointer, pub unsafe fn swap(arg: usize, old_sp: &mut StackPointer, new_sp: &StackPointer,
new_stack: &Stack) -> usize { new_stack: &Stack) -> usize {
// Address of the topmost CFA stack slot. // Address of the topmost CFA stack slot.
let new_cfa = (new_stack.top() as *mut usize).offset(-1); let new_cfa = (new_stack.base() as *mut usize).offset(-1);
#[naked] #[naked]
unsafe extern "C" fn trampoline() { unsafe extern "C" fn trampoline() {

View File

@ -12,7 +12,7 @@ pub struct StackId(self::valgrind::Value);
impl StackId { impl StackId {
#[inline(always)] #[inline(always)]
pub fn register<Stack: stack::Stack>(stack: &Stack) -> StackId { pub fn register<Stack: stack::Stack>(stack: &Stack) -> StackId {
StackId(stack_register(stack.limit(), stack.top())) StackId(stack_register(stack.limit(), stack.base()))
} }
} }

View File

@ -51,7 +51,7 @@ impl Stack {
impl stack::Stack for Stack { impl stack::Stack for Stack {
#[inline(always)] #[inline(always)]
fn top(&self) -> *mut u8 { fn base(&self) -> *mut u8 {
unsafe { unsafe {
self.ptr.offset(self.len as isize) self.ptr.offset(self.len as isize)
} }

View File

@ -5,10 +5,10 @@
/// A trait for objects that hold ownership of a stack. /// A trait for objects that hold ownership of a stack.
pub trait Stack { pub trait Stack {
/// Returns the top of the stack. /// Returns the base of the stack.
/// On all modern architectures, the stack grows downwards, /// On all modern architectures, the stack grows downwards,
/// so this is the highest address. /// so this is the highest address.
fn top(&self) -> *mut u8; fn base(&self) -> *mut u8;
/// Returns the bottom of the stack. /// Returns the bottom of the stack.
/// On all modern architectures, the stack grows downwards, /// On all modern architectures, the stack grows downwards,
/// so this is the lowest address. /// so this is the lowest address.

View File

@ -9,12 +9,12 @@ use fringe::{Stack, OsStack};
fn default_stack() { fn default_stack() {
let stack = OsStack::new(0).unwrap(); let stack = OsStack::new(0).unwrap();
// Make sure the topmost page of the stack, at least, is accessible. // Make sure the topmost page of the stack, at least, is accessible.
unsafe { *(stack.top().offset(-1)) = 0; } unsafe { *(stack.base().offset(-1)) = 0; }
} }
#[test] #[test]
fn one_page_stack() { fn one_page_stack() {
let stack = OsStack::new(4096).unwrap(); let stack = OsStack::new(4096).unwrap();
// Make sure the topmost page of the stack, at least, is accessible. // Make sure the topmost page of the stack, at least, is accessible.
unsafe { *(stack.top().offset(-1)) = 0; } unsafe { *(stack.base().offset(-1)) = 0; }
} }