36 lines
1.2 KiB
C
36 lines
1.2 KiB
C
|
/* A server must occasionally print some message. It uses a simple version of
|
||
|
* printf() found in the system library that calls putk() to output characters.
|
||
|
* The IS server cannot use the regular putk() since we do not want to over-
|
||
|
* write kernel messages with the output of the IS. Hence, it uses a special
|
||
|
* putk that directly sends to the TTY task.
|
||
|
*/
|
||
|
|
||
|
#include "is.h"
|
||
|
|
||
|
|
||
|
/*===========================================================================*
|
||
|
* kputc *
|
||
|
*===========================================================================*/
|
||
|
void kputc(c)
|
||
|
int c;
|
||
|
{
|
||
|
/* Accumulate another character. If 0 or buffer full, print it. */
|
||
|
|
||
|
static int buf_count; /* # characters in the buffer */
|
||
|
static char print_buf[80]; /* output is buffered here */
|
||
|
message m;
|
||
|
|
||
|
if ((c == 0 && buf_count > 0) || buf_count == sizeof(print_buf)) {
|
||
|
m.DIAG_BUF_COUNT = buf_count;
|
||
|
m.DIAG_PRINT_BUF = print_buf;
|
||
|
m.DIAG_PROC_NR = SELF;
|
||
|
m.m_type = DIAGNOSTICS; /* request TTY to output this buffer */
|
||
|
_sendrec(TTY, &m); /* if it fails, we cannot do better */
|
||
|
buf_count = 0; /* clear buffer for next batch */
|
||
|
}
|
||
|
if (c != 0) {
|
||
|
print_buf[buf_count++] = c;
|
||
|
}
|
||
|
}
|
||
|
|