2017-06-07 05:36:26 +03:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
|
|
|
|
#ifndef mozilla_AutoProfilerLabel_h
|
|
|
|
#define mozilla_AutoProfilerLabel_h
|
|
|
|
|
|
|
|
#include "mozilla/Attributes.h"
|
|
|
|
#include "mozilla/GuardObjects.h"
|
2019-08-14 06:46:41 +03:00
|
|
|
#include "mozilla/Tuple.h"
|
2017-06-07 05:36:26 +03:00
|
|
|
#include "mozilla/Types.h"
|
|
|
|
|
|
|
|
// The Gecko Profiler defines AutoProfilerLabel, an RAII class for
|
2018-05-15 08:03:11 +03:00
|
|
|
// pushing/popping frames to/from the ProfilingStack.
|
2017-06-07 05:36:26 +03:00
|
|
|
//
|
|
|
|
// This file defines a class of the same name that does much the same thing,
|
|
|
|
// but which can be used in (and only in) mozglue. A different class is
|
2018-05-15 08:03:11 +03:00
|
|
|
// necessary because mozglue cannot directly access sProfilingStack.
|
2017-06-07 05:36:26 +03:00
|
|
|
//
|
|
|
|
// Note that this class is slightly slower than the other AutoProfilerLabel,
|
|
|
|
// and it lacks the macro wrappers. It also is effectively hardwired to use
|
2019-02-16 20:37:43 +03:00
|
|
|
// JS::ProfilingCategory::OTHER as the category pair, because that's what
|
|
|
|
// the callbacks provided by the profiler use. (Specifying the categories in
|
|
|
|
// this file would require #including ProfilingCategory.h in mozglue, which we
|
2017-06-07 05:36:26 +03:00
|
|
|
// don't want to do.)
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
|
2019-07-04 07:38:16 +03:00
|
|
|
// Enter should return a pointer that will be given to Exit.
|
|
|
|
typedef void* (*ProfilerLabelEnter)(const char* aLabel,
|
|
|
|
const char* aDynamicString, void* aSp);
|
|
|
|
typedef void (*ProfilerLabelExit)(void* EntryContext);
|
2017-06-07 05:36:26 +03:00
|
|
|
|
2018-05-15 08:03:11 +03:00
|
|
|
// Register callbacks that do the entry/exit work involving sProfilingStack.
|
2017-06-07 05:36:26 +03:00
|
|
|
MFBT_API void RegisterProfilerLabelEnterExit(ProfilerLabelEnter aEnter,
|
|
|
|
ProfilerLabelExit aExit);
|
|
|
|
|
|
|
|
// This #ifdef prevents this AutoProfilerLabel from being defined in libxul,
|
|
|
|
// which would conflict with the one in the profiler.
|
|
|
|
#ifdef IMPL_MFBT
|
|
|
|
|
|
|
|
class MOZ_RAII AutoProfilerLabel {
|
|
|
|
public:
|
Bug 1499507 - Don't collect line numbers for profiling stack frames. r=njn
They were not displayed in the UI, and the instructions to initialize the line
field of a stack frame increased code size unnecessarily.
This change reduces the binary size on Linux x64 by around 100KB.
Here's a diff of the impact on the code generated for Attr_Binding::get_specified
in the Mac build:
@@ -20,17 +20,16 @@
movq 0x8(%rbx), %rax
movq %r12, %rcx
shlq $0x5, %rcx
leaq aGetAttrspecifi, %rdx ; "get Attr.specified"
movq %rdx, (%rax,%rcx)
movq $0x0, 0x8(%rax,%rcx)
leaq -40(%rbp), %rdx
movq %rdx, 0x10(%rax,%rcx)
- movl $0x106, 0x18(%rax,%rcx)
movl $0x1c, 0x1c(%rax,%rcx)
leal 0x1(%r12), %eax
movl %eax, 0x10(%rbx)
movq %r15, %rdi
call __ZNK7mozilla3dom4Attr9SpecifiedEv ; mozilla::dom::Attr::Specified() const
movzxl %al, %eax
movabsq $0xfff9000000000000, %rcx
Depends on D9193
Differential Revision: https://phabricator.services.mozilla.com/D9195
--HG--
extra : moz-landing-system : lando
2018-11-06 07:31:02 +03:00
|
|
|
AutoProfilerLabel(const char* aLabel,
|
2017-06-07 05:36:26 +03:00
|
|
|
const char* aDynamicString MOZ_GUARD_OBJECT_NOTIFIER_PARAM);
|
|
|
|
~AutoProfilerLabel();
|
|
|
|
|
|
|
|
private:
|
|
|
|
MOZ_DECL_USE_GUARD_OBJECT_NOTIFIER
|
2019-07-04 07:38:16 +03:00
|
|
|
void* mEntryContext;
|
2019-07-04 07:43:41 +03:00
|
|
|
// Number of RegisterProfilerLabelEnterExit calls, to avoid giving an entry
|
|
|
|
// context from one generation to the next.
|
|
|
|
uint32_t mGeneration;
|
2017-06-07 05:36:26 +03:00
|
|
|
};
|
|
|
|
|
2019-08-14 06:46:41 +03:00
|
|
|
using ProfilerLabel = Tuple<void*, uint32_t>;
|
|
|
|
|
|
|
|
bool IsProfilerPresent();
|
|
|
|
ProfilerLabel ProfilerLabelBegin(const char* aLabelName,
|
|
|
|
const char* aDynamicString, void* aSp);
|
|
|
|
void ProfilerLabelEnd(const ProfilerLabel& aLabel);
|
|
|
|
|
|
|
|
inline bool IsValidProfilerLabel(const ProfilerLabel& aLabel) {
|
|
|
|
return !!Get<0>(aLabel);
|
|
|
|
}
|
|
|
|
|
2017-06-07 05:36:26 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif // mozilla_AutoProfilerLabel_h
|