|
@@ -553,6 +553,10 @@ implementation
|
|
not tabstractprocdef(resultdef).is_addressonly then
|
|
not tabstractprocdef(resultdef).is_addressonly then
|
|
begin
|
|
begin
|
|
location_reset(location,LOC_CREGISTER,int_cgsize(voidpointertype.size*2));
|
|
location_reset(location,LOC_CREGISTER,int_cgsize(voidpointertype.size*2));
|
|
|
|
+{$if defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
|
|
+ { cpus with 16 bit address registers don't use registerhi here, so allocate already here a register for all purposes }
|
|
|
|
+ location.register:=hlcg.getintregister(current_asmdata.CurrAsmList,s32inttype);
|
|
|
|
+{$endif defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
secondpass(left);
|
|
secondpass(left);
|
|
|
|
|
|
{ load class instance/classrefdef address }
|
|
{ load class instance/classrefdef address }
|
|
@@ -569,7 +573,11 @@ 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);
|
|
|
|
+{$if defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
|
|
+ hlcg.a_load_reg_reg(current_asmdata.CurrAsmList,left.resultdef,left.resultdef,left.location.register,cg.GetNextReg(cg.GetNextReg(location.register)));
|
|
|
|
+{$else defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
location.registerhi:=left.location.register;
|
|
location.registerhi:=left.location.register;
|
|
|
|
+{$endif defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
vd:=left.resultdef;
|
|
vd:=left.resultdef;
|
|
end;
|
|
end;
|
|
LOC_CREFERENCE,
|
|
LOC_CREFERENCE,
|
|
@@ -579,14 +587,22 @@ implementation
|
|
(left.resultdef.typ=classrefdef) then
|
|
(left.resultdef.typ=classrefdef) then
|
|
begin
|
|
begin
|
|
vd:=left.resultdef;
|
|
vd:=left.resultdef;
|
|
|
|
+{$if defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
|
|
+ hlcg.a_load_ref_reg(current_asmdata.CurrAsmList,left.resultdef,left.resultdef,left.location.reference,cg.GetNextReg(cg.GetNextReg(location.register)))
|
|
|
|
+{$else defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
location.registerhi:=hlcg.getaddressregister(current_asmdata.CurrAsmList,left.resultdef);
|
|
location.registerhi:=hlcg.getaddressregister(current_asmdata.CurrAsmList,left.resultdef);
|
|
hlcg.a_load_ref_reg(current_asmdata.CurrAsmList,left.resultdef,left.resultdef,left.location.reference,location.registerhi)
|
|
hlcg.a_load_ref_reg(current_asmdata.CurrAsmList,left.resultdef,left.resultdef,left.location.reference,location.registerhi)
|
|
|
|
+{$endif defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
end
|
|
end
|
|
else
|
|
else
|
|
begin
|
|
begin
|
|
vd:=cpointerdef.getreusable(left.resultdef);
|
|
vd:=cpointerdef.getreusable(left.resultdef);
|
|
|
|
+{$if defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
|
|
+ hlcg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,left.resultdef,vd,left.location.reference,cg.GetNextReg(cg.GetNextReg(location.register)));
|
|
|
|
+{$else defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
location.registerhi:=hlcg.getaddressregister(current_asmdata.CurrAsmList,vd);
|
|
location.registerhi:=hlcg.getaddressregister(current_asmdata.CurrAsmList,vd);
|
|
hlcg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,left.resultdef,vd,left.location.reference,location.registerhi);
|
|
hlcg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,left.resultdef,vd,left.location.reference,location.registerhi);
|
|
|
|
+{$endif defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
end;
|
|
end;
|
|
location_freetemp(current_asmdata.CurrAsmList,left.location);
|
|
location_freetemp(current_asmdata.CurrAsmList,left.location);
|
|
end;
|
|
end;
|
|
@@ -621,9 +637,15 @@ implementation
|
|
end
|
|
end
|
|
else if left.resultdef.typ=classrefdef then
|
|
else if left.resultdef.typ=classrefdef then
|
|
begin
|
|
begin
|
|
|
|
+ vmtdef:=cpointerdef.getreusable(tobjectdef(tclassrefdef(left.resultdef).pointeddef).vmt_def);
|
|
{ classrefdef is a pointer to the vmt already }
|
|
{ classrefdef is a pointer to the vmt already }
|
|
|
|
+{$if defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
|
|
+ hregister:=hlcg.getaddressregister(current_asmdata.CurrAsmList,vmtdef);
|
|
|
|
+ hlcg.a_load_reg_reg(current_asmdata.CurrAsmList,left.resultdef,left.resultdef,cg.GetNextReg(cg.GetNextReg(location.register)),hregister);
|
|
|
|
+{$else defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
|
|
+ { targets with 32 bit method pointers got already a register assigned }
|
|
hregister:=location.registerhi;
|
|
hregister:=location.registerhi;
|
|
- vmtdef:=cpointerdef.getreusable(tobjectdef(tclassrefdef(left.resultdef).pointeddef).vmt_def);
|
|
|
|
|
|
+{$endif defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
hlcg.g_ptrtypecast_reg(current_asmdata.CurrAsmList,left.resultdef,vmtdef,hregister);
|
|
hlcg.g_ptrtypecast_reg(current_asmdata.CurrAsmList,left.resultdef,vmtdef,hregister);
|
|
end
|
|
end
|
|
else if is_any_interface_kind(left.resultdef) then
|
|
else if is_any_interface_kind(left.resultdef) then
|
|
@@ -640,7 +662,10 @@ implementation
|
|
vmtentry:=tabstractrecordsymtable(trecorddef(vmtdef.pointeddef).symtable).findfieldbyoffset(
|
|
vmtentry:=tabstractrecordsymtable(trecorddef(vmtdef.pointeddef).symtable).findfieldbyoffset(
|
|
tobjectdef(procdef.struct).vmtmethodoffset(procdef.extnumber));
|
|
tobjectdef(procdef.struct).vmtmethodoffset(procdef.extnumber));
|
|
hlcg.reference_reset_base(href,vmtdef,hregister,0,ctempposinvalid,vmtdef.alignment,[]);
|
|
hlcg.reference_reset_base(href,vmtdef,hregister,0,ctempposinvalid,vmtdef.alignment,[]);
|
|
|
|
+ { targets with 32 bit method pointers got already a register assigned }
|
|
|
|
+{$if not(defined(CPU8BITALU) and defined(CPU16BITADDR))}
|
|
location.register:=hlcg.getaddressregister(current_asmdata.CurrAsmList,vmtentry.vardef);
|
|
location.register:=hlcg.getaddressregister(current_asmdata.CurrAsmList,vmtentry.vardef);
|
|
|
|
+{$endif not(defined(CPU8BITALU) and defined(CPU16BITADDR))}
|
|
hlcg.g_set_addr_nonbitpacked_field_ref(current_asmdata.CurrAsmList,tabstractrecorddef(vmtdef.pointeddef),vmtentry,href);
|
|
hlcg.g_set_addr_nonbitpacked_field_ref(current_asmdata.CurrAsmList,tabstractrecorddef(vmtdef.pointeddef),vmtentry,href);
|
|
hlcg.a_load_ref_reg(current_asmdata.CurrAsmList,vmtentry.vardef,vmtentry.vardef,href,location.register);
|
|
hlcg.a_load_ref_reg(current_asmdata.CurrAsmList,vmtentry.vardef,vmtentry.vardef,href,location.register);
|
|
end
|
|
end
|
|
@@ -648,7 +673,10 @@ implementation
|
|
begin
|
|
begin
|
|
{ load address of the function }
|
|
{ load address of the function }
|
|
reference_reset_symbol(href,current_asmdata.RefAsmSymbol(procdef.mangledname,AT_FUNCTION),0,procdef.address_type.alignment,[]);
|
|
reference_reset_symbol(href,current_asmdata.RefAsmSymbol(procdef.mangledname,AT_FUNCTION),0,procdef.address_type.alignment,[]);
|
|
|
|
+ { targets with 32 bit method pointers got already a register assigned }
|
|
|
|
+{$if not(defined(CPU8BITALU) and defined(CPU16BITADDR))}
|
|
location.register:=hlcg.getaddressregister(current_asmdata.CurrAsmList,cprocvardef.getreusableprocaddr(procdef));
|
|
location.register:=hlcg.getaddressregister(current_asmdata.CurrAsmList,cprocvardef.getreusableprocaddr(procdef));
|
|
|
|
+{$endif not(defined(CPU8BITALU) and defined(CPU16BITADDR))}
|
|
hlcg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,procdef,cprocvardef.getreusableprocaddr(procdef),href,location.register);
|
|
hlcg.a_loadaddr_ref_reg(current_asmdata.CurrAsmList,procdef,cprocvardef.getreusableprocaddr(procdef),href,location.register);
|
|
end;
|
|
end;
|
|
|
|
|
|
@@ -656,6 +684,10 @@ implementation
|
|
big endian targets }
|
|
big endian targets }
|
|
if target_info.endian=endian_big then
|
|
if target_info.endian=endian_big then
|
|
begin
|
|
begin
|
|
|
|
+ { cpus with 16 bit address registers don't use registerhi here }
|
|
|
|
+{$if defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
|
|
+ Internalerror(2022091201);
|
|
|
|
+{$endif defined(CPU8BITALU) and defined(CPU16BITADDR)}
|
|
hregister:=location.register;
|
|
hregister:=location.register;
|
|
location.register:=location.registerhi;
|
|
location.register:=location.registerhi;
|
|
location.registerhi:=hregister;
|
|
location.registerhi:=hregister;
|