* Renamed sBufferStart to sFirstEntry, and sBufferEnd to

sAfterLastEntry.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@23614 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2008-01-18 18:35:45 +00:00
parent f70280a733
commit 960f8f2430

View File

@ -32,8 +32,8 @@ enum {
static const size_t kBufferSize = MAX_TRACE_SIZE / 4 - 1; static const size_t kBufferSize = MAX_TRACE_SIZE / 4 - 1;
static trace_entry* sBuffer; static trace_entry* sBuffer;
static trace_entry* sBufferStart; static trace_entry* sFirstEntry;
static trace_entry* sBufferEnd; static trace_entry* sAfterLastEntry;
static uint32 sEntries; static uint32 sEntries;
static uint32 sWritten; static uint32 sWritten;
static spinlock sLock; static spinlock sLock;
@ -46,7 +46,7 @@ next_entry(trace_entry* entry)
if ((entry->flags & WRAP_ENTRY) != 0) if ((entry->flags & WRAP_ENTRY) != 0)
entry = sBuffer; entry = sBuffer;
if (entry == sBufferEnd) if (entry == sAfterLastEntry)
return NULL; return NULL;
return entry; return entry;
@ -56,16 +56,16 @@ next_entry(trace_entry* entry)
static void static void
make_space(size_t needed) make_space(size_t needed)
{ {
if (sBufferEnd + needed / 4 > sBuffer + kBufferSize - 1) { if (sAfterLastEntry + needed / 4 > sBuffer + kBufferSize - 1) {
sBufferEnd->size = 0; sAfterLastEntry->size = 0;
sBufferEnd->flags = WRAP_ENTRY; sAfterLastEntry->flags = WRAP_ENTRY;
sBufferEnd = sBuffer; sAfterLastEntry = sBuffer;
} }
int32 space = (sBufferStart - sBufferEnd) * 4; int32 space = (sFirstEntry - sAfterLastEntry) * 4;
TRACE(("make_space(%lu), left %ld\n", needed, space)); TRACE(("make_space(%lu), left %ld\n", needed, space));
if (space < 0) if (space < 0)
sBufferEnd = sBuffer; sAfterLastEntry = sBuffer;
else if ((size_t)space < needed) else if ((size_t)space < needed)
needed -= space; needed -= space;
else else
@ -74,13 +74,13 @@ make_space(size_t needed)
while (true) { while (true) {
// TODO: If the entry is not ENTRY_INITIALIZED yet, we must not // TODO: If the entry is not ENTRY_INITIALIZED yet, we must not
// discard it, or the owner might overwrite memory we're allocating. // discard it, or the owner might overwrite memory we're allocating.
trace_entry* removed = sBufferStart; trace_entry* removed = sFirstEntry;
uint16 freed = sBufferStart->size; uint16 freed = sFirstEntry->size;
TRACE((" skip start %p, %u bytes\n", sBufferStart, freed)); TRACE((" skip start %p, %u bytes\n", sFirstEntry, freed));
sBufferStart = next_entry(sBufferStart); sFirstEntry = next_entry(sFirstEntry);
if (sBufferStart == NULL) if (sFirstEntry == NULL)
sBufferStart = sBufferEnd; sFirstEntry = sAfterLastEntry;
if (!(removed->flags & BUFFER_ENTRY)) { if (!(removed->flags & BUFFER_ENTRY)) {
((TraceEntry*)removed)->~TraceEntry(); ((TraceEntry*)removed)->~TraceEntry();
@ -93,7 +93,7 @@ make_space(size_t needed)
needed -= freed; needed -= freed;
} }
TRACE((" out: start %p, entries %ld\n", sBufferStart, sEntries)); TRACE((" out: start %p, entries %ld\n", sFirstEntry, sEntries));
} }
@ -108,12 +108,12 @@ allocate_entry(size_t size, uint16 flags)
size = (size + 3) & ~3; size = (size + 3) & ~3;
TRACE(("allocate_entry(%lu), start %p, end %p, buffer %p\n", size, TRACE(("allocate_entry(%lu), start %p, end %p, buffer %p\n", size,
sBufferStart, sBufferEnd, sBuffer)); sFirstEntry, sAfterLastEntry, sBuffer));
if (sBufferStart < sBufferEnd || sEntries == 0) { if (sFirstEntry < sAfterLastEntry || sEntries == 0) {
// the buffer ahead of us is still empty // the buffer ahead of us is still empty
uint32 space = (sBuffer + kBufferSize - sBufferEnd) * 4; uint32 space = (sBuffer + kBufferSize - sAfterLastEntry) * 4;
TRACE((" free after end %p: %lu\n", sBufferEnd, space)); TRACE((" free after end %p: %lu\n", sAfterLastEntry, space));
if (space < size) if (space < size)
make_space(size); make_space(size);
} else { } else {
@ -121,16 +121,16 @@ allocate_entry(size_t size, uint16 flags)
make_space(size); make_space(size);
} }
trace_entry* entry = sBufferEnd; trace_entry* entry = sAfterLastEntry;
entry->size = size; entry->size = size;
entry->flags = flags; entry->flags = flags;
sBufferEnd += size >> 2; sAfterLastEntry += size >> 2;
if (!(flags & BUFFER_ENTRY)) if (!(flags & BUFFER_ENTRY))
sEntries++; sEntries++;
TRACE((" entry: %p, end %p, start %p, entries %ld\n", entry, sBufferEnd, TRACE((" entry: %p, end %p, start %p, entries %ld\n", entry, sAfterLastEntry,
sBufferStart, sEntries)); sFirstEntry, sEntries));
return entry; return entry;
} }
@ -234,7 +234,7 @@ dump_tracing(int argc, char** argv)
int32 index = 1; int32 index = 1;
int32 dumped = 0; int32 dumped = 0;
for (trace_entry* current = sBufferStart; current != NULL; for (trace_entry* current = sFirstEntry; current != NULL;
current = next_entry(current), index++) { current = next_entry(current), index++) {
if ((current->flags & BUFFER_ENTRY) != 0) { if ((current->flags & BUFFER_ENTRY) != 0) {
// skip buffer entries // skip buffer entries
@ -345,8 +345,8 @@ tracing_init(void)
if (area < B_OK) if (area < B_OK)
return area; return area;
sBufferStart = sBuffer; sFirstEntry = sBuffer;
sBufferEnd = sBuffer; sAfterLastEntry = sBuffer;
add_debugger_command_etc("traced", &dump_tracing, add_debugger_command_etc("traced", &dump_tracing,
"Dump recorded trace entries", "Dump recorded trace entries",