Diff for /servers/slapd/overlays/syncprov.c between versions 1.288 and 1.291

version 1.288, 2009/10/16 15:27:18 version 1.291, 2009/11/11 02:19:01
Line 1 Line 1
 /* $OpenLDAP: pkg/ldap/servers/slapd/overlays/syncprov.c,v 1.287 2009/08/18 21:48:17 ando Exp $ */  /* $OpenLDAP: pkg/ldap/servers/slapd/overlays/syncprov.c,v 1.290 2009/11/10 18:02:33 ando 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 124  typedef struct sessionlog { Line 124  typedef struct sessionlog {
 typedef struct syncprov_info_t {  typedef struct syncprov_info_t {
         syncops         *si_ops;          syncops         *si_ops;
         BerVarray       si_ctxcsn;      /* ldapsync context */          BerVarray       si_ctxcsn;      /* ldapsync context */
           struct berval   si_contextdn;
         int             *si_sids;          int             *si_sids;
         int             si_numcsns;          int             si_numcsns;
         int             si_chkops;      /* checkpointing info */          int             si_chkops;      /* checkpointing info */
Line 137  typedef struct syncprov_info_t { Line 138  typedef struct syncprov_info_t {
         ldap_pvt_thread_rdwr_t  si_csn_rwlock;          ldap_pvt_thread_rdwr_t  si_csn_rwlock;
         ldap_pvt_thread_mutex_t si_ops_mutex;          ldap_pvt_thread_mutex_t si_ops_mutex;
         ldap_pvt_thread_mutex_t si_mods_mutex;          ldap_pvt_thread_mutex_t si_mods_mutex;
           ldap_pvt_thread_mutex_t si_resp_mutex;
 } syncprov_info_t;  } syncprov_info_t;
   
 typedef struct opcookie {  typedef struct opcookie {
Line 1360  syncprov_checkpoint( Operation *op, Slap Line 1362  syncprov_checkpoint( Operation *op, Slap
         SlapReply rsm = { 0 };          SlapReply rsm = { 0 };
         slap_callback cb = {0};          slap_callback cb = {0};
         BackendDB be;          BackendDB be;
           struct berval ctxdn;
   
 #ifdef CHECK_CSN  #ifdef CHECK_CSN
         Syntax *syn = slap_schema.si_ad_contextCSN->ad_type->sat_syntax;          Syntax *syn = slap_schema.si_ad_contextCSN->ad_type->sat_syntax;
   
Line 1385  syncprov_checkpoint( Operation *op, Slap Line 1389  syncprov_checkpoint( Operation *op, Slap
         if ( SLAP_GLUE_SUBORDINATE( op->o_bd )) {          if ( SLAP_GLUE_SUBORDINATE( op->o_bd )) {
                 be = *on->on_info->oi_origdb;                  be = *on->on_info->oi_origdb;
                 opm.o_bd = &be;                  opm.o_bd = &be;
                   ctxdn = be.be_nsuffix[0];
           } else {
                   ctxdn = si->si_contextdn;
         }          }
         opm.o_req_dn = opm.o_bd->be_suffix[0];          opm.o_req_dn = ctxdn;
         opm.o_req_ndn = opm.o_bd->be_nsuffix[0];          opm.o_req_ndn = ctxdn;
         opm.o_bd->bd_info = on->on_info->oi_orig;          opm.o_bd->bd_info = on->on_info->oi_orig;
         opm.o_managedsait = SLAP_CONTROL_NONCRITICAL;          opm.o_managedsait = SLAP_CONTROL_NONCRITICAL;
         opm.o_no_schema_check = 1;          opm.o_no_schema_check = 1;
Line 1645  syncprov_op_response( Operation *op, Sla Line 1652  syncprov_op_response( Operation *op, Sla
                 char cbuf[LDAP_PVT_CSNSTR_BUFSIZE];                  char cbuf[LDAP_PVT_CSNSTR_BUFSIZE];
                 int do_check = 0, have_psearches, foundit, csn_changed = 0;                  int do_check = 0, have_psearches, foundit, csn_changed = 0;
   
                   ldap_pvt_thread_mutex_lock( &si->si_resp_mutex );
   
                 /* Update our context CSN */                  /* Update our context CSN */
                 cbuf[0] = '\0';                  cbuf[0] = '\0';
                 maxcsn.bv_val = cbuf;                  maxcsn.bv_val = cbuf;
Line 1698  syncprov_op_response( Operation *op, Sla Line 1707  syncprov_op_response( Operation *op, Sla
                                         }                                          }
                                 }                                  }
                         }                          }
                         return SLAP_CB_CONTINUE;                          goto leave;
                 }                  }
   
                 slap_get_commit_csn( op, &maxcsn, &foundit );                  slap_get_commit_csn( op, &maxcsn, &foundit );
Line 1751  syncprov_op_response( Operation *op, Sla Line 1760  syncprov_op_response( Operation *op, Sla
                 /* Don't do any processing for consumer contextCSN updates */                  /* Don't do any processing for consumer contextCSN updates */
                 if ( op->o_dont_replicate ) {                  if ( op->o_dont_replicate ) {
                         ldap_pvt_thread_rdwr_wunlock( &si->si_csn_rwlock );                          ldap_pvt_thread_rdwr_wunlock( &si->si_csn_rwlock );
                         return SLAP_CB_CONTINUE;                          goto leave;
                 }                  }
   
                 si->si_numops++;                  si->si_numops++;
Line 1760  syncprov_op_response( Operation *op, Sla Line 1769  syncprov_op_response( Operation *op, Sla
                          * it will deadlock                           * it will deadlock
                          */                           */
                         if ( op->o_tag != LDAP_REQ_ADD ||                          if ( op->o_tag != LDAP_REQ_ADD ||
                                 !dn_match( &op->o_req_ndn, &op->o_bd->be_nsuffix[0] )) {                                  !dn_match( &op->o_req_ndn, &si->si_contextdn )) {
                                 if ( si->si_chkops && si->si_numops >= si->si_chkops ) {                                  if ( si->si_chkops && si->si_numops >= si->si_chkops ) {
                                         do_check = 1;                                          do_check = 1;
                                         si->si_numops = 0;                                          si->si_numops = 0;
Line 1818  syncprov_op_response( Operation *op, Sla Line 1827  syncprov_op_response( Operation *op, Sla
                 if ( si->si_logs && op->o_tag != LDAP_REQ_ADD ) {                  if ( si->si_logs && op->o_tag != LDAP_REQ_ADD ) {
                         syncprov_add_slog( op );                          syncprov_add_slog( op );
                 }                  }
   leave:          ldap_pvt_thread_mutex_unlock( &si->si_resp_mutex );
         }          }
         return SLAP_CB_CONTINUE;          return SLAP_CB_CONTINUE;
 }  }
Line 1834  syncprov_op_compare( Operation *op, Slap Line 1843  syncprov_op_compare( Operation *op, Slap
         syncprov_info_t         *si = on->on_bi.bi_private;          syncprov_info_t         *si = on->on_bi.bi_private;
         int rc = SLAP_CB_CONTINUE;          int rc = SLAP_CB_CONTINUE;
   
         if ( dn_match( &op->o_req_ndn, op->o_bd->be_nsuffix ) &&          if ( dn_match( &op->o_req_ndn, &si->si_contextdn ) &&
                 op->oq_compare.rs_ava->aa_desc == slap_schema.si_ad_contextCSN )                  op->oq_compare.rs_ava->aa_desc == slap_schema.si_ad_contextCSN )
         {          {
                 Entry e = {0};                  Entry e = {0};
                 Attribute a = {0};                  Attribute a = {0};
   
                 e.e_name = op->o_bd->be_suffix[0];                  e.e_name = si->si_contextdn;
                 e.e_nname = op->o_bd->be_nsuffix[0];                  e.e_nname = si->si_contextdn;
                 e.e_attrs = &a;                  e.e_attrs = &a;
   
                 a.a_desc = slap_schema.si_ad_contextCSN;                  a.a_desc = slap_schema.si_ad_contextCSN;
Line 2580  syncprov_operational( Line 2589  syncprov_operational(
                 return SLAP_CB_CONTINUE;                  return SLAP_CB_CONTINUE;
   
         if ( rs->sr_entry &&          if ( rs->sr_entry &&
                 dn_match( &rs->sr_entry->e_nname, op->o_bd->be_nsuffix )) {                  dn_match( &rs->sr_entry->e_nname, &si->si_contextdn )) {
   
                 if ( SLAP_OPATTRS( rs->sr_attr_flags ) ||                  if ( SLAP_OPATTRS( rs->sr_attr_flags ) ||
                         ad_inlist( slap_schema.si_ad_contextCSN, rs->sr_attrs )) {                          ad_inlist( slap_schema.si_ad_contextCSN, rs->sr_attrs )) {
Line 2687  sp_cf_gen(ConfigArgs *c) Line 2696  sp_cf_gen(ConfigArgs *c)
                 case SP_CHKPT:                  case SP_CHKPT:
                         if ( si->si_chkops || si->si_chktime ) {                          if ( si->si_chkops || si->si_chktime ) {
                                 struct berval bv;                                  struct berval bv;
                                   /* we assume si_chktime is a multiple of 60
                                    * because the parsed value was originally
                                    * multiplied by 60 */
                                 bv.bv_len = snprintf( c->cr_msg, sizeof( c->cr_msg ),                                  bv.bv_len = snprintf( c->cr_msg, sizeof( c->cr_msg ),
                                         "%d %d", si->si_chkops, si->si_chktime );                                          "%d %d", si->si_chkops, si->si_chktime/60 );
                                 if ( bv.bv_len >= sizeof( c->cr_msg ) ) {                                  if ( bv.bv_len >= sizeof( c->cr_msg ) ) {
                                         rc = 1;                                          rc = 1;
                                 } else {                                  } else {
Line 2870  syncprov_db_open( Line 2882  syncprov_db_open(
         op->o_dn = be->be_rootdn;          op->o_dn = be->be_rootdn;
         op->o_ndn = be->be_rootndn;          op->o_ndn = be->be_rootndn;
   
         rc = overlay_entry_get_ov( op, be->be_nsuffix, NULL,          if ( SLAP_SYNC_SUBENTRY( be )) {
                   build_new_dn( &si->si_contextdn, be->be_nsuffix,
                           (struct berval *)&slap_ldapsync_cn_bv, NULL );
           } else {
                   si->si_contextdn = be->be_nsuffix[0];
           }
           rc = overlay_entry_get_ov( op, &si->si_contextdn, NULL,
                 slap_schema.si_ad_contextCSN, 0, &e, on );                  slap_schema.si_ad_contextCSN, 0, &e, on );
   
         if ( e ) {          if ( e ) {
Line 2975  syncprov_db_init( Line 2993  syncprov_db_init(
         ldap_pvt_thread_rdwr_init( &si->si_csn_rwlock );          ldap_pvt_thread_rdwr_init( &si->si_csn_rwlock );
         ldap_pvt_thread_mutex_init( &si->si_ops_mutex );          ldap_pvt_thread_mutex_init( &si->si_ops_mutex );
         ldap_pvt_thread_mutex_init( &si->si_mods_mutex );          ldap_pvt_thread_mutex_init( &si->si_mods_mutex );
           ldap_pvt_thread_mutex_init( &si->si_resp_mutex );
   
         csn_anlist[0].an_desc = slap_schema.si_ad_entryCSN;          csn_anlist[0].an_desc = slap_schema.si_ad_entryCSN;
         csn_anlist[0].an_name = slap_schema.si_ad_entryCSN->ad_cname;          csn_anlist[0].an_name = slap_schema.si_ad_entryCSN->ad_cname;
Line 3012  syncprov_db_destroy( Line 3031  syncprov_db_destroy(
                         ber_bvarray_free( si->si_ctxcsn );                          ber_bvarray_free( si->si_ctxcsn );
                 if ( si->si_sids )                  if ( si->si_sids )
                         ch_free( si->si_sids );                          ch_free( si->si_sids );
                   ldap_pvt_thread_mutex_destroy( &si->si_resp_mutex );
                 ldap_pvt_thread_mutex_destroy( &si->si_mods_mutex );                  ldap_pvt_thread_mutex_destroy( &si->si_mods_mutex );
                 ldap_pvt_thread_mutex_destroy( &si->si_ops_mutex );                  ldap_pvt_thread_mutex_destroy( &si->si_ops_mutex );
                 ldap_pvt_thread_rdwr_destroy( &si->si_csn_rwlock );                  ldap_pvt_thread_rdwr_destroy( &si->si_csn_rwlock );

Removed from v.1.288  
changed lines
  Added in v.1.291


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