summaryrefslogtreecommitdiffstats
path: root/media/base
diff options
context:
space:
mode:
authorfbarchard@chromium.org <fbarchard@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-21 21:30:24 +0000
committerfbarchard@chromium.org <fbarchard@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-21 21:30:24 +0000
commite6676af22ae37bd1716389b2ef3396d5f4b72a8e (patch)
treef20459f4c561c9fa21e534b14b1de46b17f824b8 /media/base
parent0ff224d9d6753bd8f0a9e99ddea2f96b3e264057 (diff)
downloadchromium_src-e6676af22ae37bd1716389b2ef3396d5f4b72a8e.zip
chromium_src-e6676af22ae37bd1716389b2ef3396d5f4b72a8e.tar.gz
chromium_src-e6676af22ae37bd1716389b2ef3396d5f4b72a8e.tar.bz2
Timing code for measuring DLL load performance.
BUG=18466 TEST=reduce DLL sizes with -O2 and other options, and test performance with this code. Review URL: http://codereview.chromium.org/165039 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@24017 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'media/base')
-rw-r--r--media/base/media_win.cc30
1 files changed, 29 insertions, 1 deletions
diff --git a/media/base/media_win.cc b/media/base/media_win.cc
index 31bfe43..975a301 100644
--- a/media/base/media_win.cc
+++ b/media/base/media_win.cc
@@ -10,6 +10,23 @@
#include "base/logging.h"
#include "base/path_service.h"
+// Enable timing code by turning on TESTING macro.
+//#define TESTING 1
+
+#ifdef TESTING
+#include "base/string_util.h"
+#include "base/time.h"
+
+namespace {
+// Fetch current time as milliseconds.
+// Return as double for high duration and precision.
+// TODO(fbarchard): integrate into base/time.h
+static inline double GetTime() {
+ return base::TimeTicks::HighResNow().ToInternalValue() * (1.0 / 1000.0);
+}
+}
+#endif
+
namespace media {
namespace {
@@ -49,9 +66,20 @@ bool InitializeMediaLibrary(const FilePath& base_path) {
HMODULE libs[arraysize(path_keys)] = {NULL};
for (size_t i = 0; i < arraysize(path_keys); ++i) {
FilePath path = base_path.Append(GetDLLName(path_keys[i]));
- libs[i] = LoadLibrary(path.value().c_str());
+#ifdef TESTING
+ double dll_loadtime_start = GetTime();
+#endif
+ const wchar_t* cpath = path.value().c_str();
+ libs[i] = LoadLibrary(cpath);
if (!libs[i])
break;
+#ifdef TESTING
+ double dll_loadtime_end = GetTime();
+ std::wstring outputbuf = StringPrintf(L"DLL loadtime %5.2f ms, %ls\n",
+ dll_loadtime_end - dll_loadtime_start,
+ cpath);
+ OutputDebugStringW(outputbuf.c_str());
+#endif
}
// Check that we loaded all libraries successfully. We only need to check the