1*5f5131c1Sdholland /* $NetBSD: boot.c,v 1.8 2016/06/11 06:49:46 dholland Exp $ */
2c1c742b4Sfredette
3c1c742b4Sfredette /*-
4c1c742b4Sfredette * Copyright (c) 1982, 1986, 1990, 1993
5c1c742b4Sfredette * The Regents of the University of California. All rights reserved.
6c1c742b4Sfredette *
7c1c742b4Sfredette * Redistribution and use in source and binary forms, with or without
8c1c742b4Sfredette * modification, are permitted provided that the following conditions
9c1c742b4Sfredette * are met:
10c1c742b4Sfredette * 1. Redistributions of source code must retain the above copyright
11c1c742b4Sfredette * notice, this list of conditions and the following disclaimer.
12c1c742b4Sfredette * 2. Redistributions in binary form must reproduce the above copyright
13c1c742b4Sfredette * notice, this list of conditions and the following disclaimer in the
14c1c742b4Sfredette * documentation and/or other materials provided with the distribution.
15aad01611Sagc * 3. Neither the name of the University nor the names of its contributors
16c1c742b4Sfredette * may be used to endorse or promote products derived from this software
17c1c742b4Sfredette * without specific prior written permission.
18c1c742b4Sfredette *
19c1c742b4Sfredette * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20c1c742b4Sfredette * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21c1c742b4Sfredette * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22c1c742b4Sfredette * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23c1c742b4Sfredette * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24c1c742b4Sfredette * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25c1c742b4Sfredette * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26c1c742b4Sfredette * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27c1c742b4Sfredette * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28c1c742b4Sfredette * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29c1c742b4Sfredette * SUCH DAMAGE.
30c1c742b4Sfredette *
31c1c742b4Sfredette * @(#)boot.c 8.1 (Berkeley) 6/10/93
32c1c742b4Sfredette */
33c1c742b4Sfredette
34c1c742b4Sfredette #include <sys/param.h>
35c1c742b4Sfredette #include <sys/reboot.h>
36c1c742b4Sfredette #include <machine/mon.h>
37c1c742b4Sfredette
38c1c742b4Sfredette #include <stand.h>
39c1c742b4Sfredette #include <loadfile.h>
40c1c742b4Sfredette #include "libsa.h"
41c1c742b4Sfredette
42c1c742b4Sfredette /*
43c1c742b4Sfredette * Default the name (really tape segment number).
44c1c742b4Sfredette * The defaults assume the following tape layout:
45c1c742b4Sfredette * segment 0: tapeboot
46c1c742b4Sfredette * segment 1: netbsd.sun3 (RAMDISK3)
47c1c742b4Sfredette * segment 2: netbsd.sun3x (RAMDISK3X)
48c1c742b4Sfredette * segment 3: miniroot image
49100e6f36Sfredette * segment 4: netbsd.sun2 (RAMDISK)
50100e6f36Sfredette * Therefore, the default name is "1" or "2" or "4"
51100e6f36Sfredette * for sun3, sun3x, and sun2, respectively.
52c1c742b4Sfredette */
53c1c742b4Sfredette
54c1c742b4Sfredette char defname[32] = "1";
55c1c742b4Sfredette char line[80];
56c1c742b4Sfredette
57c1c742b4Sfredette int
main(void)5810b1a7beSchs main(void)
59c1c742b4Sfredette {
60c1c742b4Sfredette char *cp, *file;
61c1c742b4Sfredette void *entry;
62c1c742b4Sfredette u_long marks[MARK_MAX];
63100e6f36Sfredette u_long mark_start;
64c1c742b4Sfredette int fd;
65c1c742b4Sfredette
66c1c742b4Sfredette printf(">> %s tapeboot [%s]\n", bootprog_name, bootprog_rev);
67c1c742b4Sfredette prom_get_boot_info();
68c1c742b4Sfredette
69c1c742b4Sfredette /*
70c1c742b4Sfredette * Can not hold open the tape device as is done
71c1c742b4Sfredette * in the other boot programs because it does
72c1c742b4Sfredette * its position-to-segment on open.
73c1c742b4Sfredette */
74c1c742b4Sfredette
75100e6f36Sfredette /* Assume the Sun3/Sun3x load start. */
76100e6f36Sfredette memset(marks, 0, sizeof(marks));
77100e6f36Sfredette mark_start = 0;
78100e6f36Sfredette
79c1c742b4Sfredette /* If running on a Sun3X, use segment 2. */
80c1c742b4Sfredette if (_is3x)
81c1c742b4Sfredette defname[0] = '2';
82100e6f36Sfredette
83100e6f36Sfredette /*
84100e6f36Sfredette * If running on a Sun2, use segment 4 and
85100e6f36Sfredette * do the special MMU setup.
86100e6f36Sfredette */
87100e6f36Sfredette else if (_is2) {
88100e6f36Sfredette defname[0] = '4';
89100e6f36Sfredette mark_start = sun2_map_mem_load();
90100e6f36Sfredette }
91100e6f36Sfredette
92c1c742b4Sfredette file = defname;
93c1c742b4Sfredette
94c1c742b4Sfredette cp = prom_bootfile;
95c1c742b4Sfredette if (cp && *cp)
96c1c742b4Sfredette file = cp;
97c1c742b4Sfredette
98c1c742b4Sfredette for (;;) {
99c1c742b4Sfredette if (prom_boothow & RB_ASKNAME) {
100c1c742b4Sfredette printf("tapeboot: segment? [%s]: ", defname);
101*5f5131c1Sdholland kgets(line, sizeof(line));
102c1c742b4Sfredette if (line[0])
103c1c742b4Sfredette file = line;
104c1c742b4Sfredette else
105c1c742b4Sfredette file = defname;
106c1c742b4Sfredette } else
107c1c742b4Sfredette printf("tapeboot: loading segment %s\n", file);
108c1c742b4Sfredette
109100e6f36Sfredette marks[MARK_START] = mark_start;
1104d77588aStsutsui if ((fd = loadfile(file, marks,
1114d77588aStsutsui LOAD_KERNEL & ~LOAD_BACKWARDS)) != -1) {
112c1c742b4Sfredette break;
113c1c742b4Sfredette }
114c1c742b4Sfredette printf("tapeboot: segment %s: %s\n", file, strerror(errno));
115c1c742b4Sfredette prom_boothow |= RB_ASKNAME;
116c1c742b4Sfredette }
117c1c742b4Sfredette close(fd);
118c1c742b4Sfredette
119c1c742b4Sfredette entry = (void *)marks[MARK_ENTRY];
120100e6f36Sfredette if (_is2) {
121100e6f36Sfredette printf("relocating program...");
122100e6f36Sfredette entry = sun2_map_mem_run(entry);
123100e6f36Sfredette }
124fe0dea61Stsutsui printf("Starting program at 0x%x\n", (u_int)entry);
125c1c742b4Sfredette chain_to(entry);
126fe0dea61Stsutsui
127fe0dea61Stsutsui return 0;
128c1c742b4Sfredette }
129