jehanne/sys/src/lib/thread/debug.c

61 lines
1.3 KiB
C

/*
* This file is part of the UCB release of Plan 9. It is subject to the license
* terms in the LICENSE file found in the top-level directory of this
* distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
* part of the UCB release of Plan 9, including this file, may be copied,
* modified, propagated, or distributed except according to the terms contained
* in the LICENSE file.
*/
#include <u.h>
#include <libc.h>
#include <thread.h>
#include "threadimpl.h"
int _threaddebuglevel;
void
_threaddebug(uint32_t flag, char *fmt, ...)
{
char buf[128];
va_list arg;
Fmt f;
Proc *p;
if((_threaddebuglevel&flag) == 0)
return;
jehanne_fmtfdinit(&f, 2, buf, sizeof buf);
p = _threadgetproc();
if(p==nil)
jehanne_fmtprint(&f, "noproc ");
else if(p->thread)
jehanne_fmtprint(&f, "%d.%d ", p->pid, p->thread->id);
else
jehanne_fmtprint(&f, "%d._ ", p->pid);
va_start(arg, fmt);
jehanne_fmtvprint(&f, fmt, arg);
va_end(arg);
jehanne_fmtprint(&f, "\n");
jehanne_fmtfdflush(&f);
}
void
_threadassert(char *s)
{
char buf[256];
int n;
Proc *p;
p = _threadgetproc();
if(p && p->thread)
n = jehanne_sprint(buf, "%d.%d ", p->pid, p->thread->id);
else
n = 0;
jehanne_snprint(buf+n, sizeof(buf)-n, "%s: assertion failed at %#p\n", s, jehanne_getcallerpc());
jehanne_write(2, buf, jehanne_strlen(buf));
abort();
}