Stack alignment is 16 bytes on x86_64.

Make sure that the stack frame size is always a multiple of 16 as
specified by the x86_64 ABI.

Heads up @pchickey
This commit is contained in:
Jakob Stoklund Olesen
2018-01-31 16:17:53 -08:00
parent ff16583c59
commit 429027e2f2

View File

@@ -180,20 +180,28 @@ pub fn spiderwasm_prologue_epilogue(
func: &mut ir::Function,
isa: &TargetIsa,
) -> result::CtonResult {
let word_size = if isa.flags().is_64bit() { 8 } else { 4 };
let (word_size, stack_align) = if isa.flags().is_64bit() {
(8, 16)
} else {
(4, 4)
};
let bytes = StackSize::from(isa.flags().spiderwasm_prologue_words()) * word_size;
let mut ss = ir::StackSlotData::new(ir::StackSlotKind::IncomingArg, bytes);
ss.offset = -(bytes as StackOffset);
func.stack_slots.push(ss);
layout_stack(&mut func.stack_slots, word_size)?;
layout_stack(&mut func.stack_slots, stack_align)?;
Ok(())
}
/// Insert a System V-compatible prologue and epilogue.
pub fn native_prologue_epilogue(func: &mut ir::Function, isa: &TargetIsa) -> result::CtonResult {
let word_size = if isa.flags().is_64bit() { 8 } else { 4 };
let (word_size, stack_align) = if isa.flags().is_64bit() {
(8, 16)
} else {
(4, 4)
};
let csr_type = if isa.flags().is_64bit() {
ir::types::I64
} else {
@@ -215,7 +223,7 @@ pub fn native_prologue_epilogue(func: &mut ir::Function, isa: &TargetIsa) -> res
offset: -csr_stack_size,
});
let total_stack_size = layout_stack(&mut func.stack_slots, word_size)? as i32;
let total_stack_size = layout_stack(&mut func.stack_slots, stack_align)? as i32;
let local_stack_size = (total_stack_size - csr_stack_size) as i64;
// Add CSRs to function signature