projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
netifd: set current_config for simple devices when parsing device config
[project/netifd.git]
/
device.h
diff --git
a/device.h
b/device.h
index
6fceaa1
..
ca4cc11
100644
(file)
--- a/
device.h
+++ b/
device.h
@@
-11,8
+11,8
@@
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
-#ifndef __
LL
_H
-#define __
LL
_H
+#ifndef __
NETIFD_DEVICE
_H
+#define __
NETIFD_DEVICE
_H
#include <libubox/avl.h>
#include <libubox/safe_list.h>
#include <libubox/avl.h>
#include <libubox/safe_list.h>
@@
-32,6
+32,11
@@
enum {
DEV_ATTR_TXQUEUELEN,
DEV_ATTR_ENABLED,
DEV_ATTR_IPV6,
DEV_ATTR_TXQUEUELEN,
DEV_ATTR_ENABLED,
DEV_ATTR_IPV6,
+ DEV_ATTR_PROMISC,
+ DEV_ATTR_RPFILTER,
+ DEV_ATTR_ACCEPTLOCAL,
+ DEV_ATTR_IGMPVERSION,
+ DEV_ATTR_MLDVERSION,
__DEV_ATTR_MAX,
};
__DEV_ATTR_MAX,
};
@@
-46,6
+51,8
@@
struct device_type {
struct list_head list;
const char *name;
struct list_head list;
const char *name;
+ bool keep_link_status;
+
const struct uci_blob_param_list *config_params;
struct device *(*create)(const char *name, struct blob_attr *attr);
const struct uci_blob_param_list *config_params;
struct device *(*create)(const char *name, struct blob_attr *attr);
@@
-62,6
+69,11
@@
enum {
DEV_OPT_MACADDR = (1 << 1),
DEV_OPT_TXQUEUELEN = (1 << 2),
DEV_OPT_IPV6 = (1 << 3),
DEV_OPT_MACADDR = (1 << 1),
DEV_OPT_TXQUEUELEN = (1 << 2),
DEV_OPT_IPV6 = (1 << 3),
+ DEV_OPT_PROMISC = (1 << 4),
+ DEV_OPT_RPFILTER = (1 << 5),
+ DEV_OPT_ACCEPTLOCAL = (1 << 6),
+ DEV_OPT_IGMPVERSION = (1 << 7),
+ DEV_OPT_MLDVERSION = (1 << 8),
};
/* events broadcasted to all users of a device */
};
/* events broadcasted to all users of a device */
@@
-108,6
+120,11
@@
struct device_settings {
unsigned int txqueuelen;
uint8_t macaddr[6];
bool ipv6;
unsigned int txqueuelen;
uint8_t macaddr[6];
bool ipv6;
+ bool promisc;
+ unsigned int rpfilter;
+ bool acceptlocal;
+ unsigned int igmpversion;
+ unsigned int mldversion;
};
/*
};
/*
@@
-138,6
+155,7
@@
struct device {
bool current_config;
bool default_config;
bool current_config;
bool default_config;
+ bool wireless;
/* set interface up or down */
device_state_cb set_state;
/* set interface up or down */
device_state_cb set_state;
@@
-161,6
+179,7
@@
extern const struct device_type simple_device_type;
extern const struct device_type bridge_device_type;
extern const struct device_type tunnel_device_type;
extern const struct device_type macvlan_device_type;
extern const struct device_type bridge_device_type;
extern const struct device_type tunnel_device_type;
extern const struct device_type macvlan_device_type;
+extern const struct device_type vlandev_device_type;
void device_lock(void);
void device_unlock(void);
void device_lock(void);
void device_unlock(void);
@@
-173,6
+192,9
@@
void device_init_pending(void);
enum dev_change_type
device_set_config(struct device *dev, const struct device_type *type,
struct blob_attr *attr);
enum dev_change_type
device_set_config(struct device *dev, const struct device_type *type,
struct blob_attr *attr);
+enum dev_change_type
+device_apply_config(struct device *dev, const struct device_type *type,
+ struct blob_attr *config);
void device_reset_config(void);
void device_reset_old(void);
void device_reset_config(void);
void device_reset_old(void);