summaryrefslogtreecommitdiff
path: root/sal
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2011-01-05 19:58:08 +0000
committerCaolán McNamara <caolanm@redhat.com>2011-01-05 19:58:08 +0000
commitda59e86c2954db30f0bba9f3f5978457cf62d977 (patch)
tree127b4095368713a047f1c856777363cb52842a4a /sal
parent4a0b1361e3fa172b2af2bde896fab11013dcb730 (diff)
[opt] play around with callgrind to get repeatable numbers
Diffstat (limited to 'sal')
-rw-r--r--sal/workben/makefile.mk4
-rw-r--r--sal/workben/measure_oustrings.cxx185
2 files changed, 125 insertions, 64 deletions
diff --git a/sal/workben/makefile.mk b/sal/workben/makefile.mk
index 9275a2bcd1c6..09022e29d65c 100644
--- a/sal/workben/makefile.mk
+++ b/sal/workben/makefile.mk
@@ -118,6 +118,10 @@ APP5DEPN=$(SLB)$/sal.lib
OBJFILES+=\
$(OBJ)$/measure_oustrings.obj
+.IF "$(HAVE_CALLGRIND)" == "YES"
+CFLAGSCXX+=-DHAVE_CALLGRIND
+.ENDIF
+
APP6TARGET=measure_oustrings
APP6OBJS=$(OBJ)$/measure_oustrings.obj
APP6STDLIBS=$(SALLIB)
diff --git a/sal/workben/measure_oustrings.cxx b/sal/workben/measure_oustrings.cxx
index c9bd728bc395..dc5fc4e75584 100644
--- a/sal/workben/measure_oustrings.cxx
+++ b/sal/workben/measure_oustrings.cxx
@@ -28,8 +28,22 @@
#include <sal/main.h>
#include <rtl/ustring.hxx>
#include <osl/time.h>
+#include <osl/process.h>
#include <iostream>
+#include <sstream>
+#include <fstream>
+
+#ifdef HAVE_CALLGRIND
+# include <valgrind/callgrind.h>
+int COUNT = 1;
+#else
+# define CALLGRIND_DUMP_STATS_AT
+# define CALLGRIND_START_INSTRUMENTATION
+# define CALLGRIND_STOP_INSTRUMENTATION
+# define CALLGRIND_ZERO_STATS
+int COUNT = 10000000;
+#endif
#if defined __GXX_EXPERIMENTAL_CXX0X__
# define HAVE_CXX_Ox 1
@@ -51,102 +65,145 @@
#define RTL_CONSTASCII_USTRINGPARAM_CLASSIC(str) \
str, ((sal_Int32)(SAL_N_ELEMENTS(str)-1)), RTL_TEXTENCODING_ASCII_US
+int currenttest = 1;
+oslProcessInfo pidinfo;
+
+class TimerMeasure
+{
+private:
+ const char *m_pMessage;
+ sal_uInt32 m_nStartTime, m_nEndTime;
+public:
+ TimerMeasure(const char *pMessage)
+ : m_pMessage(pMessage)
+ {
+ m_nStartTime = osl_getGlobalTimer();
+ CALLGRIND_START_INSTRUMENTATION
+ CALLGRIND_ZERO_STATS
+ }
+
+ ~TimerMeasure()
+ {
+ CALLGRIND_STOP_INSTRUMENTATION
+ CALLGRIND_DUMP_STATS_AT(m_pMessage);
+ m_nEndTime = osl_getGlobalTimer();
+ std::cout << m_pMessage << std::endl;
+ std::cout << " callgrind Instruction cost is: " << std::flush;
+
+ std::stringstream aFileName;
+ aFileName << "callgrind.out." << pidinfo.Ident << "." << currenttest;
+
+ std::ifstream myfile(aFileName.str(), std::ios::in);
+ if (myfile.is_open())
+ {
+ std::stringstream aGetGrindStats;
+ aGetGrindStats << "callgrind_annotate " << aFileName.str() <<
+ " | grep TOTALS | sed 's/ PROGRAM TOTALS//'";
+ system(aGetGrindStats.str().c_str());
+ myfile.close();
+ }
+ else
+ std::cout << "Unavailable" << std::endl;
+ currenttest++;
+#ifndef HAVE_CALLGRIND
+ std::cout << " Elapsed Time is: " << m_nEndTime - m_nStartTime << "ms" << std::endl;
+#endif
+ }
+};
+
+#define TIME(msg, test) \
+{\
+ { test } /*Run the test one to shake out any firsttime lazy loading stuff*/ \
+ TimerMeasure aMeasure(msg);\
+ for (int i = 0; i < COUNT; ++i)\
+ test\
+}
SAL_IMPLEMENT_MAIN()
{
+ CALLGRIND_STOP_INSTRUMENTATION
+ CALLGRIND_ZERO_STATS
+
+ pidinfo.Size = sizeof(pidinfo);
+ osl_getProcessInfo(0, osl_Process_IDENTIFIER, &pidinfo);
+
+#ifdef HAVE_CALLGRIND
+ std::cout << "Execute using: valgrind --tool=callgrind ./measure_oustrings" << std::endl;
+#else
//get my cpu fan up to speed :-)
for (int i = 0; i < 10000000; ++i)
{
rtl::OUString sFoo(rtl::OUString::createFromAscii("X"));
rtl::OUString sBar(RTL_CONSTASCII_USTRINGPARAM_CLASSIC("X"));
-#ifdef SAL_DECLARE_UTF16
- rtl::OUString sBoo(RTL_CONSTASCII_USTRINGPARAM_WIDE("X"));
-#endif
rtl::OUString sBaz(static_cast<sal_Unicode>('X'));
rtl::OUString sNone;
}
+#endif
std::cout << "--Empty Strings--" << std::endl;
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
+ TIME
+ (
+ "rtl::OUString()",
rtl::OUString sFoo;
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString() " << nEndTime - nStartTime << "ms" << std::endl;
- }
+ )
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
+ TIME
+ (
+ "rtl::OUString::createFromAscii()",
rtl::OUString sFoo(rtl::OUString::createFromAscii(""));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString::createFromAscii() " << nEndTime - nStartTime << "ms" << std::endl;
- }
+ )
std::cout << "--Single Chars--" << std::endl;
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
- rtl::OUString sFoo(rtl::OUString::createFromAscii("X"));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString::createFromAscii(\"X\") " << nEndTime - nStartTime << "ms" << std::endl;
- }
-
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
- rtl::OUString sBar(RTL_CONSTASCII_USTRINGPARAM_CLASSIC("X"));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_CLASSIC(\"X\")) " << nEndTime - nStartTime << "ms" << std::endl;
- }
+ TIME
+ (
+ "rtl::OUString(static_cast<sal_Unicode>('X')",
+ rtl::OUString sBaz(static_cast<sal_Unicode>('X'));
+ )
#ifdef SAL_DECLARE_UTF16
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
+ TIME
+ (
+ "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_WIDE(\"X\"))",
rtl::OUString sBar(RTL_CONSTASCII_USTRINGPARAM_WIDE("X"));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_WIDE(\"X\")) " << nEndTime - nStartTime<< "ms" << std::endl;
- }
+ )
#endif
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
- rtl::OUString sBaz(static_cast<sal_Unicode>('X'));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString(static_cast<sal_Unicode>('X') " << nEndTime - nStartTime << "ms" << std::endl;
- }
+ TIME
+ (
+ "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_CLASSIC(\"X\"))",
+ rtl::OUString sBar(RTL_CONSTASCII_USTRINGPARAM_CLASSIC("X"));
+ )
- std::cout << "--MultiChar Strings--" << std::endl;
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
- rtl::OUString sFoo(rtl::OUString::createFromAscii("XXXXXXXXXXXXXXX"));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString::createFromAscii(\"XXXXXXXX\") " << nEndTime - nStartTime << "ms" << std::endl;
- }
+ TIME
+ (
+ "rtl::OUString::createFromAscii(\"X\")",
+ rtl::OUString sFoo(rtl::OUString::createFromAscii("X"));
+ )
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
- rtl::OUString sBar(RTL_CONSTASCII_USTRINGPARAM_CLASSIC("XXXXXXXXXXXXXXX"));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_CLASSIC(\"XXXXXXXX\")) " << nEndTime - nStartTime << "ms" << std::endl;
- }
+ std::cout << "--MultiChar Strings--" << std::endl;
#ifdef SAL_DECLARE_UTF16
- {
- sal_uInt32 nStartTime = osl_getGlobalTimer();
- for (int i = 0; i < 100000000; ++i)
+ TIME
+ (
+ "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_WIDE(\"XXXXXXXX\"))",
rtl::OUString sBar(RTL_CONSTASCII_USTRINGPARAM_WIDE("XXXXXXXXXXXXXXX"));
- sal_uInt32 nEndTime = osl_getGlobalTimer();
- std::cout << "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_WIDE(\"XXXXXXXX\")) " << nEndTime - nStartTime << "ms" << std::endl;
- }
+ )
#endif
+ TIME
+ (
+ "rtl::OUString(RTL_CONSTASCII_USTRINGPARAM_CLASSIC(\"XXXXXXXX\"))",
+ rtl::OUString sBar(RTL_CONSTASCII_USTRINGPARAM_CLASSIC("XXXXXXXXXXXXXXX"));
+ )
+
+ TIME
+ (
+ "rtl::OUString::createFromAscii(\"XXXXXXXX\")",
+ rtl::OUString sFoo(rtl::OUString::createFromAscii("XXXXXXXXXXXXXXX"));
+ )
+
return 0;
}