diff options
Diffstat (limited to 'src/shared')
| -rw-r--r-- | src/shared/bus-util.c | 34 | ||||
| -rw-r--r-- | src/shared/bus-util.h | 28 | 
2 files changed, 60 insertions, 2 deletions
| diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c index 1bcb8903f3..1369a61458 100644 --- a/src/shared/bus-util.c +++ b/src/shared/bus-util.c @@ -2032,3 +2032,37 @@ int bus_path_decode_unique(const char *path, const char *prefix, char **ret_send          *ret_external = external;          return 1;  } + +bool is_kdbus_wanted(void) { +        _cleanup_free_ char *value = NULL; +#ifdef ENABLE_KDBUS +        const bool configured = true; +#else +        const bool configured = false; +#endif + +        int r; + +        if (get_proc_cmdline_key("kdbus", NULL) > 0) +                return true; + +        r = get_proc_cmdline_key("kdbus=", &value); +        if (r <= 0) +                return configured; + +        return parse_boolean(value) == 1; +} + +bool is_kdbus_available(void) { +        _cleanup_close_ int fd = -1; +        struct kdbus_cmd cmd = { .size = sizeof(cmd), .flags = KDBUS_FLAG_NEGOTIATE }; + +        if (!is_kdbus_wanted()) +                return false; + +        fd = open("/sys/fs/kdbus/control", O_RDWR | O_CLOEXEC | O_NONBLOCK | O_NOCTTY); +        if (fd < 0) +                return false; + +        return ioctl(fd, KDBUS_CMD_BUS_MAKE, &cmd) >= 0; +} diff --git a/src/shared/bus-util.h b/src/shared/bus-util.h index 0c683c0713..4ae216b7d9 100644 --- a/src/shared/bus-util.h +++ b/src/shared/bus-util.h @@ -23,12 +23,18 @@  #include "sd-event.h"  #include "sd-bus.h" -#include "bus-error.h" -#include "bus-internal.h"  #include "hashmap.h"  #include "install.h"  #include "time-util.h" +typedef enum BusTransport { +        BUS_TRANSPORT_LOCAL, +        BUS_TRANSPORT_REMOTE, +        BUS_TRANSPORT_MACHINE, +        _BUS_TRANSPORT_MAX, +        _BUS_TRANSPORT_INVALID = -1 +} BusTransport; +  typedef int (*bus_property_set_t) (sd_bus *bus, const char *member, sd_bus_message *m, sd_bus_error *error, void *userdata);  struct bus_properties_map { @@ -129,6 +135,21 @@ typedef struct UnitInfo {  int bus_parse_unit_info(sd_bus_message *message, UnitInfo *u); +DEFINE_TRIVIAL_CLEANUP_FUNC(sd_bus*, sd_bus_unref); +DEFINE_TRIVIAL_CLEANUP_FUNC(sd_bus*, sd_bus_flush_close_unref); +DEFINE_TRIVIAL_CLEANUP_FUNC(sd_bus_slot*, sd_bus_slot_unref); +DEFINE_TRIVIAL_CLEANUP_FUNC(sd_bus_message*, sd_bus_message_unref); +DEFINE_TRIVIAL_CLEANUP_FUNC(sd_bus_creds*, sd_bus_creds_unref); +DEFINE_TRIVIAL_CLEANUP_FUNC(sd_bus_track*, sd_bus_track_unref); + +#define _cleanup_bus_unref_ _cleanup_(sd_bus_unrefp) +#define _cleanup_bus_flush_close_unref_ _cleanup_(sd_bus_flush_close_unrefp) +#define _cleanup_bus_slot_unref_ _cleanup_(sd_bus_slot_unrefp) +#define _cleanup_bus_message_unref_ _cleanup_(sd_bus_message_unrefp) +#define _cleanup_bus_creds_unref_ _cleanup_(sd_bus_creds_unrefp) +#define _cleanup_bus_track_unref_ _cleanup_(sd_bus_slot_unrefp) +#define _cleanup_bus_error_free_ _cleanup_(sd_bus_error_free) +  #define BUS_DEFINE_PROPERTY_GET_ENUM(function, name, type)              \          int function(sd_bus *bus,                                       \                       const char *path,                                  \ @@ -176,3 +197,6 @@ int bus_deserialize_and_dump_unit_file_changes(sd_bus_message *m, bool quiet, Un  int bus_path_encode_unique(sd_bus *b, const char *prefix, const char *sender_id, const char *external_id, char **ret_path);  int bus_path_decode_unique(const char *path, const char *prefix, char **ret_sender, char **ret_external); + +bool is_kdbus_wanted(void); +bool is_kdbus_available(void); | 
