diff options
Diffstat (limited to 'sys/dev/raidframe/rf_reconstruct.c')
-rw-r--r-- | sys/dev/raidframe/rf_reconstruct.c | 218 |
1 files changed, 99 insertions, 119 deletions
diff --git a/sys/dev/raidframe/rf_reconstruct.c b/sys/dev/raidframe/rf_reconstruct.c index 75fd5d75a03..a1263674809 100644 --- a/sys/dev/raidframe/rf_reconstruct.c +++ b/sys/dev/raidframe/rf_reconstruct.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rf_reconstruct.c,v 1.3 1999/07/30 14:45:33 peter Exp $ */ +/* $OpenBSD: rf_reconstruct.c,v 1.4 1999/08/03 13:56:37 peter Exp $ */ /* $NetBSD: rf_reconstruct.c,v 1.5 1999/03/02 03:18:49 oster Exp $ */ /* * Copyright (c) 1995 Carnegie-Mellon University. @@ -68,6 +68,12 @@ #include "rf_kintf.h" +#if defined(__GNUC__) && !defined(DDB) +#define INTEGRATE static __inline__ +#else +#define INTEGRATE +#endif + /* setting these to -1 causes them to be set to their default values if not set by debug options */ #define Dprintf(s) if (rf_reconDebug) rf_debug_printf(s,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL) @@ -96,41 +102,26 @@ static RF_FreeList_t *rf_recond_freelist; #define RF_MAX_FREE_RECOND 4 #define RF_RECOND_INC 1 -static RF_RaidReconDesc_t * -AllocRaidReconDesc(RF_Raid_t * raidPtr, - RF_RowCol_t row, RF_RowCol_t col, RF_RaidDisk_t * spareDiskPtr, - int numDisksDone, RF_RowCol_t srow, RF_RowCol_t scol); -static void FreeReconDesc(RF_RaidReconDesc_t * reconDesc); -static int -ProcessReconEvent(RF_Raid_t * raidPtr, RF_RowCol_t frow, - RF_ReconEvent_t * event); -static int -IssueNextReadRequest(RF_Raid_t * raidPtr, RF_RowCol_t row, - RF_RowCol_t col); -static int TryToRead(RF_Raid_t * raidPtr, RF_RowCol_t row, RF_RowCol_t col); -static int -ComputePSDiskOffsets(RF_Raid_t * raidPtr, RF_StripeNum_t psid, - RF_RowCol_t row, RF_RowCol_t col, RF_SectorNum_t * outDiskOffset, - RF_SectorNum_t * outFailedDiskSectorOffset, RF_RowCol_t * spRow, - RF_RowCol_t * spCol, RF_SectorNum_t * spOffset); -static int IssueNextWriteRequest(RF_Raid_t * raidPtr, RF_RowCol_t row); -static int ReconReadDoneProc(void *arg, int status); -static int ReconWriteDoneProc(void *arg, int status); -static void -CheckForNewMinHeadSep(RF_Raid_t * raidPtr, RF_RowCol_t row, - RF_HeadSepLimit_t hsCtr); -static int -CheckHeadSeparation(RF_Raid_t * raidPtr, RF_PerDiskReconCtrl_t * ctrl, - RF_RowCol_t row, RF_RowCol_t col, RF_HeadSepLimit_t hsCtr, - RF_ReconUnitNum_t which_ru); -static int -CheckForcedOrBlockedReconstruction(RF_Raid_t * raidPtr, - RF_ReconParityStripeStatus_t * pssPtr, RF_PerDiskReconCtrl_t * ctrl, - RF_RowCol_t row, RF_RowCol_t col, RF_StripeNum_t psid, - RF_ReconUnitNum_t which_ru); -static void ForceReconReadDoneProc(void *arg, int status); - -static void rf_ShutdownReconstruction(void *); +RF_RaidReconDesc_t *rf_AllocRaidReconDesc __P((RF_Raid_t *, RF_RowCol_t, RF_RowCol_t, RF_RaidDisk_t *, int, RF_RowCol_t, RF_RowCol_t)); +int rf_ProcessReconEvent __P((RF_Raid_t *, RF_RowCol_t, RF_ReconEvent_t *)); +int rf_IssueNextReadRequest __P((RF_Raid_t *, RF_RowCol_t, RF_RowCol_t)); +int rf_TryToRead __P((RF_Raid_t *, RF_RowCol_t, RF_RowCol_t)); +int rf_ComputePSDiskOffsets __P((RF_Raid_t *, RF_StripeNum_t, RF_RowCol_t, RF_RowCol_t, RF_SectorNum_t *, RF_SectorNum_t *, RF_RowCol_t *, RF_RowCol_t *, RF_SectorNum_t *)); +int rf_ReconReadDoneProc(void *, int); +int rf_ReconWriteDoneProc(void *, int); +void rf_CheckForNewMinHeadSep(RF_Raid_t *, RF_RowCol_t, RF_HeadSepLimit_t); +int rf_CheckHeadSeparation(RF_Raid_t *, RF_PerDiskReconCtrl_t *, RF_RowCol_t, RF_RowCol_t, RF_HeadSepLimit_t, RF_ReconUnitNum_t); +void rf_ForceReconReadDoneProc __P((void *, int)); +void rf_ShutdownReconstruction __P((void *)); + +/* + * these functions are inlined on gcc. If they are used more than + * once, it is strongly advised to un-line them + */ +INTEGRATE void rf_FreeReconDesc __P((RF_RaidReconDesc_t *)); +INTEGRATE int rf_IssueNextWriteRequest __P((RF_Raid_t *, RF_RowCol_t)); +INTEGRATE int rf_CheckForcedOrBlockedReconstruction __P((RF_Raid_t *, RF_ReconParityStripeStatus_t *, RF_PerDiskReconCtrl_t *, RF_RowCol_t, RF_RowCol_t, RF_StripeNum_t, RF_ReconUnitNum_t)); +INTEGRATE void rf_SignalReconDone __P((RF_Raid_t *)); /* XXX these should be in a .h file somewhere */ int raidlookup __P((char *, struct proc *, struct vnode **)); @@ -147,8 +138,8 @@ static RF_FreeList_t *rf_rdp_freelist; #define RF_MAX_FREE_RDP 4 #define RF_RDP_INC 1 -static void -SignalReconDone(RF_Raid_t * raidPtr) +INTEGRATE void +rf_SignalReconDone(RF_Raid_t * raidPtr) { RF_ReconDoneProc_t *p; @@ -190,7 +181,7 @@ rf_RegisterReconDoneProc( * in the kernel, we fire off the recon thread. * ****************************************************************************************/ -static void +void rf_ShutdownReconstruction(ignored) void *ignored; { @@ -228,8 +219,8 @@ rf_ConfigureReconstruction(listp) return (0); } -static RF_RaidReconDesc_t * -AllocRaidReconDesc(raidPtr, row, col, spareDiskPtr, numDisksDone, srow, scol) +RF_RaidReconDesc_t * +rf_AllocRaidReconDesc(raidPtr, row, col, spareDiskPtr, numDisksDone, srow, scol) RF_Raid_t *raidPtr; RF_RowCol_t row; RF_RowCol_t col; @@ -256,29 +247,31 @@ AllocRaidReconDesc(raidPtr, row, col, spareDiskPtr, numDisksDone, srow, scol) return (reconDesc); } -static void -FreeReconDesc(reconDesc) +INTEGRATE void +rf_FreeReconDesc(reconDesc) RF_RaidReconDesc_t *reconDesc; { #if RF_RECON_STATS > 0 - printf("RAIDframe: %lu recon event waits, %lu recon delays\n", - (long) reconDesc->numReconEventWaits, (long) reconDesc->numReconExecDelays); -#endif /* RF_RECON_STATS > 0 */ - printf("RAIDframe: %lu max exec ticks\n", - (long) reconDesc->maxReconExecTicks); + printf("RAIDframe: %qu recon event waits, %qu recon delays\n", + reconDesc->numReconEventWaits, reconDesc->numReconExecDelays); +#endif /* RF_RECON_STATS > 0 */ + + printf("RAIDframe: %qu max exec uSec\n", reconDesc->maxReconExecuSecs); + #if (RF_RECON_STATS > 0) || defined(KERNEL) printf("\n"); -#endif /* (RF_RECON_STATS > 0) || KERNEL */ +#endif /* (RF_RECON_STATS > 0) || KERNEL */ RF_FREELIST_FREE(rf_recond_freelist, reconDesc, next); } -/***************************************************************************************** +/*********************************************************************** * * primary routine to reconstruct a failed disk. This should be called from * within its own thread. It won't return until reconstruction completes, * fails, or is aborted. - ****************************************************************************************/ + * + ***********************************************************************/ int rf_ReconstructFailedDisk(raidPtr, row, col) RF_Raid_t *raidPtr; @@ -360,7 +353,7 @@ rf_ReconstructFailedDiskBasic(raidPtr, row, col) } RF_UNLOCK_MUTEX(raidPtr->mutex); - reconDesc = AllocRaidReconDesc((void *) raidPtr, row, col, spareDiskPtr, numDisksDone, srow, scol); + reconDesc = rf_AllocRaidReconDesc((void *) raidPtr, row, col, spareDiskPtr, numDisksDone, srow, scol); raidPtr->reconDesc = (void *) reconDesc; #if RF_RECON_STATS > 0 reconDesc->hsStallCount = 0; @@ -368,8 +361,8 @@ rf_ReconstructFailedDiskBasic(raidPtr, row, col) reconDesc->numReconEventWaits = 0; #endif /* RF_RECON_STATS > 0 */ reconDesc->reconExecTimerRunning = 0; - reconDesc->reconExecTicks = 0; - reconDesc->maxReconExecTicks = 0; + reconDesc->reconExecuSecs = 0; + reconDesc->maxReconExecuSecs = 0; rc = rf_ContinueReconstructFailedDisk(reconDesc); if (!rc) { @@ -497,7 +490,7 @@ rf_ReconstructInPlace(raidPtr, row, col) first time. Close it before trying to open it again.. */ if (raidPtr->raid_cinfo[row][col].ci_vp != NULL) { - printf("Closed the open device: %s\n", + printf("Closing the open device: %s\n", raidPtr->Disks[row][col].devname); VOP_UNLOCK(raidPtr->raid_cinfo[row][col].ci_vp, 0, proc); (void) vn_close(raidPtr->raid_cinfo[row][col].ci_vp, @@ -511,7 +504,8 @@ rf_ReconstructInPlace(raidPtr, row, col) proc, &vp); if (retcode) { - printf("raid%d: rebuilding: raidlookup on device: %s failed: %d!\n",raidPtr->raidid, + printf("raid%d: rebuilding: raidlookup on device: %s failed: %d!\n", + raidPtr->raidid, raidPtr->Disks[row][col].devname, retcode); /* XXX the component isn't responding properly... @@ -569,7 +563,7 @@ rf_ReconstructInPlace(raidPtr, row, col) RF_UNLOCK_MUTEX(raidPtr->mutex); - reconDesc = AllocRaidReconDesc((void *) raidPtr, row, col, + reconDesc = rf_AllocRaidReconDesc((void *) raidPtr, row, col, spareDiskPtr, numDisksDone, row, col); raidPtr->reconDesc = (void *) reconDesc; @@ -579,8 +573,8 @@ rf_ReconstructInPlace(raidPtr, row, col) reconDesc->numReconEventWaits = 0; #endif /* RF_RECON_STATS > 0 */ reconDesc->reconExecTimerRunning = 0; - reconDesc->reconExecTicks = 0; - reconDesc->maxReconExecTicks = 0; + reconDesc->reconExecuSecs = 0; + reconDesc->maxReconExecuSecs = 0; rc = rf_ContinueReconstructFailedDisk(reconDesc); } else { RF_ERRORMSG1("RECON: no way to reconstruct failed disk for arch %c\n", @@ -642,10 +636,7 @@ rf_ContinueReconstructFailedDisk(reconDesc) int retcode, i, ds; switch (reconDesc->state) { - - case 0: - raidPtr->accumXorTimeUs = 0; /* create one trace record per physical disk */ @@ -661,11 +652,8 @@ rf_ContinueReconstructFailedDisk(reconDesc) Dprintf("RECON: end request suspend\n"); rf_StartUserStats(raidPtr); /* zero out the stats kept on * user accs */ - /* fall through to state 1 */ - case 1: - RF_LOCK_MUTEX(raidPtr->mutex); /* create the reconstruction control pointer and install it in @@ -689,13 +677,15 @@ rf_ContinueReconstructFailedDisk(reconDesc) if (i != col) { /* find and issue the next I/O on the * indicated disk */ - if (IssueNextReadRequest(raidPtr, row, i)) { + if (rf_IssueNextReadRequest(raidPtr, row, i)) { Dprintf2("RECON: done issuing for r%d c%d\n", row, i); reconDesc->numDisksDone++; } } } + reconDesc->state = 2; + case 2: Dprintf("RECON: resume requests\n"); rf_ResumeNewRequests(raidPtr); @@ -709,14 +699,12 @@ rf_ContinueReconstructFailedDisk(reconDesc) * they've completed all work */ mapPtr = raidPtr->reconControl[row]->reconMap; - - while (reconDesc->numDisksDone < raidPtr->numCol - 1) { event = rf_GetNextReconEvent(reconDesc, row, (void (*) (void *)) rf_ContinueReconstructFailedDisk, reconDesc); RF_ASSERT(event); - if (ProcessReconEvent(raidPtr, row, event)) + if (rf_ProcessReconEvent(raidPtr, row, event)) reconDesc->numDisksDone++; raidPtr->reconControl[row]->percentComplete = 100 - (rf_UnitsLeftToReconstruct(mapPtr) * 100 / mapPtr->totalRUs); if (rf_prReconSched) { @@ -724,11 +712,8 @@ rf_ContinueReconstructFailedDisk(reconDesc) } } - - reconDesc->state = 4; - case 4: mapPtr = raidPtr->reconControl[row]->reconMap; if (rf_reconDebug) { @@ -742,7 +727,7 @@ rf_ContinueReconstructFailedDisk(reconDesc) event = rf_GetNextReconEvent(reconDesc, row, (void (*) (void *)) rf_ContinueReconstructFailedDisk, reconDesc); RF_ASSERT(event); - (void) ProcessReconEvent(raidPtr, row, event); /* ignore return code */ + (void) rf_ProcessReconEvent(raidPtr, row, event); /* ignore return code */ raidPtr->reconControl[row]->percentComplete = 100 - (rf_UnitsLeftToReconstruct(mapPtr) * 100 / mapPtr->totalRUs); if (rf_prReconSched) { rf_PrintReconSchedule(raidPtr->reconControl[row]->reconMap, &(raidPtr->reconControl[row]->starttime)); @@ -758,8 +743,6 @@ rf_ContinueReconstructFailedDisk(reconDesc) * user accesses when we free up the psstatus structure as * part of FreeReconControl() */ - - reconDesc->state = 6; retcode = rf_SuspendNewRequestsAndWait(raidPtr); @@ -770,9 +753,6 @@ rf_ContinueReconstructFailedDisk(reconDesc) /* fall through to state 6 */ case 6: - - - RF_LOCK_MUTEX(raidPtr->mutex); raidPtr->numFailures--; ds = (raidPtr->Layout.map->flags & RF_DISTRIBUTE_SPARE); @@ -807,19 +787,19 @@ rf_ContinueReconstructFailedDisk(reconDesc) #endif /* RF_RECON_STATS > 0 */ rf_FreeReconControl(raidPtr, row); RF_Free(raidPtr->recon_tracerecs, raidPtr->numCol * sizeof(RF_AccTraceEntry_t)); - FreeReconDesc(reconDesc); + rf_FreeReconDesc(reconDesc); } - SignalReconDone(raidPtr); + rf_SignalReconDone(raidPtr); return (0); } /***************************************************************************************** * do the right thing upon each reconstruction event. * returns nonzero if and only if there is nothing left unread on the indicated disk ****************************************************************************************/ -static int -ProcessReconEvent(raidPtr, frow, event) +int +rf_ProcessReconEvent(raidPtr, frow, event) RF_Raid_t *raidPtr; RF_RowCol_t frow; RF_ReconEvent_t *event; @@ -828,7 +808,7 @@ ProcessReconEvent(raidPtr, frow, event) RF_ReconBuffer_t *rbuf; RF_SectorCount_t sectorsPerRU; - Dprintf1("RECON: ProcessReconEvent type %d\n", event->type); + Dprintf1("RECON: rf_ProcessReconEvent type %d\n", event->type); switch (event->type) { /* a read I/O has completed */ @@ -843,7 +823,7 @@ ProcessReconEvent(raidPtr, frow, event) submitblocked = rf_SubmitReconBuffer(rbuf, 0, 0); Dprintf1("RECON: submitblocked=%d\n", submitblocked); if (!submitblocked) - retcode = IssueNextReadRequest(raidPtr, frow, event->col); + retcode = rf_IssueNextReadRequest(raidPtr, frow, event->col); break; /* a write I/O has completed */ @@ -879,26 +859,26 @@ ProcessReconEvent(raidPtr, frow, event) RF_ASSERT(!submitblocked); /* we wouldn't have gotten the * BUFCLEAR event if we * couldn't submit */ - retcode = IssueNextReadRequest(raidPtr, frow, event->col); + retcode = rf_IssueNextReadRequest(raidPtr, frow, event->col); break; case RF_REVENT_BLOCKCLEAR: /* A user-write reconstruction * blockage has been cleared */ DDprintf2("RECON: BLOCKCLEAR EVENT: row %d col %d\n", frow, event->col); - retcode = TryToRead(raidPtr, frow, event->col); + retcode = rf_TryToRead(raidPtr, frow, event->col); break; case RF_REVENT_HEADSEPCLEAR: /* A max-head-separation * reconstruction blockage has been * cleared */ Dprintf2("RECON: HEADSEPCLEAR EVENT: row %d col %d\n", frow, event->col); - retcode = TryToRead(raidPtr, frow, event->col); + retcode = rf_TryToRead(raidPtr, frow, event->col); break; /* a buffer has become ready to write */ case RF_REVENT_BUFREADY: Dprintf2("RECON: BUFREADY EVENT: row %d col %d\n", frow, event->col); - retcode = IssueNextWriteRequest(raidPtr, frow); + retcode = rf_IssueNextWriteRequest(raidPtr, frow); if (rf_floatingRbufDebug) { rf_CheckFloatingRbufCount(raidPtr, 1); } @@ -908,7 +888,7 @@ ProcessReconEvent(raidPtr, frow, event) * recon'd while we were waiting for something else to happen */ case RF_REVENT_SKIP: DDprintf2("RECON: SKIP EVENT: row %d col %d\n", frow, event->col); - retcode = IssueNextReadRequest(raidPtr, frow, event->col); + retcode = rf_IssueNextReadRequest(raidPtr, frow, event->col); break; /* a forced-reconstruction read access has completed. Just @@ -945,8 +925,8 @@ ProcessReconEvent(raidPtr, frow, event) * * returns nonzero if and only if there is nothing left unread on the indicated disk ****************************************************************************************/ -static int -IssueNextReadRequest(raidPtr, row, col) +int +rf_IssueNextReadRequest(raidPtr, row, col) RF_Raid_t *raidPtr; RF_RowCol_t row; RF_RowCol_t col; @@ -975,14 +955,14 @@ IssueNextReadRequest(raidPtr, row, col) /* code left over from when head-sep was based on * parity stripe id */ if (ctrl->curPSID >= raidPtr->reconControl[row]->lastPSID) { - CheckForNewMinHeadSep(raidPtr, row, ++(ctrl->headSepCounter)); + rf_CheckForNewMinHeadSep(raidPtr, row, ++(ctrl->headSepCounter)); return (1); /* finito! */ } /* find the disk offsets of the start of the parity * stripe on both the current disk and the failed * disk. skip this entire parity stripe if either disk * does not appear in the indicated PS */ - status = ComputePSDiskOffsets(raidPtr, ctrl->curPSID, row, col, &ctrl->diskOffset, &rbuf->failedDiskSectorOffset, + status = rf_ComputePSDiskOffsets(raidPtr, ctrl->curPSID, row, col, &ctrl->diskOffset, &rbuf->failedDiskSectorOffset, &rbuf->spRow, &rbuf->spCol, &rbuf->spOffset); if (status) { ctrl->ru_count = RUsPerPU - 1; @@ -1000,7 +980,7 @@ IssueNextReadRequest(raidPtr, row, col) } ctrl->headSepCounter++; if (do_new_check) - CheckForNewMinHeadSep(raidPtr, row, ctrl->headSepCounter); /* update min if needed */ + rf_CheckForNewMinHeadSep(raidPtr, row, ctrl->headSepCounter); /* update min if needed */ /* at this point, we have definitely decided what to do, and we have @@ -1010,7 +990,7 @@ IssueNextReadRequest(raidPtr, row, col) bzero((char *) &raidPtr->recon_tracerecs[col], sizeof(raidPtr->recon_tracerecs[col])); raidPtr->recon_tracerecs[col].reconacc = 1; RF_ETIMER_START(raidPtr->recon_tracerecs[col].recon_timer); - retcode = TryToRead(raidPtr, row, col); + retcode = rf_TryToRead(raidPtr, row, col); return (retcode); } /* tries to issue the next read on the indicated disk. We may be blocked by (a) the heads being too @@ -1018,8 +998,8 @@ IssueNextReadRequest(raidPtr, row, col) * In this case, we issue a head-sep or blockage wait request, which will cause this same routine * to be invoked again later when the blockage has cleared. */ -static int -TryToRead(raidPtr, row, col) +int +rf_TryToRead(raidPtr, row, col) RF_Raid_t *raidPtr; RF_RowCol_t row; RF_RowCol_t col; @@ -1034,7 +1014,7 @@ TryToRead(raidPtr, row, col) /* if the current disk is too far ahead of the others, issue a * head-separation wait and return */ - if (CheckHeadSeparation(raidPtr, ctrl, row, col, ctrl->headSepCounter, which_ru)) + if (rf_CheckHeadSeparation(raidPtr, ctrl, row, col, ctrl->headSepCounter, which_ru)) return (0); RF_LOCK_PSS_MUTEX(raidPtr, row, psid); pssPtr = rf_LookupRUStatus(raidPtr, raidPtr->reconControl[row]->pssTable, psid, which_ru, RF_PSS_CREATE, &created); @@ -1042,7 +1022,7 @@ TryToRead(raidPtr, row, col) /* if recon is blocked on the indicated parity stripe, issue a * block-wait request and return. this also must mark the indicated RU * in the stripe as under reconstruction if not blocked. */ - status = CheckForcedOrBlockedReconstruction(raidPtr, pssPtr, ctrl, row, col, psid, which_ru); + status = rf_CheckForcedOrBlockedReconstruction(raidPtr, pssPtr, ctrl, row, col, psid, which_ru); if (status == RF_PSS_RECON_BLOCKED) { Dprintf2("RECON: Stalling psid %ld ru %d: recon blocked\n", psid, which_ru); goto out; @@ -1077,7 +1057,7 @@ TryToRead(raidPtr, row, col) /* should be ok to use a NULL proc pointer here, all the bufs we use * should be in kernel space */ req = rf_CreateDiskQueueData(RF_IO_TYPE_READ, ctrl->diskOffset, sectorsPerRU, ctrl->rbuf->buffer, psid, which_ru, - ReconReadDoneProc, (void *) ctrl, NULL, &raidPtr->recon_tracerecs[col], (void *) raidPtr, 0, NULL); + rf_ReconReadDoneProc, (void *) ctrl, NULL, &raidPtr->recon_tracerecs[col], (void *) raidPtr, 0, NULL); RF_ASSERT(req); /* XXX -- fix this -- XXX */ @@ -1111,8 +1091,8 @@ out: * ASSUMES THAT THE STRIPE IDENTIFIER IDENTIFIES THE DISKS COMPRISING THE STRIPE * IN THE CORRECT ORDER */ -static int -ComputePSDiskOffsets( +int +rf_ComputePSDiskOffsets( RF_Raid_t * raidPtr, /* raid descriptor */ RF_StripeNum_t psid, /* parity stripe identifier */ RF_RowCol_t row, /* row and column of disk to find the offsets @@ -1224,8 +1204,8 @@ skipit: return (1); } /* this is called when a buffer has become ready to write to the replacement disk */ -static int -IssueNextWriteRequest(raidPtr, row) +INTEGRATE int +rf_IssueNextWriteRequest(raidPtr, row) RF_Raid_t *raidPtr; RF_RowCol_t row; { @@ -1255,7 +1235,7 @@ IssueNextWriteRequest(raidPtr, row) req = rf_CreateDiskQueueData(RF_IO_TYPE_WRITE, rbuf->spOffset, sectorsPerRU, rbuf->buffer, rbuf->parityStripeID, rbuf->which_ru, - ReconWriteDoneProc, (void *) rbuf, NULL, + rf_ReconWriteDoneProc, (void *) rbuf, NULL, &raidPtr->recon_tracerecs[fcol], (void *) raidPtr, 0, NULL); @@ -1272,8 +1252,8 @@ IssueNextWriteRequest(raidPtr, row) * * called at interrupt context in the kernel, so don't do anything illegal here. */ -static int -ReconReadDoneProc(arg, status) +int +rf_ReconReadDoneProc(arg, status) void *arg; int status; { @@ -1301,8 +1281,8 @@ ReconReadDoneProc(arg, status) * * called at interrupt context in the kernel, so don't do anything illegal here. */ -static int -ReconWriteDoneProc(arg, status) +int +rf_ReconWriteDoneProc(arg, status) void *arg; int status; { @@ -1320,8 +1300,8 @@ ReconWriteDoneProc(arg, status) /* computes a new minimum head sep, and wakes up anyone who needs to be woken as a result */ -static void -CheckForNewMinHeadSep(raidPtr, row, hsCtr) +void +rf_CheckForNewMinHeadSep(raidPtr, row, hsCtr) RF_Raid_t *raidPtr; RF_RowCol_t row; RF_HeadSepLimit_t hsCtr; @@ -1370,8 +1350,8 @@ CheckForNewMinHeadSep(raidPtr, row, hsCtr) * returns non-zero if and only if we have to stop working on the indicated disk * due to a head-separation delay. */ -static int -CheckHeadSeparation( +int +rf_CheckHeadSeparation( RF_Raid_t * raidPtr, RF_PerDiskReconCtrl_t * ctrl, RF_RowCol_t row, @@ -1435,8 +1415,8 @@ CheckHeadSeparation( * * ASSUMES THE PSS MUTEX IS LOCKED UPON ENTRY */ -static int -CheckForcedOrBlockedReconstruction( +INTEGRATE int +rf_CheckForcedOrBlockedReconstruction( RF_Raid_t * raidPtr, RF_ReconParityStripeStatus_t * pssPtr, RF_PerDiskReconCtrl_t * ctrl, @@ -1544,7 +1524,7 @@ rf_ForceOrBlockRecon(raidPtr, asmap, cbFunc, cbArg) printf("[%d] promoted read from row %d col %d\n", tid, row, diskno); } else { new_rbuf = rf_MakeReconBuffer(raidPtr, row, diskno, RF_RBUF_TYPE_FORCED); /* create new buf */ - ComputePSDiskOffsets(raidPtr, psid, row, diskno, &offset, &fd_offset, + rf_ComputePSDiskOffsets(raidPtr, psid, row, diskno, &offset, &fd_offset, &new_rbuf->spRow, &new_rbuf->spCol, &new_rbuf->spOffset); /* find offsets & spare * location */ new_rbuf->parityStripeID = psid; /* fill in the buffer */ @@ -1555,7 +1535,7 @@ rf_ForceOrBlockRecon(raidPtr, asmap, cbFunc, cbArg) /* use NULL b_proc b/c all addrs * should be in kernel space */ req = rf_CreateDiskQueueData(RF_IO_TYPE_READ, offset + which_ru * sectorsPerRU, sectorsPerRU, new_rbuf->buffer, - psid, which_ru, (int (*) (void *, int)) ForceReconReadDoneProc, (void *) new_rbuf, NULL, + psid, which_ru, (int (*) (void *, int)) rf_ForceReconReadDoneProc, (void *) new_rbuf, NULL, NULL, (void *) raidPtr, 0, NULL); RF_ASSERT(req); /* XXX -- fix this -- @@ -1589,8 +1569,8 @@ rf_ForceOrBlockRecon(raidPtr, asmap, cbFunc, cbArg) * all we do is schedule the FORCEDREADONE event. * called at interrupt context in the kernel, so don't do anything illegal here. */ -static void -ForceReconReadDoneProc(arg, status) +void +rf_ForceReconReadDoneProc(arg, status) void *arg; int status; { |