|
@@ -59,7 +59,7 @@ implementation
|
|
aasmdata,aasmllvm,
|
|
aasmdata,aasmllvm,
|
|
symtable,symconst,symdef,defutil,
|
|
symtable,symconst,symdef,defutil,
|
|
nmem,
|
|
nmem,
|
|
- cpubase,llvmbase,hlcgobj;
|
|
|
|
|
|
+ cpubase,llvmbase,hlcgobj,hlcgllvm;
|
|
|
|
|
|
{ tllvmsubscriptnode }
|
|
{ tllvmsubscriptnode }
|
|
|
|
|
|
@@ -86,6 +86,7 @@ implementation
|
|
llvmfielddef:=tabstractrecordsymtable(tabstractrecorddef(left.resultdef).symtable).llvmst[vs.llvmfieldnr].def;
|
|
llvmfielddef:=tabstractrecordsymtable(tabstractrecorddef(left.resultdef).symtable).llvmst[vs.llvmfieldnr].def;
|
|
{ load the address of that shadow field }
|
|
{ load the address of that shadow field }
|
|
newbase:=hlcg.getaddressregister(current_asmdata.CurrAsmList,getpointerdef(llvmfielddef));
|
|
newbase:=hlcg.getaddressregister(current_asmdata.CurrAsmList,getpointerdef(llvmfielddef));
|
|
|
|
+ location.reference:=thlcgllvm(hlcg).make_simple_ref(current_asmdata.CurrAsmList,location.reference,left.resultdef);
|
|
current_asmdata.CurrAsmList.concat(taillvm.getelementptr_reg_size_ref_size_const(newbase,getpointerdef(left.resultdef),location.reference,s32inttype,vs.llvmfieldnr,true));
|
|
current_asmdata.CurrAsmList.concat(taillvm.getelementptr_reg_size_ref_size_const(newbase,getpointerdef(left.resultdef),location.reference,s32inttype,vs.llvmfieldnr,true));
|
|
reference_reset_base(location.reference,newbase,vs.offsetfromllvmfield,newalignment(location.reference.alignment,vs.fieldoffset));
|
|
reference_reset_base(location.reference,newbase,vs.offsetfromllvmfield,newalignment(location.reference.alignment,vs.fieldoffset));
|
|
{ in case of an 80 bits extended type, typecast from an array of 10
|
|
{ in case of an 80 bits extended type, typecast from an array of 10
|
|
@@ -148,6 +149,7 @@ implementation
|
|
-> convert it into a pointer to an element inside this array }
|
|
-> convert it into a pointer to an element inside this array }
|
|
getarrelementptrdef;
|
|
getarrelementptrdef;
|
|
hreg:=hlcg.getaddressregister(current_asmdata.CurrAsmList,arrptrelementdef);
|
|
hreg:=hlcg.getaddressregister(current_asmdata.CurrAsmList,arrptrelementdef);
|
|
|
|
+ locref^:=thlcgllvm(hlcg).make_simple_ref(current_asmdata.CurrAsmList,location.reference,left.resultdef);
|
|
current_asmdata.CurrAsmList.Concat(taillvm.getelementptr_reg_size_ref_size_const(hreg,getpointerdef(left.resultdef),
|
|
current_asmdata.CurrAsmList.Concat(taillvm.getelementptr_reg_size_ref_size_const(hreg,getpointerdef(left.resultdef),
|
|
locref^,ptruinttype,constarrayoffset,true));
|
|
locref^,ptruinttype,constarrayoffset,true));
|
|
reference_reset_base(locref^,hreg,0,locref^.alignment);
|
|
reference_reset_base(locref^,hreg,0,locref^.alignment);
|
|
@@ -179,6 +181,7 @@ implementation
|
|
maybe_const_reg:=hreg;
|
|
maybe_const_reg:=hreg;
|
|
end;
|
|
end;
|
|
hreg:=hlcg.getaddressregister(current_asmdata.CurrAsmList,getpointerdef(resultdef));
|
|
hreg:=hlcg.getaddressregister(current_asmdata.CurrAsmList,getpointerdef(resultdef));
|
|
|
|
+ location.reference:=thlcgllvm(hlcg).make_simple_ref(current_asmdata.CurrAsmList,location.reference,left.resultdef);
|
|
{ get address of indexed array element and convert pointer to array into
|
|
{ get address of indexed array element and convert pointer to array into
|
|
pointer to the elementdef in the process }
|
|
pointer to the elementdef in the process }
|
|
current_asmdata.CurrAsmList.Concat(taillvm.getelementptr_reg_size_ref_size_reg(hreg,getpointerdef(left.resultdef),
|
|
current_asmdata.CurrAsmList.Concat(taillvm.getelementptr_reg_size_ref_size_reg(hreg,getpointerdef(left.resultdef),
|