xref: /minix3/usr.sbin/installboot/arch/sparc64.c (revision 9f8e6353e54579f3834bed052b7960946fc4bb01)
1*9f8e6353SEvgeniy Ivanov /*	$NetBSD: sparc64.c,v 1.18 2010/01/14 16:27:49 tsutsui Exp $	*/
2*9f8e6353SEvgeniy Ivanov 
3*9f8e6353SEvgeniy Ivanov /*-
4*9f8e6353SEvgeniy Ivanov  * Copyright (c) 2002 The NetBSD Foundation, Inc.
5*9f8e6353SEvgeniy Ivanov  * All rights reserved.
6*9f8e6353SEvgeniy Ivanov  *
7*9f8e6353SEvgeniy Ivanov  * This code is derived from software contributed to The NetBSD Foundation
8*9f8e6353SEvgeniy Ivanov  * by Luke Mewburn of Wasabi Systems.
9*9f8e6353SEvgeniy Ivanov  *
10*9f8e6353SEvgeniy Ivanov  * Redistribution and use in source and binary forms, with or without
11*9f8e6353SEvgeniy Ivanov  * modification, are permitted provided that the following conditions
12*9f8e6353SEvgeniy Ivanov  * are met:
13*9f8e6353SEvgeniy Ivanov  * 1. Redistributions of source code must retain the above copyright
14*9f8e6353SEvgeniy Ivanov  *    notice, this list of conditions and the following disclaimer.
15*9f8e6353SEvgeniy Ivanov  * 2. Redistributions in binary form must reproduce the above copyright
16*9f8e6353SEvgeniy Ivanov  *    notice, this list of conditions and the following disclaimer in the
17*9f8e6353SEvgeniy Ivanov  *    documentation and/or other materials provided with the distribution.
18*9f8e6353SEvgeniy Ivanov  *
19*9f8e6353SEvgeniy Ivanov  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20*9f8e6353SEvgeniy Ivanov  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21*9f8e6353SEvgeniy Ivanov  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22*9f8e6353SEvgeniy Ivanov  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23*9f8e6353SEvgeniy Ivanov  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24*9f8e6353SEvgeniy Ivanov  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25*9f8e6353SEvgeniy Ivanov  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26*9f8e6353SEvgeniy Ivanov  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27*9f8e6353SEvgeniy Ivanov  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28*9f8e6353SEvgeniy Ivanov  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29*9f8e6353SEvgeniy Ivanov  * POSSIBILITY OF SUCH DAMAGE.
30*9f8e6353SEvgeniy Ivanov  */
31*9f8e6353SEvgeniy Ivanov 
32*9f8e6353SEvgeniy Ivanov /*
33*9f8e6353SEvgeniy Ivanov  * Copyright (c) 2002 Matthew R. Green
34*9f8e6353SEvgeniy Ivanov  * All rights reserved.
35*9f8e6353SEvgeniy Ivanov  *
36*9f8e6353SEvgeniy Ivanov  * Redistribution and use in source and binary forms, with or without
37*9f8e6353SEvgeniy Ivanov  * modification, are permitted provided that the following conditions
38*9f8e6353SEvgeniy Ivanov  * are met:
39*9f8e6353SEvgeniy Ivanov  * 1. Redistributions of source code must retain the above copyright
40*9f8e6353SEvgeniy Ivanov  *    notice, this list of conditions and the following disclaimer.
41*9f8e6353SEvgeniy Ivanov  * 2. Redistributions in binary form must reproduce the above copyright
42*9f8e6353SEvgeniy Ivanov  *    notice, this list of conditions and the following disclaimer in the
43*9f8e6353SEvgeniy Ivanov  *    documentation and/or other materials provided with the distribution.
44*9f8e6353SEvgeniy Ivanov  *
45*9f8e6353SEvgeniy Ivanov  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
46*9f8e6353SEvgeniy Ivanov  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
47*9f8e6353SEvgeniy Ivanov  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
48*9f8e6353SEvgeniy Ivanov  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
49*9f8e6353SEvgeniy Ivanov  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
50*9f8e6353SEvgeniy Ivanov  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
51*9f8e6353SEvgeniy Ivanov  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
52*9f8e6353SEvgeniy Ivanov  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
53*9f8e6353SEvgeniy Ivanov  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
54*9f8e6353SEvgeniy Ivanov  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
55*9f8e6353SEvgeniy Ivanov  * SUCH DAMAGE.
56*9f8e6353SEvgeniy Ivanov  */
57*9f8e6353SEvgeniy Ivanov 
58*9f8e6353SEvgeniy Ivanov #if HAVE_NBTOOL_CONFIG_H
59*9f8e6353SEvgeniy Ivanov #include "nbtool_config.h"
60*9f8e6353SEvgeniy Ivanov #endif
61*9f8e6353SEvgeniy Ivanov 
62*9f8e6353SEvgeniy Ivanov #include <sys/cdefs.h>
63*9f8e6353SEvgeniy Ivanov #if !defined(__lint)
64*9f8e6353SEvgeniy Ivanov __RCSID("$NetBSD: sparc64.c,v 1.18 2010/01/14 16:27:49 tsutsui Exp $");
65*9f8e6353SEvgeniy Ivanov #endif	/* !__lint */
66*9f8e6353SEvgeniy Ivanov 
67*9f8e6353SEvgeniy Ivanov #include <sys/param.h>
68*9f8e6353SEvgeniy Ivanov 
69*9f8e6353SEvgeniy Ivanov #include <assert.h>
70*9f8e6353SEvgeniy Ivanov #include <err.h>
71*9f8e6353SEvgeniy Ivanov #include <stddef.h>
72*9f8e6353SEvgeniy Ivanov #include <stdio.h>
73*9f8e6353SEvgeniy Ivanov #include <stdlib.h>
74*9f8e6353SEvgeniy Ivanov #include <string.h>
75*9f8e6353SEvgeniy Ivanov #include <unistd.h>
76*9f8e6353SEvgeniy Ivanov 
77*9f8e6353SEvgeniy Ivanov #include "installboot.h"
78*9f8e6353SEvgeniy Ivanov 
79*9f8e6353SEvgeniy Ivanov static int sparc64_clearboot(ib_params *);
80*9f8e6353SEvgeniy Ivanov static int sparc64_setboot(ib_params *);
81*9f8e6353SEvgeniy Ivanov 
82*9f8e6353SEvgeniy Ivanov struct ib_mach ib_mach_sparc64 =
83*9f8e6353SEvgeniy Ivanov 	{ "sparc64", sparc64_setboot, sparc64_clearboot, no_editboot, 0};
84*9f8e6353SEvgeniy Ivanov 
85*9f8e6353SEvgeniy Ivanov static int
sparc64_clearboot(ib_params * params)86*9f8e6353SEvgeniy Ivanov sparc64_clearboot(ib_params *params)
87*9f8e6353SEvgeniy Ivanov {
88*9f8e6353SEvgeniy Ivanov 	char	bb[SPARC64_BOOT_BLOCK_MAX_SIZE];
89*9f8e6353SEvgeniy Ivanov 	ssize_t	rv;
90*9f8e6353SEvgeniy Ivanov 
91*9f8e6353SEvgeniy Ivanov 	assert(params != NULL);
92*9f8e6353SEvgeniy Ivanov 	assert(params->fsfd != -1);
93*9f8e6353SEvgeniy Ivanov 	assert(params->filesystem != NULL);
94*9f8e6353SEvgeniy Ivanov 
95*9f8e6353SEvgeniy Ivanov 	if (params->flags & (IB_STAGE1START | IB_STAGE2START)) {
96*9f8e6353SEvgeniy Ivanov 		warnx("`-b bno' and `-B bno' are not supported for %s",
97*9f8e6353SEvgeniy Ivanov 		    params->machine->name);
98*9f8e6353SEvgeniy Ivanov 		return (0);
99*9f8e6353SEvgeniy Ivanov 	}
100*9f8e6353SEvgeniy Ivanov 
101*9f8e6353SEvgeniy Ivanov 	/* first check that it _could_ exist here */
102*9f8e6353SEvgeniy Ivanov 	rv = pread(params->fsfd, &bb, sizeof(bb), SPARC64_BOOT_BLOCK_OFFSET);
103*9f8e6353SEvgeniy Ivanov 	if (rv == -1) {
104*9f8e6353SEvgeniy Ivanov 		warn("Reading `%s'", params->filesystem);
105*9f8e6353SEvgeniy Ivanov 		return (0);
106*9f8e6353SEvgeniy Ivanov 	} else if (rv != sizeof(bb)) {
107*9f8e6353SEvgeniy Ivanov 		warnx("Reading `%s': short read", params->filesystem);
108*9f8e6353SEvgeniy Ivanov 		return (0);
109*9f8e6353SEvgeniy Ivanov 	}
110*9f8e6353SEvgeniy Ivanov 
111*9f8e6353SEvgeniy Ivanov 	/* now clear it out to nothing */
112*9f8e6353SEvgeniy Ivanov 	memset(&bb, 0, sizeof(bb));
113*9f8e6353SEvgeniy Ivanov 
114*9f8e6353SEvgeniy Ivanov 	if (params->flags & IB_VERBOSE)
115*9f8e6353SEvgeniy Ivanov 		printf("%slearing boot block\n",
116*9f8e6353SEvgeniy Ivanov 		    (params->flags & IB_NOWRITE) ? "Not c" : "C");
117*9f8e6353SEvgeniy Ivanov 	if (params->flags & IB_NOWRITE)
118*9f8e6353SEvgeniy Ivanov 		return (1);
119*9f8e6353SEvgeniy Ivanov 
120*9f8e6353SEvgeniy Ivanov 	rv = pwrite(params->fsfd, &bb, sizeof(bb), SPARC64_BOOT_BLOCK_OFFSET);
121*9f8e6353SEvgeniy Ivanov 	if (rv == -1) {
122*9f8e6353SEvgeniy Ivanov 		warn("Writing `%s'", params->filesystem);
123*9f8e6353SEvgeniy Ivanov 		return (0);
124*9f8e6353SEvgeniy Ivanov 	} else if (rv != sizeof(bb)) {
125*9f8e6353SEvgeniy Ivanov 		warnx("Writing `%s': short write", params->filesystem);
126*9f8e6353SEvgeniy Ivanov 		return (0);
127*9f8e6353SEvgeniy Ivanov 	}
128*9f8e6353SEvgeniy Ivanov 
129*9f8e6353SEvgeniy Ivanov 	return (1);
130*9f8e6353SEvgeniy Ivanov }
131*9f8e6353SEvgeniy Ivanov 
132*9f8e6353SEvgeniy Ivanov static int
sparc64_setboot(ib_params * params)133*9f8e6353SEvgeniy Ivanov sparc64_setboot(ib_params *params)
134*9f8e6353SEvgeniy Ivanov {
135*9f8e6353SEvgeniy Ivanov 	char		bb[SPARC64_BOOT_BLOCK_MAX_SIZE];
136*9f8e6353SEvgeniy Ivanov 	int		retval;
137*9f8e6353SEvgeniy Ivanov 	ssize_t		rv;
138*9f8e6353SEvgeniy Ivanov 
139*9f8e6353SEvgeniy Ivanov 	assert(params != NULL);
140*9f8e6353SEvgeniy Ivanov 	assert(params->fsfd != -1);
141*9f8e6353SEvgeniy Ivanov 	assert(params->filesystem != NULL);
142*9f8e6353SEvgeniy Ivanov 	assert(params->s1fd != -1);
143*9f8e6353SEvgeniy Ivanov 	assert(params->stage1 != NULL);
144*9f8e6353SEvgeniy Ivanov 
145*9f8e6353SEvgeniy Ivanov 	retval = 0;
146*9f8e6353SEvgeniy Ivanov 
147*9f8e6353SEvgeniy Ivanov 	if (params->flags & (IB_STAGE1START | IB_STAGE2START)) {
148*9f8e6353SEvgeniy Ivanov 		warnx("`-b bno' and `-B bno' are not supported for %s",
149*9f8e6353SEvgeniy Ivanov 		    params->machine->name);
150*9f8e6353SEvgeniy Ivanov 		goto done;
151*9f8e6353SEvgeniy Ivanov 	}
152*9f8e6353SEvgeniy Ivanov 
153*9f8e6353SEvgeniy Ivanov 	memset(&bb, 0, SPARC64_BOOT_BLOCK_MAX_SIZE);
154*9f8e6353SEvgeniy Ivanov 	rv = read(params->s1fd, &bb, sizeof(bb));
155*9f8e6353SEvgeniy Ivanov 	if (rv == -1) {
156*9f8e6353SEvgeniy Ivanov 		warn("Reading `%s'", params->stage1);
157*9f8e6353SEvgeniy Ivanov 		goto done;
158*9f8e6353SEvgeniy Ivanov 	}
159*9f8e6353SEvgeniy Ivanov 
160*9f8e6353SEvgeniy Ivanov 	if (params->flags & IB_VERBOSE) {
161*9f8e6353SEvgeniy Ivanov 		printf("Bootstrap start sector: %u\n",
162*9f8e6353SEvgeniy Ivanov 		    SPARC64_BOOT_BLOCK_OFFSET / SPARC64_BOOT_BLOCK_BLOCKSIZE);
163*9f8e6353SEvgeniy Ivanov 		printf("Bootstrap byte count:   %u\n", (unsigned)rv);
164*9f8e6353SEvgeniy Ivanov 		printf("%sriting bootstrap\n",
165*9f8e6353SEvgeniy Ivanov 		    (params->flags & IB_NOWRITE) ? "Not w" : "W");
166*9f8e6353SEvgeniy Ivanov 	}
167*9f8e6353SEvgeniy Ivanov 	if (params->flags & IB_NOWRITE) {
168*9f8e6353SEvgeniy Ivanov 		retval = 1;
169*9f8e6353SEvgeniy Ivanov 		goto done;
170*9f8e6353SEvgeniy Ivanov 	}
171*9f8e6353SEvgeniy Ivanov 
172*9f8e6353SEvgeniy Ivanov 	rv = pwrite(params->fsfd, &bb, SPARC64_BOOT_BLOCK_MAX_SIZE,
173*9f8e6353SEvgeniy Ivanov 	    SPARC64_BOOT_BLOCK_OFFSET);
174*9f8e6353SEvgeniy Ivanov 	if (rv == -1) {
175*9f8e6353SEvgeniy Ivanov 		warn("Writing `%s'", params->filesystem);
176*9f8e6353SEvgeniy Ivanov 		goto done;
177*9f8e6353SEvgeniy Ivanov 	} else if (rv != SPARC64_BOOT_BLOCK_MAX_SIZE) {
178*9f8e6353SEvgeniy Ivanov 		warnx("Writing `%s': short write", params->filesystem);
179*9f8e6353SEvgeniy Ivanov 		goto done;
180*9f8e6353SEvgeniy Ivanov 	} else
181*9f8e6353SEvgeniy Ivanov 		retval = 1;
182*9f8e6353SEvgeniy Ivanov 
183*9f8e6353SEvgeniy Ivanov  done:
184*9f8e6353SEvgeniy Ivanov 	return (retval);
185*9f8e6353SEvgeniy Ivanov }
186