sh_console.cpp revision 1.11.78.1 1 1.11.78.1 yamt /* -*-C++-*- $NetBSD: sh_console.cpp,v 1.11.78.1 2008/05/16 02:22:26 yamt Exp $ */
2 1.1 uch
3 1.1 uch /*-
4 1.8 uch * Copyright (c) 2001, 2002 The NetBSD Foundation, Inc.
5 1.1 uch * All rights reserved.
6 1.1 uch *
7 1.1 uch * This code is derived from software contributed to The NetBSD Foundation
8 1.1 uch * by UCHIYAMA Yasushi.
9 1.1 uch *
10 1.1 uch * Redistribution and use in source and binary forms, with or without
11 1.1 uch * modification, are permitted provided that the following conditions
12 1.1 uch * are met:
13 1.1 uch * 1. Redistributions of source code must retain the above copyright
14 1.1 uch * notice, this list of conditions and the following disclaimer.
15 1.1 uch * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 uch * notice, this list of conditions and the following disclaimer in the
17 1.1 uch * documentation and/or other materials provided with the distribution.
18 1.1 uch *
19 1.1 uch * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 uch * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 uch * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 uch * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 uch * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 uch * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 uch * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 uch * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 uch * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 uch * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 uch * POSSIBILITY OF SUCH DAMAGE.
30 1.1 uch */
31 1.1 uch
32 1.2 uch #include <hpcmenu.h>
33 1.1 uch #include <sh3/sh_console.h>
34 1.9 uch #include <sh3/dev/sh.h>
35 1.9 uch #include <sh3/dev/hd64461.h>
36 1.9 uch #include <sh3/dev/hd64465.h>
37 1.1 uch
38 1.9 uch // console switch
39 1.9 uch #include "../../../../hpcsh/include/console.h"
40 1.3 uch
41 1.9 uch const struct SHConsole::console_info
42 1.2 uch SHConsole::_console_info[] = {
43 1.8 uch { PLATID_CPU_SH_3 , PLATID_MACH_HP , SCIFPrint , BI_CNUSE_SCIF , BI_CNUSE_HD64461VIDEO },
44 1.8 uch { PLATID_CPU_SH_3_7709 , PLATID_MACH_HITACHI , HD64461COMPrint , BI_CNUSE_HD64461COM , BI_CNUSE_HD64461VIDEO },
45 1.7 uch { PLATID_CPU_SH_3_7709 , PLATID_MACH_CASIO_CASSIOPEIAA_A55V , 0 , BI_CNUSE_BUILTIN , BI_CNUSE_BUILTIN },
46 1.9 uch { PLATID_CPU_SH_4_7750 , PLATID_MACH_HITACHI_PERSONA_HPW650PA , HD64465COMPrint , BI_CNUSE_HD64465COM , BI_CNUSE_BUILTIN },
47 1.2 uch { 0, 0, 0 } // terminator.
48 1.2 uch };
49 1.2 uch
50 1.9 uch const struct SHConsole::console_info *
51 1.7 uch SHConsole::selectBootConsole(Console &cons, enum consoleSelect select)
52 1.7 uch {
53 1.9 uch const struct console_info *tab = _console_info;
54 1.7 uch platid_mask_t target, entry;
55 1.7 uch
56 1.7 uch target.dw.dw0 = HPC_PREFERENCE.platid_hi;
57 1.7 uch target.dw.dw1 = HPC_PREFERENCE.platid_lo;
58 1.7 uch
59 1.7 uch // search apriori setting if any.
60 1.7 uch for (; tab->cpu; tab++) {
61 1.7 uch entry.dw.dw0 = tab->cpu;
62 1.7 uch entry.dw.dw1 = tab->machine;
63 1.7 uch if (platid_match(&target, &entry)) {
64 1.7 uch switch (select) {
65 1.7 uch case SERIAL:
66 1.7 uch cons.setBootConsole(tab->serial_console);
67 1.8 uch return tab;
68 1.7 uch case VIDEO:
69 1.7 uch cons.setBootConsole(tab->video_console);
70 1.8 uch return tab;
71 1.7 uch }
72 1.7 uch }
73 1.7 uch }
74 1.7 uch
75 1.8 uch return NULL;
76 1.7 uch }
77 1.7 uch
78 1.2 uch SHConsole::SHConsole()
79 1.2 uch {
80 1.8 uch
81 1.2 uch _print = 0;
82 1.2 uch }
83 1.2 uch
84 1.2 uch SHConsole::~SHConsole()
85 1.2 uch {
86 1.7 uch // NO-OP
87 1.2 uch }
88 1.2 uch
89 1.2 uch BOOL
90 1.2 uch SHConsole::init()
91 1.2 uch {
92 1.10 uch
93 1.5 uch if (!super::init())
94 1.5 uch return FALSE;
95 1.5 uch
96 1.9 uch const struct console_info *tab = selectBootConsole(*this, SERIAL);
97 1.9 uch if (tab != 0) {
98 1.9 uch SetKMode(1); // Native method access P4.
99 1.7 uch _print = tab->print;
100 1.10 uch }
101 1.10 uch
102 1.9 uch // override default instance.
103 1.9 uch Console::_instance = this;
104 1.9 uch
105 1.5 uch return TRUE;
106 1.2 uch }
107 1.2 uch
108 1.1 uch void
109 1.1 uch SHConsole::print(const TCHAR *fmt, ...)
110 1.1 uch {
111 1.8 uch
112 1.5 uch SETUP_WIDECHAR_BUFFER();
113 1.1 uch
114 1.5 uch if (!setupMultibyteBuffer())
115 1.1 uch return;
116 1.1 uch
117 1.4 uch if (_print == 0)
118 1.5 uch super::genericPrint(_bufm);
119 1.4 uch else
120 1.4 uch _print(_bufm);
121 1.4 uch }
122 1.4 uch
123 1.4 uch void
124 1.4 uch SHConsole::SCIPrint(const char *buf)
125 1.4 uch {
126 1.8 uch
127 1.9 uch SH3_SCI_PRINT(buf);
128 1.1 uch }
129 1.2 uch
130 1.2 uch void
131 1.2 uch SHConsole::SCIFPrint(const char *buf)
132 1.2 uch {
133 1.8 uch
134 1.9 uch SH3_SCIF_PRINT(buf);
135 1.2 uch }
136 1.4 uch
137 1.4 uch void
138 1.4 uch SHConsole::HD64461COMPrint(const char *buf)
139 1.4 uch {
140 1.8 uch
141 1.4 uch HD64461COM_PRINT(buf);
142 1.8 uch }
143 1.8 uch
144 1.8 uch void
145 1.8 uch SHConsole::HD64465COMPrint(const char *buf)
146 1.8 uch {
147 1.8 uch
148 1.8 uch HD64465COM_PRINT(buf);
149 1.4 uch }
150