Home | History | Annotate | Line # | Download | only in raidframe
rf_shutdown.c revision 1.6.6.5
      1  1.6.6.3  nathanw /*	$NetBSD: rf_shutdown.c,v 1.6.6.5 2002/09/17 21:21:00 nathanw Exp $	*/
      2      1.1    oster /*
      3      1.1    oster  * rf_shutdown.c
      4      1.1    oster  */
      5      1.1    oster /*
      6      1.1    oster  * Copyright (c) 1996 Carnegie-Mellon University.
      7      1.1    oster  * All rights reserved.
      8      1.1    oster  *
      9      1.1    oster  * Author: Jim Zelenka
     10      1.1    oster  *
     11      1.1    oster  * Permission to use, copy, modify and distribute this software and
     12      1.1    oster  * its documentation is hereby granted, provided that both the copyright
     13      1.1    oster  * notice and this permission notice appear in all copies of the
     14      1.1    oster  * software, derivative works or modified versions, and any portions
     15      1.1    oster  * thereof, and that both notices appear in supporting documentation.
     16      1.1    oster  *
     17      1.1    oster  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
     18      1.1    oster  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
     19      1.1    oster  * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
     20      1.1    oster  *
     21      1.1    oster  * Carnegie Mellon requests users of this software to return to
     22      1.1    oster  *
     23      1.1    oster  *  Software Distribution Coordinator  or  Software.Distribution (at) CS.CMU.EDU
     24      1.1    oster  *  School of Computer Science
     25      1.1    oster  *  Carnegie Mellon University
     26      1.1    oster  *  Pittsburgh PA 15213-3890
     27      1.1    oster  *
     28      1.1    oster  * any improvements or extensions that they make and grant Carnegie the
     29      1.1    oster  * rights to redistribute these changes.
     30      1.1    oster  */
     31      1.1    oster /*
     32      1.1    oster  * Maintain lists of cleanup functions. Also, mechanisms for coordinating
     33      1.1    oster  * thread startup and shutdown.
     34      1.1    oster  */
     35  1.6.6.3  nathanw 
     36  1.6.6.3  nathanw #include <sys/cdefs.h>
     37  1.6.6.3  nathanw __KERNEL_RCSID(0, "$NetBSD: rf_shutdown.c,v 1.6.6.5 2002/09/17 21:21:00 nathanw Exp $");
     38      1.1    oster 
     39  1.6.6.2  nathanw #include <dev/raidframe/raidframevar.h>
     40  1.6.6.2  nathanw 
     41  1.6.6.1  nathanw #include "rf_archs.h"
     42      1.1    oster #include "rf_shutdown.h"
     43      1.1    oster #include "rf_freelist.h"
     44      1.1    oster 
     45  1.6.6.5  nathanw 
     46  1.6.6.5  nathanw #ifndef RF_DEBUG_SHUTDOWN
     47  1.6.6.5  nathanw #define RF_DEBUG_SHUTDOWN 0
     48  1.6.6.5  nathanw #endif
     49  1.6.6.5  nathanw 
     50      1.4    oster static void
     51      1.4    oster rf_FreeShutdownEnt(RF_ShutdownList_t * ent)
     52      1.1    oster {
     53      1.4    oster 	FREE(ent, M_RAIDFRAME);
     54      1.1    oster }
     55      1.1    oster 
     56      1.4    oster int
     57      1.4    oster _rf_ShutdownCreate(
     58      1.4    oster     RF_ShutdownList_t ** listp,
     59      1.4    oster     void (*cleanup) (void *arg),
     60      1.4    oster     void *arg,
     61      1.4    oster     char *file,
     62      1.4    oster     int line)
     63      1.1    oster {
     64      1.4    oster 	RF_ShutdownList_t *ent;
     65      1.1    oster 
     66      1.4    oster 	/*
     67      1.4    oster          * Have to directly allocate memory here, since we start up before
     68      1.4    oster          * and shutdown after RAIDframe internal allocation system.
     69      1.4    oster          */
     70      1.6    oster 	/* 	ent = (RF_ShutdownList_t *) malloc(sizeof(RF_ShutdownList_t),
     71      1.6    oster 		M_RAIDFRAME, M_WAITOK); */
     72      1.6    oster 	ent = (RF_ShutdownList_t *) malloc(sizeof(RF_ShutdownList_t),
     73      1.6    oster 					   M_RAIDFRAME, M_NOWAIT);
     74      1.4    oster 	if (ent == NULL)
     75      1.4    oster 		return (ENOMEM);
     76      1.4    oster 	ent->cleanup = cleanup;
     77      1.4    oster 	ent->arg = arg;
     78      1.4    oster 	ent->file = file;
     79      1.4    oster 	ent->line = line;
     80      1.4    oster 	ent->next = *listp;
     81      1.4    oster 	*listp = ent;
     82      1.4    oster 	return (0);
     83      1.1    oster }
     84      1.1    oster 
     85      1.4    oster int
     86      1.4    oster rf_ShutdownList(RF_ShutdownList_t ** list)
     87      1.1    oster {
     88      1.4    oster 	RF_ShutdownList_t *r, *next;
     89      1.4    oster 	char   *file;
     90      1.4    oster 	int     line;
     91      1.4    oster 
     92      1.4    oster 	for (r = *list; r; r = next) {
     93      1.4    oster 		next = r->next;
     94      1.4    oster 		file = r->file;
     95      1.4    oster 		line = r->line;
     96      1.4    oster 
     97  1.6.6.5  nathanw #if RF_DEBUG_SHUTDOWN
     98      1.4    oster 		if (rf_shutdownDebug) {
     99      1.5    oster 			printf("call shutdown, created %s:%d\n", file, line);
    100      1.4    oster 		}
    101  1.6.6.5  nathanw #endif
    102      1.4    oster 		r->cleanup(r->arg);
    103  1.6.6.5  nathanw #if RF_DEBUG_SHUTDOWN
    104      1.4    oster 		if (rf_shutdownDebug) {
    105      1.5    oster 			printf("completed shutdown, created %s:%d\n", file, line);
    106      1.4    oster 		}
    107  1.6.6.5  nathanw #endif
    108      1.4    oster 		rf_FreeShutdownEnt(r);
    109      1.4    oster 	}
    110      1.4    oster 	*list = NULL;
    111      1.4    oster 	return (0);
    112      1.1    oster }
    113