From 16e421a30caae0e2968941c7bde48f512d9ec106 Mon Sep 17 00:00:00 2001 From: Hannes Reinecke Date: Tue, 19 Nov 2013 20:26:05 +0000 Subject: [PATCH 08/17] fipvlan: Start FCoE from netlink handler Whenever a VLAN or real device is found to have a FCF record we can go ahead and start FCoE. With this change we can remove the start_fcoe() loop. Signed-off-by: Hannes Reinecke Signed-off-by: Robert Love --- fipvlan.c | 83 ++++++++++++++++++++++++++++++++++++--------------------------- 1 file changed, 47 insertions(+), 36 deletions(-) diff --git a/fipvlan.c b/fipvlan.c index 501f79c..9261b1d 100644 --- a/fipvlan.c +++ b/fipvlan.c @@ -139,6 +139,7 @@ struct iff { bool req_sent; bool resp_recv; bool fip_ready; + bool fcoe_started; TAILQ_ENTRY(iff) list_node; struct iff_list_head vlans; }; @@ -367,8 +368,14 @@ static void rtnl_recv_newlink(struct nlmsghdr *nh) struct rtattr *linkinfo[__IFLA_INFO_MAX]; struct rtattr *vlan[__IFLA_VLAN_MAX]; struct iff *iff, *real_dev; + struct fcf_list_head *head; bool running; + if (config.vn2vn) + head = &vn2vns; + else + head = &fcfs; + FIP_LOG_DBG("RTM_NEWLINK: ifindex %d, type %d, flags %x", ifm->ifi_index, ifm->ifi_type, ifm->ifi_flags); @@ -383,12 +390,38 @@ static void rtnl_recv_newlink(struct nlmsghdr *nh) running = !!(ifm->ifi_flags & (IFF_RUNNING | IFF_SLAVE)); iff = lookup_iff(ifm->ifi_index, NULL); if (iff) { + int ifindex; + /* already tracking, update operstate and return */ iff->running = running; - if (iff->running) - pfd_add(iff->ps); - else + if (!iff->running) { pfd_remove(iff->ps); + return; + } + pfd_add(iff->ps); + if (!config.start) + return; + + FIP_LOG_DBG("Checking for FCoE on %sif %d", + iff->is_vlan ? "VLAN " : "", iff->ifindex); + if (iff->is_vlan) { + real_dev = find_vlan_real_dev(iff); + if (!real_dev) { + FIP_LOG_ERR(ENODEV, "VLAN %d without a parent", + iff->ifindex); + return; + } + ifindex = real_dev->ifindex; + } else + ifindex = iff->ifindex; + + if (!iff->fcoe_started && + lookup_fcf(head, ifindex, iff->vid, NULL)) { + printf("Starting FCoE on interface %s\n", + iff->ifname); + fcoe_instance_start(iff->ifname); + iff->fcoe_started = true; + } return; } @@ -588,11 +621,19 @@ create_and_start_vlan(struct fcf *fcf, bool vn2vn) } printf("Created VLAN device %s\n", vlan_name); } - if (config.start && !vlan->running) { - FIP_LOG_DBG("%s if %d not running, " - "starting", vlan == real_dev ? "real" : "vlan", + if (!config.start) + return rc; + + if (!vlan->running) { + FIP_LOG_DBG("%s if %d not running, starting", + vlan == real_dev ? "real" : "vlan", vlan->ifindex); rtnl_set_iff_up(vlan->ifindex, NULL); + } else if (!vlan->fcoe_started) { + printf("Starting FCoE on interface %s\n", + vlan->ifname); + fcoe_instance_start(vlan->ifname); + vlan->fcoe_started = true; } return rc; } @@ -669,34 +710,6 @@ static void determine_libfcoe_interface(void) } } -static void start_fcoe(void) -{ - struct fcf_list_head *head; - struct fcf *fcf; - struct iff *iff; - - if (config.vn2vn) - head = &vn2vns; - else - head = &fcfs; - - TAILQ_FOREACH(fcf, head, list_node) { - if (fcf->vlan) - iff = lookup_vlan(fcf->ifindex, fcf->vlan); - else - iff = lookup_iff(fcf->ifindex, NULL); - if (!iff) { - FIP_LOG_ERR(ENODEV, - "Cannot start FCoE on VLAN %d, ifindex %d, " - "because the VLAN device does not exist", - fcf->vlan, fcf->ifindex); - continue; - } - printf("Starting FCoE on interface %s\n", iff->ifname); - fcoe_instance_start(iff->ifname); - } -} - static void print_list(struct fcf_list_head *list, const char *label) { struct iff *iff; @@ -948,8 +961,6 @@ int main(int argc, char **argv) do_vlan_discovery(); rc = print_results(); - if (!rc && config.start) - start_fcoe(); cleanup_interfaces(); -- 1.8.1.4