projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add some code for parsing static ipaddr/ip6addr/netmask
[project/netifd.git]
/
interface.h
diff --git
a/interface.h
b/interface.h
index
b3a86f2
..
e3b5ff7
100644
(file)
--- a/
interface.h
+++ b/
interface.h
@@
-1,22
+1,21
@@
#ifndef __NETIFD_INTERFACE_H
#define __NETIFD_INTERFACE_H
#ifndef __NETIFD_INTERFACE_H
#define __NETIFD_INTERFACE_H
+#include "device.h"
+
struct interface;
struct interface;
-struct interface_proto;
struct interface_proto_state;
struct interface_proto_state;
-extern struct list_head interfaces;
-
enum interface_event {
IFEV_UP,
IFEV_DOWN,
};
enum interface_event {
IFEV_UP,
IFEV_DOWN,
};
-
struct interface_proto
_state {
- const struct interface_proto *proto;
-
- int (*event)(struct interface *, struct interface_proto_state *, enum interface_event ev);
- void (*free)(struct interface *, struct interface_proto_state *);
+
enum interface
_state {
+ IFS_SETUP,
+ IFS_UP,
+ IFS_TEARDOWN,
+ IFS_DOWN,
};
struct interface_error {
};
struct interface_error {
@@
-33,17
+32,13
@@
struct interface_error {
struct interface {
struct list_head list;
struct interface {
struct list_head list;
- char name[IFNAMSIZ - 2];
-
- /* interface is up and running */
- bool up;
+ char name[IFNAMSIZ];
- /* interface can be brought up */
bool active;
bool active;
-
- /* interface will be brought up when available */
bool autostart;
bool autostart;
+ enum interface_state state;
+
/* 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;
@@
-51,7
+46,7
@@
struct interface {
struct device_user *l3_iface;
/* primary protocol state */
struct device_user *l3_iface;
/* primary protocol state */
- struct interface_proto_state *
state
;
+ struct interface_proto_state *
proto
;
/* 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;
@@
-60,9
+55,11
@@
struct interface {
};
struct interface *get_interface(const char *name);
};
struct interface *get_interface(const char *name);
-struct interface *alloc_interface(const char *name);
+struct interface *alloc_interface(const char *name
, struct uci_section *s
);
void free_interface(struct interface *iface);
void free_interface(struct interface *iface);
+void interface_set_proto_state(struct interface *iface, struct interface_proto_state *state);
+
int set_interface_up(struct interface *iface);
int set_interface_down(struct interface *iface);
int set_interface_up(struct interface *iface);
int set_interface_down(struct interface *iface);
@@
-74,4
+71,6
@@
void interface_add_error(struct interface *iface, const char *subsystem,
int interface_attach_bridge(struct interface *iface, struct uci_section *s);
int interface_attach_bridge(struct interface *iface, struct uci_section *s);
+void start_pending_interfaces(void);
+
#endif
#endif