1 /* $NetBSD: db_output.c,v 1.29 2005/12/11 12:20:53 christos Exp $ */
4 * Mach Operating System
5 * Copyright (c) 1991,1990 Carnegie Mellon University
8 * Permission to use, copy, modify and distribute this software and its
9 * documentation is hereby granted, provided that both the copyright
10 * notice and this permission notice appear in all copies of the
11 * software, derivative works or modified versions, and any portions
12 * thereof, and that both notices appear in supporting documentation.
14 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
15 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
16 * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
18 * Carnegie Mellon requests users of this software to return to
20 * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
21 * School of Computer Science
22 * Carnegie Mellon University
23 * Pittsburgh PA 15213-3890
25 * any improvements or extensions that they make and grant Carnegie the
26 * rights to redistribute these changes.
30 * Printf and character output for debugger.
33 #include <sys/cdefs.h>
34 __KERNEL_RCSID(0, "$NetBSD: db_output.c,v 1.29 2005/12/11 12:20:53 christos Exp $");
36 #include <sys/param.h>
37 #include <sys/systm.h>
39 #include <machine/stdarg.h>
46 * Character output - tracks position in line.
47 * To do this correctly, we should know how wide
48 * the output device is - then we could zero
49 * the line position when the output device wraps
50 * around to the start of the next line.
52 * Instead, we count the number of spaces printed
53 * since the last printing character so that we
54 * don't print trailing spaces. This avoids most
59 #define DB_MAX_LINE 24 /* maximum line */
60 #endif /* DB_MAX_LINE */
62 #define DB_MAX_WIDTH 80 /* maximum width */
63 #endif /* DB_MAX_WIDTH */
65 #define DB_MIN_MAX_WIDTH 20 /* minimum max width */
66 #define DB_MIN_MAX_LINE 3 /* minimum max line */
67 #define CTRL(c) ((c) & 0xff)
69 int db_output_line
= 0; /* output line number */
70 int db_tab_stop_width
= 8; /* how wide are tab stops? */
71 int db_max_line
= DB_MAX_LINE
; /* output max lines */
72 int db_max_width
= DB_MAX_WIDTH
; /* output line width */
74 static int db_output_position
= 0; /* output column */
75 static int db_last_non_space
= 0; /* last non-space character */
77 static void db_more(void);
80 * Force pending whitespace.
83 db_force_whitespace(void)
85 int last_print
, next_tab
;
87 last_print
= db_last_non_space
;
88 while (last_print
< db_output_position
) {
89 next_tab
= DB_NEXT_TAB(last_print
);
90 if (next_tab
<= db_output_position
) {
91 while (last_print
< next_tab
) { /* DON'T send a tab!! */
100 db_last_non_space
= db_output_position
;
109 for (p
= "--db_more--"; *p
; p
++)
124 p
= "\b\b\b\b\b\b\b\b\b\b\b \b\b\b\b\b\b\b\b\b\b\b";
134 * Output character. Buffer whitespace.
139 if (db_max_line
>= DB_MIN_MAX_LINE
&& db_output_line
>= db_max_line
-1)
141 if (c
> ' ' && c
<= '~') {
143 * Printing character.
144 * If we have spaces to print, print them first.
145 * Use tabs if possible.
147 db_force_whitespace();
149 db_output_position
++;
150 if (db_max_width
>= DB_MIN_MAX_WIDTH
151 && db_output_position
>= db_max_width
) {
154 db_output_position
= 0;
155 db_last_non_space
= 0;
158 db_last_non_space
= db_output_position
;
159 } else if (c
== '\n') {
162 db_output_position
= 0;
163 db_last_non_space
= 0;
165 db_check_interrupt();
166 } else if (c
== '\t') {
167 /* assume tabs every 8 positions */
168 db_output_position
= DB_NEXT_TAB(db_output_position
);
169 } else if (c
== ' ') {
171 db_output_position
++;
172 } else if (c
== '\007') {
176 /* other characters are assumed non-printing */
180 * Return output position
183 db_print_position(void)
186 return (db_output_position
);
190 * End line if too long.
196 if (db_output_position
>= db_max_width
)
201 * Replacement for old '%r' kprintf format.
204 db_format_radix(char *buf
, size_t bufsiz
, quad_t val
, int altflag
)
208 if (db_radix
== 16) {
209 db_format_hex(buf
, bufsiz
, val
, altflag
);
214 fmt
= altflag
? "-%#qo" : "-%qo";
216 fmt
= altflag
? "-%#qu" : "-%qu";
223 snprintf(buf
, bufsiz
, fmt
, val
);
227 * Replacement for old '%z' kprintf format.
230 db_format_hex(char *buf
, size_t bufsiz
, quad_t val
, int altflag
)
232 /* Only use alternate form if val is nonzero. */
233 const char *fmt
= (altflag
&& val
) ? "-%#qx" : "-%qx";
240 snprintf(buf
, bufsiz
, fmt
, val
);