projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
interface: clear iface->available before changing main_dev
[project/netifd.git]
/
interface.c
diff --git
a/interface.c
b/interface.c
index
684fd22
..
95e1ee8
100644
(file)
--- a/
interface.c
+++ b/
interface.c
@@
-775,15
+775,12
@@
interface_set_l3_dev(struct interface *iface, struct device *dev)
void
interface_set_main_dev(struct interface *iface, struct device *dev)
{
void
interface_set_main_dev(struct interface *iface, struct device *dev)
{
- bool set_l3 = (!dev || iface->main_dev.dev == iface->l3_dev.dev);
bool claimed = iface->l3_dev.claimed;
if (iface->main_dev.dev == dev)
return;
bool claimed = iface->l3_dev.claimed;
if (iface->main_dev.dev == dev)
return;
- if (set_l3)
- interface_set_l3_dev(iface, dev);
-
+ interface_set_available(iface, false);
device_add_user(&iface->main_dev, dev);
if (!dev) {
interface_set_link_state(iface, false);
device_add_user(&iface->main_dev, dev);
if (!dev) {
interface_set_link_state(iface, false);
@@
-811,7
+808,7
@@
interface_remove_link(struct interface *iface, struct device *dev)
if (dev != iface->main_dev.dev)
return UBUS_STATUS_INVALID_ARGUMENT;
if (dev != iface->main_dev.dev)
return UBUS_STATUS_INVALID_ARGUMENT;
-
device_remove_user(&iface->main_dev
);
+
interface_set_main_dev(iface, NULL
);
return 0;
}
return 0;
}