NetBSD/sys/dev/raidframe/rf_threadid.h

230 lines
6.5 KiB
C

/* $NetBSD: rf_threadid.h,v 1.1 1998/11/13 04:20:35 oster Exp $ */
/*
* Copyright (c) 1995 Carnegie-Mellon University.
* All rights reserved.
*
* Author: Daniel Stodolsky, Mark Holland
*
* Permission to use, copy, modify and distribute this software and
* its documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie the
* rights to redistribute these changes.
*/
/* rf_threadid.h
*
* simple macros to register and lookup integer identifiers for threads.
* must include pthread.h before including this
*
* This is one of two places where the pthreads package is used explicitly.
* The other is in threadstuff.h
*
* none of this is used in the kernel, so it all gets compiled out if KERNEL is defined
*/
/* :
* Log: rf_threadid.h,v
* Revision 1.17 1996/08/12 20:11:17 jimz
* fix up for AIX4
*
* Revision 1.16 1996/06/05 18:06:02 jimz
* Major code cleanup. The Great Renaming is now done.
* Better modularity. Better typing. Fixed a bunch of
* synchronization bugs. Made a lot of global stuff
* per-desc or per-array. Removed dead code.
*
* Revision 1.15 1996/06/03 23:28:26 jimz
* more bugfixes
* check in tree to sync for IPDS runs with current bugfixes
* there still may be a problem with threads in the script test
* getting I/Os stuck- not trivially reproducible (runs ~50 times
* in a row without getting stuck)
*
* Revision 1.14 1996/05/30 11:29:41 jimz
* Numerous bug fixes. Stripe lock release code disagreed with the taking code
* about when stripes should be locked (I made it consistent: no parity, no lock)
* There was a lot of extra serialization of I/Os which I've removed- a lot of
* it was to calculate values for the cache code, which is no longer with us.
* More types, function, macro cleanup. Added code to properly quiesce the array
* on shutdown. Made a lot of stuff array-specific which was (bogusly) general
* before. Fixed memory allocation, freeing bugs.
*
* Revision 1.13 1996/05/24 22:17:04 jimz
* continue code + namespace cleanup
* typed a bunch of flags
*
* Revision 1.12 1996/05/23 21:46:35 jimz
* checkpoint in code cleanup (release prep)
* lots of types, function names have been fixed
*
* Revision 1.11 1996/05/20 16:13:46 jimz
* switch to rf_{mutex,cond}_{init,destroy}
*
* Revision 1.10 1996/05/18 19:51:34 jimz
* major code cleanup- fix syntax, make some types consistent,
* add prototypes, clean out dead code, et cetera
*
* Revision 1.9 1996/05/17 13:29:06 jimz
* did a dance on get_threadid such that it will do the pthread_attr_t -> int
* assignment without warnings, even on really anal compilers
*
* Revision 1.8 1995/12/06 15:15:00 root
* added copyright info
*
*/
#ifndef _RF__RF_THREADID_H_
#define _RF__RF_THREADID_H_
#ifdef _KERNEL
#define KERNEL
#endif
#ifndef SIMULATE
#ifndef KERNEL
/*
* User
*/
#include "rf_threadstuff.h"
extern int rf_numThrsRegistered;
extern pthread_key_t rf_thread_id_key;
RF_DECLARE_EXTERN_MUTEX(rf_threadid_mutex)
#define RF_THREAD_MAX 200
/* these should be global since a function is declared. Should be invoked at only one place in code */
#define RF_DECLARE_GLOBAL_THREADID \
int rf_numThrsRegistered = 0; \
pthread_key_t rf_thread_id_key; \
RF_DECLARE_MUTEX(rf_threadid_mutex) \
RF_Thread_t rf_regdThrs[RF_THREAD_MAX]; \
void rf_ThreadIdEmptyFunc() {}
/* setup must be called exactly once, i.e. it can't be called by each thread */
#ifdef AIX
typedef void (*pthread_destructor_t)(void *);
#endif /* AIX */
#ifdef __osf__
#define rf_setup_threadid() { \
extern void rf_ThreadIdEmptyFunc(); \
pthread_keycreate(&rf_thread_id_key, (pthread_destructor_t) rf_ThreadIdEmptyFunc); \
rf_mutex_init(&rf_threadid_mutex); /* XXX check return val */ \
rf_numThrsRegistered = 0; \
}
#endif /* __osf__ */
#ifdef AIX
#define rf_setup_threadid() { \
extern void rf_ThreadIdEmptyFunc(); \
pthread_key_create(&rf_thread_id_key, (pthread_destructor_t) rf_ThreadIdEmptyFunc); \
rf_mutex_init(&rf_threadid_mutex); /* XXX check return val */ \
rf_numThrsRegistered = 0; \
}
#endif /* AIX */
#define rf_shutdown_threadid() { \
rf_mutex_destroy(&rf_threadid_mutex); \
}
#ifdef __osf__
typedef pthread_addr_t RF_THID_cast_t;
#endif /* __osf__ */
#ifdef AIX
typedef void *RF_THID_cast_t;
#endif /* AIX */
#define rf_assign_threadid() {RF_LOCK_MUTEX(rf_threadid_mutex); \
if (pthread_setspecific(rf_thread_id_key, (RF_THID_cast_t) ((unsigned long)(rf_numThrsRegistered++)))) { RF_PANIC(); } \
RF_UNLOCK_MUTEX(rf_threadid_mutex);}
#ifdef __osf__
#define rf_get_threadid(_id_) { \
RF_THID_cast_t _val; \
unsigned long _val2; \
if (pthread_getspecific(rf_thread_id_key, &_val)) \
RF_PANIC(); \
(_val2) = (unsigned long)_val; \
(_id_) = (int)_val2; \
}
#endif /* __osf__ */
#ifdef AIX
#define rf_get_threadid(_id_) { \
RF_THID_cast_t _val; \
unsigned long _val2; \
_val = pthread_getspecific(rf_thread_id_key); \
(_val2) = (unsigned long)_val; \
(_id_) = (int)_val2; \
}
#endif /* AIX */
#else /* KERNEL */
/*
* Kernel
*/
#ifndef __NetBSD__
#include <kern/task.h>
#include <kern/thread.h>
#include <mach/machine/vm_param.h>
#endif
#define RF_DECLARE_GLOBAL_THREADID
#define rf_setup_threadid()
#define rf_shutdown_threadid()
#define rf_assign_threadid()
#ifdef __NetBSD__
#define rf_get_threadid(_id_) _id_ = 0;
#else
#define rf_get_threadid(_id_) { \
thread_t thread = current_thread(); \
_id_ = (int)(((thread->thread_self)>>(8*sizeof(int *)))&0x0fffffff); \
}
#endif /* __NetBSD__ */
#endif /* KERNEL */
#else /* SIMULATE */
/*
* Simulator
*/
#include "rf_diskevent.h"
#define RF_DECLARE_GLOBAL_THREADID
#define rf_setup_threadid()
#define rf_shutdown_threadid()
#define rf_assign_threadid()
#define rf_get_threadid(_id_) _id_ = rf_GetCurrentOwner()
#endif /* SIMULATE */
#endif /* !_RF__RF_THREADID_H_ */