Initial checkin of a new project: LLDB Performance Testing Infrastructure
authorEnrico Granata <egranata@apple.com>
Fri, 8 Mar 2013 20:29:13 +0000 (20:29 +0000)
committerEnrico Granata <egranata@apple.com>
Fri, 8 Mar 2013 20:29:13 +0000 (20:29 +0000)
commitf58cececaaee321143b177a0d7cbbffddcbfea4c
treea488537dcc777a7b1b68c3a35b1618d2f94850c1
parent8106d8082c406b4c381cd0d9604835fc35b45990
Initial checkin of a new project: LLDB Performance Testing Infrastructure

This is a very basic implementation of a library that easily allows to drive LLDB.framework to write test cases for performance

This is separate from the LLDB testsuite in test/ in that:
a) this uses C++ instead of Python to avoid measures being affected by SWIG
b) this is in very early development and needs lots of tweaking before it can be considered functionally complete
c) this is not meant to test correctness but to help catch performance regressions

There is a sample application built against the library (in darwin/sketch) that uses the famous sample app Sketch as an inferior to measure certain basic parameters of LLDB's behavior.
The resulting output is a PLIST much like the following:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<array>
<dict>
<key>fetch-frames</key>
<real>0.13161715522222225</real>
</dict>
<dict>
<key>file-line-bkpt</key>
<real>0.029111678750000002</real>
</dict>
<dict>
<key>fetch-modules</key>
<real>0.00026376766666666668</real>
</dict>
<dict>
<key>fetch-vars</key>
<real>0.17820429311111111</real>
</dict>
<dict>
<key>run-expr</key>
<real>0.029676525769230768</real>
</dict>
</array>
</plist>

Areas for improvement:
- code cleanups (I will be out of the office for a couple days this coming week, but please keep ideas coming!)
- more metrics and test cases
- better error checking

This toolkit also comprises a simple event-loop-driven controller for LLDB, similar yet much simpler to what the Driver does to implement the lldb command-line tool.

llvm-svn: 176715
18 files changed:
lldb/examples/python/process_events.py
lldb/lldb.xcodeproj/project.pbxproj
lldb/source/Host/macosx/cfcpp/CFCMutableDictionary.cpp
lldb/source/Host/macosx/cfcpp/CFCMutableDictionary.h
lldb/source/Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCRuntimeV2.cpp
lldb/tools/lldb-perf/darwin/sketch/main.cpp [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Gauge.h [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Measurement.h [new file with mode: 0644]
lldb/tools/lldb-perf/lib/MemoryGauge.cpp [new file with mode: 0644]
lldb/tools/lldb-perf/lib/MemoryGauge.h [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Metric.cpp [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Metric.h [new file with mode: 0644]
lldb/tools/lldb-perf/lib/TestCase.cpp [new file with mode: 0644]
lldb/tools/lldb-perf/lib/TestCase.h [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Timer.cpp [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Timer.h [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Xcode.cpp [new file with mode: 0644]
lldb/tools/lldb-perf/lib/Xcode.h [new file with mode: 0644]