Home | History | Annotate | Line # | Download | only in raidframe
rf_netbsd.h revision 1.7
      1  1.7  oster /*	$NetBSD: rf_netbsd.h,v 1.7 2000/02/13 04:53:57 oster 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.7  oster 				 only.  (Not currently used) */
     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.4  oster 
    108  1.4  oster /* XXX this is *not* the place for these... */
    109  1.5  oster int rf_add_hot_spare(RF_Raid_t *raidPtr, RF_SingleComponent_t *sparePtr);
    110  1.5  oster int rf_remove_hot_spare(RF_Raid_t *raidPtr, RF_SingleComponent_t *sparePtr);
    111  1.1  oster 
    112  1.1  oster 
    113  1.1  oster struct raidcinfo {
    114  1.4  oster 	struct vnode *ci_vp;	/* component device's vnode */
    115  1.4  oster 	dev_t   ci_dev;		/* component device's dev_t */
    116  1.4  oster 	RF_ComponentLabel_t ci_label; /* components RAIDframe label */
    117  1.1  oster #if 0
    118  1.3  oster 	size_t  ci_size;	/* size */
    119  1.3  oster 	char   *ci_path;	/* path to component */
    120  1.3  oster 	size_t  ci_pathlen;	/* length of component path */
    121  1.1  oster #endif
    122  1.1  oster };
    123  1.4  oster 
    124  1.7  oster 
    125  1.7  oster 
    126  1.7  oster /* XXX probably belongs in a different .h file. */
    127  1.7  oster typedef struct RF_AutoConfig_s {
    128  1.7  oster 	char devname[56];
    129  1.7  oster 	dev_t dev;
    130  1.7  oster 	struct vnode *vp;
    131  1.7  oster 	RF_ComponentLabel_t *clabel;
    132  1.7  oster 	struct RF_AutoConfig_s *next;
    133  1.7  oster 	/* 	LIST_ENTRY(RF_AutoConfig_s) component_list; */
    134  1.7  oster } RF_AutoConfig_t;
    135  1.7  oster 
    136  1.7  oster typedef struct RF_ConfigSet_s {
    137  1.7  oster 	struct RF_AutoConfig_s *ac;
    138  1.7  oster 	struct RF_ConfigSet_s *next;
    139  1.7  oster } RF_ConfigSet_t;
    140  1.4  oster 
    141  1.4  oster #endif /* _KERNEL */
    142  1.4  oster #endif /* _RF__RF_NETBSDSTUFF_H_ */
    143