* take care of po_noreturn in more cases

git-svn-id: trunk@47623 -
This commit is contained in:
florian 2020-11-28 16:02:51 +00:00
parent ff87df7581
commit 5ca2356638
2 changed files with 9 additions and 0 deletions

View File

@ -1884,6 +1884,11 @@ unit cgcpu;
ref : TReference;
ref2: TReference;
begin
{ if a subroutine is marked as non-returning, we do
not generate any exit code, so we really trust the noreturn directive
}
if po_noreturn in current_procinfo.procdef.procoptions then
exit;
if not nostackframe then
begin
list.concat(taicpu.op_reg(A_UNLK,S_NO,NR_FRAME_POINTER_REG));

View File

@ -870,6 +870,8 @@ implementation
procedure gen_save_used_regs(list:TAsmList);
begin
if po_noreturn in current_procinfo.procdef.procoptions then
exit;
{ Pure assembler routines need to save the registers themselves }
if (po_assembler in current_procinfo.procdef.procoptions) then
exit;
@ -880,6 +882,8 @@ implementation
procedure gen_restore_used_regs(list:TAsmList);
begin
if po_noreturn in current_procinfo.procdef.procoptions then
exit;
{ Pure assembler routines need to save the registers themselves }
if (po_assembler in current_procinfo.procdef.procoptions) then
exit;