projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
netifd: Link layer state support on interface level
[project/netifd.git]
/
interface.h
diff --git
a/interface.h
b/interface.h
index
6304eca
..
1004bdd
100644
(file)
--- a/
interface.h
+++ b/
interface.h
@@
-23,6
+23,7
@@
struct interface_proto_state;
enum interface_event {
IFEV_DOWN,
IFEV_UP,
enum interface_event {
IFEV_DOWN,
IFEV_UP,
+ IFEV_UPDATE,
IFEV_FREE,
IFEV_RELOAD,
};
IFEV_FREE,
IFEV_RELOAD,
};
@@
-58,9
+59,12
@@
struct interface_ip_settings {
struct interface *iface;
bool enabled;
bool no_defaultroute;
struct interface *iface;
bool enabled;
bool no_defaultroute;
+ bool no_dns;
+ bool no_delegation;
struct vlist_tree addr;
struct vlist_tree route;
struct vlist_tree addr;
struct vlist_tree route;
+ struct vlist_tree prefix;
struct vlist_simple_tree dns_servers;
struct vlist_simple_tree dns_search;
struct vlist_simple_tree dns_servers;
struct vlist_simple_tree dns_search;
@@
-71,6
+75,11
@@
struct interface_data {
struct blob_attr data[];
};
struct blob_attr data[];
};
+struct interface_assignment_class {
+ struct list_head head;
+ char name[];
+};
+
/*
* interface configuration
*/
/*
* interface configuration
*/
@@
-79,12
+88,16
@@
struct interface {
struct list_head hotplug_list;
enum interface_event hotplug_ev;
struct list_head hotplug_list;
enum interface_event hotplug_ev;
- c
har name[IFNAMSIZ]
;
+ c
onst char *name
;
const char *ifname;
bool available;
bool autostart;
bool config_autostart;
const char *ifname;
bool available;
bool autostart;
bool config_autostart;
+ bool device_config;
+ bool enabled;
+ bool link_state;
+ bool dynamic;
time_t start_time;
enum interface_state state;
time_t start_time;
enum interface_state state;
@@
-92,6
+105,9
@@
struct interface {
struct list_head users;
struct list_head users;
+ const char *parent_ifname;
+ struct interface_user parent_iface;
+
/* main interface that the interface is bound to */
struct device_user main_dev;
/* main interface that the interface is bound to */
struct device_user main_dev;
@@
-109,6
+125,13
@@
struct interface {
struct vlist_tree host_routes;
int metric;
struct vlist_tree host_routes;
int metric;
+ unsigned int ip4table;
+ unsigned int ip6table;
+
+ /* IPv6 assignment parameters */
+ uint8_t assignment_length;
+ int32_t assignment_hint;
+ struct list_head assignment_classes;
/* 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;
@@
-120,13
+143,16
@@
struct interface {
struct ubus_object ubus;
};
struct ubus_object ubus;
};
+
extern struct vlist_tree interfaces;
extern struct vlist_tree interfaces;
-extern const struct config_param_list interface_attr_list;
+extern const struct uci_blob_param_list interface_attr_list;
+
+struct interface *interface_alloc(const char *name, struct blob_attr *config);
-void interface_init(struct interface *iface, const char *name,
- struct blob_attr *config);
+void interface_set_dynamic(struct interface *iface);
void interface_add(struct interface *iface, struct blob_attr *config);
void interface_add(struct interface *iface, struct blob_attr *config);
+bool interface_add_alias(struct interface *iface, struct blob_attr *config);
void interface_set_proto_state(struct interface *iface, struct interface_proto_state *state);
void interface_set_proto_state(struct interface *iface, struct interface_proto_state *state);
@@
-143,6
+169,7
@@
void interface_remove_user(struct interface_user *dep);
int interface_add_link(struct interface *iface, struct device *dev);
int interface_remove_link(struct interface *iface, struct device *dev);
int interface_add_link(struct interface *iface, struct device *dev);
int interface_remove_link(struct interface *iface, struct device *dev);
+int interface_handle_link(struct interface *iface, const char *name, bool add);
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);