
Software Support for Aritmetic Routines
Motorola
About g56k
4-15
5. Pass the return value address in accumulator a.
4.8.2 Callee Sequence
During the initial portion of the subroutine calling sequence, the
callee
is responsible for:
1. Saving return address (ssh) and the old frame pointer (R0).
2. Updating frame and stack pointers.
3. Saving the following registers, as required, B1, B0, X1, X0, Y1, Y0, R1 - R5 and
R7.
4.8.3 Return Sequence
During the final portion of the subroutine calling sequence, the
callee
is responsible for:
1. Placing the return value in accumulator a.
2. Testing the return value. This optimizes the case where function calls are
arguments to conditional operators.
Additional
callee
sequence when the subroutine called will return a structure:
3. The return value is not passed in accumulator a. A copy of the return structure is
placed into the space allocated in the caller’s activation record and pointed to by
accumulator A.
4.9 Software Support for Aritmetic Routines
The DSP56000 family architecture provides full hardware support for all 24-bit arithmetic
operations, and partial support for 48-bit
integer
operations. Support for all float/double
and a portion of the 48-bit long is provided via special software library routines. These
special library routines
do not
pass arguments to the routines according to the normal
subroutine calling convention, instead, each routine has its arguments passed in the A and
B accumulators and the result returned in the A accumulator, limiting the overhead
involved in the call/return sequence. See Table 4-10 and Table 4-11 for a list of the
routines supported in software. All but two of these routines restore all registers used
except for the A accumulator which contains the result. The two routines that do not
restore the registers are
F_ _uldiv
and
F_ _ulmod
which use the registers according the C
standard shown in Table 4-9.
F
Freescale Semiconductor, Inc.
For More Information On This Product,
Go to: www.freescale.com
n
.