|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From 581fe6c8176c6ea4ad998566df0746bf7b56456f Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From: Daniel Mack <daniel@zonque.org>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Date: Thu, 2 Oct 2014 13:02:41 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Subject: [PATCH] sd-bus: sync kdbus.h (ABI break)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
struct kdbus_cmd_conn_info takes a list of items now instead of a string.
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Fix the only user in SD of that ioctl.
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/libsystemd/sd-bus/bus-control.c | 10 +++++++---
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/libsystemd/sd-bus/kdbus.h | 2 +-
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
2 files changed, 8 insertions(+), 4 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 4ad44469b5..d9a53c702f 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 |
@@ -389,13 +389,17 @@ static int bus_get_owner_kdbus(
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (r < 0)
|
|
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 |
+ size = offsetof(struct kdbus_cmd_conn_info, items);
|
|
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 |
+ size_t item_size = KDBUS_ITEM_HEADER_SIZE + strlen(name) + 1;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ size = offsetof(struct kdbus_cmd_conn_info, items) + item_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 |
+ cmd->items[0].size = item_size;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ cmd->items[0].type = KDBUS_ITEM_NAME;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ strcpy(cmd->items[0].str, name);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
cmd->size = size;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/libsystemd/sd-bus/kdbus.h b/src/libsystemd/sd-bus/kdbus.h
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 7fb11713fc..c97994974b 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/libsystemd/sd-bus/kdbus.h
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/libsystemd/sd-bus/kdbus.h
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -681,7 +681,7 @@ struct kdbus_cmd_conn_info {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
__u64 flags;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
__u64 id;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
__u64 offset;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- char name[0];
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ struct kdbus_item items[0];
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
} __attribute__((aligned(8)));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
/**
|