Zilog Z8F0130 User Manual
Page 243
![background image](https://www.manualsdir.com/files/771166/content/doc243.png)
UM013037-1212
Function Call Mechanism: Register Parameter
Zilog Developer Studio II – Z8 Encore!
User Manual
219
1. For a non-
varargs
function, place the scalar parameters (not structures or unions) of
the called function in registers R8–R13 starting from left to right. Push the remaining
parameters including the nonscalar parameters on the stack for dynamic frame func-
tions or load into the static locations for static frame functions.
For a
varargs
function, a dynamic frame is always used, no parameter is passed in
register, and all parameters are pushed on the stack in reverse order.
2. Then call the function. The call instruction pushes the return address on the top of the
stack.
3. On return from the function, the return address is automatically popped from the stack
by the
ret
instruction.
4. On return from the called function, if there were any stack parameters, caller pops
them off the stack or increments the stack pointer.
The called function performs the following tasks:
1. If the called function is a monitor function only, push the existing value of the inter-
rupt control register IRQCTL on the stack and disable interrupts.
2. Push the frame pointer onto the stack and allocate the local frame:
a.
Set the frame pointer to the current value of the stack pointer.
b. Decrement the stack pointer by the size of locals and temporaries on stack, if
required.
3. Execute the code for the function.
4. If the function returns a scalar value, place it in the return value registers. For func-
tions returning an aggregate, see the
5. Deallocate the local frame (set the stack pointer to the current value of frame pointer),
if required, and restore the frame pointer from stack.
6. If the called function is a monitor function only, restore the interrupt control register
IRQCTL from the stack.
7. Return.
All registers, other than the return register, are considered as caller save; that is, they are
saved and restored by the caller function. The flag register is not saved and restored by the
caller function. For a static frame function, steps 2 and 5 are only done if the
–debug
(Debug) or
–reduceopt
(Limit Optimizations for Easier Debugging) option is selected.
In the case of a monitor function, add (-1) to the offsets of all arguments on the stack to take
into account the insertion of the saved interrupt control register IRQCTL on the stack.
Note:
- Z8F0131 Z8F0230 Z8F0231 Z8F0430 Z8F0431 Z8F043A Z8F0830 Z8F0831 Z8F083A Z8F1232 Z8F1233 Z8F0113 Z8F011A Z8F0123 Z8F012A Z8F0213 Z8F021A Z8F0223 Z8F022A Z8F0411 Z8F0412 Z8F0413 Z8F041A Z8F0421 Z8F0422 Z8F0423 Z8F042A Z8F0811 Z8F0812 Z8F0813 Z8F081A Z8F0821 Z8F0822 Z8F0823 Z8F082A Z8F0880 Z8F1621 Z8F1622 Z8F1680 Z8F1681 Z8F1682 Z8F2421 Z8F2422 Z8F2480 Z8F3221 Z8F3222 Z8F3281 Z8F3282 Z8F4821 Z8F4822 Z8F4823 Z8F6081 Z8F6082 Z8F6421 Z8F6422 Z8F6423 Z8F6481 Z8F6482 Z8FS021A ZMOT1AHH Z8FS040B ZMOT0BHH ZMOT0BSB Z8FMC04 Z8FMC08 Z8FMC16