summaryrefslogtreecommitdiff
path: root/interface.h
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2011-03-29 01:16:59 +0200
committerFelix Fietkau <nbd@openwrt.org>2011-03-29 01:16:59 +0200
commitd5202486636818e3ff48ede9d3e06c886c659c0a (patch)
tree9cefcabc1a153efd38dcb295bf386e4cd5dfc37c /interface.h
parentf62eea9492a669bcf96464e85f04ae5e80190a76 (diff)
downloadnetifd-d5202486636818e3ff48ede9d3e06c886c659c0a.tar.gz
add rudimentary protocol handling
Diffstat (limited to 'interface.h')
-rw-r--r--interface.h28
1 files changed, 8 insertions, 20 deletions
diff --git a/interface.h b/interface.h
index dd72389..87a7cb3 100644
--- a/interface.h
+++ b/interface.h
@@ -2,31 +2,18 @@
#define __NETIFD_INTERFACE_H
struct interface;
-struct interface_proto;
struct interface_proto_state;
-extern struct list_head interfaces;
-
enum interface_event {
IFEV_UP,
IFEV_DOWN,
};
-enum interface_proto_event {
- PROTO_UP,
- PROTO_DOWN,
-};
-
-struct interface_proto_state {
- struct interface *iface;
- const struct interface_proto *proto;
-
- /* filled in by the protocol user */
- int (*proto_event)(struct interface_proto_state *, enum interface_proto_event ev);
-
- /* filled in by the protocol handler */
- int (*event)(struct interface_proto_state *, enum interface_event ev);
- void (*free)(struct interface_proto_state *);
+enum interface_state {
+ IFS_SETUP,
+ IFS_UP,
+ IFS_TEARDOWN,
+ IFS_DOWN,
};
struct interface_error {
@@ -45,10 +32,11 @@ struct interface {
char name[IFNAMSIZ];
- bool up;
bool active;
bool autostart;
+ enum interface_state state;
+
/* main interface that the interface is bound to */
struct device_user main_dev;
@@ -56,7 +44,7 @@ struct interface {
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;