]> git.sur5r.net Git - openldap/commitdiff
ITS#8158 Fix sendto() address length for CLDAP
authorHallvard Furuseth <h.b.furuseth@usit.uio.no>
Mon, 15 Jun 2015 17:57:48 +0000 (19:57 +0200)
committerHallvard Furuseth <h.b.furuseth@usit.uio.no>
Mon, 15 Jun 2015 17:57:48 +0000 (19:57 +0200)
libraries/liblber/sockbuf.c

index cbcaa9b5ea04141f1c6ffe1f5586a73a6579ae3b..79935f34ef9699d0e633b318a2b02b5be5ba4b92 100644 (file)
@@ -928,6 +928,7 @@ sb_dgram_write( Sockbuf_IO_Desc *sbiod, void *buf, ber_len_t len )
 {
        ber_slen_t rc;
        struct sockaddr *dst;
+       socklen_t dstsize;
    
        assert( sbiod != NULL );
        assert( SOCKBUF_VALID( sbiod->sbiod_sb ) );
@@ -936,9 +937,12 @@ sb_dgram_write( Sockbuf_IO_Desc *sbiod, void *buf, ber_len_t len )
        dst = buf;
        buf = (char *) buf + sizeof( struct sockaddr_storage );
        len -= sizeof( struct sockaddr_storage );
-   
-       rc = sendto( sbiod->sbiod_sb->sb_fd, buf, len, 0, dst,
-               sizeof( struct sockaddr_storage ) );
+       dstsize = dst->sa_family == AF_INET ? sizeof( struct sockaddr_in )
+#ifdef LDAP_PF_INET6
+               : dst->sa_family == AF_INET6 ? sizeof( struct sockaddr_in6 )
+#endif
+               : sizeof( struct sockaddr_storage );
+       rc = sendto( sbiod->sbiod_sb->sb_fd, buf, len, 0, dst, dstsize );
 
        if ( rc < 0 ) return -1;