mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-10-24 05:37:41 +02:00
* Do not set pi_needs_got in current_procinfo.flags at the node level, since the GOT usage can only be estimated there. Instead set the pi_needs_got flag at places where the GOT register is accessed during the code generation. This eliminates generation of the unneeded initialization of the GOT register and fixes linker errors when the _GLOBAL_OFFSET_TABLE_ symbol is referenced but no actual GOT references are present.
git-svn-id: trunk@41460 -
This commit is contained in:
parent
ab92dcd162
commit
e5c2d13671
@ -261,10 +261,6 @@ unit cgcpu;
|
||||
reference_reset_symbol(tmpref,dirref.symbol,0,sizeof(pint),[]);
|
||||
tmpref.refaddr:=addr_pic;
|
||||
tmpref.base:=current_procinfo.got;
|
||||
{$ifdef EXTDEBUG}
|
||||
if not (pi_needs_got in current_procinfo.flags) then
|
||||
Comment(V_warning,'pi_needs_got not included');
|
||||
{$endif EXTDEBUG}
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
list.concat(taicpu.op_ref(A_PUSH,S_L,tmpref));
|
||||
end
|
||||
|
@ -198,6 +198,7 @@ implementation
|
||||
{ Alloc EBX }
|
||||
getcpuregister(list, NR_PIC_OFFSET_REG);
|
||||
list.concat(taicpu.op_reg_reg(A_MOV,S_L,current_procinfo.got,NR_PIC_OFFSET_REG));
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
Result:=inherited a_call_name(list, pd, s, paras, forceresdef, weak);
|
||||
{ Free EBX }
|
||||
|
@ -1093,10 +1093,6 @@ implementation
|
||||
{ temps which are immutable do not need to be initialized/finalized }
|
||||
if (tempinfo^.typedef.needs_inittable) and not(ti_const in tempflags) then
|
||||
include(current_procinfo.flags,pi_needs_implicit_finally);
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
(tf_pic_uses_got in target_info.flags) and
|
||||
is_rtti_managed_type(tempinfo^.typedef) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
if assigned(tempinfo^.withnode) then
|
||||
firstpass(tempinfo^.withnode);
|
||||
if assigned(tempinfo^.tempinitcode) then
|
||||
|
@ -1086,19 +1086,6 @@ implementation
|
||||
aktcallnode.procdefinition.proccalloption) then
|
||||
copy_value_by_ref_para;
|
||||
|
||||
{ does it need to load RTTI? }
|
||||
if assigned(parasym) and (parasym.varspez=vs_out) and
|
||||
(cs_create_pic in current_settings.moduleswitches) and
|
||||
(
|
||||
is_rtti_managed_type(left.resultdef) or
|
||||
(
|
||||
is_open_array(resultdef) and
|
||||
is_managed_type(tarraydef(resultdef).elementdef)
|
||||
)
|
||||
) and
|
||||
not(target_info.system in systems_garbage_collected_managed_types) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
|
||||
if assigned(fparainit) then
|
||||
firstpass(fparainit);
|
||||
firstpass(left);
|
||||
@ -4382,11 +4369,6 @@ implementation
|
||||
([cnf_member_call,cnf_inherited] * callnodeflags <> []) then
|
||||
current_procinfo.ConstructorCallingConstructor:=true;
|
||||
|
||||
{ object check helper will load VMT -> needs GOT }
|
||||
if (cs_check_object in current_settings.localswitches) and
|
||||
(cs_create_pic in current_settings.moduleswitches) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
|
||||
{ Continue with checking a normal call or generate the inlined code }
|
||||
if cnf_do_inline in callnodeflags then
|
||||
result:=pass1_inline
|
||||
|
@ -2022,9 +2022,6 @@ implementation
|
||||
begin
|
||||
s:=def.rtti_mangledname(rt)+suffix;
|
||||
result:=current_asmdata.RefAsmSymbol(s,AT_DATA,indirect);
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
assigned(current_procinfo) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
if def.owner.moduleid<>current_module.moduleid then
|
||||
current_module.add_extern_asmsym(s,AB_EXTERNAL,AT_DATA);
|
||||
end;
|
||||
|
@ -3177,9 +3177,6 @@ implementation
|
||||
begin
|
||||
result:=nil;
|
||||
expectloc:=LOC_REGISTER;
|
||||
{ Use of FPC_EMPTYCHAR label requires setting pi_needs_got flag }
|
||||
if (cs_create_pic in current_settings.moduleswitches) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
|
||||
|
||||
@ -3604,9 +3601,6 @@ implementation
|
||||
begin
|
||||
first_ansistring_to_pchar:=nil;
|
||||
expectloc:=LOC_REGISTER;
|
||||
{ Use of FPC_EMPTYCHAR label requires setting pi_needs_got flag }
|
||||
if (cs_create_pic in current_settings.moduleswitches) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
|
||||
|
||||
|
@ -465,8 +465,6 @@ implementation
|
||||
begin
|
||||
result:=nil;
|
||||
expectloc:=LOC_CREFERENCE;
|
||||
if (cs_create_pic in current_settings.moduleswitches) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
|
||||
|
||||
@ -868,9 +866,6 @@ implementation
|
||||
end
|
||||
else
|
||||
expectloc:=LOC_CREFERENCE;
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
(expectloc <> LOC_CONSTANT) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
|
||||
|
||||
@ -1160,9 +1155,6 @@ implementation
|
||||
expectloc:=LOC_CONSTANT
|
||||
else
|
||||
expectloc:=LOC_CREFERENCE;
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
(expectloc <> LOC_CONSTANT) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
|
||||
|
||||
@ -1254,9 +1246,6 @@ implementation
|
||||
begin
|
||||
result:=nil;
|
||||
expectloc:=LOC_CREFERENCE;
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
(tf_pic_uses_got in target_info.flags) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
|
||||
|
||||
|
@ -2416,11 +2416,6 @@ implementation
|
||||
begin
|
||||
result:=nil;
|
||||
include(current_procinfo.flags,pi_do_call);
|
||||
{ Loads exception class VMT, therefore may need GOT
|
||||
(generic code only; descendants may need to avoid this check) }
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
(tf_pic_uses_got in target_info.flags) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
expectloc:=LOC_VOID;
|
||||
if assigned(left) then
|
||||
firstpass(left);
|
||||
|
@ -400,9 +400,6 @@ implementation
|
||||
begin
|
||||
result:=nil;
|
||||
expectloc:=LOC_REFERENCE;
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
not(symtableentry.typ in [paravarsym,localvarsym]) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
|
||||
case symtableentry.typ of
|
||||
absolutevarsym :
|
||||
@ -424,9 +421,6 @@ implementation
|
||||
else
|
||||
if (tabstractvarsym(symtableentry).varspez=vs_const) then
|
||||
expectloc:=LOC_CREFERENCE;
|
||||
if (target_info.system=system_powerpc_darwin) and
|
||||
([vo_is_dll_var,vo_is_external] * tabstractvarsym(symtableentry).varoptions <> []) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
{ call to get address of threadvar }
|
||||
if (vo_is_thread_var in tabstractvarsym(symtableentry).varoptions) then
|
||||
begin
|
||||
@ -1383,9 +1377,6 @@ implementation
|
||||
begin
|
||||
result:=nil;
|
||||
expectloc:=LOC_CREFERENCE;
|
||||
if (cs_create_pic in current_settings.moduleswitches) and
|
||||
(tf_pic_uses_got in target_info.flags) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
|
||||
|
||||
|
@ -242,9 +242,6 @@ implementation
|
||||
begin
|
||||
result:=nil;
|
||||
expectloc:=LOC_REGISTER;
|
||||
if (left.nodetype=typen) and
|
||||
(cs_create_pic in current_settings.moduleswitches) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
if left.nodetype<>typen then
|
||||
begin
|
||||
if (is_objc_class_or_protocol(left.resultdef) or
|
||||
|
@ -297,11 +297,6 @@ implementation
|
||||
include(current_procinfo.flags,pi_needs_implicit_finally);
|
||||
include(current_procinfo.flags,pi_do_call);
|
||||
end;
|
||||
if (tparavarsym(p).varspez in [vs_value,vs_out]) and
|
||||
(cs_create_pic in current_settings.moduleswitches) and
|
||||
(tf_pic_uses_got in target_info.flags) and
|
||||
is_rtti_managed_type(tparavarsym(p).vardef) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
end;
|
||||
|
||||
@ -316,10 +311,6 @@ implementation
|
||||
begin
|
||||
include(current_procinfo.flags,pi_needs_implicit_finally);
|
||||
include(current_procinfo.flags,pi_do_call);
|
||||
if is_rtti_managed_type(tlocalvarsym(p).vardef) and
|
||||
(cs_create_pic in current_settings.moduleswitches) and
|
||||
(tf_pic_uses_got in target_info.flags) then
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end;
|
||||
end;
|
||||
|
||||
|
@ -102,6 +102,7 @@ implementation
|
||||
begin
|
||||
if not(cs_create_pic in current_settings.moduleswitches) then
|
||||
Internalerror(2018110701);
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
reference_reset(href,0,[]);
|
||||
location.reference.index:=current_procinfo.got;
|
||||
location.reference.scalefactor:=1;
|
||||
|
@ -176,6 +176,7 @@ implementation
|
||||
cg.a_load_ref_reg(current_asmdata.CurrAsmList,OS_ADDR,OS_ADDR,href,jumpreg);
|
||||
cg.a_op_reg_reg(current_asmdata.CurrAsmList,OP_ADD,OS_ADDR,current_procinfo.got,jumpreg);
|
||||
emit_reg(A_JMP,S_NO,jumpreg);
|
||||
include(current_procinfo.flags,pi_needs_got);
|
||||
end
|
||||
else
|
||||
emit_ref(A_JMP,S_NO,href);
|
||||
|
Loading…
Reference in New Issue
Block a user