X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=proto-static.c;h=3e33c3d872930d08b9e1bef907afa14c0db7507c;hp=86f2f20d2459f788a9736fa31d837370c13c8939;hb=a03216660797173fbe67866f75564e3fec9c1e8d;hpb=bfe5db1ea8018aaa940dc6e991110fac62b85516 diff --git a/proto-static.c b/proto-static.c index 86f2f20..3e33c3d 100644 --- a/proto-static.c +++ b/proto-static.c @@ -33,7 +33,11 @@ struct static_proto_state { static bool static_proto_setup(struct static_proto_state *state) { - return proto_apply_ip_settings(state->proto.iface, state->config, false) == 0; + struct interface *iface = state->proto.iface; + struct device *dev = iface->main_dev.dev; + + interface_set_l3_dev(iface, dev); + return proto_apply_static_ip_settings(state->proto.iface, state->config) == 0; } static int @@ -52,8 +56,10 @@ static_handler(struct interface_proto_state *proto, break; case PROTO_CMD_TEARDOWN: + case PROTO_CMD_RENEW: break; } + return ret; } @@ -94,7 +100,8 @@ error: static struct proto_handler static_proto = { .name = "static", - .flags = PROTO_FLAG_IMMEDIATE, + .flags = PROTO_FLAG_IMMEDIATE | + PROTO_FLAG_FORCE_LINK_DEFAULT, .config_params = &proto_ip_attr, .attach = static_attach, };