Zbigniew Jędrzejewski-Szmek f1004d
From 40885bb29e3f39fc06787075f666a0ec2ac35361 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek f1004d
From: Daniel Mack <daniel@zonque.org>
Zbigniew Jędrzejewski-Szmek f1004d
Date: Wed, 8 Oct 2014 15:32:41 +0200
Zbigniew Jędrzejewski-Szmek f1004d
Subject: [PATCH] sd-bus: sync kdbus.h (ABI break)
Zbigniew Jędrzejewski-Szmek f1004d
Zbigniew Jędrzejewski-Szmek f1004d
Sync kdbus.h once again. Two thing have changed:
Zbigniew Jędrzejewski-Szmek f1004d
Zbigniew Jędrzejewski-Szmek f1004d
 a) KDBUS_CMD_EP_* was renamed to KDBUS_CMD_ENDPOINT_*
Zbigniew Jędrzejewski-Szmek f1004d
 b) struct kdbus_cmd_hello and struct kdbus_cmd_make gained a
Zbigniew Jędrzejewski-Szmek f1004d
    'features' bitfield (which is currently unused)
Zbigniew Jędrzejewski-Szmek f1004d
---
Zbigniew Jędrzejewski-Szmek f1004d
 src/libsystemd/sd-bus/bus-kernel.c | 19 ++++++++++---------
Zbigniew Jędrzejewski-Szmek f1004d
 src/libsystemd/sd-bus/kdbus.h      | 16 ++++++++++------
Zbigniew Jędrzejewski-Szmek f1004d
 2 files changed, 20 insertions(+), 15 deletions(-)
Zbigniew Jędrzejewski-Szmek f1004d
Zbigniew Jędrzejewski-Szmek f1004d
diff --git a/src/libsystemd/sd-bus/bus-kernel.c b/src/libsystemd/sd-bus/bus-kernel.c
Zbigniew Jędrzejewski-Szmek f1004d
index b431d78139..c3dbc837d7 100644
Zbigniew Jędrzejewski-Szmek f1004d
--- a/src/libsystemd/sd-bus/bus-kernel.c
Zbigniew Jędrzejewski-Szmek f1004d
+++ b/src/libsystemd/sd-bus/bus-kernel.c
Zbigniew Jędrzejewski-Szmek f1004d
@@ -1307,9 +1307,9 @@ int bus_kernel_create_bus(const char *name, bool world, char **s) {
Zbigniew Jędrzejewski-Szmek f1004d
                 return -errno;
Zbigniew Jędrzejewski-Szmek f1004d
         }
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-        /* The higher 32bit of the flags field are considered
Zbigniew Jędrzejewski-Szmek f1004d
-         * 'incompatible flags'. Refuse them all for now. */
Zbigniew Jędrzejewski-Szmek f1004d
-        if (make->flags > 0xFFFFFFFFULL) {
Zbigniew Jędrzejewski-Szmek f1004d
+        /* The features field are considered 'incompatible flags'.
Zbigniew Jędrzejewski-Szmek f1004d
+         * Refuse them all for now. */
Zbigniew Jędrzejewski-Szmek f1004d
+        if (make->features) {
Zbigniew Jędrzejewski-Szmek f1004d
                 safe_close(fd);
Zbigniew Jędrzejewski-Szmek f1004d
                 return -ENOTSUP;
Zbigniew Jędrzejewski-Szmek f1004d
         }
Zbigniew Jędrzejewski-Szmek f1004d
@@ -1439,14 +1439,14 @@ int bus_kernel_create_endpoint(const char *bus_name, const char *ep_name, char *
Zbigniew Jędrzejewski-Szmek f1004d
         n->size = offsetof(struct kdbus_item, str) + strlen(ep_name) + 1;
Zbigniew Jędrzejewski-Szmek f1004d
         strcpy(n->str, ep_name);
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-        if (ioctl(fd, KDBUS_CMD_EP_MAKE, make) < 0) {
Zbigniew Jędrzejewski-Szmek f1004d
+        if (ioctl(fd, KDBUS_CMD_ENDPOINT_MAKE, make) < 0) {
Zbigniew Jędrzejewski-Szmek f1004d
                 safe_close(fd);
Zbigniew Jędrzejewski-Szmek f1004d
                 return -errno;
Zbigniew Jędrzejewski-Szmek f1004d
         }
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-        /* The higher 32bit of the flags field are considered
Zbigniew Jędrzejewski-Szmek f1004d
-         * 'incompatible flags'. Refuse them all for now. */
Zbigniew Jędrzejewski-Szmek f1004d
-        if (make->flags > 0xFFFFFFFFULL) {
Zbigniew Jędrzejewski-Szmek f1004d
+        /* The features field are considered 'incompatible flags'.
Zbigniew Jędrzejewski-Szmek f1004d
+         * Refuse them all for now. */
Zbigniew Jędrzejewski-Szmek f1004d
+        if (make->features) {
Zbigniew Jędrzejewski-Szmek f1004d
                 safe_close(fd);
Zbigniew Jędrzejewski-Szmek f1004d
                 return -ENOTSUP;
Zbigniew Jędrzejewski-Szmek f1004d
         }
Zbigniew Jędrzejewski-Szmek f1004d
@@ -1503,7 +1503,7 @@ int bus_kernel_set_endpoint_policy(int fd, uid_t uid, BusEndpoint *ep) {
Zbigniew Jędrzejewski-Szmek f1004d
                 n = KDBUS_ITEM_NEXT(n);
Zbigniew Jędrzejewski-Szmek f1004d
         }
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-        r = ioctl(fd, KDBUS_CMD_EP_UPDATE, update);
Zbigniew Jędrzejewski-Szmek f1004d
+        r = ioctl(fd, KDBUS_CMD_ENDPOINT_UPDATE, update);
Zbigniew Jędrzejewski-Szmek f1004d
         if (r < 0)
Zbigniew Jędrzejewski-Szmek f1004d
                 return -errno;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
@@ -1576,7 +1576,8 @@ int bus_kernel_make_starter(
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
         /* The higher 32bit of both flags fields are considered
Zbigniew Jędrzejewski-Szmek f1004d
          * 'incompatible flags'. Refuse them all for now. */
Zbigniew Jędrzejewski-Szmek f1004d
-        if (hello->bus_flags > 0xFFFFFFFFULL ||
Zbigniew Jędrzejewski-Szmek f1004d
+        if (hello->features ||
Zbigniew Jędrzejewski-Szmek f1004d
+            hello->bus_flags > 0xFFFFFFFFULL ||
Zbigniew Jędrzejewski-Szmek f1004d
             hello->conn_flags > 0xFFFFFFFFULL)
Zbigniew Jędrzejewski-Szmek f1004d
                 return -ENOTSUP;
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
diff --git a/src/libsystemd/sd-bus/kdbus.h b/src/libsystemd/sd-bus/kdbus.h
Zbigniew Jędrzejewski-Szmek f1004d
index 8994b5673d..79a17f3449 100644
Zbigniew Jędrzejewski-Szmek f1004d
--- a/src/libsystemd/sd-bus/kdbus.h
Zbigniew Jędrzejewski-Szmek f1004d
+++ b/src/libsystemd/sd-bus/kdbus.h
Zbigniew Jędrzejewski-Szmek f1004d
@@ -554,6 +554,7 @@ enum kdbus_attach_flags {
Zbigniew Jędrzejewski-Szmek f1004d
 /**
Zbigniew Jędrzejewski-Szmek f1004d
  * struct kdbus_cmd_hello - struct to say hello to kdbus
Zbigniew Jędrzejewski-Szmek f1004d
  * @size:		The total size of the structure
Zbigniew Jędrzejewski-Szmek f1004d
+ * @features:		Feature negotiation bitmask
Zbigniew Jędrzejewski-Szmek f1004d
  * @conn_flags:		Connection flags (KDBUS_HELLO_*).
Zbigniew Jędrzejewski-Szmek f1004d
  * @attach_flags:	Mask of metadata to attach to each message sent
Zbigniew Jędrzejewski-Szmek f1004d
  *			(KDBUS_ATTACH_*)
Zbigniew Jędrzejewski-Szmek f1004d
@@ -573,6 +574,7 @@ enum kdbus_attach_flags {
Zbigniew Jędrzejewski-Szmek f1004d
  */
Zbigniew Jędrzejewski-Szmek f1004d
 struct kdbus_cmd_hello {
Zbigniew Jędrzejewski-Szmek f1004d
 	__u64 size;
Zbigniew Jędrzejewski-Szmek f1004d
+	__u64 features;
Zbigniew Jędrzejewski-Szmek f1004d
 	__u64 conn_flags;
Zbigniew Jędrzejewski-Szmek f1004d
 	__u64 attach_flags;
Zbigniew Jędrzejewski-Szmek f1004d
 	__u64 bus_flags;
Zbigniew Jędrzejewski-Szmek f1004d
@@ -596,14 +598,16 @@ enum kdbus_make_flags {
Zbigniew Jędrzejewski-Szmek f1004d
 /**
Zbigniew Jędrzejewski-Szmek f1004d
  * struct kdbus_cmd_make - struct to make a bus, an endpoint or a domain
Zbigniew Jędrzejewski-Szmek f1004d
  * @size:		The total size of the struct
Zbigniew Jędrzejewski-Szmek f1004d
+ * @features:		Feature negotiation bitmask
Zbigniew Jędrzejewski-Szmek f1004d
  * @flags:		Properties for the bus/ep/domain to create
Zbigniew Jędrzejewski-Szmek f1004d
  * @items:		Items describing details
Zbigniew Jędrzejewski-Szmek f1004d
  *
Zbigniew Jędrzejewski-Szmek f1004d
- * This structure is used with the KDBUS_CMD_BUS_MAKE, KDBUS_CMD_EP_MAKE and
Zbigniew Jędrzejewski-Szmek f1004d
- * KDBUS_CMD_DOMAIN_MAKE ioctls.
Zbigniew Jędrzejewski-Szmek f1004d
+ * This structure is used with the KDBUS_CMD_BUS_MAKE, KDBUS_CMD_ENDPOINT_MAKE
Zbigniew Jędrzejewski-Szmek f1004d
+ * and KDBUS_CMD_DOMAIN_MAKE ioctls.
Zbigniew Jędrzejewski-Szmek f1004d
  */
Zbigniew Jędrzejewski-Szmek f1004d
 struct kdbus_cmd_make {
Zbigniew Jędrzejewski-Szmek f1004d
 	__u64 size;
Zbigniew Jędrzejewski-Szmek f1004d
+	__u64 features;
Zbigniew Jędrzejewski-Szmek f1004d
 	__u64 flags;
Zbigniew Jędrzejewski-Szmek f1004d
 	struct kdbus_item items[0];
Zbigniew Jędrzejewski-Szmek f1004d
 } __attribute__((aligned(8)));
Zbigniew Jędrzejewski-Szmek f1004d
@@ -775,7 +779,7 @@ struct kdbus_cmd_match {
Zbigniew Jędrzejewski-Szmek f1004d
  *				is closed.
Zbigniew Jędrzejewski-Szmek f1004d
  * @KDBUS_CMD_DOMAIN_MAKE:	Similar to KDBUS_CMD_BUS_MAKE, but it creates a
Zbigniew Jędrzejewski-Szmek f1004d
  *				new kdbus domain.
Zbigniew Jędrzejewski-Szmek f1004d
- * @KDBUS_CMD_EP_MAKE:		Creates a new named special endpoint to talk to
Zbigniew Jędrzejewski-Szmek f1004d
+ * @KDBUS_CMD_ENDPOINT_MAKE:	Creates a new named special endpoint to talk to
Zbigniew Jędrzejewski-Szmek f1004d
  *				the bus. Such endpoints usually carry a more
Zbigniew Jędrzejewski-Szmek f1004d
  *				restrictive policy and grant restricted access
Zbigniew Jędrzejewski-Szmek f1004d
  *				to specific applications.
Zbigniew Jędrzejewski-Szmek f1004d
@@ -811,7 +815,7 @@ struct kdbus_cmd_match {
Zbigniew Jędrzejewski-Szmek f1004d
  * @KDBUS_CMD_CONN_UPDATE:	Update the properties of a connection. Used to
Zbigniew Jędrzejewski-Szmek f1004d
  *				update the metadata subscription mask and
Zbigniew Jędrzejewski-Szmek f1004d
  *				policy.
Zbigniew Jędrzejewski-Szmek f1004d
- * @KDBUS_CMD_EP_UPDATE:	Update the properties of a custom enpoint. Used
Zbigniew Jędrzejewski-Szmek f1004d
+ * @KDBUS_CMD_ENDPOINT_UPDATE:	Update the properties of a custom enpoint. Used
Zbigniew Jędrzejewski-Szmek f1004d
  *				to update the policy.
Zbigniew Jędrzejewski-Szmek f1004d
  * @KDBUS_CMD_MATCH_ADD:	Install a match which broadcast messages should
Zbigniew Jędrzejewski-Szmek f1004d
  *				be delivered to the connection.
Zbigniew Jędrzejewski-Szmek f1004d
@@ -822,7 +826,7 @@ enum kdbus_ioctl_type {
Zbigniew Jędrzejewski-Szmek f1004d
 					     struct kdbus_cmd_make),
Zbigniew Jędrzejewski-Szmek f1004d
 	KDBUS_CMD_DOMAIN_MAKE =		_IOW(KDBUS_IOCTL_MAGIC, 0x10,
Zbigniew Jędrzejewski-Szmek f1004d
 					     struct kdbus_cmd_make),
Zbigniew Jędrzejewski-Szmek f1004d
-	KDBUS_CMD_EP_MAKE =		_IOW(KDBUS_IOCTL_MAGIC, 0x20,
Zbigniew Jędrzejewski-Szmek f1004d
+	KDBUS_CMD_ENDPOINT_MAKE =	_IOW(KDBUS_IOCTL_MAGIC, 0x20,
Zbigniew Jędrzejewski-Szmek f1004d
 					     struct kdbus_cmd_make),
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
 	KDBUS_CMD_HELLO =		_IOWR(KDBUS_IOCTL_MAGIC, 0x30,
Zbigniew Jędrzejewski-Szmek f1004d
@@ -850,7 +854,7 @@ enum kdbus_ioctl_type {
Zbigniew Jędrzejewski-Szmek f1004d
 	KDBUS_CMD_CONN_UPDATE =		_IOW(KDBUS_IOCTL_MAGIC, 0x61,
Zbigniew Jędrzejewski-Szmek f1004d
 					     struct kdbus_cmd_update),
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
-	KDBUS_CMD_EP_UPDATE =		_IOW(KDBUS_IOCTL_MAGIC, 0x71,
Zbigniew Jędrzejewski-Szmek f1004d
+	KDBUS_CMD_ENDPOINT_UPDATE =	_IOW(KDBUS_IOCTL_MAGIC, 0x71,
Zbigniew Jędrzejewski-Szmek f1004d
 					     struct kdbus_cmd_update),
Zbigniew Jędrzejewski-Szmek f1004d
 
Zbigniew Jędrzejewski-Szmek f1004d
 	KDBUS_CMD_MATCH_ADD =		_IOW(KDBUS_IOCTL_MAGIC, 0x80,