mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-12 16:09:25 +02:00
* fixed alignment of subscripts if the variant part of a record starts at a
non-zero offset from the reference field in the llvm version of the record git-svn-id: trunk@31637 -
This commit is contained in:
parent
c7a418829b
commit
54172d7de4
@ -123,7 +123,7 @@ implementation
|
|||||||
newbase:=hlcg.getaddressregister(current_asmdata.CurrAsmList,cpointerdef.getreusable(llvmfielddef));
|
newbase:=hlcg.getaddressregister(current_asmdata.CurrAsmList,cpointerdef.getreusable(llvmfielddef));
|
||||||
location.reference:=thlcgllvm(hlcg).make_simple_ref(current_asmdata.CurrAsmList,location.reference,left.resultdef);
|
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,subscriptdef,location.reference,s32inttype,vs.llvmfieldnr,true));
|
current_asmdata.CurrAsmList.concat(taillvm.getelementptr_reg_size_ref_size_const(newbase,subscriptdef,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+vs.offsetfromllvmfield));
|
||||||
{ 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
|
||||||
bytes (used because otherwise llvm will allocate the ABI-defined
|
bytes (used because otherwise llvm will allocate the ABI-defined
|
||||||
size for extended, which is usually larger) into an extended }
|
size for extended, which is usually larger) into an extended }
|
||||||
|
Loading…
Reference in New Issue
Block a user