projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix source-restrictions of routes when no mask was provided
[project/netifd.git]
/
interface.h
diff --git
a/interface.h
b/interface.h
index
efd3560
..
c3a4379
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,
};
@@
-40,6
+41,13
@@
enum interface_config_state {
IFC_REMOVE
};
IFC_REMOVE
};
+enum interface_update_flags {
+ IUF_ADDRESS = (1 << 0),
+ IUF_ROUTE = (1 << 1),
+ IUF_PREFIX = (1 << 2),
+ IUF_DATA = (1 << 3),
+};
+
struct interface_error {
struct list_head list;
struct interface_error {
struct list_head list;
@@
-59,9
+67,11
@@
struct interface_ip_settings {
bool enabled;
bool no_defaultroute;
bool no_dns;
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;
@@
-72,6
+82,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
*/
@@
-80,17
+95,19
@@
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;
bool device_config;
const char *ifname;
bool available;
bool autostart;
bool config_autostart;
bool device_config;
+ bool dynamic;
time_t start_time;
enum interface_state state;
enum interface_config_state config_state;
time_t start_time;
enum interface_state state;
enum interface_config_state config_state;
+ enum interface_update_flags updated;
struct list_head users;
struct list_head users;
@@
-114,6
+131,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;
@@
-125,11
+149,13
@@
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);
bool interface_add_alias(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);
@@
-149,6
+175,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);