mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-21 21:51:42 +02:00
+ added $error if compiled with -pg
+ all output to stderr
This commit is contained in:
parent
50ccd479d2
commit
16524901b4
@ -17,6 +17,11 @@
|
||||
}
|
||||
|
||||
{$S- do not use stackcheck here .. PM }
|
||||
{$ifdef FPC_PROFILE}
|
||||
{$error }
|
||||
{$message you can not compile profile unit with profiling}
|
||||
{$endif FPC_PROFILE}
|
||||
|
||||
Unit profile;
|
||||
|
||||
interface
|
||||
@ -54,14 +59,11 @@ var
|
||||
no lookup. }
|
||||
procedure mcount;
|
||||
|
||||
|
||||
implementation
|
||||
|
||||
uses
|
||||
go32,dpmiexcp;
|
||||
|
||||
{$ASMMODE ATT}
|
||||
|
||||
type
|
||||
plongint = ^longint;
|
||||
var
|
||||
@ -69,6 +71,27 @@ var
|
||||
const
|
||||
cache : pMTABE = nil;
|
||||
|
||||
(*
|
||||
{$ASMMODE DIRECT}
|
||||
procedure sbrk_getmem(var p : pointer;size : longint);assembler;
|
||||
asm
|
||||
movl size,%eax
|
||||
pushl %eax
|
||||
call ___sbrk
|
||||
addl $4,%esp
|
||||
movl %eax,p
|
||||
end;
|
||||
|
||||
this nice piece of code make serious problems !!! PM *)
|
||||
|
||||
procedure sbrk_getmem(var p : pointer;size : longint);
|
||||
|
||||
begin
|
||||
system.getmem(p,size);
|
||||
end;
|
||||
|
||||
{$ASMMODE ATT}
|
||||
|
||||
{ problem how to avoid mcount calling itself !! }
|
||||
procedure mcount; [public, alias : 'MCOUNT'];
|
||||
{
|
||||
@ -151,7 +174,9 @@ begin
|
||||
end;
|
||||
end;
|
||||
{ lob off another page of memory and initialize the new table }
|
||||
getmem(m,sizeof(M_TAB));
|
||||
{ problem here : getmem is not reentrant yet !! PM }
|
||||
{ lets hope that a direct call to sbrk correct this }
|
||||
sbrk_getmem(m,sizeof(M_TAB));
|
||||
fillchar(m^, sizeof(M_TAB),#0);
|
||||
m^.prev := mtab;
|
||||
mtab := m;
|
||||
@ -206,7 +231,7 @@ begin
|
||||
movl _RELOAD,%eax
|
||||
movl %eax,___djgpp_timer_countdown
|
||||
end;
|
||||
mcount_tick(x);
|
||||
timer:=mcount_tick(x);
|
||||
{ _raise(SIGPROF); }
|
||||
end;
|
||||
|
||||
@ -226,13 +251,13 @@ begin
|
||||
set_pm_interrupt($8,old_timer);
|
||||
reload:=0;
|
||||
exitproc:=oldexitproc;
|
||||
writeln('Writing profile output');
|
||||
writeln('histogram length = ',histlen);
|
||||
writeln('Nb of double calls = ',doublecall);
|
||||
writeln(stderr,'Writing profile output');
|
||||
writeln(stderr,'histogram length = ',histlen);
|
||||
writeln(stderr,'Nb of double calls = ',doublecall);
|
||||
if invalid_mcount_call>0 then
|
||||
writeln('nb of invalid mcount : ',invalid_mcount_call,'/',mcount_nb)
|
||||
writeln(stderr,'nb of invalid mcount : ',invalid_mcount_call,'/',mcount_nb)
|
||||
else
|
||||
writeln('nb of mcount : ',mcount_nb);
|
||||
writeln(stderr,'nb of mcount : ',mcount_nb);
|
||||
assign(f,'gmon.out');
|
||||
rewrite(f,1);
|
||||
blockwrite(f, h, sizeof(header));
|
||||
@ -247,7 +272,7 @@ begin
|
||||
blockwrite(f, m^.calls[i],sizeof(MTABE));
|
||||
{$ifdef DEBUG}
|
||||
if m^.calls[i].count>0 then
|
||||
writeln(' 0x',hexstr(m^.calls[i]._to,8),' called from ',hexstr(m^.calls[i].from,8),
|
||||
writeln(stderr,' 0x',hexstr(m^.calls[i]._to,8),' called from ',hexstr(m^.calls[i].from,8),
|
||||
' ',m^.calls[i].count,' times');
|
||||
{$endif DEBUG}
|
||||
end;
|
||||
@ -330,7 +355,11 @@ begin
|
||||
end.
|
||||
{
|
||||
$Log$
|
||||
Revision 1.3 1998-11-17 09:43:22 pierre
|
||||
Revision 1.4 1998-11-18 09:22:10 pierre
|
||||
+ added $error if compiled with -pg
|
||||
+ all output to stderr
|
||||
|
||||
Revision 1.3 1998/11/17 09:43:22 pierre
|
||||
+ No stack check
|
||||
|
||||
Revision 1.2 1998/05/31 14:18:28 peter
|
||||
|
Loading…
Reference in New Issue
Block a user