mirror of
				https://gitlab.com/freepascal.org/fpc/source.git
				synced 2025-10-25 00:32:24 +02:00 
			
		
		
		
	+ inlined procedures inherit procinfo flags
This commit is contained in:
		
							parent
							
								
									8fc8644de0
								
							
						
					
					
						commit
						2258e941af
					
				| @ -2465,8 +2465,8 @@ type | |||||||
|                      CGMessage(cg_e_unable_inline_procvar); |                      CGMessage(cg_e_unable_inline_procvar); | ||||||
|                    if not assigned(inlinecode) then |                    if not assigned(inlinecode) then | ||||||
|                      begin |                      begin | ||||||
|                        if assigned(tprocdef(procdefinition).code) then |                        if assigned(tprocdef(procdefinition).inlininginfo^.code) then | ||||||
|                          inlinecode:=tprocdef(procdefinition).code.getcopy |                          inlinecode:=tprocdef(procdefinition).inlininginfo^.code.getcopy | ||||||
|                        else |                        else | ||||||
|                          CGMessage(cg_e_no_code_for_inline_stored); |                          CGMessage(cg_e_no_code_for_inline_stored); | ||||||
|                        if assigned(inlinecode) then |                        if assigned(inlinecode) then | ||||||
| @ -2612,7 +2612,10 @@ type | |||||||
|            end; |            end; | ||||||
|       errorexit: |       errorexit: | ||||||
|          if assigned(inlinecode) then |          if assigned(inlinecode) then | ||||||
|            procdefinition.proccalloption:=pocall_inline; |            begin | ||||||
|  |              procdefinition.proccalloption:=pocall_inline; | ||||||
|  |              current_procinfo.flags:=current_procinfo.flags+((procdefinition as tprocdef).inlininginfo^.flags*inherited_inlining_flags); | ||||||
|  |            end; | ||||||
|       end; |       end; | ||||||
| 
 | 
 | ||||||
| {$ifdef state_tracking} | {$ifdef state_tracking} | ||||||
| @ -2698,7 +2701,10 @@ begin | |||||||
| end. | end. | ||||||
| { | { | ||||||
|   $Log$ |   $Log$ | ||||||
|   Revision 1.212  2003-12-08 22:37:28  peter |   Revision 1.213  2003-12-16 21:29:24  florian | ||||||
|  |     + inlined procedures inherit procinfo flags | ||||||
|  | 
 | ||||||
|  |   Revision 1.212  2003/12/08 22:37:28  peter | ||||||
|     * paralength is private again |     * paralength is private again | ||||||
| 
 | 
 | ||||||
|   Revision 1.211  2003/12/08 16:34:23  peter |   Revision 1.211  2003/12/08 16:34:23  peter | ||||||
|  | |||||||
| @ -86,7 +86,7 @@ var | |||||||
| implementation | implementation | ||||||
| 
 | 
 | ||||||
| uses cutils, htypechk, defutil, defcmp, globtype, globals, cpubase, ncnv, ncon,ncal, | uses cutils, htypechk, defutil, defcmp, globtype, globals, cpubase, ncnv, ncon,ncal, | ||||||
|      verbose, symdef, cgbase, procinfo; |      verbose, symconst,symdef, cgbase, procinfo; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| {***************************************************************************** | {***************************************************************************** | ||||||
| @ -290,7 +290,10 @@ end. | |||||||
| 
 | 
 | ||||||
| { | { | ||||||
|   $Log$ |   $Log$ | ||||||
|   Revision 1.17  2003-10-01 20:34:49  peter |   Revision 1.18  2003-12-16 21:29:24  florian | ||||||
|  |     + inlined procedures inherit procinfo flags | ||||||
|  | 
 | ||||||
|  |   Revision 1.17  2003/10/01 20:34:49  peter | ||||||
|     * procinfo unit contains tprocinfo |     * procinfo unit contains tprocinfo | ||||||
|     * cginfo renamed to cgbase |     * cginfo renamed to cgbase | ||||||
|     * moved cgmessage to verbose |     * moved cgmessage to verbose | ||||||
|  | |||||||
| @ -38,21 +38,9 @@ unit procinfo; | |||||||
|       aasmbase,aasmtai |       aasmbase,aasmtai | ||||||
|       ; |       ; | ||||||
| 
 | 
 | ||||||
|  |     const | ||||||
|  |       inherited_inlining_flags : tprocinfoflags = [pi_do_call]; | ||||||
| 
 | 
 | ||||||
|     type |  | ||||||
|       tprocinfoflag=( |  | ||||||
|         {# procedure uses asm } |  | ||||||
|         pi_uses_asm, |  | ||||||
|         {# procedure does a call } |  | ||||||
|         pi_do_call, |  | ||||||
|         {# procedure has a try statement = no register optimization } |  | ||||||
|         pi_uses_exceptions, |  | ||||||
|         {# procedure is declared as @var(assembler), don't optimize} |  | ||||||
|         pi_is_assembler, |  | ||||||
|         {# procedure contains data which needs to be finalized } |  | ||||||
|         pi_needs_implicit_finally |  | ||||||
|       ); |  | ||||||
|       tprocinfoflags=set of tprocinfoflag; |  | ||||||
| 
 | 
 | ||||||
|     type |     type | ||||||
|        {# This object gives information on the current routine being |        {# This object gives information on the current routine being | ||||||
| @ -211,7 +199,10 @@ implementation | |||||||
| end. | end. | ||||||
| { | { | ||||||
|   $Log$ |   $Log$ | ||||||
|   Revision 1.9  2003-12-03 23:13:20  peter |   Revision 1.10  2003-12-16 21:29:24  florian | ||||||
|  |     + inlined procedures inherit procinfo flags | ||||||
|  | 
 | ||||||
|  |   Revision 1.9  2003/12/03 23:13:20  peter | ||||||
|     * delayed paraloc allocation, a_param_*() gets extra parameter |     * delayed paraloc allocation, a_param_*() gets extra parameter | ||||||
|       if it needs to allocate temp or real paralocation |       if it needs to allocate temp or real paralocation | ||||||
|     * optimized/simplified int-real loading |     * optimized/simplified int-real loading | ||||||
|  | |||||||
| @ -249,7 +249,7 @@ implementation | |||||||
|         writeln(printnodefile,'*******************************************************************************'); |         writeln(printnodefile,'*******************************************************************************'); | ||||||
|         writeln(printnodefile,current_procinfo.procdef.fullprocname(false)); |         writeln(printnodefile,current_procinfo.procdef.fullprocname(false)); | ||||||
|         writeln(printnodefile,'*******************************************************************************'); |         writeln(printnodefile,'*******************************************************************************'); | ||||||
|         printnode(printnodefile,pd.code); |         printnode(printnodefile,pd.inlininginfo^.code); | ||||||
|         close(printnodefile); |         close(printnodefile); | ||||||
|       end; |       end; | ||||||
| 
 | 
 | ||||||
| @ -895,7 +895,7 @@ implementation | |||||||
|             code.free; |             code.free; | ||||||
|             code:=nil; |             code:=nil; | ||||||
|             if (procdef.proccalloption<>pocall_inline) then |             if (procdef.proccalloption<>pocall_inline) then | ||||||
|               procdef.code:=nil; |               procdef.inlininginfo^.code:=nil; | ||||||
|           end; |           end; | ||||||
|        end; |        end; | ||||||
| 
 | 
 | ||||||
| @ -985,13 +985,14 @@ implementation | |||||||
|                printnode_procdef(procdef); |                printnode_procdef(procdef); | ||||||
|            end; |            end; | ||||||
| 
 | 
 | ||||||
|  |          new(procdef.inlininginfo); | ||||||
|          { store a copy of the original tree for inline, for |          { store a copy of the original tree for inline, for | ||||||
|            normal procedures only store a reference to the |            normal procedures only store a reference to the | ||||||
|            current tree } |            current tree } | ||||||
|          if (procdef.proccalloption=pocall_inline) then |          if (procdef.proccalloption=pocall_inline) then | ||||||
|            procdef.code:=code.getcopy |            procdef.inlininginfo^.code:=code.getcopy | ||||||
|          else |          else | ||||||
|            procdef.code:=code; |            procdef.inlininginfo^.code:=code; | ||||||
| 
 | 
 | ||||||
|          { ... remove symbol tables } |          { ... remove symbol tables } | ||||||
|          remove_from_symtablestack; |          remove_from_symtablestack; | ||||||
| @ -1330,7 +1331,10 @@ implementation | |||||||
| end. | end. | ||||||
| { | { | ||||||
|   $Log$ |   $Log$ | ||||||
|   Revision 1.177  2003-12-15 21:25:48  peter |   Revision 1.178  2003-12-16 21:29:24  florian | ||||||
|  |     + inlined procedures inherit procinfo flags | ||||||
|  | 
 | ||||||
|  |   Revision 1.177  2003/12/15 21:25:48  peter | ||||||
|     * reg allocations for imaginary register are now inserted just |     * reg allocations for imaginary register are now inserted just | ||||||
|       before reg allocation |       before reg allocation | ||||||
|     * tregister changed to enum to allow compile time check |     * tregister changed to enum to allow compile time check | ||||||
|  | |||||||
| @ -319,6 +319,20 @@ type | |||||||
|     te_exact |     te_exact | ||||||
|   ); |   ); | ||||||
| 
 | 
 | ||||||
|  |   tprocinfoflag=( | ||||||
|  |     {# procedure uses asm } | ||||||
|  |     pi_uses_asm, | ||||||
|  |     {# procedure does a call } | ||||||
|  |     pi_do_call, | ||||||
|  |     {# procedure has a try statement = no register optimization } | ||||||
|  |     pi_uses_exceptions, | ||||||
|  |     {# procedure is declared as @var(assembler), don't optimize} | ||||||
|  |     pi_is_assembler, | ||||||
|  |     {# procedure contains data which needs to be finalized } | ||||||
|  |     pi_needs_implicit_finally | ||||||
|  |   ); | ||||||
|  |   tprocinfoflags=set of tprocinfoflag; | ||||||
|  | 
 | ||||||
| {$ifdef GDB} | {$ifdef GDB} | ||||||
| type | type | ||||||
|   tdefstabstatus = ( |   tdefstabstatus = ( | ||||||
| @ -379,7 +393,10 @@ initialization | |||||||
| end. | end. | ||||||
| { | { | ||||||
|   $Log$ |   $Log$ | ||||||
|   Revision 1.71  2003-11-23 17:05:16  peter |   Revision 1.72  2003-12-16 21:29:24  florian | ||||||
|  |     + inlined procedures inherit procinfo flags | ||||||
|  | 
 | ||||||
|  |   Revision 1.71  2003/11/23 17:05:16  peter | ||||||
|     * register calling is left-right |     * register calling is left-right | ||||||
|     * parameter ordering |     * parameter ordering | ||||||
|     * left-right calling inserts result parameter last |     * left-right calling inserts result parameter last | ||||||
|  | |||||||
| @ -494,6 +494,13 @@ interface | |||||||
|            1 : (i : longint); |            1 : (i : longint); | ||||||
|        end; |        end; | ||||||
| 
 | 
 | ||||||
|  |        tinlininginfo = record | ||||||
|  |          { node tree } | ||||||
|  |           code : tnode; | ||||||
|  |           flags : tprocinfoflags; | ||||||
|  |        end; | ||||||
|  |        pinlininginfo = ^tinlininginfo; | ||||||
|  | 
 | ||||||
|        tprocdef = class(tabstractprocdef) |        tprocdef = class(tabstractprocdef) | ||||||
|        private |        private | ||||||
|           _mangledname : pstring; |           _mangledname : pstring; | ||||||
| @ -528,13 +535,11 @@ interface | |||||||
|           refcount : longint; |           refcount : longint; | ||||||
|           _class : tobjectdef; |           _class : tobjectdef; | ||||||
|           _classderef : tderef; |           _classderef : tderef; | ||||||
|           { it's a tree, but this not easy to handle } | 
 | ||||||
|           { used for inlined procs                   } |  | ||||||
|           code : tnode; |  | ||||||
|           { name of the result variable to insert in the localsymtable } |           { name of the result variable to insert in the localsymtable } | ||||||
|           resultname : stringid; |           resultname : stringid; | ||||||
|           { true, if the procedure is only declared } |           { true, if the procedure is only declared | ||||||
|           { (forward procedure) } |             (forward procedure) } | ||||||
|           forwarddef, |           forwarddef, | ||||||
|           { true if the procedure is declared in the interface } |           { true if the procedure is declared in the interface } | ||||||
|           interfacedef : boolean; |           interfacedef : boolean; | ||||||
| @ -542,6 +547,9 @@ interface | |||||||
|           hasforward : boolean; |           hasforward : boolean; | ||||||
|           { check the problems of manglednames } |           { check the problems of manglednames } | ||||||
|           has_mangledname : boolean; |           has_mangledname : boolean; | ||||||
|  |           { info for inlining the subroutine, if this pointer is nil, | ||||||
|  |             the procedure can't be inlined } | ||||||
|  |           inlininginfo : pinlininginfo; | ||||||
|           constructor create(level:byte); |           constructor create(level:byte); | ||||||
|           constructor ppuload(ppufile:tcompilerppufile); |           constructor ppuload(ppufile:tcompilerppufile); | ||||||
|           destructor  destroy;override; |           destructor  destroy;override; | ||||||
| @ -3597,7 +3605,11 @@ implementation | |||||||
|          interfacedef:=false; |          interfacedef:=false; | ||||||
|          hasforward:=false; |          hasforward:=false; | ||||||
|          _class := nil; |          _class := nil; | ||||||
|          code:=nil; |          { only for non inlined procedures loaded from a unit | ||||||
|  |            we don't need this info | ||||||
|  |          } | ||||||
|  |          new(inlininginfo); | ||||||
|  |          fillchar(inlininginfo^,sizeof(tinlininginfo),0); | ||||||
|          overloadnumber:=0; |          overloadnumber:=0; | ||||||
| {$ifdef GDB} | {$ifdef GDB} | ||||||
|          isstabwritten := false; |          isstabwritten := false; | ||||||
| @ -3647,9 +3659,13 @@ implementation | |||||||
| 
 | 
 | ||||||
|          { inline stuff } |          { inline stuff } | ||||||
|          if proccalloption=pocall_inline then |          if proccalloption=pocall_inline then | ||||||
|            code:=ppuloadnodetree(ppufile) |            begin | ||||||
|  |              new(inlininginfo); | ||||||
|  |              inlininginfo^.code:=ppuloadnodetree(ppufile); | ||||||
|  |              ppufile.getsmallset(inlininginfo^.flags); | ||||||
|  |            end | ||||||
|          else |          else | ||||||
|            code := nil; |            inlininginfo := nil; | ||||||
| 
 | 
 | ||||||
|          { default values for no persistent data } |          { default values for no persistent data } | ||||||
|          if (cs_link_deffile in aktglobalswitches) and |          if (cs_link_deffile in aktglobalswitches) and | ||||||
| @ -3688,16 +3704,18 @@ implementation | |||||||
|             memproclocalst.start; |             memproclocalst.start; | ||||||
| {$endif MEMDEBUG} | {$endif MEMDEBUG} | ||||||
|           end; |           end; | ||||||
|          if (proccalloption=pocall_inline) and assigned(code) then |          if (proccalloption=pocall_inline) and assigned(inlininginfo) then | ||||||
|           begin |           begin | ||||||
| {$ifdef MEMDEBUG} | {$ifdef MEMDEBUG} | ||||||
|             memprocnodetree.start; |             memprocnodetree.start; | ||||||
| {$endif MEMDEBUG} | {$endif MEMDEBUG} | ||||||
|             tnode(code).free; |             tnode(inlininginfo^.code).free; | ||||||
| {$ifdef MEMDEBUG} | {$ifdef MEMDEBUG} | ||||||
|             memprocnodetree.start; |             memprocnodetree.start; | ||||||
| {$endif MEMDEBUG} | {$endif MEMDEBUG} | ||||||
|           end; |           end; | ||||||
|  |          if assigned(inlininginfo) then | ||||||
|  |            dispose(inlininginfo); | ||||||
|          if (po_msgstr in procoptions) then |          if (po_msgstr in procoptions) then | ||||||
|            strdispose(messageinf.str); |            strdispose(messageinf.str); | ||||||
|          if assigned(_mangledname) then |          if assigned(_mangledname) then | ||||||
| @ -3774,7 +3792,11 @@ implementation | |||||||
|          oldintfcrc:=ppufile.do_crc; |          oldintfcrc:=ppufile.do_crc; | ||||||
|          ppufile.do_crc:=false; |          ppufile.do_crc:=false; | ||||||
|          if proccalloption=pocall_inline then |          if proccalloption=pocall_inline then | ||||||
|            ppuwritenodetree(ppufile,code); |            begin | ||||||
|  |              ppuwritenodetree(ppufile,inlininginfo^.code); | ||||||
|  |              ppufile.putsmallset(inlininginfo^.flags); | ||||||
|  |            end; | ||||||
|  | 
 | ||||||
|          ppufile.do_crc:=oldintfcrc; |          ppufile.do_crc:=oldintfcrc; | ||||||
| 
 | 
 | ||||||
|          aktparasymtable:=oldparasymtable; |          aktparasymtable:=oldparasymtable; | ||||||
| @ -3792,7 +3814,6 @@ implementation | |||||||
|      end; |      end; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     function tprocdef.fullprocname(showhidden:boolean):string; |     function tprocdef.fullprocname(showhidden:boolean):string; | ||||||
|       var |       var | ||||||
|         s : string; |         s : string; | ||||||
| @ -4169,7 +4190,7 @@ implementation | |||||||
| 
 | 
 | ||||||
|          { inline tree } |          { inline tree } | ||||||
|          if (proccalloption=pocall_inline) then |          if (proccalloption=pocall_inline) then | ||||||
|            code.buildderefimpl; |            inlininginfo^.code.buildderefimpl; | ||||||
| 
 | 
 | ||||||
|          aktparasymtable:=oldparasymtable; |          aktparasymtable:=oldparasymtable; | ||||||
|          aktlocalsymtable:=oldlocalsymtable; |          aktlocalsymtable:=oldlocalsymtable; | ||||||
| @ -4229,7 +4250,7 @@ implementation | |||||||
| 
 | 
 | ||||||
|         { inline tree } |         { inline tree } | ||||||
|         if (proccalloption=pocall_inline) then |         if (proccalloption=pocall_inline) then | ||||||
|           code.derefimpl; |           inlininginfo^.code.derefimpl; | ||||||
| 
 | 
 | ||||||
|         aktparasymtable:=oldparasymtable; |         aktparasymtable:=oldparasymtable; | ||||||
|         aktlocalsymtable:=oldlocalsymtable; |         aktlocalsymtable:=oldlocalsymtable; | ||||||
| @ -6118,7 +6139,10 @@ implementation | |||||||
| end. | end. | ||||||
| { | { | ||||||
|   $Log$ |   $Log$ | ||||||
|   Revision 1.192  2003-12-12 12:09:40  marco |   Revision 1.193  2003-12-16 21:29:24  florian | ||||||
|  |     + inlined procedures inherit procinfo flags | ||||||
|  | 
 | ||||||
|  |   Revision 1.192  2003/12/12 12:09:40  marco | ||||||
|    * always generate RTTI patch from peter |    * always generate RTTI patch from peter | ||||||
| 
 | 
 | ||||||
|   Revision 1.191  2003/12/08 22:34:24  peter |   Revision 1.191  2003/12/08 22:34:24  peter | ||||||
|  | |||||||
| @ -43,6 +43,20 @@ const | |||||||
|   v_all            = $ff; |   v_all            = $ff; | ||||||
| 
 | 
 | ||||||
| type | type | ||||||
|  |   tprocinfoflag=( | ||||||
|  |     {# procedure uses asm } | ||||||
|  |     pi_uses_asm, | ||||||
|  |     {# procedure does a call } | ||||||
|  |     pi_do_call, | ||||||
|  |     {# procedure has a try statement = no register optimization } | ||||||
|  |     pi_uses_exceptions, | ||||||
|  |     {# procedure is declared as @var(assembler), don't optimize} | ||||||
|  |     pi_is_assembler, | ||||||
|  |     {# procedure contains data which needs to be finalized } | ||||||
|  |     pi_needs_implicit_finally | ||||||
|  |   ); | ||||||
|  |   tprocinfoflags=set of tprocinfoflag; | ||||||
|  | 
 | ||||||
|   { Copied from systems.pas } |   { Copied from systems.pas } | ||||||
|   ttargetcpu= |   ttargetcpu= | ||||||
|   ( |   ( | ||||||
| @ -1219,6 +1233,8 @@ var | |||||||
|   totaldefs,l,j, |   totaldefs,l,j, | ||||||
|   defcnt : longint; |   defcnt : longint; | ||||||
|   calloption : tproccalloption; |   calloption : tproccalloption; | ||||||
|  |   procinfooptions : tprocinfoflag; | ||||||
|  | 
 | ||||||
| begin | begin | ||||||
|   defcnt:=0; |   defcnt:=0; | ||||||
|   with ppufile do |   with ppufile do | ||||||
| @ -1330,7 +1346,11 @@ begin | |||||||
|               end; |               end; | ||||||
|              { code } |              { code } | ||||||
|              if (calloption=pocall_inline) then |              if (calloption=pocall_inline) then | ||||||
|                readnodetree; |                begin | ||||||
|  |                  readnodetree; | ||||||
|  |                  ppufile.getsmallset(procinfooptions); | ||||||
|  |                  writeln(space,'  ProcInfoOptions : ',dword(procinfooptions)); | ||||||
|  |                end; | ||||||
|              delete(space,1,4); |              delete(space,1,4); | ||||||
|            end; |            end; | ||||||
| 
 | 
 | ||||||
| @ -1929,7 +1949,10 @@ begin | |||||||
| end. | end. | ||||||
| { | { | ||||||
|   $Log$ |   $Log$ | ||||||
|   Revision 1.49  2003-12-08 21:04:08  peter |   Revision 1.50  2003-12-16 21:29:25  florian | ||||||
|  |     + inlined procedures inherit procinfo flags | ||||||
|  | 
 | ||||||
|  |   Revision 1.49  2003/12/08 21:04:08  peter | ||||||
|     * line break in uses unit |     * line break in uses unit | ||||||
| 
 | 
 | ||||||
|   Revision 1.48  2003/11/10 22:02:52  peter |   Revision 1.48  2003/11/10 22:02:52  peter | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 florian
						florian