| Index: src/perf-jit.h
|
| diff --git a/src/perf-jit.h b/src/perf-jit.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..9aeff7a5d6dd8eeda3386be6b8e7f0a6a16034c2
|
| --- /dev/null
|
| +++ b/src/perf-jit.h
|
| @@ -0,0 +1,136 @@
|
| +// Copyright 2014 the V8 project authors. All rights reserved.
|
| +// Redistribution and use in source and binary forms, with or without
|
| +// modification, are permitted provided that the following conditions are
|
| +// met:
|
| +//
|
| +// * Redistributions of source code must retain the above copyright
|
| +// notice, this list of conditions and the following disclaimer.
|
| +// * Redistributions in binary form must reproduce the above
|
| +// copyright notice, this list of conditions and the following
|
| +// disclaimer in the documentation and/or other materials provided
|
| +// with the distribution.
|
| +// * Neither the name of Google Inc. nor the names of its
|
| +// contributors may be used to endorse or promote products derived
|
| +// from this software without specific prior written permission.
|
| +//
|
| +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
| +// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
| +// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
| +// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
| +// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
| +// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
| +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
| +// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
| +// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
| +// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
| +// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
| +
|
| +#ifndef V8_PERF_JIT_H_
|
| +#define V8_PERF_JIT_H_
|
| +
|
| +#include "src/v8.h"
|
| +
|
| +namespace v8 {
|
| +namespace internal {
|
| +
|
| +// TODO(jarin) For now, we disable perf integration on Android because of a
|
| +// build problem - when building the snapshot with AOSP, librt is not
|
| +// available, so we cannot use the clock_gettime function. To fix this, we
|
| +// should thread through the V8_LIBRT_NOT_AVAILABLE flag here and only disable
|
| +// the perf integration when this flag is present (the perf integration is not
|
| +// needed when generating snapshot, so it is fine to ifdef it away).
|
| +
|
| +#if defined(__linux__) && !defined(ANDROID)
|
| +
|
| +// Linux perf tool logging support
|
| +class PerfJitLogger : public CodeEventLogger {
|
| + public:
|
| + PerfJitLogger();
|
| + virtual ~PerfJitLogger();
|
| +
|
| + virtual void CodeMoveEvent(Address from, Address to);
|
| + virtual void CodeDeleteEvent(Address from);
|
| + virtual void CodeDisableOptEvent(Code* code, SharedFunctionInfo* shared) { }
|
| + virtual void SnapshotPositionEvent(Address addr, int pos);
|
| +
|
| + private:
|
| + uint64_t GetTimestamp();
|
| + virtual void LogRecordedBuffer(Code* code,
|
| + SharedFunctionInfo* shared,
|
| + const char* name,
|
| + int length);
|
| +
|
| + // Extension added to V8 log file name to get the low-level log name.
|
| + static const char kFilenameFormatString[];
|
| + static const int kFilenameBufferPadding;
|
| +
|
| + static const char kTraceClockDevice[];
|
| + static const int kClockInvalid = -1;
|
| + static const uint64_t kNsecPerSec = 1000000000;
|
| +
|
| + // File buffer size of the low-level log. We don't use the default to
|
| + // minimize the associated overhead.
|
| + static const int kLogBufferSize = 2 * MB;
|
| +
|
| + void LogWriteBytes(const char* bytes, int size);
|
| + void LogWriteHeader();
|
| +
|
| + static const uint32_t kElfMachIA32 = 3;
|
| + static const uint32_t kElfMachX64 = 62;
|
| + static const uint32_t kElfMachARM = 40;
|
| + static const uint32_t kElfMachMIPS = 10;
|
| +
|
| + uint32_t GetElfMach() {
|
| +#if V8_TARGET_ARCH_IA32
|
| + return kElfMachIA32;
|
| +#elif V8_TARGET_ARCH_X64
|
| + return kElfMachX64;
|
| +#elif V8_TARGET_ARCH_ARM
|
| + return kElfMachARM;
|
| +#elif V8_TARGET_ARCH_MIPS
|
| + return kElfMachMIPS;
|
| +#else
|
| + UNIMPLEMENTED();
|
| + return 0;
|
| +#endif
|
| + }
|
| +
|
| + FILE* perf_output_handle_;
|
| + int clock_fd_;
|
| + int clock_id_;
|
| + uint64_t code_index_;
|
| +};
|
| +
|
| +#else
|
| +
|
| +// PerfJitLogger is only implemented on Linux
|
| +class PerfJitLogger : public CodeEventLogger {
|
| + public:
|
| + virtual void CodeMoveEvent(Address from, Address to) {
|
| + UNIMPLEMENTED();
|
| + }
|
| +
|
| + virtual void CodeDeleteEvent(Address from) {
|
| + UNIMPLEMENTED();
|
| + }
|
| +
|
| + virtual void CodeDisableOptEvent(Code* code, SharedFunctionInfo* shared) {
|
| + UNIMPLEMENTED();
|
| + }
|
| +
|
| + virtual void SnapshotPositionEvent(Address addr, int pos) {
|
| + UNIMPLEMENTED();
|
| + }
|
| +
|
| + virtual void LogRecordedBuffer(Code* code,
|
| + SharedFunctionInfo* shared,
|
| + const char* name,
|
| + int length) {
|
| + UNIMPLEMENTED();
|
| + }
|
| +};
|
| +
|
| +#endif // defined(__linux__) && !defined(ANDROID)
|
| +
|
| +} } // namespace v8::internal
|
| +#endif
|
|
|