devopen.c revision 1.8 1 1.8 junyoung /* $NetBSD: devopen.c,v 1.8 2005/06/22 20:36:17 junyoung 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.1 perry #include <dosfile.h>
36 1.3 drochner #include <bootinfo.h>
37 1.1 perry
38 1.1 perry struct devsw devsw[] = {
39 1.8 junyoung {"disk", biosdisk_strategy, biosdisk_open, biosdisk_close, biosdisk_ioctl},
40 1.1 perry };
41 1.2 thorpej int ndevs = sizeof(devsw) / sizeof(struct devsw);
42 1.1 perry
43 1.1 perry static struct fs_ops dosfs = {
44 1.2 thorpej dos_open, dos_close, dos_read, dos_write, dos_seek, dos_stat
45 1.1 perry };
46 1.1 perry static struct fs_ops ufsfs = {
47 1.2 thorpej ufs_open, ufs_close, ufs_read, ufs_write, ufs_seek, ufs_stat
48 1.1 perry };
49 1.1 perry
50 1.2 thorpej struct fs_ops file_system[] = {
51 1.2 thorpej {0},
52 1.1 perry };
53 1.2 thorpej int nfsys = 1;
54 1.1 perry
55 1.1 perry static struct {
56 1.2 thorpej char *name;
57 1.2 thorpej int biosdev;
58 1.2 thorpej } biosdevtab[] = {
59 1.2 thorpej {
60 1.2 thorpej "fd", 0
61 1.2 thorpej },
62 1.2 thorpej {
63 1.2 thorpej "wd", 0x80
64 1.2 thorpej },
65 1.2 thorpej {
66 1.2 thorpej "sd", 0x80
67 1.2 thorpej },
68 1.2 thorpej {
69 1.2 thorpej "hd", 0x80
70 1.2 thorpej }
71 1.1 perry };
72 1.1 perry #define NUMBIOSDEVS (sizeof(biosdevtab) / sizeof(biosdevtab[0]))
73 1.4 drochner
74 1.4 drochner static int dev2bios __P((char *, unsigned int, int *));
75 1.1 perry
76 1.1 perry static int
77 1.1 perry dev2bios(devname, unit, biosdev)
78 1.2 thorpej char *devname;
79 1.2 thorpej unsigned int unit;
80 1.2 thorpej int *biosdev;
81 1.1 perry {
82 1.6 fvdl unsigned i;
83 1.1 perry
84 1.2 thorpej for (i = 0; i < NUMBIOSDEVS; i++)
85 1.2 thorpej if (!strcmp(devname, biosdevtab[i].name)) {
86 1.2 thorpej *biosdev = biosdevtab[i].biosdev + unit;
87 1.2 thorpej if (unit >= 4) /* ??? */
88 1.2 thorpej return (EUNIT);
89 1.2 thorpej return (0);
90 1.2 thorpej }
91 1.2 thorpej return (ENXIO);
92 1.1 perry }
93 1.1 perry
94 1.3 drochner struct btinfo_bootpath bibp;
95 1.3 drochner
96 1.1 perry int
97 1.1 perry devopen(f, fname, file)
98 1.2 thorpej struct open_file *f;
99 1.2 thorpej const char *fname;
100 1.2 thorpej char **file;
101 1.1 perry {
102 1.2 thorpej char *devname;
103 1.2 thorpej char *fsmode;
104 1.2 thorpej unsigned int unit, partition;
105 1.2 thorpej int biosdev;
106 1.2 thorpej int error;
107 1.2 thorpej struct devsw *dp;
108 1.2 thorpej
109 1.2 thorpej if ((error = parsebootfile(fname, &fsmode, &devname, &unit,
110 1.2 thorpej &partition, (const char **) file)))
111 1.2 thorpej return (error);
112 1.2 thorpej
113 1.2 thorpej if (!strcmp(fsmode, "dos")) {
114 1.2 thorpej file_system[0] = dosfs; /* structure assignment! */
115 1.2 thorpej f->f_flags |= F_NODEV; /* handled by DOS */
116 1.2 thorpej return (0);
117 1.2 thorpej } else if (!strcmp(fsmode, "ufs")) {
118 1.2 thorpej if ((error = dev2bios(devname, unit, &biosdev)))
119 1.2 thorpej return (error);
120 1.2 thorpej file_system[0] = ufsfs; /* structure assignment! */
121 1.2 thorpej dp = &devsw[0]; /* must be biosdisk */
122 1.2 thorpej f->f_dev = dp;
123 1.3 drochner
124 1.3 drochner strncpy(bibp.bootpath, *file, sizeof(bibp.bootpath));
125 1.3 drochner BI_ADD(&bibp, BTINFO_BOOTPATH, sizeof(bibp));
126 1.3 drochner
127 1.8 junyoung return (biosdisk_open(f, biosdev, partition));
128 1.2 thorpej } else {
129 1.2 thorpej printf("no file system\n");
130 1.2 thorpej return (ENXIO);
131 1.2 thorpej }
132 1.2 thorpej /* NOTREACHED */
133 1.1 perry }
134