react-native/ReactCommon/cxxreact
Andy Street 0418353249 Add MicroProfiler for low-overhead profiling of JSC/bridge performance
Summary:
We have a lot of small-ish calls to JSC and within the bridge that add up during TTI. This gives us a way to measure them in aggregate in a reasonable way.

From the comments:

MicroProfiler is a performance profiler for measuring the cumulative impact of
a large number of small-ish calls. This is normally a problem for standard profilers
like Systrace because the overhead of the profiler itself skews the timings you
are able to collect. This is especially a problem when doing nested calls to
profiled functions, as the parent calls will contain the overhead of their profiling
plus the overhead of all their childrens' profiling.

MicroProfiler attempts to be low overhead by 1) aggregating timings in memory and
2) trying to remove estimated profiling overhead from the returned timings.

To remove estimated overhead, at the beginning of each trace we calculate the
average cost of profiling a no-op code section, as well as invoking the average
cost of invoking the system clock. The former is subtracted out for each child
profiler section that is invoked within a parent profiler section. The latter is
subtracted from each section, child or not.

The usage is similar to Systrace: you put a MICRO_PROFILER_BLOCK in the block you want to profile and C++ RAII will handle timing it.

After MicroProfiler::stopProfiling() is called, a table of tracing data is emitted
to glog (which shows up in logcat on Android).

Differential Revision: D3635319

fbshipit-source-id: 01390b8ac76a68dd425cba2adfdde6e4957440cc
2016-08-02 07:43:31 -07:00
..
tests Move some really old tests to the cxx bridge 2016-07-25 12:29:25 -07:00
Android.mk Fix optimized bundle stuff. 2016-07-14 15:28:46 -07:00
BUCK Add MicroProfiler for low-overhead profiling of JSC/bridge performance 2016-08-02 07:43:31 -07:00
CxxMessageQueue.cpp Add c++-runloop-backed message queue 2016-06-13 18:13:34 -07:00
CxxMessageQueue.h Add c++-runloop-backed message queue 2016-06-13 18:13:34 -07:00
CxxModule.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
Executor.cpp Fix optimized bundle stuff. 2016-07-14 15:28:46 -07:00
Executor.h Fix optimized bundle stuff. 2016-07-14 15:28:46 -07:00
ExecutorToken.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
ExecutorTokenFactory.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
FollySupport.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
Instance.cpp Fix optimized bundle stuff. 2016-07-14 15:28:46 -07:00
Instance.h Fix optimized bundle stuff. 2016-07-14 15:28:46 -07:00
JSCExecutor.cpp Remove some throw specifications 2016-07-21 17:43:27 -07:00
JSCExecutor.h Remove some throw specifications 2016-07-21 17:43:27 -07:00
JSCHelpers.cpp Add new FileSourceProvider 2016-07-11 06:58:26 -07:00
JSCHelpers.h Add new FileSourceProvider 2016-07-11 06:58:26 -07:00
JSCLegacyProfiler.cpp Do not set forceProfilerBytecodeGeneration option 2016-07-26 07:28:41 -07:00
JSCLegacyProfiler.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCLegacyTracing.cpp Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCLegacyTracing.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCMemory.cpp Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCMemory.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCPerfStats.cpp Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCPerfStats.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCSamplingProfiler.cpp #6 Notify SamplingProfiler of the main MachineThread 2016-07-15 11:58:31 -07:00
JSCSamplingProfiler.h #6 Notify SamplingProfiler of the main MachineThread 2016-07-15 11:58:31 -07:00
JSCTracing.cpp Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCTracing.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCWebWorker.cpp Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSCWebWorker.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JSModulesUnbundle.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JsArgumentHelpers-inl.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
JsArgumentHelpers.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
MessageQueueThread.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
MethodCall.cpp Move some really old tests to the cxx bridge 2016-07-25 12:29:25 -07:00
MethodCall.h Add some (possibly temporary) noexcept/throw specifications 2016-06-16 16:13:17 -07:00
ModuleRegistry.cpp Add better markers for getConfig 2016-06-06 11:58:32 -07:00
ModuleRegistry.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
NativeModule.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
NativeToJsBridge.cpp Fix optimized bundle stuff. 2016-07-14 15:28:46 -07:00
NativeToJsBridge.h Fix optimized bundle stuff. 2016-07-14 15:28:46 -07:00
Platform.cpp Build new bridge with gradle 2016-05-27 16:13:37 -07:00
Platform.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
SampleCxxModule.cpp Build new bridge with gradle 2016-05-27 16:13:37 -07:00
SampleCxxModule.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
SystraceSection.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00
Value.cpp Remove some throw specifications 2016-07-21 17:43:27 -07:00
Value.h Remove some throw specifications 2016-07-21 17:43:27 -07:00
noncopyable.h Build new bridge with gradle 2016-05-27 16:13:37 -07:00