* src/vm/jit/code.c (code_get_stack_frame_size): Implement stack alignment
[cacao.git] / doc / stack_frames.txt
index 16e0abc4966faec84e6776371fb8793cfe8faa2a..7855d10e9830a50516464055d612955043d7120e 100644 (file)
@@ -39,7 +39,7 @@ x86_64 stack frames
 
 ,--memory address rising
 |
-V   >>>> sp in method (after initial sub) <<<<
+V   >>>> sp in method (after initial sub) (16-byte aligned in non-leaf methods) <<<<
 |          
 |   u8[]  v  arguments for calling methods              \__ rd->memuse slots
 V   u8[]  v  local variable slots allocated on stack    /
@@ -50,7 +50,7 @@ V   u8[0..1] alignment dummy slot                           (in non-leaf methods
 |   u8[]  ^  callee-saved float registers
 V   u8[]  ^  callee-saved integer registers
 |          
-|   >>>> sp on method entry, stack base for replacement  <<<<
+|   >>>> sp on method entry, stack base for replacement  (16-byte aligned) <<<<
 V
 |   u8       return address
 |   u8[]     arguments on stack
@@ -61,6 +61,8 @@ V
 alpha stack frames
 ------------------
 
+XXX currently the stack on alpha is not 16-byte aligned!
+
 ,--memory address rising
 |
 V   >>>> sp in method (after initial sub) <<<<
@@ -83,3 +85,30 @@ V
 |
 V
 
+
+mips stack frames
+-----------------
+
+,--memory address rising
+|
+V   >>>> sp in method (after initial sub) (16-byte aligned) <<<<
+|          
+|   u8[]  v  arguments for calling methods              \__ rd->memuse slots
+V   u8[]  v  local variable slots allocated on stack    /
+|
+|   u8       synchronized object / saved return value       (only for synched methods)
+|   u8[0..1] alignment dummy-slot                           (to ensure 16-byte alignment of sp)
+V
+|   u8[]  ^  callee-saved float registers
+|   u8[]  ^  callee-saved integer registers
+V
+|     >>>> !!!replacement code regards this point as stack base!!!  <<<<
+|                
+V   u8    ^  saved return address                           (only for non-leaf methods)
+|
+|   >>>> sp on method entry (16-byte aligned) <<<<
+V
+|   u8[]     arguments on stack
+|
+V
+