projects
/
oweals
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
make sure iface->proto_handler is always initialized
[oweals/netifd.git]
/
interface.h
diff --git
a/interface.h
b/interface.h
index 8a009004f27e45f3dc0646c4e2811ce032f12869..4580c5b9e848710ddfe25994a4b6bb1fd3cbfb1e 100644
(file)
--- a/
interface.h
+++ b/
interface.h
@@
-39,6
+39,18
@@
struct interface_user {
void (*cb)(struct interface_user *dep, enum interface_event ev);
};
void (*cb)(struct interface_user *dep, enum interface_event ev);
};
+struct interface_ip_settings {
+ struct interface *iface;
+ bool enabled;
+ bool no_defaultroute;
+
+ struct vlist_tree addr;
+ struct vlist_tree route;
+
+ struct vlist_simple_tree dns_servers;
+ struct vlist_simple_tree dns_search;
+};
+
/*
* interface configuration
*/
/*
* interface configuration
*/
@@
-72,11
+84,8
@@
struct interface {
const struct proto_handler *proto_handler;
struct interface_proto_state *proto;
const struct proto_handler *proto_handler;
struct interface_proto_state *proto;
- struct vlist_tree proto_addr;
- struct vlist_tree proto_route;
-
- struct list_head proto_dns_servers;
- struct list_head proto_dns_search;
+ struct interface_ip_settings proto_ip;
+ struct interface_ip_settings config_ip;
/* errors/warnings while trying to bring up the interface */
struct list_head errors;
/* errors/warnings while trying to bring up the interface */
struct list_head errors;
@@
-110,6
+119,9
@@
void interface_remove_link(struct interface *iface, struct device *llif);
void interface_add_error(struct interface *iface, const char *subsystem,
const char *code, const char **data, int n_data);
void interface_add_error(struct interface *iface, const char *subsystem,
const char *code, const char **data, int n_data);
+void interface_update_start(struct interface *iface);
+void interface_update_complete(struct interface *iface);
+
void interface_queue_event(struct interface *iface, enum interface_event ev);
void interface_dequeue_event(struct interface *iface);
void interface_queue_event(struct interface *iface, enum interface_event ev);
void interface_dequeue_event(struct interface *iface);