haiku/headers/private/kernel/AllocationTracking.h
Michael Lotz 75088a863b Move AllocationTrackingInfo into a header. This way it can be re-used outside
of the slab code. It is generic as it only contains the link to a tracing entry
and not any application specific info.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@43188 a95241bf-73f2-0310-859d-f6bbb57e9c96
2011-11-04 18:03:34 +00:00

61 lines
1.2 KiB
C++

/*
* Copyright 2011, Michael Lotz <mmlr@mlotz.ch>.
* Copyright 2011, Ingo Weinhold <ingo_weinhold@gmx.de>.
*
* Distributed under the terms of the MIT License.
*/
#ifndef ALLOCATION_TRACKING_H
#define ALLOCATION_TRACKING_H
#include <debug.h>
#include <tracing.h>
namespace BKernel {
class AllocationTrackingInfo {
public:
AbstractTraceEntryWithStackTrace* traceEntry;
bigtime_t traceEntryTimestamp;
public:
void Init(AbstractTraceEntryWithStackTrace* entry)
{
traceEntry = entry;
traceEntryTimestamp = entry != NULL ? entry->Time() : -1;
// Note: this is a race condition, if the tracing buffer wrapped and
// got overwritten once, we would access an invalid trace entry
// here. Obviously this is rather unlikely.
}
void Clear()
{
traceEntry = NULL;
traceEntryTimestamp = 0;
}
bool IsInitialized() const
{
return traceEntryTimestamp != 0;
}
AbstractTraceEntryWithStackTrace* TraceEntry() const
{
return traceEntry;
}
bool IsTraceEntryValid() const
{
return tracing_is_entry_valid(traceEntry, traceEntryTimestamp);
}
};
} // namespace BKernel
using BKernel::AllocationTrackingInfo;
#endif // ALLOCATION_TRACKING_H