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