1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
/*
* Copyright (c) 1993,1994 The University of Utah and
* the Computer Systems Laboratory (CSL). All rights reserved.
*
* Permission to use, copy, modify and distribute this software and its
* documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* THE UNIVERSITY OF UTAH AND CSL ALLOW FREE USE OF THIS SOFTWARE IN ITS "AS
* IS" CONDITION. THE UNIVERSITY OF UTAH AND CSL DISCLAIM ANY LIABILITY OF
* ANY KIND FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* CSL requests users of this software to return to csl-dist@cs.utah.edu any
* improvements that they make and grant CSL redistribution rights.
*
* Author: Bryan Ford, University of Utah CSL
*/
/*
* File: debug.h
* Author: Bryan Ford
*
* This file contains definitions for kernel debugging,
* which are compiled in on the DEBUG symbol.
*
*/
#ifndef _mach_debug__debug_
#define _mach_debug__debug_
#include <kern/assert.h> /*XXX*/
#ifndef NDEBUG
#define here() printf("@ %s:%d\n", __FILE__, __LINE__)
#define message(args) ({ printf("@ %s:%d: ", __FILE__, __LINE__); printf args; printf("\n"); })
#define otsan() panic("%s:%d: off the straight and narrow!", __FILE__, __LINE__)
#define struct_id_decl unsigned struct_id;
#define struct_id_init(p,id) ((p)->struct_id = (id))
#define struct_id_denit(p) ((p)->struct_id = 0)
#define struct_id_verify(p,id) \
({ if ((p)->struct_id != (id)) \
panic("%s:%d: "#p" (%08x) struct_id should be "#id" (%08x), is %08x\n", \
__FILE__, __LINE__, (p), (id), (p->struct_id)); \
})
#else /* NDEBUG */
#define otsan()
#define struct_id_decl
#define struct_id_init(p,id)
#define struct_id_denit(p)
#define struct_id_verify(p,id)
#endif /* NDEBUG */
extern void log (int level, const char *fmt, ...);
extern void panic_init(void);
extern void Panic (const char *file, int line, const char *fun,
const char *s, ...)
__attribute__ ((noreturn, format (printf, 4, 5)));
#define panic(s, ...) \
Panic (__FILE__, __LINE__, __FUNCTION__, s, ##__VA_ARGS__)
extern void SoftDebugger (const char *message);
extern void Debugger (const char *message) __attribute__ ((noreturn));
#endif /* _mach_debug__debug_ */
|