Diff for /servers/slapd/overlays/syncprov.c between versions 1.56.2.35 and 1.56.2.36

version 1.56.2.35, 2006/07/31 18:27:42 version 1.56.2.36, 2006/08/15 17:11:10
Line 1 Line 1
 /* $OpenLDAP: pkg/ldap/servers/slapd/overlays/syncprov.c,v 1.56.2.34 2006/07/28 22:11:19 quanah Exp $ */  /* $OpenLDAP: pkg/ldap/servers/slapd/overlays/syncprov.c,v 1.157 2006/08/15 10:37:59 hyc Exp $ */
 /* syncprov.c - syncrepl provider */  /* syncprov.c - syncrepl provider */
 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.  /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
  *   *
Line 911  syncprov_qtask( void *ctx, void *arg ) Line 911  syncprov_qtask( void *ctx, void *arg )
         return NULL;          return NULL;
 }  }
   
   /* Start the task to play back queued psearch responses */
   static void
   syncprov_qstart( syncops *so )
   {
           int wake=0;
           ldap_pvt_thread_mutex_lock( &slapd_rq.rq_mutex );
           if ( !so->s_qtask ) {
                   so->s_qtask = ldap_pvt_runqueue_insert( &slapd_rq, RUNQ_INTERVAL,
                           syncprov_qtask, so, "syncprov_qtask",
                           so->s_op->o_conn->c_peer_name.bv_val );
                   ++so->s_inuse;
                   wake = 1;
           } else {
                   if (!ldap_pvt_runqueue_isrunning( &slapd_rq, so->s_qtask ) &&
                           !so->s_qtask->next_sched.tv_sec ) {
                           so->s_qtask->interval.tv_sec = 0;
                           ldap_pvt_runqueue_resched( &slapd_rq, so->s_qtask, 0 );
                           so->s_qtask->interval.tv_sec = RUNQ_INTERVAL;
                           ++so->s_inuse;
                           wake = 1;
                   }
           }
           ldap_pvt_thread_mutex_unlock( &slapd_rq.rq_mutex );
           if ( wake )
                   slap_wake_listener();
   }
   
 /* Queue a persistent search response */  /* Queue a persistent search response */
 static int  static int
 syncprov_qresp( opcookie *opc, syncops *so, int mode )  syncprov_qresp( opcookie *opc, syncops *so, int mode )
Line 949  syncprov_qresp( opcookie *opc, syncops * Line 976  syncprov_qresp( opcookie *opc, syncops *
                 so->s_flags |= PS_FIND_BASE;                  so->s_flags |= PS_FIND_BASE;
         }          }
         if ( so->s_flags & PS_IS_DETACHED ) {          if ( so->s_flags & PS_IS_DETACHED ) {
                 int wake=0;                  syncprov_qstart( so );
                 ldap_pvt_thread_mutex_lock( &slapd_rq.rq_mutex );  
                 if ( !so->s_qtask ) {  
                         so->s_qtask = ldap_pvt_runqueue_insert( &slapd_rq, RUNQ_INTERVAL,  
                                 syncprov_qtask, so, "syncprov_qtask",  
                                 so->s_op->o_conn->c_peer_name.bv_val );  
                         ++so->s_inuse;  
                         wake = 1;  
                 } else {  
                         if (!ldap_pvt_runqueue_isrunning( &slapd_rq, so->s_qtask ) &&  
                                 !so->s_qtask->next_sched.tv_sec ) {  
                                 so->s_qtask->interval.tv_sec = 0;  
                                 ldap_pvt_runqueue_resched( &slapd_rq, so->s_qtask, 0 );  
                                 so->s_qtask->interval.tv_sec = RUNQ_INTERVAL;  
                                 ++so->s_inuse;  
                                 wake = 1;  
                         }  
                 }  
                 ldap_pvt_thread_mutex_unlock( &slapd_rq.rq_mutex );  
                 if ( wake )  
                         slap_wake_listener();  
         }          }
         ldap_pvt_thread_mutex_unlock( &so->s_mutex );          ldap_pvt_thread_mutex_unlock( &so->s_mutex );
         return LDAP_SUCCESS;          return LDAP_SUCCESS;
Line 1489  syncprov_op_response( Operation *op, Sla Line 1496  syncprov_op_response( Operation *op, Sla
                 /* Update our context CSN */                  /* Update our context CSN */
                 cbuf[0] = '\0';                  cbuf[0] = '\0';
                 ldap_pvt_thread_mutex_lock( &si->si_csn_mutex );                  ldap_pvt_thread_mutex_lock( &si->si_csn_mutex );
                 slap_get_commit_csn( op, &maxcsn, NULL );                  slap_get_commit_csn( op, &maxcsn );
                 if ( !BER_BVISNULL( &maxcsn ) ) {                  if ( !BER_BVISNULL( &maxcsn ) ) {
                         strcpy( cbuf, maxcsn.bv_val );                          strcpy( cbuf, maxcsn.bv_val );
                         if ( ber_bvcmp( &maxcsn, &si->si_ctxcsn ) > 0 ) {                          if ( ber_bvcmp( &maxcsn, &si->si_ctxcsn ) > 0 ) {
Line 1877  syncprov_search_response( Operation *op, Line 1884  syncprov_search_response( Operation *op,
                         op->o_tmpfree( cookie.bv_val, op->o_tmpmemctx );                          op->o_tmpfree( cookie.bv_val, op->o_tmpmemctx );
                 } else {                  } else {
                 /* It's RefreshAndPersist, transition to Persist phase */                  /* It's RefreshAndPersist, transition to Persist phase */
                         syncprov_sendinfo( op, rs, ( ss->ss_present && rs->sr_nentries ) ?                          syncprov_sendinfo( op, rs, ss->ss_present ?
                                 LDAP_TAG_SYNC_REFRESH_PRESENT : LDAP_TAG_SYNC_REFRESH_DELETE,                                  LDAP_TAG_SYNC_REFRESH_PRESENT : LDAP_TAG_SYNC_REFRESH_DELETE,
                                 &cookie, 1, NULL, 0 );                                  &cookie, 1, NULL, 0 );
                         op->o_tmpfree( cookie.bv_val, op->o_tmpmemctx );                          op->o_tmpfree( cookie.bv_val, op->o_tmpmemctx );
Line 1889  syncprov_search_response( Operation *op, Line 1896  syncprov_search_response( Operation *op,
                         ss->ss_so->s_flags ^= PS_IS_REFRESHING;                          ss->ss_so->s_flags ^= PS_IS_REFRESHING;
   
                         syncprov_detach_op( op, ss->ss_so, on );                          syncprov_detach_op( op, ss->ss_so, on );
   
                           /* If there are queued responses, fire them off */
                           if ( ss->ss_so->s_res )
                                   syncprov_qstart( ss->ss_so );
                         ldap_pvt_thread_mutex_unlock( &ss->ss_so->s_mutex );                          ldap_pvt_thread_mutex_unlock( &ss->ss_so->s_mutex );
   
                         return LDAP_SUCCESS;                          return LDAP_SUCCESS;
Line 1996  syncprov_op_search( Operation *op, SlapR Line 2007  syncprov_op_search( Operation *op, SlapR
                 sl=si->si_logs;                  sl=si->si_logs;
                 if ( sl ) {                  if ( sl ) {
                         ldap_pvt_thread_mutex_lock( &sl->sl_mutex );                          ldap_pvt_thread_mutex_lock( &sl->sl_mutex );
                         if ( ber_bvcmp( &srs->sr_state.ctxcsn, &sl->sl_mincsn ) >= 0 ) {                          /* Are there any log entries, and is the consumer state
                            * present in the session log?
                            */
                           if ( sl->sl_num > 0 && ber_bvcmp( &srs->sr_state.ctxcsn, &sl->sl_mincsn ) >= 0 ) {
                                 do_present = 0;                                  do_present = 0;
                                 /* mutex is unlocked in playlog */                                  /* mutex is unlocked in playlog */
                                 syncprov_playlog( op, rs, sl, srs, &ctxcsn );                                  syncprov_playlog( op, rs, sl, srs, &ctxcsn );

Removed from v.1.56.2.35  
changed lines
  Added in v.1.56.2.36


______________
© Copyright 1998-2020, OpenLDAP Foundation, info@OpenLDAP.org