2 # This is BROKEN on a 21264 running gcc, and probably in other cases.
3 # The compiler may spill pointers to fp registers, and this code doesn't
6 # define call_push(x) \
7 lda $
16, 0(x
);
/* copy x to first argument register */ \
8 jsr $
26, GC_push_one;
/* call GC_push_one, ret addr in $26 */ \
9 ldgp $gp
, 0($
26) /* restore $gp register from $ra */
16 ldgp $gp
, 0($
27) # set gp from the procedure value reg
17 lda $sp
, -32($sp
) # make stack frame
18 stq $
26, 8($sp
) # save return address
20 .frame $sp, 16, $26, 0
22 # call_push($0) # expression eval and int func result
24 # call_push($1) # temp regs - not preserved cross calls
33 call_push
($
9) # Saved regs
40 call_push
($
15) # frame ptr or saved reg
42 # call_push($16) # argument regs - not preserved cross calls
49 # call_push($22) # temp regs - not preserved cross calls
54 # call_push($26) # return address - expression eval
55 # call_push($27) # procedure value or temporary reg
56 # call_push($28) # assembler temp - not presrved
57 call_push
($
29) # Global Pointer
58 # call_push($30) # Stack Pointer
60 ldq $
26, 8($sp
) # restore return address
61 lda $sp
, 32($sp
) # pop stack frame
62 ret $
31, ($
26), 1 # return ($31 == hardwired zero)