]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/repl.c
Use a separate mutex for the replication timestamp
[openldap] / servers / slapd / repl.c
index 6a54a9bb74948d4472aaafa156b0a5de2d4fce82..cb50ba6879c9dc825eefffd6e310963956f888c6 100644 (file)
@@ -116,10 +116,30 @@ add_replica_attrs(
        return ( be->be_replica[nr]->ri_attrs == NULL );
 }
    
+static struct timestamp {
+       long time;
+       long seq;
+} oldstamp;
+
 static void
 print_vals( FILE *fp, struct berval *type, struct berval *bv );
 static void
-replog1( struct slap_replica_info *ri, Operation *op, FILE *fp, long now);
+replog1( struct slap_replica_info *ri, Operation *op, FILE *fp );
+
+void
+repstamp( Operation *op )
+{
+       ldap_pvt_thread_mutex_lock( &repstamp_mutex );
+       op->o_time = slap_get_time();
+       if ( op->o_time == oldstamp.time ) {
+               op->o_tseq = ++oldstamp.seq;
+       } else {
+               oldstamp.time = op->o_time;
+               oldstamp.seq = 0;
+               op->o_tseq = 0;
+       }
+       ldap_pvt_thread_mutex_unlock( &repstamp_mutex );
+}
 
 void
 replog( Operation *op )
@@ -133,7 +153,6 @@ replog( Operation *op )
        int     count = 0;
 #endif
        int     subsets = 0;
-       long now = slap_get_time();
 
        if ( op->o_bd->be_replogfile == NULL && replogfile == NULL ) {
                return;
@@ -189,7 +208,7 @@ replog( Operation *op )
        }
 #endif
 
-       replog1( NULL, op, fp, now );
+       replog1( NULL, op, fp );
 
        if ( subsets > 0 ) {
                for ( i = subsets - 1; op->o_bd->be_replica[i] != NULL; i++ ) {
@@ -226,7 +245,7 @@ replog( Operation *op )
                                /* Other operations were logged in the first pass */
                                continue;
                        }
-                       replog1( op->o_bd->be_replica[i], op, fp, now );
+                       replog1( op->o_bd->be_replica[i], op, fp );
                }
        }
 
@@ -238,14 +257,13 @@ static void
 rephdr(
        struct slap_replica_info *ri,
        Operation *op,
-       FILE *fp,
-       long now
+       FILE *fp
 )
 {
        if ( ri ) {
                fprintf( fp, "replica: %s\n", ri->ri_host );
        }
-       fprintf( fp, "time: %ld\n", now );
+       fprintf( fp, "time: %ld.%ld\n", op->o_time, op->o_tseq );
        fprintf( fp, "dn: %s\n", op->o_req_dn.bv_val );
 }
 
@@ -253,8 +271,7 @@ static void
 replog1(
        struct slap_replica_info *ri,
        Operation *op,
-       FILE    *fp,
-       long    now
+       FILE    *fp
 )
 {
        Modifications   *ml;
@@ -328,7 +345,7 @@ replog1(
                                                /* Found a match, log it */
                                                if ( match ) {
                                                        if ( dohdr ) {
-                                                               rephdr( ri, op, fp, now );
+                                                               rephdr( ri, op, fp );
                                                                fprintf( fp, "changetype: modify\n" );
                                                                dohdr = 0;
                                                        }
@@ -352,7 +369,7 @@ replog1(
                                }
                        }
                        if ( dohdr ) {
-                               rephdr( ri, op, fp, now );
+                               rephdr( ri, op, fp );
                                fprintf( fp, "changetype: modify\n" );
                                dohdr = 0;
                        }
@@ -400,7 +417,7 @@ replog1(
                                                match ^= ri->ri_exclude;
                                                if ( match ) {
                                                        if ( dohdr ) {
-                                                               rephdr( ri, op, fp, now );
+                                                               rephdr( ri, op, fp );
                                                                fprintf( fp, "changetype: add\n" );
                                                                dohdr = 0;
                                                        }
@@ -412,7 +429,7 @@ replog1(
                                }
                        }
                        if ( dohdr ) {
-                               rephdr( ri, op, fp, now );
+                               rephdr( ri, op, fp );
                                fprintf( fp, "changetype: add\n" );
                                dohdr = 0;
                        }
@@ -421,12 +438,12 @@ replog1(
                break;
 
        case LDAP_REQ_DELETE:
-               rephdr( ri, op, fp, now );
+               rephdr( ri, op, fp );
                fprintf( fp, "changetype: delete\n" );
                break;
 
        case LDAP_REQ_MODRDN:
-               rephdr( ri, op, fp, now );
+               rephdr( ri, op, fp );
                fprintf( fp, "changetype: modrdn\n" );
                fprintf( fp, "newrdn: %s\n", op->orr_newrdn.bv_val );
                fprintf( fp, "deleteoldrdn: %d\n", op->orr_deleteoldrdn ? 1 : 0 );