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