rf_archs.h revision 1.5 1 /* $NetBSD: rf_archs.h,v 1.5 1999/08/03 22:07:39 oster Exp $ */
2 /*
3 * Copyright (c) 1995 Carnegie-Mellon University.
4 * All rights reserved.
5 *
6 * Author: Mark Holland
7 *
8 * Permission to use, copy, modify and distribute this software and
9 * its documentation is hereby granted, provided that both the copyright
10 * notice and this permission notice appear in all copies of the
11 * software, derivative works or modified versions, and any portions
12 * thereof, and that both notices appear in supporting documentation.
13 *
14 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
15 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
16 * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
17 *
18 * Carnegie Mellon requests users of this software to return to
19 *
20 * Software Distribution Coordinator or Software.Distribution (at) CS.CMU.EDU
21 * School of Computer Science
22 * Carnegie Mellon University
23 * Pittsburgh PA 15213-3890
24 *
25 * any improvements or extensions that they make and grant Carnegie the
26 * rights to redistribute these changes.
27 */
28
29 /* rf_archs.h -- defines for which architectures you want to
30 * include is some particular build of raidframe. Unfortunately,
31 * it's difficult to exclude declustering, P+Q, and distributed
32 * sparing because the code is intermixed with RAID5 code. This
33 * should be fixed.
34 *
35 * this is really intended only for use in the kernel, where I
36 * am worried about the size of the object module. At user level and
37 * in the simulator, I don't really care that much, so all the
38 * architectures can be compiled together. Note that by itself, turning
39 * off these defines does not affect the size of the executable; you
40 * have to edit the makefile for that.
41 *
42 * comment out any line below to eliminate that architecture.
43 * the list below includes all the modules that can be compiled
44 * out.
45 *
46 */
47
48 #ifndef _RF__RF_ARCHS_H_
49 #define _RF__RF_ARCHS_H_
50
51 /*
52 * Khalil's performance-displaying demo stuff.
53 * Relies on CMU meter tools.
54 */
55
56 #define RF_INCLUDE_EVENODD 1
57
58 #define RF_INCLUDE_RAID5_RS 1
59 #define RF_INCLUDE_PARITYLOGGING 1
60
61 #define RF_INCLUDE_CHAINDECLUSTER 1
62 #define RF_INCLUDE_INTERDECLUSTER 1
63
64 #define RF_INCLUDE_RAID0 1
65 #define RF_INCLUDE_RAID1 1
66 #define RF_INCLUDE_RAID4 1
67 #define RF_INCLUDE_RAID5 1
68 #define RF_INCLUDE_RAID6 0
69 #define RF_INCLUDE_DECL_PQ 0
70
71 #define RF_MEMORY_REDZONES 0
72 #define RF_RECON_STATS 1
73
74 #define RF_INCLUDE_QUEUE_RANDOM 0
75
76 #define RF_KEEP_DISKSTATS 1
77
78 /* These two symbols enable nonstandard forms of error recovery.
79 * These modes are only valid for performance measurements and
80 * data corruption will occur if an error occurs when either
81 * forward or backward error recovery are enabled. In general
82 * both of the following two definitions should be commented
83 * out--this forces RAIDframe to use roll-away error recovery
84 * which does guarantee proper error recovery without data corruption
85 */
86 /* #define RF_FORWARD 1 */
87 /* #define RF_BACKWARD 1 */
88
89 #include "rf_options.h"
90
91 #endif /* !_RF__RF_ARCHS_H_ */
92