1
0
mirror of https://git.libssh.org/projects/libssh.git synced 2025-11-30 13:01:23 +03:00

Moved pthread specific code in src/threads/pthread.c

pthread example doesn't compile du to the lack of
libssh_threads_native.so library
This commit is contained in:
Aris Adamantiadis
2010-09-06 14:51:01 +02:00
parent f7842e3a4b
commit 2cca490076
4 changed files with 85 additions and 75 deletions

View File

@@ -277,59 +277,7 @@ struct ssh_threads_callbacks_struct {
LIBSSH_API int ssh_threads_set_callbacks(struct ssh_threads_callbacks_struct
*cb);
/** @brief Defines the needed callbacks for pthread. Use this if your
* OS supports libpthread and want to use it for threading.
* @code
* #include <libssh/callbacks.h>
* #include <errno.h>
* #include <pthread.h>
* SSH_THREADS_PTHREAD(ssh_pthread_callbacks);
* int main(){
* ssh_init_set_threads_callbacks(&ssh_pthread_callbacks);
* ssh_init();
* ...
* }
* @endcode
* @param name name of the structure to be declared, containing the
* callbacks for threading
*
*/
#define SSH_THREADS_PTHREAD(name) \
static int ssh_pthread_mutex_init (void **priv){ \
int err = 0; \
*priv = malloc (sizeof (pthread_mutex_t)); \
if (*priv==NULL) \
return ENOMEM; \
err = pthread_mutex_init (*priv, NULL); \
if (err != 0){ \
free (*priv); \
*priv=NULL; \
} \
return err; \
} \
static int ssh_pthread_mutex_destroy (void **lock) { \
int err = pthread_mutex_destroy (*lock); \
free (*lock); \
*lock=NULL; \
return err; \
} \
static int ssh_pthread_mutex_lock (void **lock) { \
return pthread_mutex_lock (*lock); \
} \
static int ssh_pthread_mutex_unlock (void **lock){ \
return pthread_mutex_unlock (*lock); \
} \
static unsigned long ssh_pthread_thread_id (void){ \
return (unsigned long) pthread_self(); \
} \
static struct ssh_threads_callbacks_struct name= \
{ \
.mutex_init=ssh_pthread_mutex_init, \
.mutex_destroy=ssh_pthread_mutex_destroy, \
.mutex_lock=ssh_pthread_mutex_lock, \
.mutex_unlock=ssh_pthread_mutex_unlock, \
.thread_id=ssh_pthread_thread_id \
}
extern struct ssh_threads_callbacks_struct ssh_pthread_callbacks;
/** @} */
#ifdef __cplusplus