NetBSD/sys/dev/raidframe/rf_archs.h

92 lines
3.0 KiB
C

/* $NetBSD: rf_archs.h,v 1.5 1999/08/03 22:07:39 oster Exp $ */
/*
* Copyright (c) 1995 Carnegie-Mellon University.
* All rights reserved.
*
* Author: Mark Holland
*
* Permission to use, copy, modify and distribute this software and
* its documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie the
* rights to redistribute these changes.
*/
/* rf_archs.h -- defines for which architectures you want to
* include is some particular build of raidframe. Unfortunately,
* it's difficult to exclude declustering, P+Q, and distributed
* sparing because the code is intermixed with RAID5 code. This
* should be fixed.
*
* this is really intended only for use in the kernel, where I
* am worried about the size of the object module. At user level and
* in the simulator, I don't really care that much, so all the
* architectures can be compiled together. Note that by itself, turning
* off these defines does not affect the size of the executable; you
* have to edit the makefile for that.
*
* comment out any line below to eliminate that architecture.
* the list below includes all the modules that can be compiled
* out.
*
*/
#ifndef _RF__RF_ARCHS_H_
#define _RF__RF_ARCHS_H_
/*
* Khalil's performance-displaying demo stuff.
* Relies on CMU meter tools.
*/
#define RF_INCLUDE_EVENODD 1
#define RF_INCLUDE_RAID5_RS 1
#define RF_INCLUDE_PARITYLOGGING 1
#define RF_INCLUDE_CHAINDECLUSTER 1
#define RF_INCLUDE_INTERDECLUSTER 1
#define RF_INCLUDE_RAID0 1
#define RF_INCLUDE_RAID1 1
#define RF_INCLUDE_RAID4 1
#define RF_INCLUDE_RAID5 1
#define RF_INCLUDE_RAID6 0
#define RF_INCLUDE_DECL_PQ 0
#define RF_MEMORY_REDZONES 0
#define RF_RECON_STATS 1
#define RF_INCLUDE_QUEUE_RANDOM 0
#define RF_KEEP_DISKSTATS 1
/* These two symbols enable nonstandard forms of error recovery.
* These modes are only valid for performance measurements and
* data corruption will occur if an error occurs when either
* forward or backward error recovery are enabled. In general
* both of the following two definitions should be commented
* out--this forces RAIDframe to use roll-away error recovery
* which does guarantee proper error recovery without data corruption
*/
/* #define RF_FORWARD 1 */
/* #define RF_BACKWARD 1 */
#include "rf_options.h"
#endif /* !_RF__RF_ARCHS_H_ */