ahdi.c revision 1.1 1 1.1 leo /* $NetBSD: ahdi.c,v 1.1 2002/02/24 20:51:07 leo Exp $ */
2 1.1 leo
3 1.1 leo /*
4 1.1 leo * Copyright (c) 1996 Leo Weppelman, Waldi Ravens.
5 1.1 leo * All rights reserved.
6 1.1 leo *
7 1.1 leo * Redistribution and use in source and binary forms, with or without
8 1.1 leo * modification, are permitted provided that the following conditions
9 1.1 leo * are met:
10 1.1 leo * 1. Redistributions of source code must retain the above copyright
11 1.1 leo * notice, this list of conditions and the following disclaimer.
12 1.1 leo * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 leo * notice, this list of conditions and the following disclaimer in the
14 1.1 leo * documentation and/or other materials provided with the distribution.
15 1.1 leo * 3. All advertising materials mentioning features or use of this software
16 1.1 leo * must display the following acknowledgement:
17 1.1 leo * This product includes software developed by
18 1.1 leo * Leo Weppelman and Waldi Ravens.
19 1.1 leo * 4. The name of the author may not be used to endorse or promote products
20 1.1 leo * derived from this software without specific prior written permission.
21 1.1 leo *
22 1.1 leo * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23 1.1 leo * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 1.1 leo * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 1.1 leo * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
26 1.1 leo * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27 1.1 leo * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 1.1 leo * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 1.1 leo * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 1.1 leo * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
31 1.1 leo * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 1.1 leo */
33 1.1 leo
34 1.1 leo #include <sys/types.h>
35 1.1 leo #include <stdlib.h>
36 1.1 leo #include <string.h>
37 1.1 leo #include <ctype.h>
38 1.1 leo #include <stdio.h>
39 1.1 leo #include <xhdi.h>
40 1.1 leo #include "libtos.h"
41 1.1 leo #include "diskio.h"
42 1.1 leo #include "ahdilbl.h"
43 1.1 leo
44 1.1 leo u_int
45 1.1 leo ahdi_getparts(dd, ptable, rsec, esec)
46 1.1 leo disk_t *dd;
47 1.1 leo ptable_t *ptable;
48 1.1 leo u_int rsec,
49 1.1 leo esec;
50 1.1 leo {
51 1.1 leo struct ahdi_part *part, *end;
52 1.1 leo struct ahdi_root *root;
53 1.1 leo u_int rv;
54 1.1 leo
55 1.1 leo root = disk_read(dd, rsec, 1);
56 1.1 leo if (!root) {
57 1.1 leo rv = rsec + (rsec == 0);
58 1.1 leo goto done;
59 1.1 leo }
60 1.1 leo
61 1.1 leo if (rsec == AHDI_BBLOCK)
62 1.1 leo end = &root->ar_parts[AHDI_MAXRPD];
63 1.1 leo else end = &root->ar_parts[AHDI_MAXARPD];
64 1.1 leo for (part = root->ar_parts; part < end; ++part) {
65 1.1 leo u_int id = *((u_int32_t *)&part->ap_flg);
66 1.1 leo if (!(id & 0x01000000))
67 1.1 leo continue;
68 1.1 leo if ((id &= 0x00ffffff) == AHDI_PID_XGM) {
69 1.1 leo u_int offs = part->ap_st + esec;
70 1.1 leo rv = ahdi_getparts(dd, ptable, offs,
71 1.1 leo esec == AHDI_BBLOCK ? offs : esec);
72 1.1 leo if (rv)
73 1.1 leo goto done;
74 1.1 leo } else {
75 1.1 leo part_t *p;
76 1.1 leo u_int i = ++ptable->nparts;
77 1.1 leo ptable->parts = xrealloc(ptable->parts,
78 1.1 leo i * sizeof *ptable->parts);
79 1.1 leo p = &ptable->parts[--i];
80 1.1 leo *((u_int32_t *)&p->id) = id << 8;
81 1.1 leo p->start = part->ap_st + rsec;
82 1.1 leo p->end = p->start + part->ap_size - 1;
83 1.1 leo p->rsec = rsec;
84 1.1 leo p->rent = part - root->ar_parts;
85 1.1 leo p->mod = 0;
86 1.1 leo }
87 1.1 leo }
88 1.1 leo rv = 0;
89 1.1 leo done:
90 1.1 leo free(root);
91 1.1 leo return(rv);
92 1.1 leo }
93