2
0
Эх сурвалжийг харах

* when creating method pointers, put them into registers

git-svn-id: trunk@22341 -
florian 13 жил өмнө
parent
commit
370d42035a
1 өөрчлөгдсөн 14 нэмэгдсэн , 21 устгасан
  1. 14 21
      compiler/ncgld.pas

+ 14 - 21
compiler/ncgld.pas

@@ -459,13 +459,12 @@ implementation
                  if assigned(left) then
                  if assigned(left) then
                    begin
                    begin
                      {$if sizeof(pint) = 4}
                      {$if sizeof(pint) = 4}
-                        location_reset_ref(location,LOC_CREFERENCE,OS_64,sizeof(pint));
+                        location_reset(location,LOC_CREGISTER,OS_64);
                      {$else} {$if sizeof(pint) = 8}
                      {$else} {$if sizeof(pint) = 8}
-                        location_reset_ref(location,LOC_CREFERENCE,OS_128,sizeof(pint));
+                        location_reset(location,LOC_CREGISTER,OS_128);
                      {$else}
                      {$else}
                         internalerror(20020520);
                         internalerror(20020520);
                      {$endif} {$endif}
                      {$endif} {$endif}
-                     tg.gethltemp(current_asmdata.CurrAsmList,methodpointertype,methodpointertype.size,tt_normal,location.reference);
                      secondpass(left);
                      secondpass(left);
 
 
                      { load class instance/classrefdef address }
                      { load class instance/classrefdef address }
@@ -479,27 +478,22 @@ implementation
                              { this is not possible for objects }
                              { this is not possible for objects }
                              if is_object(left.resultdef) then
                              if is_object(left.resultdef) then
                                internalerror(200304234);
                                internalerror(200304234);
-                             hregister:=left.location.register;
+                             location.registerhi:=left.location.register;
                           end;
                           end;
                         LOC_CREFERENCE,
                         LOC_CREFERENCE,
                         LOC_REFERENCE:
                         LOC_REFERENCE:
                           begin
                           begin
-                             hregister:=cg.getaddressregister(current_asmdata.CurrAsmList);
+                             location.registerhi:=cg.getaddressregister(current_asmdata.CurrAsmList);
                              if not is_object(left.resultdef) then
                              if not is_object(left.resultdef) then
-                               cg.a_load_ref_reg(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,left.location.reference,hregister)
+                               cg.a_load_ref_reg(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,left.location.reference,location.registerhi)
                              else
                              else
-                               cg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,left.location.reference,hregister);
+                               cg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,left.location.reference,location.registerhi);
                              location_freetemp(current_asmdata.CurrAsmList,left.location);
                              location_freetemp(current_asmdata.CurrAsmList,left.location);
                           end;
                           end;
                         else
                         else
                           internalerror(200610311);
                           internalerror(200610311);
                      end;
                      end;
 
 
-                     { store the class instance or classredef address }
-                     href:=location.reference;
-                     inc(href.offset,sizeof(pint));
-                     cg.a_load_reg_ref(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,hregister,href);
-
                      { virtual method ? }
                      { virtual method ? }
                      if (po_virtualmethod in procdef.procoptions) and
                      if (po_virtualmethod in procdef.procoptions) and
                         not(loadnf_inherited in loadnodeflags) and
                         not(loadnf_inherited in loadnodeflags) and
@@ -519,24 +513,23 @@ implementation
                          if (left.resultdef.typ<>classrefdef) then
                          if (left.resultdef.typ<>classrefdef) then
                            begin
                            begin
                              { load vmt pointer }
                              { load vmt pointer }
-                             reference_reset_base(href,hregister,tobjectdef(left.resultdef).vmt_offset,sizeof(pint));
+                             reference_reset_base(href,location.registerhi,tobjectdef(left.resultdef).vmt_offset,sizeof(pint));
                              hregister:=cg.getaddressregister(current_asmdata.CurrAsmList);
                              hregister:=cg.getaddressregister(current_asmdata.CurrAsmList);
                              cg.a_load_ref_reg(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,href,hregister);
                              cg.a_load_ref_reg(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,href,hregister);
-                           end;
+                           end
+                         else
+                           hregister:=location.registerhi;
                          { load method address }
                          { load method address }
                          reference_reset_base(href,hregister,tobjectdef(procdef.struct).vmtmethodoffset(procdef.extnumber),sizeof(pint));
                          reference_reset_base(href,hregister,tobjectdef(procdef.struct).vmtmethodoffset(procdef.extnumber),sizeof(pint));
-                         hregister:=cg.getaddressregister(current_asmdata.CurrAsmList);
-                         cg.a_load_ref_reg(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,href,hregister);
-                         { ... and store it }
-                         cg.a_load_reg_ref(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,hregister,location.reference);
+                         location.register:=cg.getaddressregister(current_asmdata.CurrAsmList);
+                         cg.a_load_ref_reg(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,href,location.register);
                        end
                        end
                      else
                      else
                        begin
                        begin
                          { load address of the function }
                          { load address of the function }
                          reference_reset_symbol(href,current_asmdata.RefAsmSymbol(procdef.mangledname),0,sizeof(pint));
                          reference_reset_symbol(href,current_asmdata.RefAsmSymbol(procdef.mangledname),0,sizeof(pint));
-                         hregister:=cg.getaddressregister(current_asmdata.CurrAsmList);
-                         cg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,href,hregister);
-                         cg.a_load_reg_ref(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,hregister,location.reference);
+                         location.register:=cg.getaddressregister(current_asmdata.CurrAsmList);
+                         cg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,href,location.register);
                        end;
                        end;
                    end
                    end
                  else
                  else