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