mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-14 05:29:22 +02:00
And another place where I forgot to (de)allocate address registers...
m68k/cgcpu.pas, tcg68k.call_rtl_mul_const_reg & tcg68k.call_rtl_mul_reg_reg: * (de)allocate address registers git-svn-id: trunk@25654 -
This commit is contained in:
parent
f8fe25f8cf
commit
20587d8547
@ -627,9 +627,11 @@ unit cgcpu;
|
|||||||
paramanager.freecgpara(list,paraloc3);
|
paramanager.freecgpara(list,paraloc3);
|
||||||
paramanager.freecgpara(list,paraloc2);
|
paramanager.freecgpara(list,paraloc2);
|
||||||
paramanager.freecgpara(list,paraloc1);
|
paramanager.freecgpara(list,paraloc1);
|
||||||
|
alloccpuregisters(list,R_ADDRESSREGISTER,paramanager.get_volatile_registers_address(pocall_default));
|
||||||
alloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
alloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
||||||
a_call_name(list,name,false);
|
a_call_name(list,name,false);
|
||||||
dealloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
dealloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
||||||
|
dealloccpuregisters(list,R_ADDRESSREGISTER,paramanager.get_volatile_registers_address(pocall_default));
|
||||||
cg.a_reg_alloc(list,NR_FUNCTION_RESULT_REG);
|
cg.a_reg_alloc(list,NR_FUNCTION_RESULT_REG);
|
||||||
cg.a_load_reg_reg(list,OS_32,OS_32,NR_FUNCTION_RESULT_REG,reg);
|
cg.a_load_reg_reg(list,OS_32,OS_32,NR_FUNCTION_RESULT_REG,reg);
|
||||||
paraloc3.done;
|
paraloc3.done;
|
||||||
@ -657,7 +659,9 @@ unit cgcpu;
|
|||||||
paramanager.freecgpara(list,paraloc2);
|
paramanager.freecgpara(list,paraloc2);
|
||||||
paramanager.freecgpara(list,paraloc1);
|
paramanager.freecgpara(list,paraloc1);
|
||||||
alloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
alloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
||||||
|
alloccpuregisters(list,R_ADDRESSREGISTER,paramanager.get_volatile_registers_address(pocall_default));
|
||||||
a_call_name(list,name,false);
|
a_call_name(list,name,false);
|
||||||
|
dealloccpuregisters(list,R_ADDRESSREGISTER,paramanager.get_volatile_registers_address(pocall_default));
|
||||||
dealloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
dealloccpuregisters(list,R_INTREGISTER,paramanager.get_volatile_registers_int(pocall_default));
|
||||||
cg.a_reg_alloc(list,NR_FUNCTION_RESULT_REG);
|
cg.a_reg_alloc(list,NR_FUNCTION_RESULT_REG);
|
||||||
cg.a_load_reg_reg(list,OS_32,OS_32,NR_FUNCTION_RESULT_REG,reg2);
|
cg.a_load_reg_reg(list,OS_32,OS_32,NR_FUNCTION_RESULT_REG,reg2);
|
||||||
|
Loading…
Reference in New Issue
Block a user