]> git.sur5r.net Git - openldap/commitdiff
ITS#8864 Fix ber_realloc after a partial ber_flush
authorOndřej Kuzník <okuznik@symas.com>
Fri, 8 Jun 2018 11:51:35 +0000 (12:51 +0100)
committerOndřej Kuzník <ondra@openldap.org>
Thu, 14 Jun 2018 16:07:19 +0000 (17:07 +0100)
libraries/liblber/io.c

index e44a46c3b17890056f6eec5f14a69761a24c97eb..84777940223ad8e1eca679fa2a269499af548efd 100644 (file)
@@ -128,7 +128,7 @@ ber_write(
 int
 ber_realloc( BerElement *ber, ber_len_t len )
 {
-       ber_len_t       total, offset, sos_offset;
+       ber_len_t       total, offset, sos_offset, rw_offset;
        char            *buf;
 
        assert( ber != NULL );
@@ -165,6 +165,7 @@ ber_realloc( BerElement *ber, ber_len_t len )
        offset = ber->ber_ptr - buf;
        sos_offset = ber->ber_sos_ptr ? ber->ber_sos_ptr - buf : 0;
        /* if ber_sos_ptr != NULL, it is > ber_buf so that sos_offset > 0 */
+       rw_offset = ber->ber_rwptr ? ber->ber_rwptr - buf : 0;
 
        buf = (char *) ber_memrealloc_x( buf, total, ber->ber_memctx );
        if ( buf == NULL ) {
@@ -176,6 +177,8 @@ ber_realloc( BerElement *ber, ber_len_t len )
        ber->ber_ptr = buf + offset;
        if ( sos_offset )
                ber->ber_sos_ptr = buf + sos_offset;
+       if ( ber->ber_rwptr )
+               ber->ber_rwptr = buf + rw_offset;
 
        return( 0 );
 }