2018-05-31 15:31:03 -07:00
|
|
|
// Copyright (c) 2004-present, Facebook, Inc.
|
|
|
|
|
|
|
|
// This source code is licensed under the MIT license found in the
|
|
|
|
// LICENSE file in the root directory of this source tree.
|
2016-05-13 17:15:03 -07:00
|
|
|
|
|
|
|
#include "JSCLegacyTracing.h"
|
|
|
|
|
2017-07-25 04:45:08 -07:00
|
|
|
#if defined(WITH_JSC_EXTRA_TRACING)
|
|
|
|
|
2016-05-13 17:15:03 -07:00
|
|
|
#include <fbsystrace.h>
|
2016-11-22 06:05:36 -08:00
|
|
|
#include <JavaScriptCore/API/JSProfilerPrivate.h>
|
2016-11-01 11:38:43 -07:00
|
|
|
#include <jschelpers/JSCHelpers.h>
|
2016-11-18 06:25:24 -08:00
|
|
|
#include <jschelpers/Value.h>
|
2016-11-01 11:38:43 -07:00
|
|
|
|
2016-05-13 17:15:03 -07:00
|
|
|
static const char *ENABLED_FBSYSTRACE_PROFILE_NAME = "__fbsystrace__";
|
|
|
|
|
2016-11-18 06:25:24 -08:00
|
|
|
using namespace facebook::react;
|
|
|
|
|
2017-07-25 04:45:08 -07:00
|
|
|
static int64_t int64FromJSValue(JSContextRef ctx, JSValueRef value, JSValueRef* exception) {
|
|
|
|
return static_cast<int64_t>(JSC_JSValueToNumber(ctx, value, exception));
|
|
|
|
}
|
|
|
|
|
2016-05-13 17:15:03 -07:00
|
|
|
static JSValueRef nativeTraceBeginLegacy(
|
|
|
|
JSContextRef ctx,
|
|
|
|
JSObjectRef function,
|
|
|
|
JSObjectRef thisObject,
|
|
|
|
size_t argumentCount,
|
|
|
|
const JSValueRef arguments[],
|
|
|
|
JSValueRef* exception) {
|
|
|
|
if (FBSYSTRACE_LIKELY(argumentCount >= 1)) {
|
2017-07-25 04:45:08 -07:00
|
|
|
uint64_t tag = int64FromJSValue(ctx, arguments[0], exception);
|
2016-05-13 17:15:03 -07:00
|
|
|
if (!fbsystrace_is_tracing(tag)) {
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-13 17:15:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-25 04:45:08 -07:00
|
|
|
JSStartProfiling(ctx, String(ctx, ENABLED_FBSYSTRACE_PROFILE_NAME), true);
|
2016-05-13 17:15:03 -07:00
|
|
|
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-13 17:15:03 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static JSValueRef nativeTraceEndLegacy(
|
|
|
|
JSContextRef ctx,
|
|
|
|
JSObjectRef function,
|
|
|
|
JSObjectRef thisObject,
|
|
|
|
size_t argumentCount,
|
|
|
|
const JSValueRef arguments[],
|
|
|
|
JSValueRef* exception) {
|
|
|
|
if (FBSYSTRACE_LIKELY(argumentCount >= 1)) {
|
2017-07-25 04:45:08 -07:00
|
|
|
uint64_t tag = int64FromJSValue(ctx, arguments[0], exception);
|
2016-05-13 17:15:03 -07:00
|
|
|
if (!fbsystrace_is_tracing(tag)) {
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-13 17:15:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-25 04:45:08 -07:00
|
|
|
JSEndProfiling(ctx, String(ctx, ENABLED_FBSYSTRACE_PROFILE_NAME));
|
2016-05-13 17:15:03 -07:00
|
|
|
|
2016-11-18 06:25:24 -08:00
|
|
|
return Value::makeUndefined(ctx);
|
2016-05-13 17:15:03 -07:00
|
|
|
}
|
|
|
|
|
2017-07-25 04:45:08 -07:00
|
|
|
#endif
|
|
|
|
|
2016-05-13 17:15:03 -07:00
|
|
|
namespace facebook {
|
|
|
|
namespace react {
|
|
|
|
|
|
|
|
void addNativeTracingLegacyHooks(JSGlobalContextRef ctx) {
|
2017-07-25 04:45:08 -07:00
|
|
|
#if defined(WITH_JSC_EXTRA_TRACING)
|
2016-05-13 17:15:03 -07:00
|
|
|
installGlobalFunction(ctx, "nativeTraceBeginLegacy", nativeTraceBeginLegacy);
|
|
|
|
installGlobalFunction(ctx, "nativeTraceEndLegacy", nativeTraceEndLegacy);
|
2017-07-25 04:45:08 -07:00
|
|
|
#endif
|
2016-05-13 17:15:03 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
} }
|