Home | History | Annotate | Line # | Download | only in libtos
      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