Home | History | Annotate | Line # | Download | only in raidframe
rf_netbsd.h revision 1.11.2.1
      1  1.11.2.1  minoura /*	$NetBSD: rf_netbsd.h,v 1.11.2.1 2000/06/22 17:07:55 minoura Exp $	*/
      2       1.1    oster 
      3       1.1    oster /*-
      4       1.1    oster  * Copyright (c) 1996, 1997, 1998 The NetBSD Foundation, Inc.
      5       1.1    oster  * All rights reserved.
      6       1.1    oster  *
      7       1.1    oster  * This code is derived from software contributed to The NetBSD Foundation
      8       1.6       ad  * by Greg Oster; Jason R. Thorpe.
      9       1.1    oster  *
     10       1.1    oster  * Redistribution and use in source and binary forms, with or without
     11       1.1    oster  * modification, are permitted provided that the following conditions
     12       1.1    oster  * are met:
     13       1.1    oster  * 1. Redistributions of source code must retain the above copyright
     14       1.1    oster  *    notice, this list of conditions and the following disclaimer.
     15       1.1    oster  * 2. Redistributions in binary form must reproduce the above copyright
     16       1.1    oster  *    notice, this list of conditions and the following disclaimer in the
     17       1.1    oster  *    documentation and/or other materials provided with the distribution.
     18       1.1    oster  * 3. All advertising materials mentioning features or use of this software
     19       1.1    oster  *    must display the following acknowledgement:
     20       1.1    oster  *        This product includes software developed by the NetBSD
     21       1.1    oster  *        Foundation, Inc. and its contributors.
     22       1.1    oster  * 4. Neither the name of The NetBSD Foundation nor the names of its
     23       1.1    oster  *    contributors may be used to endorse or promote products derived
     24       1.1    oster  *    from this software without specific prior written permission.
     25       1.1    oster  *
     26       1.1    oster  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     27       1.1    oster  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     28       1.1    oster  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     29       1.1    oster  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     30       1.1    oster  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     31       1.1    oster  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     32       1.1    oster  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     33       1.1    oster  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     34       1.1    oster  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     35       1.1    oster  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     36       1.1    oster  * POSSIBILITY OF SUCH DAMAGE.
     37       1.1    oster  */
     38       1.1    oster 
     39       1.1    oster #ifndef _RF__RF_NETBSDSTUFF_H_
     40       1.1    oster #define _RF__RF_NETBSDSTUFF_H_
     41       1.1    oster 
     42       1.2    oster #ifdef _KERNEL
     43       1.1    oster #include <sys/fcntl.h>
     44       1.1    oster #include <sys/systm.h>
     45       1.1    oster #include <sys/namei.h>
     46       1.1    oster #include <sys/vnode.h>
     47       1.4    oster #endif /* _KERNEL */
     48       1.1    oster 
     49       1.4    oster /* The per-component label information that the user can set */
     50       1.4    oster typedef struct RF_ComponentInfo_s {
     51       1.4    oster 	int row;              /* the row number of this component */
     52       1.4    oster 	int column;           /* the column number of this component */
     53       1.4    oster 	int serial_number;    /* a user-specified serial number for this
     54       1.4    oster 				 RAID set */
     55       1.4    oster } RF_ComponentInfo_t;
     56       1.4    oster 
     57       1.4    oster /* The per-component label information */
     58       1.4    oster typedef struct RF_ComponentLabel_s {
     59       1.4    oster 	int version;          /* The version of this label. */
     60       1.4    oster 	int serial_number;    /* a user-specified serial number for this
     61       1.4    oster 				 RAID set */
     62       1.4    oster 	int mod_counter;      /* modification counter.  Changed (usually
     63       1.4    oster 				 by incrementing) every time the label
     64       1.4    oster 				 is changed */
     65       1.4    oster 	int row;              /* the row number of this component */
     66       1.4    oster 	int column;           /* the column number of this component */
     67       1.4    oster 	int num_rows;         /* number of rows in this RAID set */
     68       1.4    oster 	int num_columns;      /* number of columns in this RAID set */
     69       1.4    oster 	int clean;            /* 1 when clean, 0 when dirty */
     70       1.4    oster 	int status;           /* rf_ds_optimal, rf_ds_dist_spared, whatever. */
     71       1.7    oster 	/* stuff that will be in version 2 of the label */
     72       1.7    oster 	int sectPerSU;        /* Sectors per Stripe Unit */
     73       1.7    oster 	int SUsPerPU;         /* Stripe Units per Parity Units */
     74       1.7    oster 	int SUsPerRU;         /* Stripe Units per Reconstruction Units */
     75       1.7    oster 	int parityConfig;     /* '0' == RAID0, '1' == RAID1, etc. */
     76       1.7    oster 	int maxOutstanding;   /* maxOutstanding disk requests */
     77       1.7    oster 	int blockSize;        /* size of component block.
     78       1.7    oster 				 (disklabel->d_secsize) */
     79       1.7    oster 	int numBlocks;        /* number of blocks on this component.  May
     80       1.7    oster 			         be smaller than the partition size. */
     81       1.7    oster 	int partitionSize;    /* number of blocks on this *partition*.
     82       1.7    oster 				 Must exactly match the partition size
     83       1.7    oster 				 from the disklabel. */
     84       1.7    oster 	int future_use[33];   /* Future expansion */
     85       1.7    oster 	int autoconfigure;    /* automatically configure this RAID set.
     86       1.7    oster 				 0 == no, 1 == yes */
     87       1.7    oster 	int root_partition;   /* Use this set as /
     88       1.7    oster 				 0 == no, 1 == yes*/
     89       1.7    oster 	int last_unit;        /* last unit number (e.g. 0 for /dev/raid0)
     90       1.7    oster 				 of this component.  Used for autoconfigure
     91       1.9    oster 				 only. */
     92       1.7    oster 	int config_order;     /* 0 .. n.  The order in which the component
     93       1.7    oster 				 should be auto-configured.  E.g. 0 is will
     94       1.7    oster 				 done first, (and would become raid0).
     95       1.7    oster 				 This may be in conflict with last_unit!!?! */
     96       1.7    oster 	                      /* Not currently used. */
     97       1.7    oster 	int future_use2[44];  /* More future expansion */
     98       1.4    oster } RF_ComponentLabel_t;
     99       1.4    oster 
    100       1.5    oster typedef struct RF_SingleComponent_s {
    101       1.5    oster 	int row;
    102       1.5    oster 	int column;
    103       1.5    oster 	char component_name[50]; /* name of the component */
    104       1.5    oster } RF_SingleComponent_t;
    105       1.4    oster 
    106       1.4    oster #ifdef _KERNEL
    107       1.1    oster 
    108       1.1    oster struct raidcinfo {
    109       1.4    oster 	struct vnode *ci_vp;	/* component device's vnode */
    110       1.4    oster 	dev_t   ci_dev;		/* component device's dev_t */
    111       1.4    oster 	RF_ComponentLabel_t ci_label; /* components RAIDframe label */
    112       1.1    oster #if 0
    113       1.3    oster 	size_t  ci_size;	/* size */
    114       1.3    oster 	char   *ci_path;	/* path to component */
    115       1.3    oster 	size_t  ci_pathlen;	/* length of component path */
    116       1.1    oster #endif
    117       1.1    oster };
    118       1.4    oster 
    119       1.7    oster 
    120       1.7    oster 
    121       1.7    oster /* XXX probably belongs in a different .h file. */
    122       1.7    oster typedef struct RF_AutoConfig_s {
    123       1.8    oster 	char devname[56];       /* the name of this component */
    124  1.11.2.1  minoura 	int flag;               /* a general-purpose flag */
    125       1.8    oster 	dev_t dev;              /* the device for this component */
    126       1.8    oster 	struct vnode *vp;       /* Mr. Vnode Pointer */
    127       1.8    oster 	RF_ComponentLabel_t *clabel;  /* the label */
    128       1.8    oster 	struct RF_AutoConfig_s *next; /* the next autoconfig structure
    129       1.8    oster 				         in this set. */
    130       1.7    oster } RF_AutoConfig_t;
    131       1.7    oster 
    132       1.7    oster typedef struct RF_ConfigSet_s {
    133       1.8    oster 	struct RF_AutoConfig_s *ac; /* all of the autoconfig structures for
    134       1.8    oster 				       this config set. */
    135       1.8    oster 	int rootable;               /* Set to 1 if this set can be root */
    136       1.7    oster 	struct RF_ConfigSet_s *next;
    137       1.7    oster } RF_ConfigSet_t;
    138       1.4    oster 
    139       1.4    oster #endif /* _KERNEL */
    140       1.4    oster #endif /* _RF__RF_NETBSDSTUFF_H_ */
    141