devopen.c revision 1.12 1 1.12 rin /* $NetBSD: devopen.c,v 1.12 2024/06/29 13:46:40 rin Exp $ */
2 1.1 perry
3 1.1 perry /*
4 1.1 perry * Copyright (c) 1996
5 1.1 perry * Matthias Drochner. All rights reserved.
6 1.1 perry *
7 1.1 perry * Redistribution and use in source and binary forms, with or without
8 1.1 perry * modification, are permitted provided that the following conditions
9 1.1 perry * are met:
10 1.1 perry * 1. Redistributions of source code must retain the above copyright
11 1.1 perry * notice, this list of conditions and the following disclaimer.
12 1.1 perry * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 perry * notice, this list of conditions and the following disclaimer in the
14 1.1 perry * documentation and/or other materials provided with the distribution.
15 1.1 perry *
16 1.1 perry * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 1.1 perry * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.1 perry * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 1.1 perry * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.1 perry * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 1.1 perry * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 1.1 perry * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 1.1 perry * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 1.1 perry * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 1.1 perry * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 1.1 perry */
27 1.1 perry
28 1.1 perry
29 1.1 perry #include <lib/libsa/stand.h>
30 1.3 drochner #include <lib/libkern/libkern.h>
31 1.1 perry #include <lib/libsa/ufs.h>
32 1.1 perry
33 1.1 perry #include <libi386.h>
34 1.1 perry #include <biosdisk.h>
35 1.3 drochner #include <bootinfo.h>
36 1.1 perry
37 1.12 rin #include "dosfile.h"
38 1.12 rin
39 1.1 perry struct devsw devsw[] = {
40 1.8 junyoung {"disk", biosdisk_strategy, biosdisk_open, biosdisk_close, biosdisk_ioctl},
41 1.1 perry };
42 1.2 thorpej int ndevs = sizeof(devsw) / sizeof(struct devsw);
43 1.1 perry
44 1.1 perry static struct fs_ops dosfs = {
45 1.2 thorpej dos_open, dos_close, dos_read, dos_write, dos_seek, dos_stat
46 1.1 perry };
47 1.1 perry static struct fs_ops ufsfs = {
48 1.2 thorpej ufs_open, ufs_close, ufs_read, ufs_write, ufs_seek, ufs_stat
49 1.1 perry };
50 1.1 perry
51 1.2 thorpej struct fs_ops file_system[] = {
52 1.2 thorpej {0},
53 1.1 perry };
54 1.2 thorpej int nfsys = 1;
55 1.1 perry
56 1.1 perry static struct {
57 1.2 thorpej char *name;
58 1.2 thorpej int biosdev;
59 1.2 thorpej } biosdevtab[] = {
60 1.2 thorpej {
61 1.2 thorpej "fd", 0
62 1.2 thorpej },
63 1.2 thorpej {
64 1.2 thorpej "wd", 0x80
65 1.2 thorpej },
66 1.2 thorpej {
67 1.2 thorpej "sd", 0x80
68 1.2 thorpej },
69 1.2 thorpej {
70 1.2 thorpej "hd", 0x80
71 1.2 thorpej }
72 1.1 perry };
73 1.1 perry #define NUMBIOSDEVS (sizeof(biosdevtab) / sizeof(biosdevtab[0]))
74 1.4 drochner
75 1.9 dyoung static int dev2bios(char *, unsigned int, int *);
76 1.1 perry
77 1.1 perry static int
78 1.11 dsl dev2bios(char *devname, unsigned int unit, int *biosdev)
79 1.1 perry {
80 1.6 fvdl unsigned i;
81 1.1 perry
82 1.2 thorpej for (i = 0; i < NUMBIOSDEVS; i++)
83 1.2 thorpej if (!strcmp(devname, biosdevtab[i].name)) {
84 1.2 thorpej *biosdev = biosdevtab[i].biosdev + unit;
85 1.2 thorpej if (unit >= 4) /* ??? */
86 1.2 thorpej return (EUNIT);
87 1.2 thorpej return (0);
88 1.2 thorpej }
89 1.2 thorpej return (ENXIO);
90 1.1 perry }
91 1.1 perry
92 1.3 drochner struct btinfo_bootpath bibp;
93 1.3 drochner
94 1.1 perry int
95 1.11 dsl devopen(struct open_file *f, const char *fname, char **file)
96 1.1 perry {
97 1.2 thorpej char *devname;
98 1.2 thorpej char *fsmode;
99 1.9 dyoung int unit, partition;
100 1.2 thorpej int biosdev;
101 1.2 thorpej int error;
102 1.2 thorpej struct devsw *dp;
103 1.2 thorpej
104 1.2 thorpej if ((error = parsebootfile(fname, &fsmode, &devname, &unit,
105 1.2 thorpej &partition, (const char **) file)))
106 1.2 thorpej return (error);
107 1.2 thorpej
108 1.2 thorpej if (!strcmp(fsmode, "dos")) {
109 1.2 thorpej file_system[0] = dosfs; /* structure assignment! */
110 1.2 thorpej f->f_flags |= F_NODEV; /* handled by DOS */
111 1.2 thorpej return (0);
112 1.2 thorpej } else if (!strcmp(fsmode, "ufs")) {
113 1.2 thorpej if ((error = dev2bios(devname, unit, &biosdev)))
114 1.2 thorpej return (error);
115 1.2 thorpej file_system[0] = ufsfs; /* structure assignment! */
116 1.2 thorpej dp = &devsw[0]; /* must be biosdisk */
117 1.2 thorpej f->f_dev = dp;
118 1.3 drochner
119 1.3 drochner strncpy(bibp.bootpath, *file, sizeof(bibp.bootpath));
120 1.3 drochner BI_ADD(&bibp, BTINFO_BOOTPATH, sizeof(bibp));
121 1.3 drochner
122 1.8 junyoung return (biosdisk_open(f, biosdev, partition));
123 1.2 thorpej } else {
124 1.2 thorpej printf("no file system\n");
125 1.2 thorpej return (ENXIO);
126 1.2 thorpej }
127 1.2 thorpej /* NOTREACHED */
128 1.1 perry }
129