X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslurpd%2Freplica.c;h=50aca4e77ef72525b543b732f56e4f96f3dda049;hb=51190984eefbdbedd47185e41ece37f72773744d;hp=596d14d383e18af4e87f561a58c3a7416c3ea214;hpb=e4af28135dabef8037ae468e2b56e289d9818fd1;p=openldap diff --git a/servers/slurpd/replica.c b/servers/slurpd/replica.c index 596d14d383..50aca4e77e 100644 --- a/servers/slurpd/replica.c +++ b/servers/slurpd/replica.c @@ -1,3 +1,4 @@ +/* $OpenLDAP$ */ /* * Copyright (c) 1996 Regents of the University of Michigan. * All rights reserved. @@ -15,6 +16,7 @@ * replica.c - code to start up replica threads. */ +#include "portable.h" #include @@ -26,22 +28,21 @@ * Just invoke the Ri's process() member function, and log the start and * finish. */ -void +static void * replicate( - Ri *ri + void *ri_arg ) { - int i; - unsigned long seq; + Ri *ri = (Ri *) ri_arg; Debug( LDAP_DEBUG_ARGS, "begin replication thread for %s:%d\n", - ri->ri_hostname, ri->ri_port, 0 ); + ((Ri *)ri)->ri_hostname, ((Ri *)ri)->ri_port, 0 ); ri->ri_process( ri ); Debug( LDAP_DEBUG_ARGS, "end replication thread for %s:%d\n", ri->ri_hostname, ri->ri_port, 0 ); - return; + return NULL; } @@ -54,34 +55,13 @@ start_replica_thread( Ri *ri ) { - pthread_attr_t attr; - - pthread_attr_init( &attr ); - pthread_attr_setdetachstate( &attr, PTHREAD_CREATE_DETACHED ); - -#ifndef THREAD_MIT_PTHREADS - /* POSIX_THREADS or compatible - * This is a draft 10 or standard pthreads implementation - */ - if ( pthread_create( &(ri->ri_tid), &attr, (void *) replicate, + /* POSIX_THREADS or compatible */ + if ( ldap_pvt_thread_create( &(ri->ri_tid), 0, replicate, (void *) ri ) != 0 ) { - Debug( LDAP_DEBUG_ANY, "replica \"%s:%d\" pthread_create failed\n", + Debug( LDAP_DEBUG_ANY, "replica \"%s:%d\" ldap_pvt_thread_create failed\n", ri->ri_hostname, ri->ri_port, 0 ); - pthread_attr_destroy( &attr ); return -1; } -#else /* !THREAD_MIT_PTHREADS */ - /* - * This is a draft 4 or earlier pthreads implementation - */ - if ( pthread_create( &(ri->ri_tid), attr, (void *) replicate, - (void *) ri ) != 0 ) { - Debug( LDAP_DEBUG_ANY, "replica \"%s:%d\" pthread_create failed\n", - ri->ri_hostname, ri->ri_port, 0 ); - pthread_attr_destroy( &attr ); - return -1; - } -#endif /* !THREAD_MIT_PTHREADS */ - pthread_attr_destroy( &attr ); + return 0; }