Zbigniew Jędrzejewski-Szmek 62fe94
From 7f3d3ba1a61f28a951ca5fbe59ed15c7ce55219c Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: David Herrmann <dh.herrmann@gmail.com>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Mon, 22 Sep 2014 12:49:47 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] bus: align kdbus ioctl parameters to 8byte
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
All kdbus ioctl arguments must be 8byte aligned. Make sure we use
Zbigniew Jędrzejewski-Szmek 62fe94
alloca_align() and _alignas_(8) in all situations where gcc doesn't
Zbigniew Jędrzejewski-Szmek 62fe94
guarantee 8-byte alignment.
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Note that objects on the stack are always 8byte aligned as we put
Zbigniew Jędrzejewski-Szmek 62fe94
_alignas_(8) into the structure definition in kdbus.h.
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/libsystemd/sd-bus/bus-control.c | 14 +++++++-------
Zbigniew Jędrzejewski-Szmek 62fe94
 src/libsystemd/sd-bus/bus-kernel.c  | 26 ++++++++++++++------------
Zbigniew Jędrzejewski-Szmek 62fe94
 src/libsystemd/sd-bus/bus-message.c |  2 +-
Zbigniew Jędrzejewski-Szmek 62fe94
 3 files changed, 22 insertions(+), 20 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/libsystemd/sd-bus/bus-control.c b/src/libsystemd/sd-bus/bus-control.c
Zbigniew Jędrzejewski-Szmek 62fe94
index ad372f6772..5ac48c081f 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/libsystemd/sd-bus/bus-control.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/libsystemd/sd-bus/bus-control.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -60,7 +60,7 @@ static int bus_request_name_kernel(sd_bus *bus, const char *name, uint64_t flags
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         l = strlen(name);
Zbigniew Jędrzejewski-Szmek 62fe94
         size = offsetof(struct kdbus_cmd_name, name) + l + 1;
Zbigniew Jędrzejewski-Szmek 62fe94
-        n = alloca0(size);
Zbigniew Jędrzejewski-Szmek 62fe94
+        n = alloca0_align(size, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
         n->size = size;
Zbigniew Jędrzejewski-Szmek 62fe94
         kdbus_translate_request_name_flags(flags, (uint64_t *) &n->flags);
Zbigniew Jędrzejewski-Szmek 62fe94
         memcpy(n->name, name, l+1);
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -151,7 +151,7 @@ static int bus_release_name_kernel(sd_bus *bus, const char *name) {
Zbigniew Jędrzejewski-Szmek 62fe94
         assert(name);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         l = strlen(name);
Zbigniew Jędrzejewski-Szmek 62fe94
-        n = alloca0(offsetof(struct kdbus_cmd_name, name) + l + 1);
Zbigniew Jędrzejewski-Szmek 62fe94
+        n = alloca0_align(offsetof(struct kdbus_cmd_name, name) + l + 1, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
         n->size = offsetof(struct kdbus_cmd_name, name) + l + 1;
Zbigniew Jędrzejewski-Szmek 62fe94
         memcpy(n->name, name, l+1);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -376,11 +376,11 @@ static int bus_get_owner_kdbus(
Zbigniew Jędrzejewski-Szmek 62fe94
                 return r;
Zbigniew Jędrzejewski-Szmek 62fe94
         if (r > 0) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 size = offsetof(struct kdbus_cmd_conn_info, name);
Zbigniew Jędrzejewski-Szmek 62fe94
-                cmd = alloca0(size);
Zbigniew Jędrzejewski-Szmek 62fe94
+                cmd = alloca0_align(size, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
                 cmd->id = id;
Zbigniew Jędrzejewski-Szmek 62fe94
         } else {
Zbigniew Jędrzejewski-Szmek 62fe94
                 size = offsetof(struct kdbus_cmd_conn_info, name) + strlen(name) + 1;
Zbigniew Jędrzejewski-Szmek 62fe94
-                cmd = alloca0(size);
Zbigniew Jędrzejewski-Szmek 62fe94
+                cmd = alloca0_align(size, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
                 strcpy(cmd->name, name);
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -827,7 +827,7 @@ static int add_name_change_match(sd_bus *bus,
Zbigniew Jędrzejewski-Szmek 62fe94
                             offsetof(struct kdbus_notify_name_change, name) +
Zbigniew Jędrzejewski-Szmek 62fe94
                             l);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-                m = alloca0(sz);
Zbigniew Jędrzejewski-Szmek 62fe94
+                m = alloca0_align(sz, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
                 m->size = sz;
Zbigniew Jędrzejewski-Szmek 62fe94
                 m->cookie = cookie;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -887,7 +887,7 @@ static int add_name_change_match(sd_bus *bus,
Zbigniew Jędrzejewski-Szmek 62fe94
                             offsetof(struct kdbus_item, id_change) +
Zbigniew Jędrzejewski-Szmek 62fe94
                             sizeof(struct kdbus_notify_id_change));
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-                m = alloca0(sz);
Zbigniew Jędrzejewski-Szmek 62fe94
+                m = alloca0_align(sz, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
                 m->size = sz;
Zbigniew Jędrzejewski-Szmek 62fe94
                 m->cookie = cookie;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1057,7 +1057,7 @@ int bus_add_match_internal_kernel(
Zbigniew Jędrzejewski-Szmek 62fe94
         if (using_bloom)
Zbigniew Jędrzejewski-Szmek 62fe94
                 sz += ALIGN8(offsetof(struct kdbus_item, data64) + bus->bloom_size);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        m = alloca0(sz);
Zbigniew Jędrzejewski-Szmek 62fe94
+        m = alloca0_align(sz, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
         m->size = sz;
Zbigniew Jędrzejewski-Szmek 62fe94
         m->cookie = cookie;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/libsystemd/sd-bus/bus-kernel.c b/src/libsystemd/sd-bus/bus-kernel.c
Zbigniew Jędrzejewski-Szmek 62fe94
index b3cc996b1e..c30491e687 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/libsystemd/sd-bus/bus-kernel.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/libsystemd/sd-bus/bus-kernel.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -709,7 +709,7 @@ int bus_kernel_take_fd(sd_bus *b) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 sz += ALIGN8(offsetof(struct kdbus_item, str) + l + 1);
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        hello = alloca0(sz);
Zbigniew Jędrzejewski-Szmek 62fe94
+        hello = alloca0_align(sz, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
         hello->size = sz;
Zbigniew Jędrzejewski-Szmek 62fe94
         hello->conn_flags = b->hello_flags;
Zbigniew Jędrzejewski-Szmek 62fe94
         hello->attach_flags = b->attach_flags;
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -796,7 +796,7 @@ int bus_kernel_connect(sd_bus *b) {
Zbigniew Jędrzejewski-Szmek 62fe94
 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 static void close_kdbus_msg(sd_bus *bus, struct kdbus_msg *k) {
Zbigniew Jędrzejewski-Szmek 62fe94
-        uint64_t off;
Zbigniew Jędrzejewski-Szmek 62fe94
+        uint64_t off _alignas_(8);
Zbigniew Jędrzejewski-Szmek 62fe94
         struct kdbus_item *d;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         assert(bus);
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1268,10 +1268,11 @@ int bus_kernel_create_bus(const char *name, bool world, char **s) {
Zbigniew Jędrzejewski-Szmek 62fe94
         if (fd < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
                 return -errno;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        make = alloca0(ALIGN8(offsetof(struct kdbus_cmd_make, items) +
Zbigniew Jędrzejewski-Szmek 62fe94
-                              offsetof(struct kdbus_item, data64) + sizeof(uint64_t) +
Zbigniew Jędrzejewski-Szmek 62fe94
-                              offsetof(struct kdbus_item, str) +
Zbigniew Jędrzejewski-Szmek 62fe94
-                              DECIMAL_STR_MAX(uid_t) + 1 + strlen(name) + 1));
Zbigniew Jędrzejewski-Szmek 62fe94
+        make = alloca0_align(ALIGN8(offsetof(struct kdbus_cmd_make, items) +
Zbigniew Jędrzejewski-Szmek 62fe94
+                                    offsetof(struct kdbus_item, data64) + sizeof(uint64_t) +
Zbigniew Jędrzejewski-Szmek 62fe94
+                                    offsetof(struct kdbus_item, str) +
Zbigniew Jędrzejewski-Szmek 62fe94
+                                    DECIMAL_STR_MAX(uid_t) + 1 + strlen(name) + 1),
Zbigniew Jędrzejewski-Szmek 62fe94
+                             8);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         make->size = offsetof(struct kdbus_cmd_make, items);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1423,7 +1424,7 @@ int bus_kernel_create_endpoint(const char *bus_name, const char *ep_name, char *
Zbigniew Jędrzejewski-Szmek 62fe94
         size = ALIGN8(offsetof(struct kdbus_cmd_make, items));
Zbigniew Jędrzejewski-Szmek 62fe94
         size += ALIGN8(offsetof(struct kdbus_item, str) + strlen(ep_name) + 1);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        make = alloca0(size);
Zbigniew Jędrzejewski-Szmek 62fe94
+        make = alloca0_align(size, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
         make->size = size;
Zbigniew Jędrzejewski-Szmek 62fe94
         make->flags = KDBUS_MAKE_ACCESS_WORLD;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1472,7 +1473,7 @@ int bus_kernel_set_endpoint_policy(int fd, uid_t uid, BusEndpoint *ep) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 size += ALIGN8(offsetof(struct kdbus_item, policy_access) + sizeof(struct kdbus_policy_access));
Zbigniew Jędrzejewski-Szmek 62fe94
         }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        update = alloca0(size);
Zbigniew Jędrzejewski-Szmek 62fe94
+        update = alloca0_align(size, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
         update->size = size;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         n = update->items;
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1528,7 +1529,7 @@ int bus_kernel_make_starter(
Zbigniew Jędrzejewski-Szmek 62fe94
                ALIGN8(offsetof(struct kdbus_item, str) + strlen(name) + 1) +
Zbigniew Jędrzejewski-Szmek 62fe94
                policy_cnt * ALIGN8(offsetof(struct kdbus_item, policy_access) + sizeof(struct kdbus_policy_access));
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        hello = alloca0(size);
Zbigniew Jędrzejewski-Szmek 62fe94
+        hello = alloca0_align(size, 8);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         n = hello->items;
Zbigniew Jędrzejewski-Szmek 62fe94
         strcpy(n->str, name);
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1588,9 +1589,10 @@ int bus_kernel_create_domain(const char *name, char **s) {
Zbigniew Jędrzejewski-Szmek 62fe94
         if (fd < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
                 return -errno;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-        make = alloca0(ALIGN8(offsetof(struct kdbus_cmd_make, items) +
Zbigniew Jędrzejewski-Szmek 62fe94
-                              offsetof(struct kdbus_item, str) +
Zbigniew Jędrzejewski-Szmek 62fe94
-                              strlen(name) + 1));
Zbigniew Jędrzejewski-Szmek 62fe94
+        make = alloca0_align(ALIGN8(offsetof(struct kdbus_cmd_make, items) +
Zbigniew Jędrzejewski-Szmek 62fe94
+                                    offsetof(struct kdbus_item, str) +
Zbigniew Jędrzejewski-Szmek 62fe94
+                                    strlen(name) + 1),
Zbigniew Jędrzejewski-Szmek 62fe94
+                             8);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         n = make->items;
Zbigniew Jędrzejewski-Szmek 62fe94
         strcpy(n->str, name);
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/libsystemd/sd-bus/bus-message.c b/src/libsystemd/sd-bus/bus-message.c
Zbigniew Jędrzejewski-Szmek 62fe94
index 1fa3ad2611..400ba307bc 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/libsystemd/sd-bus/bus-message.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/libsystemd/sd-bus/bus-message.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -128,7 +128,7 @@ static void message_free(sd_bus_message *m) {
Zbigniew Jędrzejewski-Szmek 62fe94
         message_reset_parts(m);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
         if (m->release_kdbus) {
Zbigniew Jędrzejewski-Szmek 62fe94
-                uint64_t off;
Zbigniew Jędrzejewski-Szmek 62fe94
+                uint64_t off _alignas_(8);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
                 off = (uint8_t *)m->kdbus - (uint8_t *)m->bus->kdbus_buffer;
Zbigniew Jędrzejewski-Szmek 62fe94
                 ioctl(m->bus->input_fd, KDBUS_CMD_FREE, &off;;