|
@@ -244,7 +244,6 @@ const
|
|
|
|
|
|
{ calling a code fragment by name }
|
|
|
procedure tcgppc.a_call_name(list : taasmoutput;const s : string);
|
|
|
-
|
|
|
var
|
|
|
href : treference;
|
|
|
begin
|
|
@@ -258,19 +257,21 @@ const
|
|
|
procinfo.flags:=procinfo.flags or pi_do_call;
|
|
|
end;
|
|
|
|
|
|
+
|
|
|
{ calling a code fragment through a reference }
|
|
|
procedure tcgppc.a_call_ref(list : taasmoutput;const ref : treference);
|
|
|
-
|
|
|
var
|
|
|
href : treference;
|
|
|
+ tmpreg : tregister;
|
|
|
begin
|
|
|
{ save our RTOC register value. Only necessary when doing pointer based }
|
|
|
{ calls or cross TOC calls, but currently done always }
|
|
|
reference_reset_base(href,STACK_POINTER_REG,LA_RTOC);
|
|
|
list.concat(taicpu.op_reg_ref(A_STW,R_TOC,href));
|
|
|
- a_reg_alloc(list,R_0);
|
|
|
- a_load_ref_reg(list,OS_ADDR,ref,R_0);
|
|
|
- list.concat(taicpu.op_reg_reg(A_MTSPR,R_LR,R_0));
|
|
|
+ tmpreg := get_scratch_reg_int(list);
|
|
|
+ a_load_ref_reg(list,OS_ADDR,ref,tmpreg);
|
|
|
+ list.concat(taicpu.op_reg(A_MTLR,tmpreg));
|
|
|
+ free_scratch_reg(list,tmpreg);
|
|
|
a_reg_dealloc(list,R_0);
|
|
|
list.concat(taicpu.op_none(A_BCCTRL));
|
|
|
list.concat(taicpu.op_reg_ref(A_LWZ,R_TOC,href));
|
|
@@ -1687,7 +1688,10 @@ begin
|
|
|
end.
|
|
|
{
|
|
|
$Log$
|
|
|
- Revision 1.46 2002-08-31 19:25:50 jonas
|
|
|
+ Revision 1.47 2002-08-31 21:30:45 florian
|
|
|
+ * fixed several problems caused by Jonas' commit :)
|
|
|
+
|
|
|
+ Revision 1.46 2002/08/31 19:25:50 jonas
|
|
|
+ implemented a_call_ref()
|
|
|
|
|
|
Revision 1.45 2002/08/18 22:16:14 florian
|