From: Lennart Poettering Date: Tue, 14 May 2013 22:46:24 +0000 (+0200) Subject: bus: seal off memfds when sealing messages X-Git-Tag: v205~247 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=47e6ce32bb5bc8353c2070b8247be82410f4d78e bus: seal off memfds when sealing messages --- diff --git a/src/libsystemd-bus/bus-message.c b/src/libsystemd-bus/bus-message.c index e0fb1f41d..5783140cf 100644 --- a/src/libsystemd-bus/bus-message.c +++ b/src/libsystemd-bus/bus-message.c @@ -3555,8 +3555,10 @@ int bus_message_parse_fields(sd_bus_message *m) { } int bus_message_seal(sd_bus_message *m, uint64_t serial) { - int r; + struct bus_body_part *part; size_t l, a; + unsigned i; + int r; assert(m); @@ -3595,6 +3597,10 @@ int bus_message_seal(sd_bus_message *m, uint64_t serial) { m->header->fields_size -= a; } + for (i = 0, part = &m->body; i < m->n_body_parts; i++, part = part->next) + if (part->memfd >= 0 && part->sealed) + ioctl(part->memfd, KDBUS_CMD_MEMFD_SEAL_SET, 1); + m->header->serial = serial; m->sealed = true;