Home | History | Annotate | Line # | Download | only in raidframe
rf_raid0.h revision 1.1
      1 /*	$NetBSD: rf_raid0.h,v 1.1 1998/11/13 04:20:33 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_raid0.h - header file for RAID Level 0 */
     30 
     31 /*
     32  * :
     33  * Log: rf_raid0.h,v
     34  * Revision 1.15  1996/07/27 23:36:08  jimz
     35  * Solaris port of simulator
     36  *
     37  * Revision 1.14  1996/06/19  22:07:42  jimz
     38  * added parity verify
     39  *
     40  * Revision 1.13  1996/06/10  11:55:47  jimz
     41  * Straightened out some per-array/not-per-array distinctions, fixed
     42  * a couple bugs related to confusion. Added shutdown lists. Removed
     43  * layout shutdown function (now subsumed by shutdown lists).
     44  *
     45  * Revision 1.12  1996/06/07  22:26:27  jimz
     46  * type-ify which_ru (RF_ReconUnitNum_t)
     47  *
     48  * Revision 1.11  1996/06/07  21:33:04  jimz
     49  * begin using consistent types for sector numbers,
     50  * stripe numbers, row+col numbers, recon unit numbers
     51  *
     52  * Revision 1.10  1996/06/03  23:28:26  jimz
     53  * more bugfixes
     54  * check in tree to sync for IPDS runs with current bugfixes
     55  * there still may be a problem with threads in the script test
     56  * getting I/Os stuck- not trivially reproducible (runs ~50 times
     57  * in a row without getting stuck)
     58  *
     59  * Revision 1.9  1996/05/31  22:26:54  jimz
     60  * fix a lot of mapping problems, memory allocation problems
     61  * found some weird lock issues, fixed 'em
     62  * more code cleanup
     63  *
     64  * Revision 1.8  1996/05/27  18:56:37  jimz
     65  * more code cleanup
     66  * better typing
     67  * compiles in all 3 environments
     68  *
     69  * Revision 1.7  1996/05/24  01:59:45  jimz
     70  * another checkpoint in code cleanup for release
     71  * time to sync kernel tree
     72  *
     73  * Revision 1.6  1996/05/18  19:51:34  jimz
     74  * major code cleanup- fix syntax, make some types consistent,
     75  * add prototypes, clean out dead code, et cetera
     76  *
     77  * Revision 1.5  1995/12/06  15:02:36  root
     78  * added copyright info
     79  *
     80  * Revision 1.4  1995/11/17  18:58:33  wvcii
     81  * added prototyping to MapParity
     82  *
     83  * Revision 1.3  1995/11/07  15:21:00  wvcii
     84  * changed RAID0DagSelect prototype
     85  *
     86  * Revision 1.2  1995/06/23  13:39:10  robby
     87  * updeated to prototypes in rf_layout.h
     88  *
     89  */
     90 
     91 #ifndef _RF__RF_RAID0_H_
     92 #define _RF__RF_RAID0_H_
     93 
     94 int  rf_ConfigureRAID0(RF_ShutdownList_t **listp, RF_Raid_t *raidPtr,
     95 	RF_Config_t *cfgPtr);
     96 void rf_MapSectorRAID0(RF_Raid_t *raidPtr, RF_RaidAddr_t raidSector,
     97 	RF_RowCol_t *row, RF_RowCol_t *col, RF_SectorNum_t *diskSector, int remap);
     98 void rf_MapParityRAID0(RF_Raid_t *raidPtr, RF_RaidAddr_t raidSector,
     99 	RF_RowCol_t *row, RF_RowCol_t *col, RF_SectorNum_t *diskSector, int remap);
    100 void rf_IdentifyStripeRAID0(RF_Raid_t *raidPtr, RF_RaidAddr_t addr,
    101 	RF_RowCol_t **diskids, RF_RowCol_t *outRow);
    102 void rf_MapSIDToPSIDRAID0(RF_RaidLayout_t *layoutPtr,
    103 	RF_StripeNum_t stripeID, RF_StripeNum_t *psID,
    104 	RF_ReconUnitNum_t *which_ru);
    105 void rf_RAID0DagSelect(RF_Raid_t *raidPtr, RF_IoType_t type,
    106 	RF_AccessStripeMap_t *asmap, RF_VoidFuncPtr *createFunc);
    107 int rf_VerifyParityRAID0(RF_Raid_t *raidPtr, RF_RaidAddr_t raidAddr,
    108 	RF_PhysDiskAddr_t *parityPDA, int correct_it, RF_RaidAccessFlags_t flags);
    109 
    110 #endif /* !_RF__RF_RAID0_H_ */
    111