]> git.saurik.com Git - apple/xnu.git/blame - pexpert/ppc/pe_kprintf.c
xnu-123.5.tar.gz
[apple/xnu.git] / pexpert / ppc / pe_kprintf.c
CommitLineData
1c79356b
A
1/*
2 * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
11 *
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
18 * under the License.
19 *
20 * @APPLE_LICENSE_HEADER_END@
21 */
22/*
23 * file: pe_kprintf.c
24 * PPC platform expert debugging output initialization.
25 */
26#include <stdarg.h>
27#include <machine/machine_routines.h>
28#include <pexpert/protos.h>
29#include <pexpert/pexpert.h>
30#include <pexpert/ppc/powermac.h>
31#include <kern/debug.h>
32#include <kern/simple_lock.h>
33
34/* extern references */
35extern void init_display_putc(unsigned char*, int, int);
36extern void display_putc(char c);
37extern int scc_putc(int unit, int line, int c);
38extern void cnputc(char c);
39
40/* Internal routines -- eventually put this in serial driver */
41void serial_putc(char c);
42
43/* Globals */
44void (*PE_kputc)(char c) = 0;
45
46unsigned int disableSerialOuput = TRUE;
47
48
49static struct slock kprintf_lock;
50
51void PE_init_kprintf(boolean_t vm_initialized)
52{
53 static vm_offset_t scc;
54 unsigned int boot_arg;
55
56 if (PE_state.initialized == FALSE)
57 panic("Platform Expert not initialized");
58
59 if (!vm_initialized)
60 {
61 if (PE_parse_boot_arg("debug", &boot_arg))
62 if(boot_arg & DB_KPRT) disableSerialOuput = FALSE;
63
64 if( (scc = PE_find_scc()))
65 {
66 initialize_serial( (void *) scc );
67 PE_kputc = serial_putc;
68
69 simple_lock_init(&kprintf_lock, 0);
70 } else
71 PE_kputc = cnputc;
72
73 } else if( scc){
74 initialize_serial( (void *) io_map( scc, 0x1000) );
75 }
76
77#if 0
78 /*
79 * FUTURE: eventually let the boot command determine where
80 * the debug output will be, serial, video, etc.
81 */
82 switch (PE_state.debug_video.v_display) {
83 case kDebugTypeSerial:
84 PE_kputc = serial_putc;
85 break;
86
87 case kDebugTypeDisplay:
88 init_display_putc( (unsigned char*)PE_state.debug_video.v_baseAddr,
89 PE_state.debug_video.v_rowBytes,
90 PE_state.debug_video.v_height);
91 PE_kputc = display_putc;
92 break;
93
94 default:
95 PE_state.debug_video.v_baseAddr = 0;
96 }
97#endif
98}
99
100void serial_putc(char c)
101{
102 (void) scc_putc(0, 1, c);
103 if (c == '\n') (void) scc_putc(0, 1, '\r');
104
105#if 0
106 (void) scc_putc(0, (int)PE_state.debug_video.v_baseAddr, c);
107 if (c == '\n') (void) scc_putc(0, (int)PE_state.debug_video.v_baseAddr, '\r');
108#endif
109}
110
111void kprintf(const char *fmt, ...)
112{
113 va_list listp;
114 boolean_t state;
115
116 state = ml_set_interrupts_enabled(FALSE);
117 simple_lock(&kprintf_lock);
118
119 if (!disableSerialOuput) {
120 va_start(listp, fmt);
121 _doprnt(fmt, &listp, PE_kputc, 16);
122 va_end(listp);
123 }
124
125 simple_unlock(&kprintf_lock);
126 ml_set_interrupts_enabled(state);
127}
128