2 * Mach Operating System
3 * Copyright (c) 1992, 1991 Carnegie Mellon University
6 * Permission to use, copy, modify and distribute this software and its
7 * documentation is hereby granted, provided that both the copyright
8 * notice and this permission notice appear in all copies of the
9 * software, derivative works or modified versions, and any portions
10 * thereof, and that both notices appear in supporting documentation.
12 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
13 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
14 * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
16 * Carnegie Mellon requests users of this software to return to
18 * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
19 * School of Computer Science
20 * Carnegie Mellon University
21 * Pittsburgh PA 15213-3890
23 * any improvements or extensions that they make and grant Carnegie Mellon
24 * the rights to redistribute these changes.
26 * from: Mach, Revision 2.2 92/04/04 11:35:49 rpd
29 * Ported to PC-9801 by Yoshio Kimura
34 * If there is no 386BSD partition, initialize the label sector with
35 * LABELSECTOR instead of with garbage.
38 * Fixed reading of bad sector table. It is at the end of the 'c'
39 * partition, which is not always at the end of the disk.
41 * $FreeBSD: src/sys/boot/pc98/boot2/disk.c,v 1.10 2003/09/08 09:11:20 obrien Exp $
42 * $DragonFly: src/sys/boot/pc98/boot2/Attic/disk.c,v 1.3 2003/11/10 06:08:38 dillon Exp $
46 #include <sys/disklabel.h>
47 #include <sys/diskpc98.h>
48 #include <machine/bootinfo.h>
50 #define BIOS_DEV_FLOPPY 0x0
51 #define BIOS_DEV_WIN 0x80
54 #define SPT(di) ((di)&0xff)
55 #define HEADS(di) (((di)>>8)&0xff)
62 int dosdev, unit, slice, part, maj, boff;
64 /*#define EMBEDDED_DISKLABEL 1*/
66 /* Read ahead buffer large enough for one track on a 1440K floppy. For
67 * reading from floppies, the bootstrap has to be loaded on a 64K boundary
68 * to ensure that this buffer doesn't cross a 64K DMA boundary.
71 static char ra_buf[RA_SECTORS * BPS];
76 static char *Bread(int dosdev, int sector);
81 struct pc98_partition *dptr;
84 int i, sector = 0, di, dosdev_copy;
87 di = get_diskinfo(dosdev_copy);
88 spc = (spt = SPT(di)) * HEADS(di);
91 if ((dosdev_copy & 0xf0) == 0x90)
94 part = (spt == 15 ? 0 : 1);
98 #ifdef EMBEDDED_DISKLABEL
100 #else /* EMBEDDED_DISKLABEL */
102 p = Bread(dosdev_copy, 1);
103 dptr = (struct pc98_partition *)p;
104 slice = WHOLE_DISK_SLICE;
105 for (i = 0; i < NDOSPART; i++, dptr++)
106 if (dptr->dp_mid == DOSPTYP_386BSD) {
107 slice = BASE_SLICE + i;
108 sector = dptr->dp_scyl * spc;
111 p = Bread(dosdev, sector + LABELSECTOR);
112 dl=((struct disklabel *)p);
113 disklabel = *dl; /* structure copy (maybe useful later)*/
115 p = Bread(dosdev_copy, 0);
116 dptr = (struct dos_partition *)(p+DOSPARTOFF);
117 slice = WHOLE_DISK_SLICE;
118 for (i = 0; i < NDOSPART; i++, dptr++)
119 if (dptr->dp_typ == DOSPTYP_386BSD) {
120 slice = BASE_SLICE + i;
121 sector = dptr->dp_start;
124 p = Bread(dosdev_copy, sector + LABELSECTOR);
125 dl=((struct disklabel *)p);
126 disklabel = *dl; /* structure copy (maybe useful later)*/
128 #endif /* EMBEDDED_DISKLABEL */
129 if (dl->d_magic != DISKMAGIC) {
130 printf("bad disklabel\n");
133 /* This little trick is for OnTrack DiskManager disks */
134 boff = dl->d_partitions[part].p_offset -
135 dl->d_partitions[2].p_offset + sector;
138 bsize = dl->d_partitions[part].p_size;
140 printf("empty partition\n");
153 * Be aware that cnt is rounded up to N*BPS
156 devread(char *iodest, int sector, int cnt)
162 for (offset = 0; offset < cnt; offset += BPS)
164 dosdev_copy = dosdev;
165 p = Bread(dosdev_copy, sector++);
166 bcopy(p, iodest+offset, BPS);
172 Bread(int dosdev, int sector)
174 if (dosdev != ra_dev || sector < ra_first || sector >= ra_end)
176 int cyl, head, sec, nsec;
181 printf("Error: C:%d > 1023 (BIOS limit)\n", cyl);
182 for(;;); /* loop forever */
185 head = (sector % spc) / spt;
188 if (nsec > RA_SECTORS)
191 if (biosread(dosdev, cyl, head, sec, nsec, ra_buf) != 0)
195 while (biosread(dosdev, cyl, head, sec, nsec, ra_buf) != 0) {
196 printf("Error: D:0x%x C:%d H:%d S:%d\n",
197 dosdev, cyl, head, sec);
203 ra_end = sector + nsec;
205 return (ra_buf + (sector - ra_first) * BPS);