69 lines
3.1 KiB
C
69 lines
3.1 KiB
C
#ifndef __OUTPUT_H
|
|
#define __OUTPUT_H
|
|
|
|
#include "config.h" // CONFIG_DEBUG_LEVEL
|
|
#include "types.h" // u32
|
|
|
|
// output.c
|
|
void debug_banner(void);
|
|
void panic(const char *fmt, ...)
|
|
__attribute__ ((format (printf, 1, 2))) __noreturn;
|
|
void printf(const char *fmt, ...)
|
|
__attribute__ ((format (printf, 1, 2)));
|
|
int snprintf(char *str, size_t size, const char *fmt, ...)
|
|
__attribute__ ((format (printf, 3, 4)));
|
|
char * znprintf(size_t size, const char *fmt, ...)
|
|
__attribute__ ((format (printf, 2, 3)));
|
|
void __dprintf(const char *fmt, ...)
|
|
__attribute__ ((format (printf, 1, 2)));
|
|
struct bregs;
|
|
void __debug_enter(struct bregs *regs, const char *fname);
|
|
void __debug_isr(const char *fname);
|
|
void __debug_stub(struct bregs *regs, int lineno, const char *fname);
|
|
void __warn_invalid(struct bregs *regs, int lineno, const char *fname);
|
|
void __warn_unimplemented(struct bregs *regs, int lineno, const char *fname);
|
|
void __warn_internalerror(int lineno, const char *fname);
|
|
void __warn_noalloc(int lineno, const char *fname);
|
|
void __warn_timeout(int lineno, const char *fname);
|
|
void __set_invalid(struct bregs *regs, int lineno, const char *fname);
|
|
void __set_unimplemented(struct bregs *regs, int lineno, const char *fname);
|
|
void __set_code_invalid(struct bregs *regs, u32 linecode, const char *fname);
|
|
void __set_code_unimplemented(struct bregs *regs, u32 linecode
|
|
, const char *fname);
|
|
void hexdump(const void *d, int len);
|
|
|
|
#define dprintf(lvl, fmt, args...) do { \
|
|
if (CONFIG_DEBUG_LEVEL && (lvl) <= CONFIG_DEBUG_LEVEL) \
|
|
__dprintf((fmt) , ##args ); \
|
|
} while (0)
|
|
#define debug_enter(regs, lvl) do { \
|
|
if ((lvl) && (lvl) <= CONFIG_DEBUG_LEVEL) \
|
|
__debug_enter((regs), __func__); \
|
|
} while (0)
|
|
#define debug_isr(lvl) do { \
|
|
if ((lvl) && (lvl) <= CONFIG_DEBUG_LEVEL) \
|
|
__debug_isr(__func__); \
|
|
} while (0)
|
|
#define debug_stub(regs) \
|
|
__debug_stub((regs), __LINE__, __func__)
|
|
#define warn_invalid(regs) \
|
|
__warn_invalid((regs), __LINE__, __func__)
|
|
#define warn_unimplemented(regs) \
|
|
__warn_unimplemented((regs), __LINE__, __func__)
|
|
#define warn_internalerror() \
|
|
__warn_internalerror(__LINE__, __func__)
|
|
#define warn_noalloc() \
|
|
__warn_noalloc(__LINE__, __func__)
|
|
#define warn_timeout() \
|
|
__warn_timeout(__LINE__, __func__)
|
|
#define set_invalid(regs) \
|
|
__set_invalid((regs), __LINE__, __func__)
|
|
#define set_code_invalid(regs, code) \
|
|
__set_code_invalid((regs), (code) | (__LINE__ << 8), __func__)
|
|
#define set_unimplemented(regs) \
|
|
__set_unimplemented((regs), __LINE__, __func__)
|
|
#define set_code_unimplemented(regs, code) \
|
|
__set_code_unimplemented((regs), (code) | (__LINE__ << 8), __func__)
|
|
|
|
#endif // output.h
|