From 5384d4b3d76424a466fe54da744dca8711ffa60f Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Sat, 30 Mar 2013 15:19:22 +0100 Subject: [PATCH] bus: if we recieve fds but fd passing is off, consider this an error --- src/libsystemd-bus/bus-socket.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/libsystemd-bus/bus-socket.c b/src/libsystemd-bus/bus-socket.c index 9512d2e318..de823d582f 100644 --- a/src/libsystemd-bus/bus-socket.c +++ b/src/libsystemd-bus/bus-socket.c @@ -542,6 +542,15 @@ int bus_socket_read_message(sd_bus *bus, sd_bus_message **m) { n = (cmsg->cmsg_len - CMSG_LEN(0)) / sizeof(int); + if (!bus->can_fds) { + /* Whut? We received fds but this + * isn't actually enabled? Close them, + * and fail */ + + close_many((int*) CMSG_DATA(cmsg), n); + return -EIO; + } + f = realloc(bus->fds, sizeof(int) + (bus->n_fds + n)); if (!f) { close_many((int*) CMSG_DATA(cmsg), n);