xref: /AOO41X/main/automation/source/server/prof_usl.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
29*cdf0e10cSrcweir #include "precompiled_automation.hxx"
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir 
32*cdf0e10cSrcweir #include <procfs.h>
33*cdf0e10cSrcweir #include <tools/stream.hxx>
34*cdf0e10cSrcweir #include "profiler.hxx"
35*cdf0e10cSrcweir 
36*cdf0e10cSrcweir 
37*cdf0e10cSrcweir struct SysdepProfileSnapshot
38*cdf0e10cSrcweir {
39*cdf0e10cSrcweir 	pstatus mpstatus;
40*cdf0e10cSrcweir 	psinfo mpsinfo;
41*cdf0e10cSrcweir 	prusage mprusage;
42*cdf0e10cSrcweir };
43*cdf0e10cSrcweir 
44*cdf0e10cSrcweir 
45*cdf0e10cSrcweir struct SysdepStaticData
46*cdf0e10cSrcweir {
47*cdf0e10cSrcweir 	// Hier steht alles, was w�hrend des Profiles st�ndig gebraucht wird
48*cdf0e10cSrcweir };
49*cdf0e10cSrcweir 
50*cdf0e10cSrcweir 
51*cdf0e10cSrcweir void TTProfiler::InitSysdepProfiler()
52*cdf0e10cSrcweir {
53*cdf0e10cSrcweir 	if ( !pSysDepStatic )	// Sollte immer so sein!!
54*cdf0e10cSrcweir 		pSysDepStatic = new SysdepStaticData;
55*cdf0e10cSrcweir 	// Hier initialisieren
56*cdf0e10cSrcweir 
57*cdf0e10cSrcweir };
58*cdf0e10cSrcweir 
59*cdf0e10cSrcweir void TTProfiler::DeinitSysdepProfiler()
60*cdf0e10cSrcweir {
61*cdf0e10cSrcweir 	if ( pSysDepStatic )	// Sollte immer so sein!!
62*cdf0e10cSrcweir 	{
63*cdf0e10cSrcweir 		// Hier aufr�umen und eventuell Speicher freigeben
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir 		delete pSysDepStatic;
66*cdf0e10cSrcweir 	}
67*cdf0e10cSrcweir };
68*cdf0e10cSrcweir 
69*cdf0e10cSrcweir SysdepProfileSnapshot *TTProfiler::NewSysdepSnapshotData()
70*cdf0e10cSrcweir {
71*cdf0e10cSrcweir 	return new SysdepProfileSnapshot;
72*cdf0e10cSrcweir };
73*cdf0e10cSrcweir 
74*cdf0e10cSrcweir void TTProfiler::DeleteSysdepSnapshotData( SysdepProfileSnapshot *pSysdepProfileSnapshot )
75*cdf0e10cSrcweir {
76*cdf0e10cSrcweir 	delete pSysdepProfileSnapshot;
77*cdf0e10cSrcweir };
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir 
80*cdf0e10cSrcweir // Titelzeile f�r Logdatei
81*cdf0e10cSrcweir String TTProfiler::GetSysdepProfileHeader()
82*cdf0e10cSrcweir {
83*cdf0e10cSrcweir 	return String::CreateFromAscii(" Size(Kb) ResidentSZ  rtime  ktime  utime  total");
84*cdf0e10cSrcweir };
85*cdf0e10cSrcweir 
86*cdf0e10cSrcweir 
87*cdf0e10cSrcweir // Zustand merken
88*cdf0e10cSrcweir void TTProfiler::GetSysdepProfileSnapshot( SysdepProfileSnapshot *pSysdepProfileSnapshot, sal_uInt16 )
89*cdf0e10cSrcweir {
90*cdf0e10cSrcweir 	SvFileStream aStream( String::CreateFromAscii("/proc/self/psinfo"), STREAM_READ );		// Das ist ein expliziter Pfad f�r UNXSOL!
91*cdf0e10cSrcweir 	if ( aStream.IsOpen() )
92*cdf0e10cSrcweir 	{
93*cdf0e10cSrcweir 		aStream.Read( &(pSysdepProfileSnapshot->mpsinfo), sizeof( psinfo ) );
94*cdf0e10cSrcweir 		aStream.Close();
95*cdf0e10cSrcweir 	}
96*cdf0e10cSrcweir 	SvFileStream anotherStream( String::CreateFromAscii("/proc/self/status"), STREAM_READ );		// Das ist ein expliziter Pfad f�r UNXSOL!
97*cdf0e10cSrcweir 	if ( anotherStream.IsOpen() )
98*cdf0e10cSrcweir 	{
99*cdf0e10cSrcweir 		anotherStream.Read( &(pSysdepProfileSnapshot->mpstatus), sizeof( pstatus ) );
100*cdf0e10cSrcweir 		anotherStream.Close();
101*cdf0e10cSrcweir 	}
102*cdf0e10cSrcweir 	SvFileStream YetAnotherStream( String::CreateFromAscii("/proc/self/usage"), STREAM_READ );		// Das ist ein expliziter Pfad f�r UNXSOL!
103*cdf0e10cSrcweir 	if ( YetAnotherStream.IsOpen() )
104*cdf0e10cSrcweir 	{
105*cdf0e10cSrcweir 		YetAnotherStream.Read( &(pSysdepProfileSnapshot->mprusage), sizeof( prusage ) );
106*cdf0e10cSrcweir 		YetAnotherStream.Close();
107*cdf0e10cSrcweir 	}
108*cdf0e10cSrcweir };
109*cdf0e10cSrcweir 
110*cdf0e10cSrcweir #define DIFF2( aFirst, aSecond, Membername ) ( aSecond.Membername - aFirst.Membername )
111*cdf0e10cSrcweir #define CALC_MS( nSec, nNSec ) ( nSec * 1000 + (nNSec+500000) / 1000000 )
112*cdf0e10cSrcweir #define DIFF_MS( pStart, pEnd, Member ) ( CALC_MS( pEnd->Member.tv_sec, pEnd->Member.tv_nsec ) - CALC_MS( pStart->Member.tv_sec, pStart->Member.tv_nsec ) )
113*cdf0e10cSrcweir // Informationszeile zusammenbauen
114*cdf0e10cSrcweir String TTProfiler::GetSysdepProfileLine( SysdepProfileSnapshot *pStart, SysdepProfileSnapshot *pStop )
115*cdf0e10cSrcweir {
116*cdf0e10cSrcweir 	String aProfile;
117*cdf0e10cSrcweir 
118*cdf0e10cSrcweir 	aProfile += Pad( String::CreateFromInt64(pStop->mpsinfo.pr_size), 9);
119*cdf0e10cSrcweir 	aProfile += Pad( String::CreateFromInt64(pStop->mpsinfo.pr_rssize), 11);
120*cdf0e10cSrcweir 
121*cdf0e10cSrcweir 
122*cdf0e10cSrcweir 	aProfile += Pad( String::CreateFromInt64(DIFF_MS( pStart, pStop, mprusage.pr_rtime ) / AVER( pStart, pStop, mprusage.pr_count )), 7 );
123*cdf0e10cSrcweir 
124*cdf0e10cSrcweir 
125*cdf0e10cSrcweir 	sal_uLong d_utime = DIFF_MS( pStart, pStop, mpstatus.pr_utime ) + DIFF_MS( pStart, pStop, mpstatus.pr_cutime );
126*cdf0e10cSrcweir 	sal_uLong d_stime = DIFF_MS( pStart, pStop, mpstatus.pr_stime ) + DIFF_MS( pStart, pStop, mpstatus.pr_cstime );
127*cdf0e10cSrcweir 
128*cdf0e10cSrcweir 	aProfile += Pad( String::CreateFromInt64(d_utime), 7 );
129*cdf0e10cSrcweir 	aProfile += Pad( String::CreateFromInt64(d_stime), 7 );
130*cdf0e10cSrcweir 	aProfile += Pad( String::CreateFromInt64(d_utime + d_stime), 7 );
131*cdf0e10cSrcweir 
132*cdf0e10cSrcweir 	return aProfile;
133*cdf0e10cSrcweir };
134*cdf0e10cSrcweir 
135*cdf0e10cSrcweir 
136*cdf0e10cSrcweir 
137