mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-03-31 17:10:47 +08:00
[svn-r15165] Purpose: Create new HDpthread_self and HDpthread_self_ulong macros
Description: On Windows, the pthread_self function cannot be used to print the returned thread ID for debugging. Instead, we need a separate function, GetCurrentThreadId. To eliminate some Windows ifdef's in the code, we create two new function macros which can be used by all platforms. It is conditionally defined in H5win32defs.h, and globally in H5private.h. Tested: VS2005 w/ pthreads on WinXP kagiso w/ pthreads
This commit is contained in:
parent
ba9abd2006
commit
259d1afce9
@ -135,7 +135,7 @@ H5CS_print_stack(const H5CS_t *fstack, FILE *stream)
|
||||
HDfprintf (stream, "HDF5-DIAG: Function stack from %s ", H5_lib_vers_info_g);
|
||||
/* try show the process or thread id in multiple processes cases*/
|
||||
#ifdef H5_HAVE_THREADSAFE
|
||||
HDfprintf (stream, "thread %d.", (int)pthread_self());
|
||||
HDfprintf (stream, "thread %lu.", HDpthread_self_ulong());
|
||||
#else /* H5_HAVE_THREADSAFE */
|
||||
HDfprintf (stream, "thread 0.");
|
||||
#endif /* H5_HAVE_THREADSAFE */
|
||||
|
16
src/H5Eint.c
16
src/H5Eint.c
@ -275,13 +275,7 @@ H5E_walk1_cb(int n, H5E_error1_t *err_desc, void *client_data)
|
||||
fprintf(stream, "thread 0");
|
||||
} /* end block */
|
||||
#elif defined(H5_HAVE_THREADSAFE)
|
||||
#ifdef _WIN32
|
||||
/* use GetCurrentThreadId because pthread_self return cannot be cast */
|
||||
/* as an unsigned long on Windows */
|
||||
fprintf(stream, "thread %lu", (unsigned long)GetCurrentThreadId());
|
||||
#else
|
||||
fprintf(stream, "thread %lu", (unsigned long)pthread_self());
|
||||
#endif
|
||||
fprintf(stream, "thread %lu", HDpthread_self_ulong());
|
||||
#else
|
||||
fprintf(stream, "thread 0");
|
||||
#endif
|
||||
@ -397,13 +391,7 @@ H5E_walk2_cb(unsigned n, const H5E_error2_t *err_desc, void *client_data)
|
||||
fprintf(stream, "thread 0");
|
||||
} /* end block */
|
||||
#elif defined(H5_HAVE_THREADSAFE)
|
||||
#ifdef _WIN32
|
||||
/* use GetCurrentThreadId because pthread_self return cannot be cast */
|
||||
/* as an unsigned long on Windows */
|
||||
fprintf(stream, "thread %lu", (unsigned long)GetCurrentThreadId());
|
||||
#else
|
||||
fprintf(stream, "thread %lu", (unsigned long)pthread_self());
|
||||
#endif
|
||||
fprintf(stream, "thread %lu", HDpthread_self_ulong());
|
||||
#else
|
||||
fprintf(stream, "thread 0");
|
||||
#endif
|
||||
|
@ -146,7 +146,7 @@ H5TS_mutex_lock(H5TS_mutex_t *mutex)
|
||||
if (ret_value)
|
||||
return ret_value;
|
||||
|
||||
if(mutex->lock_count && pthread_equal(pthread_self(), mutex->owner_thread)) {
|
||||
if(mutex->lock_count && pthread_equal(HDpthread_self(), mutex->owner_thread)) {
|
||||
/* already owned by self - increment count */
|
||||
mutex->lock_count++;
|
||||
} else {
|
||||
@ -155,7 +155,7 @@ H5TS_mutex_lock(H5TS_mutex_t *mutex)
|
||||
pthread_cond_wait(&mutex->cond_var, &mutex->atomic_lock);
|
||||
|
||||
/* After we've received the signal, take ownership of the mutex */
|
||||
mutex->owner_thread = pthread_self();
|
||||
mutex->owner_thread = HDpthread_self();
|
||||
mutex->lock_count = 1;
|
||||
}
|
||||
|
||||
|
@ -1356,6 +1356,15 @@ extern char *strdup(const char *s);
|
||||
#define HDstrdup(S) strdup(S)
|
||||
#endif /* HDstrdup */
|
||||
|
||||
#ifndef HDpthread_self
|
||||
#define HDpthread_self() pthread_self()
|
||||
#endif /* HDpthread_self */
|
||||
|
||||
/* Use this version of pthread_self for printing the thread ID */
|
||||
#ifndef HDpthread_self_ulong
|
||||
#define HDpthread_self_ulong() ((unsigned long)pthread_self())
|
||||
#endif /* HDpthread_self_ulong */
|
||||
|
||||
|
||||
#ifdef H5_HAVE_WINDOW_PATH
|
||||
|
||||
|
@ -52,5 +52,11 @@ typedef __int64 h5_stat_size_t;
|
||||
#define HDvsnprintf(S,N,FMT,A) _vsnprintf(S,N,FMT,A)
|
||||
#define HDwrite(F,M,Z) _write(F,M,Z)
|
||||
|
||||
/* Non-POSIX functions */
|
||||
|
||||
/* Don't use actual pthread_self on Windows because the return
|
||||
* type cannot be cast as a ulong like other systems. */
|
||||
#define HDpthread_self_ulong() ((unsigned long)GetCurrentThreadId())
|
||||
|
||||
|
||||
#endif /* _WIN32 */
|
||||
|
@ -667,14 +667,7 @@ h5_show_hostname(void)
|
||||
printf("thread 0.");
|
||||
}
|
||||
#elif defined(H5_HAVE_THREADSAFE)
|
||||
#ifdef _WIN32
|
||||
/* use GetCurrentThreadId because pthread_self return cannot be cast */
|
||||
/* as an int on Windows */
|
||||
fprintf("thread %d.", (int)GetCurrentThreadId());
|
||||
#else
|
||||
printf("thread %d.", (int)pthread_self());
|
||||
#endif
|
||||
|
||||
printf("thread %lu.", HDpthread_self_ulong());
|
||||
#else
|
||||
printf("thread 0.");
|
||||
#endif
|
||||
|
Loading…
x
Reference in New Issue
Block a user