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