summaryrefslogtreecommitdiff
path: root/src/network/networkd.h
diff options
context:
space:
mode:
authorTom Gundersen <teg@jklm.no>2013-11-14 16:22:51 +0100
committerTom Gundersen <teg@jklm.no>2013-11-17 23:12:27 +0100
commitf882c247ad59776c3a7753bb963c1f8e2386cb79 (patch)
treefa042fb8ddef72319f7a66aa4c267fa8824c5995 /src/network/networkd.h
parent8cd11a0f0f4ca05199e1166f6a07472b296f7455 (diff)
networkd: make all calls async
Diffstat (limited to 'src/network/networkd.h')
-rw-r--r--src/network/networkd.h23
1 files changed, 20 insertions, 3 deletions
diff --git a/src/network/networkd.h b/src/network/networkd.h
index c019ceca76..7c23793cf9 100644
--- a/src/network/networkd.h
+++ b/src/network/networkd.h
@@ -87,6 +87,17 @@ struct Route {
LIST_FIELDS(Route, routes);
};
+typedef enum LinkState {
+ LINK_STATE_SET_ADDRESSES,
+ LINK_STATE_ADDRESSES_SET,
+ LINK_STATE_SET_ROUTES,
+ LINK_STATE_ROUTES_SET,
+ LINK_STATE_CONFIGURED,
+ LINK_STATE_FAILED,
+ _LINK_STATE_MAX,
+ _LINK_STATE_INVALID = -1
+} LinkState;
+
struct Link {
Manager *manager;
@@ -96,6 +107,10 @@ struct Link {
unsigned flags;
Network *network;
+
+ LinkState state;
+
+ unsigned rtnl_messages;
};
struct Manager {
@@ -120,6 +135,8 @@ void manager_free(Manager *m);
int manager_udev_enumerate_links(Manager *m);
int manager_udev_listen(Manager *m);
+int manager_rtnl_listen(Manager *m);
+
DEFINE_TRIVIAL_CLEANUP_FUNC(Manager*, manager_free);
#define _cleanup_manager_free_ _cleanup_(manager_freep)
@@ -141,7 +158,7 @@ const struct ConfigPerfItem* network_gperf_lookup(const char *key, unsigned leng
/* Route */
int route_new(Network *network, Route **ret);
void route_free(Route *route);
-int route_configure(Manager *manager, Route *route, Link *link);
+int route_configure(Route *route, Link *link, sd_rtnl_message_handler_t callback);
DEFINE_TRIVIAL_CLEANUP_FUNC(Route*, route_free);
#define _cleanup_route_free_ _cleanup_(route_freep)
@@ -153,7 +170,7 @@ int config_parse_gateway(const char *unit, const char *filename, unsigned line,
/* Address */
int address_new(Network *network, Address **ret);
void address_free(Address *address);
-int address_configure(Manager *manager, Address *address, Link *link);
+int address_configure(Address *address, Link *link, sd_rtnl_message_handler_t callback);
DEFINE_TRIVIAL_CLEANUP_FUNC(Address*, address_free);
#define _cleanup_address_free_ _cleanup_(address_freep)
@@ -167,7 +184,7 @@ int config_parse_address(const char *unit, const char *filename, unsigned line,
int link_new(Manager *manager, struct udev_device *device, Link **ret);
void link_free(Link *link);
int link_add(Manager *manager, struct udev_device *device);
-int link_up(Manager *manager, Link *link);
+int link_configure(Link *link);
DEFINE_TRIVIAL_CLEANUP_FUNC(Link*, link_free);
#define _cleanup_link_free_ _cleanup_(link_freep)