summaryrefslogtreecommitdiff
path: root/src/libunixonacid/unixmessage_put.c
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2015-01-09 17:00:34 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2015-01-09 17:00:34 +0000
commit978416c7e201d8261f9ecf512169f384261b1a9a (patch)
treeb3f3ad55cca0b4dfedfdac0e8d5e05307f2836c4 /src/libunixonacid/unixmessage_put.c
parentb59ce39f9779cf4b1ad423783b6a532f94a8e880 (diff)
downloadskalibs-978416c7e201d8261f9ecf512169f384261b1a9a.tar.xz
Bugfix: unixmessage_put was recording the wrong number of fds
Diffstat (limited to 'src/libunixonacid/unixmessage_put.c')
-rw-r--r--src/libunixonacid/unixmessage_put.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/libunixonacid/unixmessage_put.c b/src/libunixonacid/unixmessage_put.c
index 908bc31..015264a 100644
--- a/src/libunixonacid/unixmessage_put.c
+++ b/src/libunixonacid/unixmessage_put.c
@@ -49,7 +49,7 @@ static inline int copyfds (char *s, int const *fds, unsigned int n, unsigned cha
static int reserve_and_copy (unixmessage_sender_t *b, unsigned int len, int const *fds, unsigned int nfds, unsigned char const *bits)
{
- diuint cur = { .left = b->data.len, .right = b->fds.len } ;
+ diuint cur = { .left = b->data.len, .right = genalloc_len(int, &b->fds) } ;
if (len > UNIXMESSAGE_MAXSIZE || nfds > UNIXMESSAGE_MAXFDS)
return (errno = EPROTO, 0) ;
if (!genalloc_readyplus(diuint, &b->offsets, 1)
@@ -57,7 +57,7 @@ static int reserve_and_copy (unixmessage_sender_t *b, unsigned int len, int cons
|| !stralloc_readyplus(&b->data, len))
return 0 ;
if (!copyfds(b->fds.s + b->fds.len, fds, nfds, bits)) return 0 ;
- b->fds.len += nfds * sizeof(int) ;
+ genalloc_setlen(int, &b->fds, cur.right + nfds) ;
byte_copy(b->offsets.s + b->offsets.len, sizeof(diuint), (char const *)&cur) ;
b->offsets.len += sizeof(diuint) ;
return 1 ;