/* * 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 #include #include #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(); }