mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-03-03 15:38:22 +00:00
Reduce ftrace overhead to 280ns
This commit is contained in:
parent
4245da19e2
commit
c8a2f04058
2 changed files with 33 additions and 17 deletions
|
@ -17,6 +17,7 @@
|
||||||
│ PERFORMANCE OF THIS SOFTWARE. │
|
│ PERFORMANCE OF THIS SOFTWARE. │
|
||||||
╚─────────────────────────────────────────────────────────────────────────────*/
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
||||||
#define ShouldUseMsabiAttribute() 1
|
#define ShouldUseMsabiAttribute() 1
|
||||||
|
#include "libc/bits/bits.h"
|
||||||
#include "libc/bits/likely.h"
|
#include "libc/bits/likely.h"
|
||||||
#include "libc/bits/safemacros.internal.h"
|
#include "libc/bits/safemacros.internal.h"
|
||||||
#include "libc/bits/weaken.h"
|
#include "libc/bits/weaken.h"
|
||||||
|
@ -707,9 +708,14 @@ privileged static size_t kformat(char *b, size_t n, const char *fmt, va_list va,
|
||||||
if (p < e) *p = hash;
|
if (p < e) *p = hash;
|
||||||
++p;
|
++p;
|
||||||
}
|
}
|
||||||
for (; cols > i; --cols) {
|
while (cols > i) {
|
||||||
if (p < e) {
|
if (p + 8 < e && cols - i > 8) {
|
||||||
|
WRITE64LE(p, 0x2020202020202020);
|
||||||
|
cols -= 8;
|
||||||
|
p += 8;
|
||||||
|
} else if (p < e) {
|
||||||
*p++ = ' ';
|
*p++ = ' ';
|
||||||
|
--cols;
|
||||||
} else {
|
} else {
|
||||||
p = kadvance(p, e, cols - i);
|
p = kadvance(p, e, cols - i);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -18,10 +18,12 @@
|
||||||
╚─────────────────────────────────────────────────────────────────────────────*/
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
||||||
#include "libc/calls/calls.h"
|
#include "libc/calls/calls.h"
|
||||||
#include "libc/fmt/itoa.h"
|
#include "libc/fmt/itoa.h"
|
||||||
|
#include "libc/intrin/cmpxchg.h"
|
||||||
#include "libc/intrin/kprintf.h"
|
#include "libc/intrin/kprintf.h"
|
||||||
#include "libc/intrin/lockcmpxchgp.h"
|
#include "libc/intrin/lockcmpxchgp.h"
|
||||||
#include "libc/macros.internal.h"
|
#include "libc/macros.internal.h"
|
||||||
#include "libc/nexgen32e/stackframe.h"
|
#include "libc/nexgen32e/stackframe.h"
|
||||||
|
#include "libc/nexgen32e/threaded.h"
|
||||||
#include "libc/runtime/stack.h"
|
#include "libc/runtime/stack.h"
|
||||||
#include "libc/runtime/symbols.internal.h"
|
#include "libc/runtime/symbols.internal.h"
|
||||||
|
|
||||||
|
@ -69,21 +71,29 @@ static privileged inline void ReleaseFtraceLock(void) {
|
||||||
|
|
||||||
static privileged inline bool AcquireFtraceLock(void) {
|
static privileged inline bool AcquireFtraceLock(void) {
|
||||||
int me, owner, tries;
|
int me, owner, tries;
|
||||||
for (tries = 0, me = gettid();;) {
|
if (!__threaded) {
|
||||||
owner = 0;
|
return _cmpxchg(&ftrace_lock, 0, -1);
|
||||||
if (_lockcmpxchgp(&ftrace_lock, &owner, me)) {
|
} else {
|
||||||
return true;
|
for (tries = 0, me = gettid();;) {
|
||||||
}
|
owner = 0;
|
||||||
if (owner == me) {
|
if (_lockcmpxchgp(&ftrace_lock, &owner, me)) {
|
||||||
// we ignore re-entry into ftrace. while the code and build config
|
return true;
|
||||||
// is written to make re-entry highly unlikely, it's impossible to
|
}
|
||||||
// guarantee. there's also the possibility of asynchronous signals
|
if (owner == -1) {
|
||||||
return false;
|
// avoid things getting weird after first clone() call transition
|
||||||
}
|
return false;
|
||||||
if (++tries & 7) {
|
}
|
||||||
__builtin_ia32_pause();
|
if (owner == me) {
|
||||||
} else {
|
// we ignore re-entry into ftrace. while the code and build config
|
||||||
sched_yield();
|
// is written to make re-entry highly unlikely, it's impossible to
|
||||||
|
// guarantee. there's also the possibility of asynchronous signals
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (++tries & 7) {
|
||||||
|
__builtin_ia32_pause();
|
||||||
|
} else {
|
||||||
|
sched_yield();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue