xref: /netbsd-src/usr.sbin/installboot/arch/news.c (revision e5c09b191b3a14e8b4648a699077b773caf1ed9b)
1*e5c09b19Sthorpej /*	$NetBSD: news.c,v 1.8 2019/05/07 04:35:31 thorpej Exp $ */
2d22f5cffSlukem 
3d22f5cffSlukem /*-
4d22f5cffSlukem  * Copyright (c) 2002 The NetBSD Foundation, Inc.
5d22f5cffSlukem  * All rights reserved.
6d22f5cffSlukem  *
7d22f5cffSlukem  * This code is derived from software contributed to The NetBSD Foundation
8d22f5cffSlukem  * by Luke Mewburn and Izumi Tsutsui.
9d22f5cffSlukem  *
10d22f5cffSlukem  * Redistribution and use in source and binary forms, with or without
11d22f5cffSlukem  * modification, are permitted provided that the following conditions
12d22f5cffSlukem  * are met:
13d22f5cffSlukem  * 1. Redistributions of source code must retain the above copyright
14d22f5cffSlukem  *    notice, this list of conditions and the following disclaimer.
15d22f5cffSlukem  * 2. Redistributions in binary form must reproduce the above copyright
16d22f5cffSlukem  *    notice, this list of conditions and the following disclaimer in the
17d22f5cffSlukem  *    documentation and/or other materials provided with the distribution.
18d22f5cffSlukem  *
19d22f5cffSlukem  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20d22f5cffSlukem  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21d22f5cffSlukem  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22d22f5cffSlukem  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23d22f5cffSlukem  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24d22f5cffSlukem  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25d22f5cffSlukem  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26d22f5cffSlukem  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27d22f5cffSlukem  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28d22f5cffSlukem  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29d22f5cffSlukem  * POSSIBILITY OF SUCH DAMAGE.
30d22f5cffSlukem  */
31d22f5cffSlukem 
32171d6532Slukem #if HAVE_NBTOOL_CONFIG_H
33171d6532Slukem #include "nbtool_config.h"
34d22f5cffSlukem #endif
35d22f5cffSlukem 
36171d6532Slukem #include <sys/cdefs.h>
37171d6532Slukem #if !defined(__lint)
38*e5c09b19Sthorpej __RCSID("$NetBSD: news.c,v 1.8 2019/05/07 04:35:31 thorpej Exp $");
39171d6532Slukem #endif	/* !__lint */
40171d6532Slukem 
41d22f5cffSlukem #include <sys/param.h>
42d22f5cffSlukem 
43d22f5cffSlukem #include <assert.h>
44d22f5cffSlukem #include <err.h>
45d22f5cffSlukem #include <stddef.h>
46d22f5cffSlukem #include <stdio.h>
47d22f5cffSlukem #include <stdlib.h>
48d22f5cffSlukem #include <string.h>
49d22f5cffSlukem #include <unistd.h>
50d22f5cffSlukem 
51d22f5cffSlukem #include "installboot.h"
52d22f5cffSlukem 
536a574a38Slukem static int news_copydisklabel(ib_params *, struct bbinfo_params *, uint8_t *);
54d22f5cffSlukem 
55cce659e2Sdsl static int news68k_clearboot(ib_params *);
56cce659e2Sdsl static int news68k_setboot(ib_params *);
57cce659e2Sdsl static int newsmips_clearboot(ib_params *);
58cce659e2Sdsl static int newsmips_setboot(ib_params *);
59cce659e2Sdsl 
60*e5c09b19Sthorpej struct ib_mach ib_mach_news68k = {
61*e5c09b19Sthorpej 	.name		=	"news68k",
62*e5c09b19Sthorpej 	.setboot	=	news68k_setboot,
63*e5c09b19Sthorpej 	.clearboot	=	news68k_clearboot,
64*e5c09b19Sthorpej 	.editboot	=	no_editboot,
65*e5c09b19Sthorpej 	.valid_flags	=	IB_STAGE2START,
66*e5c09b19Sthorpej };
67cce659e2Sdsl 
68*e5c09b19Sthorpej struct ib_mach ib_mach_newsmips = {
69*e5c09b19Sthorpej 	.name		=	"newsmips",
70*e5c09b19Sthorpej 	.setboot	=	newsmips_setboot,
71*e5c09b19Sthorpej 	.clearboot	=	newsmips_clearboot,
72*e5c09b19Sthorpej 	.editboot	=	no_editboot,
73*e5c09b19Sthorpej 	.valid_flags	=	IB_STAGE2START,
74*e5c09b19Sthorpej };
75d22f5cffSlukem 
76d22f5cffSlukem /*
77d22f5cffSlukem  * news68k specific support
78d22f5cffSlukem  */
79d22f5cffSlukem 
80d22f5cffSlukem static struct bbinfo_params news68k_bbparams = {
81d22f5cffSlukem 	NEWS68K_BBINFO_MAGIC,
826a574a38Slukem 	NEWS_BOOT_BLOCK_OFFSET,		/* write all 8K (including disklabel) */
83d22f5cffSlukem 	NEWS_BOOT_BLOCK_BLOCKSIZE,
84d22f5cffSlukem 	NEWS_BOOT_BLOCK_MAX_SIZE,
856a574a38Slukem 	0,
86d22f5cffSlukem 	BBINFO_BIG_ENDIAN,
87d22f5cffSlukem };
88d22f5cffSlukem 
89cce659e2Sdsl static int
news68k_clearboot(ib_params * params)90d22f5cffSlukem news68k_clearboot(ib_params *params)
91d22f5cffSlukem {
92d22f5cffSlukem 
93d22f5cffSlukem 	assert(params != NULL);
94d22f5cffSlukem 
95d22f5cffSlukem 	return (shared_bbinfo_clearboot(params, &news68k_bbparams,
966a574a38Slukem 	    news_copydisklabel));
97d22f5cffSlukem }
98d22f5cffSlukem 
99cce659e2Sdsl static int
news68k_setboot(ib_params * params)100d22f5cffSlukem news68k_setboot(ib_params *params)
101d22f5cffSlukem {
102d22f5cffSlukem 
103d22f5cffSlukem 	assert(params != NULL);
104d22f5cffSlukem 
1056a574a38Slukem 	return (shared_bbinfo_setboot(params, &news68k_bbparams,
1066a574a38Slukem 	    news_copydisklabel));
107d22f5cffSlukem }
108d22f5cffSlukem 
109d22f5cffSlukem 
110d22f5cffSlukem /*
111d22f5cffSlukem  * newsmips specific support
112d22f5cffSlukem  */
113d22f5cffSlukem 
114d22f5cffSlukem static struct bbinfo_params newsmips_bbparams = {
115d22f5cffSlukem 	NEWSMIPS_BBINFO_MAGIC,
1166a574a38Slukem 	NEWS_BOOT_BLOCK_OFFSET,		/* write all 8K (including disklabel) */
117d22f5cffSlukem 	NEWS_BOOT_BLOCK_BLOCKSIZE,
118d22f5cffSlukem 	NEWS_BOOT_BLOCK_MAX_SIZE,
1196a574a38Slukem 	0,
120d22f5cffSlukem 	BBINFO_BIG_ENDIAN,
121d22f5cffSlukem };
122d22f5cffSlukem 
123cce659e2Sdsl static int
newsmips_clearboot(ib_params * params)124d22f5cffSlukem newsmips_clearboot(ib_params *params)
125d22f5cffSlukem {
126d22f5cffSlukem 
127d22f5cffSlukem 	assert(params != NULL);
128d22f5cffSlukem 
129d22f5cffSlukem 	return (shared_bbinfo_clearboot(params, &newsmips_bbparams,
1306a574a38Slukem 	    news_copydisklabel));
131d22f5cffSlukem }
132d22f5cffSlukem 
133cce659e2Sdsl static int
newsmips_setboot(ib_params * params)134d22f5cffSlukem newsmips_setboot(ib_params *params)
135d22f5cffSlukem {
136d22f5cffSlukem 
137d22f5cffSlukem 	assert(params != NULL);
138d22f5cffSlukem 
139d22f5cffSlukem 	return (shared_bbinfo_setboot(params, &newsmips_bbparams,
1406a574a38Slukem 	    news_copydisklabel));
141d22f5cffSlukem }
142d22f5cffSlukem 
143d22f5cffSlukem 
144d22f5cffSlukem /*
1456a574a38Slukem  * news_copydisklabel --
1466a574a38Slukem  *	copy disklabel from existing location on disk into bootstrap,
1476a574a38Slukem  *	as the primary bootstrap contains the disklabel.
148d22f5cffSlukem  */
149d22f5cffSlukem static int
news_copydisklabel(ib_params * params,struct bbinfo_params * bbparams,uint8_t * bb)1506a574a38Slukem news_copydisklabel(ib_params *params, struct bbinfo_params *bbparams,
1516a574a38Slukem 	uint8_t *bb)
152d22f5cffSlukem {
1536734af58Stsutsui 	uint8_t	boot00[NEWS_BOOT_BLOCK_BLOCKSIZE];
154d22f5cffSlukem 	ssize_t	rv;
155d22f5cffSlukem 
156d22f5cffSlukem 	assert(params != NULL);
157d22f5cffSlukem 	assert(params->fsfd != -1);
158d22f5cffSlukem 	assert(bbparams != NULL);
159d22f5cffSlukem 	assert(bb != NULL);
160d22f5cffSlukem 
1616a574a38Slukem 		/* Read label sector to copy disklabel from */
162d22f5cffSlukem 	memset(boot00, 0, sizeof(boot00));
163d22f5cffSlukem 	rv = pread(params->fsfd, boot00, sizeof(boot00), 0);
164d22f5cffSlukem 	if (rv == -1) {
165d22f5cffSlukem 		warn("Reading label sector from `%s'", params->filesystem);
166d22f5cffSlukem 		return (0);
167d22f5cffSlukem 	}
168d22f5cffSlukem 		/* Copy disklabel */
169d22f5cffSlukem 	memcpy(bb + NEWS_BOOT_BLOCK_LABELOFFSET,
170d22f5cffSlukem 	    boot00 + NEWS_BOOT_BLOCK_LABELOFFSET,
171d22f5cffSlukem 	    sizeof(boot00) - NEWS_BOOT_BLOCK_LABELOFFSET);
172d22f5cffSlukem 
173d22f5cffSlukem 	return (1);
174d22f5cffSlukem }
175