2008-01-12 18:41:35 +00:00
|
|
|
#ifndef KERNEL_UTIL_TRACING_H
|
|
|
|
#define KERNEL_UTIL_TRACING_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <SupportDefs.h>
|
2008-01-12 23:55:53 +00:00
|
|
|
#include <KernelExport.h>
|
2008-01-12 18:41:35 +00:00
|
|
|
|
2008-01-13 02:50:32 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
|
2008-01-12 18:41:35 +00:00
|
|
|
|
|
|
|
#define ENABLE_TRACING 0
|
|
|
|
#define MAX_TRACE_SIZE 1024 * 1024
|
|
|
|
|
|
|
|
struct trace_entry {
|
|
|
|
uint16 size;
|
|
|
|
uint16 flags;
|
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
|
|
|
#include <new>
|
|
|
|
|
|
|
|
class TraceEntry : trace_entry {
|
|
|
|
public:
|
|
|
|
TraceEntry();
|
|
|
|
virtual ~TraceEntry();
|
|
|
|
|
2008-01-13 02:50:32 +00:00
|
|
|
virtual void Dump(char* buffer, size_t bufferSize);
|
2008-01-12 18:41:35 +00:00
|
|
|
|
|
|
|
size_t Size() const { return size; }
|
|
|
|
uint16 Flags() const { return flags; }
|
|
|
|
|
|
|
|
void Initialized();
|
|
|
|
|
2008-01-12 23:55:53 +00:00
|
|
|
void* operator new(size_t size, const std::nothrow_t&) throw();
|
|
|
|
};
|
|
|
|
|
|
|
|
class AbstractTraceEntry : public TraceEntry {
|
|
|
|
public:
|
|
|
|
AbstractTraceEntry()
|
|
|
|
:
|
|
|
|
fThread(find_thread(NULL)),
|
|
|
|
fTime(system_time())
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2008-01-13 02:50:32 +00:00
|
|
|
virtual void Dump(char* buffer, size_t bufferSize)
|
|
|
|
{
|
|
|
|
int length = snprintf(buffer, bufferSize, "[%6ld] %Ld: ",
|
|
|
|
fThread, fTime);
|
|
|
|
AddDump(buffer + length, bufferSize - length);
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual void AddDump(char* buffer, size_t bufferSize)
|
2008-01-12 23:55:53 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
thread_id Thread() const { return fThread; }
|
|
|
|
bigtime_t Time() const { return fTime; }
|
|
|
|
|
|
|
|
protected:
|
|
|
|
thread_id fThread;
|
|
|
|
bigtime_t fTime;
|
2008-01-12 18:41:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // __cplusplus
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
2008-01-13 02:50:32 +00:00
|
|
|
extern "C" {
|
2008-01-12 18:41:35 +00:00
|
|
|
#endif
|
2008-01-13 02:50:32 +00:00
|
|
|
|
|
|
|
uint8* alloc_tracing_buffer(size_t size);
|
2008-01-17 01:58:08 +00:00
|
|
|
uint8* alloc_tracing_buffer_memcpy(const void* source, size_t size, bool user);
|
|
|
|
char* alloc_tracing_buffer_strcpy(const char* source, size_t maxSize,
|
|
|
|
bool user);
|
2008-01-12 18:41:35 +00:00
|
|
|
status_t tracing_init(void);
|
|
|
|
|
2008-01-13 02:50:32 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2008-01-12 18:41:35 +00:00
|
|
|
#endif /* KERNEL_UTIL_TRACING_H */
|