mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-06 17:16:12 +00:00
7bc6762bed
--HG-- extra : rebase_source : 5383b80a1d0d1ddb36351dea1ad44f27b93001a2
126 lines
3.3 KiB
C++
126 lines
3.3 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* 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 PROFILER_MARKERS_H
|
|
#define PROFILER_MARKERS_H
|
|
|
|
#include "JSStreamWriter.h"
|
|
#include "mozilla/TimeStamp.h"
|
|
#include "nsAutoPtr.h"
|
|
|
|
/**
|
|
* This is an abstract object that can be implied to supply
|
|
* data to be attached with a profiler marker. Most data inserted
|
|
* into a profile is stored in a circular buffer. This buffer
|
|
* typically wraps around and overwrites most entries. Because
|
|
* of this, this structure is designed to defer the work of
|
|
* prepare the payload only when 'preparePayload' is called.
|
|
*
|
|
* Note when implementing that this object is typically constructed
|
|
* on a particular thread but 'preparePayload' and the destructor
|
|
* is called from the main thread.
|
|
*/
|
|
class ProfilerMarkerPayload
|
|
{
|
|
public:
|
|
/**
|
|
* ProfilerMarkerPayload takes ownership of aStack
|
|
*/
|
|
ProfilerMarkerPayload(ProfilerBacktrace* aStack = nullptr);
|
|
ProfilerMarkerPayload(const mozilla::TimeStamp& aStartTime,
|
|
const mozilla::TimeStamp& aEndTime,
|
|
ProfilerBacktrace* aStack = nullptr);
|
|
|
|
/**
|
|
* Called from the main thread
|
|
*/
|
|
virtual ~ProfilerMarkerPayload();
|
|
|
|
/**
|
|
* Called from the main thread
|
|
*/
|
|
void StreamPayload(JSStreamWriter& b) {
|
|
return streamPayload(b);
|
|
}
|
|
|
|
protected:
|
|
/**
|
|
* Called from the main thread
|
|
*/
|
|
void streamCommonProps(const char* aMarkerType, JSStreamWriter& b);
|
|
|
|
/**
|
|
* Called from the main thread
|
|
*/
|
|
virtual void
|
|
streamPayload(JSStreamWriter& b) = 0;
|
|
|
|
void SetStack(ProfilerBacktrace* aStack) { mStack = aStack; }
|
|
|
|
private:
|
|
mozilla::TimeStamp mStartTime;
|
|
mozilla::TimeStamp mEndTime;
|
|
ProfilerBacktrace* mStack;
|
|
};
|
|
|
|
class ProfilerMarkerTracing : public ProfilerMarkerPayload
|
|
{
|
|
public:
|
|
ProfilerMarkerTracing(const char* aCategory, TracingMetadata aMetaData);
|
|
ProfilerMarkerTracing(const char* aCategory, TracingMetadata aMetaData, ProfilerBacktrace* aCause);
|
|
|
|
const char *GetCategory() const { return mCategory; }
|
|
TracingMetadata GetMetaData() const { return mMetaData; }
|
|
|
|
protected:
|
|
virtual void
|
|
streamPayload(JSStreamWriter& b) { return streamPayloadImp(b); }
|
|
|
|
private:
|
|
void streamPayloadImp(JSStreamWriter& b);
|
|
|
|
private:
|
|
const char *mCategory;
|
|
TracingMetadata mMetaData;
|
|
};
|
|
|
|
|
|
class gfxASurface;
|
|
class ProfilerMarkerImagePayload : public ProfilerMarkerPayload
|
|
{
|
|
public:
|
|
ProfilerMarkerImagePayload(gfxASurface *aImg);
|
|
|
|
protected:
|
|
virtual void
|
|
streamPayload(JSStreamWriter& b) { return streamPayloadImp(b); }
|
|
|
|
private:
|
|
void streamPayloadImp(JSStreamWriter& b);
|
|
|
|
nsRefPtr<gfxASurface> mImg;
|
|
};
|
|
|
|
class IOMarkerPayload : public ProfilerMarkerPayload
|
|
{
|
|
public:
|
|
IOMarkerPayload(const char* aSource, const char* aFilename, const mozilla::TimeStamp& aStartTime,
|
|
const mozilla::TimeStamp& aEndTime,
|
|
ProfilerBacktrace* aStack);
|
|
~IOMarkerPayload();
|
|
|
|
protected:
|
|
virtual void
|
|
streamPayload(JSStreamWriter& b) { return streamPayloadImp(b); }
|
|
|
|
private:
|
|
void streamPayloadImp(JSStreamWriter& b);
|
|
|
|
const char* mSource;
|
|
char* mFilename;
|
|
};
|
|
|
|
#endif // PROFILER_MARKERS_H
|