3cc092ff06
now used for printing diagnostic messages through the kernel message buffer. this lets processes print diagnostics without sending messages to tty and log directly, simplifying the message protocol a lot and reducing difficulties with deadlocks and other situations in which diagnostics are blackholed (e.g. grants don't work). this makes DIAGNOSTICS(_S), ASYN_DIAGNOSTICS and DIAG_REPL obsolete, although tty and log still accept the codes for 'old' binaries. This also simplifies diagnostics in several servers and drivers - only tty needs its own kputc() now. . simplifications in vfs, and some effort to get the vnode references right (consistent) even during shutdown. m_mounted_on is now NULL for root filesystems (!) (the original and new root), a less awkward special case than 'm_mounted_on == m_root_node'. root now has exactly one reference, to root, if no files are open, just like all other filesystems. m_driver_e is unused.
37 lines
912 B
C
37 lines
912 B
C
/* Includes. */
|
|
#include "../drivers.h"
|
|
#include "../libdriver/driver.h"
|
|
#include <minix/type.h>
|
|
#include <minix/const.h>
|
|
#include <minix/com.h>
|
|
#include <sys/types.h>
|
|
#include <minix/ipc.h>
|
|
|
|
/* Constants and types. */
|
|
|
|
#define LOG_SIZE (50*1024)
|
|
#define SUSPENDABLE 1
|
|
|
|
struct logdevice {
|
|
char log_buffer[LOG_SIZE];
|
|
int log_size, /* no. of bytes in log buffer */
|
|
log_read, /* read mark */
|
|
log_write; /* write mark */
|
|
#if SUSPENDABLE
|
|
int log_proc_nr,
|
|
log_source,
|
|
log_iosize,
|
|
log_revive_alerted,
|
|
log_status; /* proc that is blocking on read */
|
|
vir_bytes log_user_vir_g, log_user_vir_offset;
|
|
int log_safe;
|
|
#endif
|
|
int log_selected, log_select_proc,
|
|
log_select_alerted, log_select_ready_ops;
|
|
};
|
|
|
|
/* Function prototypes. */
|
|
_PROTOTYPE( int do_new_kmess, (message *m) );
|
|
_PROTOTYPE( int do_diagnostics, (message *m, int safe) );
|
|
_PROTOTYPE( void log_append, (char *buf, int len) );
|
|
|