diff --git a/src/afs/afs_call.c b/src/afs/afs_call.c index 29daefa21e..858dc5c11c 100644 --- a/src/afs/afs_call.c +++ b/src/afs/afs_call.c @@ -65,7 +65,9 @@ static int AFS_Running = 0; static int afs_CacheInit_Done = 0; static int afs_Go_Done = 0; extern struct interfaceAddr afs_cb_interface; +#ifdef RXK_LISTENER_ENV static int afs_RX_Running = 0; +#endif static int afs_InitSetup_done = 0; afs_int32 afs_numcachefiles = -1; afs_int32 afs_numfilesperdir = -1; @@ -1376,6 +1378,15 @@ afs_shutdown(void) afs_FlushAllVCaches(); #endif + afs_termState = AFSOP_STOP_BKG; + + afs_warn("BkG... "); + /* Wake-up afs_brsDaemons so that we don't have to wait for a bkg job! */ + while (afs_termState == AFSOP_STOP_BKG) { + afs_osi_Wakeup(&afs_brsDaemons); + afs_osi_Sleep(&afs_termState); + } + afs_warn("CB... "); afs_termState = AFSOP_STOP_RXCALLBACK; @@ -1398,12 +1409,6 @@ afs_shutdown(void) afs_osi_Sleep(&afs_termState); } } - afs_warn("BkG... "); - /* Wake-up afs_brsDaemons so that we don't have to wait for a bkg job! */ - while (afs_termState == AFSOP_STOP_BKG) { - afs_osi_Wakeup(&afs_brsDaemons); - afs_osi_Sleep(&afs_termState); - } afs_warn("CTrunc... "); /* Cancel cache truncate daemon. */ while (afs_termState == AFSOP_STOP_TRUNCDAEMON) { diff --git a/src/afs/afs_cell.c b/src/afs/afs_cell.c index 99e21286b1..7cf1fb45d3 100644 --- a/src/afs/afs_cell.c +++ b/src/afs/afs_cell.c @@ -57,7 +57,11 @@ afs_StopAFSDB(void) afs_osi_Wakeup(&afsdb_req); } else { afsdb_handler_shutdown = 1; +#if defined(AFS_SUN5_ENV) || defined(RXK_LISTENER_ENV) || defined(RXK_UPCALL_ENV) afs_termState = AFSOP_STOP_RXEVENT; +#else + afs_termState = AFSOP_STOP_COMPLETE; +#endif afs_osi_Wakeup(&afs_termState); } } diff --git a/src/afs/afs_daemons.c b/src/afs/afs_daemons.c index a4c9c88a27..75d057e9c5 100644 --- a/src/afs/afs_daemons.c +++ b/src/afs/afs_daemons.c @@ -90,7 +90,7 @@ afs_CheckServerDaemon(void) last10MinCheck = lastCheck = osi_Time(); while (1) { if (afs_termState == AFSOP_STOP_CS) { - afs_termState = AFSOP_STOP_BKG; + afs_termState = AFSOP_STOP_TRUNCDAEMON; afs_osi_Wakeup(&afs_termState); break; } @@ -108,7 +108,7 @@ afs_CheckServerDaemon(void) } /* shutdown check. */ if (afs_termState == AFSOP_STOP_CS) { - afs_termState = AFSOP_STOP_BKG; + afs_termState = AFSOP_STOP_TRUNCDAEMON; afs_osi_Wakeup(&afs_termState); break; } @@ -309,7 +309,7 @@ afs_Daemon(void) if (afs_CheckServerDaemonStarted) afs_termState = AFSOP_STOP_CS; else - afs_termState = AFSOP_STOP_BKG; + afs_termState = AFSOP_STOP_TRUNCDAEMON; afs_osi_Wakeup(&afs_termState); return; } @@ -1046,7 +1046,7 @@ afs_BackgroundDaemon(void) if (afs_termState == AFSOP_STOP_BKG) { if (--afs_nbrs <= 0) - afs_termState = AFSOP_STOP_TRUNCDAEMON; + afs_termState = AFSOP_STOP_RXCALLBACK; ReleaseWriteLock(&afs_xbrs); afs_osi_Wakeup(&afs_termState); #ifdef AFS_NEW_BKG