summaryrefslogtreecommitdiff
path: root/i386/i386at/immc.c
blob: bd61522da0d331f6a87fc7b40c0fff88a2587c5d (plain)
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*
 * Copyright (c) 1995-1994 The University of Utah and
 * the Computer Systems Laboratory at the University of Utah (CSL).
 * All rights reserved.
 *
 * Permission to use, copy, modify and distribute this software is hereby
 * granted provided that (1) source code retains these copyright, permission,
 * and disclaimer notices, and (2) redistributions including binaries
 * reproduce the notices in supporting documentation, and (3) all advertising
 * materials mentioning features or use of this software display the following
 * acknowledgement: ``This product includes software developed by the
 * Computer Systems Laboratory at the University of Utah.''
 *
 * 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
 */

#if	ENABLE_IMMEDIATE_CONSOLE

#include <device/cons.h>
#include <mach/boolean.h>
#include <i386/vm_param.h>
#include <string.h>

/* This is a special "feature" (read: kludge)
   intended for use only for kernel debugging.
   It enables an extremely simple console output mechanism
   that sends text straight to CGA/EGA/VGA video memory.
   It has the nice property of being functional right from the start,
   so it can be used to debug things that happen very early
   before any devices are initialized.  */

boolean_t immediate_console_enable = TRUE;

/*
 * XXX we assume that pcs *always* have a console
 */
int
immc_cnprobe(struct consdev *cp)
{
	int maj, unit, pri;

	maj = 0;
	unit = 0;
	pri = CN_INTERNAL;

	cp->cn_dev = makedev(maj, unit);
	cp->cn_pri = pri;
	return 0;
}

int
immc_cninit(struct consdev *cp)
{
	return 0;
}

int immc_cnmaygetc(void)
{
	return -1;
}

int
immc_cngetc(dev_t dev, int wait)
{
	if (wait) {
		int c;
		while ((c = immc_cnmaygetc()) < 0)
			continue;
		return c;
	}
	else
		return immc_cnmaygetc();
}

int
immc_cnputc(dev_t dev, int c)
{
	static int ofs = -1;

	if (!immediate_console_enable)
		return -1;
	if (ofs < 0 || ofs >= 80)
	{
		ofs = 0;
		immc_cnputc(dev, '\n');
	}

	if (c == '\n')
	{
		memmove((void *) phystokv(0xb8000),
			(void *) phystokv(0xb8000+80*2), 80*2*24);
		memset((void *) phystokv((0xb8000+80*2*24)), 0, 80*2);
		ofs = 0;
	}
	else
	{
		volatile unsigned char *p;

		if (ofs >= 80)
		{
			immc_cnputc(dev, '\r');
			immc_cnputc(dev, '\n');
		}

		p = (void *) phystokv(0xb8000 + 80*2*24 + ofs*2);
		p[0] = c;
		p[1] = 0x0f;
		ofs++;
	}
	return 0;
}

void
immc_romputc(char c)
{
	immc_cnputc (0, c);
}

#endif /* ENABLE_IMMEDIATE_CONSOLE */