ソースを参照

+ added syscall optimizations similar to trunk one

git-svn-id: branches/fixes_2_0@3967 -
Károly Balogh 19 年 前
コミット
861f3031e4
1 ファイル変更10 行追加13 行削除
  1. 10 13
      compiler/powerpc/nppccal.pas

+ 10 - 13
compiler/powerpc/nppccal.pas

@@ -78,41 +78,38 @@ implementation
                 (po_syscall_sysvbase in tprocdef(procdefinition).procoptions) then
                 begin
                   cg.getcpuregister(exprasmlist,NR_R0);
-                  cg.getcpuregister(exprasmlist,NR_R31);
+                  { Use R12, because it can be used for function linkage on SysV4 ABI (KB) }
+                  cg.getcpuregister(exprasmlist,NR_R12);
 
                   reference_reset(tmpref);
                   tmpref.symbol:=objectlibrary.newasmsymbol(tglobalvarsym(tprocdef(procdefinition).libsym).mangledname,AB_EXTERNAL,AT_DATA);
                   tmpref.refaddr:=addr_hi;
-                  exprasmlist.concat(taicpu.op_reg_ref(A_LIS,NR_R31,tmpref));
-                  tmpref.base:=NR_R31;
+                  exprasmlist.concat(taicpu.op_reg_ref(A_LIS,NR_R12,tmpref));
+                  tmpref.base:=NR_R12;
                   tmpref.refaddr:=addr_lo;
-                  exprasmlist.concat(taicpu.op_reg_ref(A_LWZ,NR_R31,tmpref));
+                  exprasmlist.concat(taicpu.op_reg_ref(A_LWZ,NR_R12,tmpref));
 
-                  exprasmlist.concat(taicpu.op_reg_reg_const(A_ADDI,NR_R31,NR_R31,-tprocdef(procdefinition).extnumber));
-                  reference_reset_base(tmpref,NR_R31,0);
+                  reference_reset_base(tmpref,NR_R12,-tprocdef(procdefinition).extnumber);
                   exprasmlist.concat(taicpu.op_reg_ref(A_LWZ,NR_R0,tmpref));
                   exprasmlist.concat(taicpu.op_reg(A_MTCTR,NR_R0));
                   exprasmlist.concat(taicpu.op_none(A_BCTRL));
 
-                  cg.ungetcpuregister(exprasmlist,NR_R31);
+                  cg.ungetcpuregister(exprasmlist,NR_R12);
                   cg.ungetcpuregister(exprasmlist,NR_R0);
                 end
               else if (po_syscall_basesysv in tprocdef(procdefinition).procoptions) or
                 (po_syscall_r12base in tprocdef(procdefinition).procoptions) then
                 begin
                   cg.getcpuregister(exprasmlist,NR_R0);
-                  cg.getcpuregister(exprasmlist,NR_R31);
 
                   if (po_syscall_basesysv in tprocdef(procdefinition).procoptions) then
-                    exprasmlist.concat(taicpu.op_reg_reg_const(A_ADDI,NR_R31,NR_R3,-tprocdef(procdefinition).extnumber))
+                    reference_reset_base(tmpref,NR_R3,-tprocdef(procdefinition).extnumber);
                   else
-                    exprasmlist.concat(taicpu.op_reg_reg_const(A_ADDI,NR_R31,NR_R12,-tprocdef(procdefinition).extnumber));
-                  reference_reset_base(tmpref,NR_R31,0);
+                    reference_reset_base(tmpref,NR_R12,-tprocdef(procdefinition).extnumber);
                   exprasmlist.concat(taicpu.op_reg_ref(A_LWZ,NR_R0,tmpref));
                   exprasmlist.concat(taicpu.op_reg(A_MTCTR,NR_R0));
                   exprasmlist.concat(taicpu.op_none(A_BCTRL));
 
-                  cg.ungetcpuregister(exprasmlist,NR_R31);
                   cg.ungetcpuregister(exprasmlist,NR_R0);
                 end
               else if po_syscall_legacy in tprocdef(procdefinition).procoptions then
@@ -129,8 +126,8 @@ implementation
                   exprasmlist.concat(taicpu.op_reg(A_MTLR,NR_R0));
                   exprasmlist.concat(taicpu.op_none(A_BLRL));
 
-                  cg.ungetcpuregister(exprasmlist,NR_R0);
                   cg.ungetcpuregister(exprasmlist,NR_R3);
+                  cg.ungetcpuregister(exprasmlist,NR_R0);
                 end
               else
                 internalerror(2005010403);