Lines Matching refs:fcoe
291 static int fcoe_interface_setup(struct fcoe_interface *fcoe, in fcoe_interface_setup() argument
294 struct fcoe_ctlr *fip = fcoe_to_ctlr(fcoe); in fcoe_interface_setup()
300 fcoe->netdev = netdev; in fcoe_interface_setup()
319 fcoe->realdev = real_dev; in fcoe_interface_setup()
353 fcoe->fcoe_packet_type.func = fcoe_rcv; in fcoe_interface_setup()
354 fcoe->fcoe_packet_type.type = htons(ETH_P_FCOE); in fcoe_interface_setup()
355 fcoe->fcoe_packet_type.dev = netdev; in fcoe_interface_setup()
356 dev_add_pack(&fcoe->fcoe_packet_type); in fcoe_interface_setup()
358 fcoe->fip_packet_type.func = fcoe_fip_recv; in fcoe_interface_setup()
359 fcoe->fip_packet_type.type = htons(ETH_P_FIP); in fcoe_interface_setup()
360 fcoe->fip_packet_type.dev = netdev; in fcoe_interface_setup()
361 dev_add_pack(&fcoe->fip_packet_type); in fcoe_interface_setup()
364 fcoe->fip_vlan_packet_type.func = fcoe_fip_vlan_recv; in fcoe_interface_setup()
365 fcoe->fip_vlan_packet_type.type = htons(ETH_P_FIP); in fcoe_interface_setup()
366 fcoe->fip_vlan_packet_type.dev = real_dev; in fcoe_interface_setup()
367 dev_add_pack(&fcoe->fip_vlan_packet_type); in fcoe_interface_setup()
384 struct fcoe_interface *fcoe; in fcoe_interface_create() local
391 fcoe = ERR_PTR(-EBUSY); in fcoe_interface_create()
400 fcoe = ERR_PTR(-ENOMEM); in fcoe_interface_create()
406 fcoe = fcoe_ctlr_priv(ctlr); in fcoe_interface_create()
418 err = fcoe_interface_setup(fcoe, netdev); in fcoe_interface_create()
423 fcoe = ERR_PTR(err); in fcoe_interface_create()
432 return fcoe; in fcoe_interface_create()
441 static void fcoe_interface_remove(struct fcoe_interface *fcoe) in fcoe_interface_remove() argument
443 struct net_device *netdev = fcoe->netdev; in fcoe_interface_remove()
444 struct fcoe_ctlr *fip = fcoe_to_ctlr(fcoe); in fcoe_interface_remove()
454 __dev_remove_pack(&fcoe->fcoe_packet_type); in fcoe_interface_remove()
455 __dev_remove_pack(&fcoe->fip_packet_type); in fcoe_interface_remove()
456 if (netdev != fcoe->realdev) in fcoe_interface_remove()
457 __dev_remove_pack(&fcoe->fip_vlan_packet_type); in fcoe_interface_remove()
477 fcoe->removed = 1; in fcoe_interface_remove()
485 static void fcoe_interface_cleanup(struct fcoe_interface *fcoe) in fcoe_interface_cleanup() argument
487 struct net_device *netdev = fcoe->netdev; in fcoe_interface_cleanup()
488 struct fcoe_ctlr *fip = fcoe_to_ctlr(fcoe); in fcoe_interface_cleanup()
512 struct fcoe_interface *fcoe; in fcoe_fip_recv() local
515 fcoe = container_of(ptype, struct fcoe_interface, fip_packet_type); in fcoe_fip_recv()
516 ctlr = fcoe_to_ctlr(fcoe); in fcoe_fip_recv()
535 struct fcoe_interface *fcoe; in fcoe_fip_vlan_recv() local
538 fcoe = container_of(ptype, struct fcoe_interface, fip_vlan_packet_type); in fcoe_fip_vlan_recv()
539 ctlr = fcoe_to_ctlr(fcoe); in fcoe_fip_vlan_recv()
564 struct fcoe_interface *fcoe = fcoe_from_ctlr(fip); in fcoe_fip_send() local
576 fcoe->realdev != fcoe->netdev) in fcoe_fip_send()
577 skb->dev = fcoe->realdev; in fcoe_fip_send()
579 skb->dev = fcoe->netdev; in fcoe_fip_send()
594 struct fcoe_interface *fcoe = port->priv; in fcoe_update_src_mac() local
597 dev_uc_del(fcoe->netdev, port->data_src_addr); in fcoe_update_src_mac()
599 dev_uc_add(fcoe->netdev, addr); in fcoe_update_src_mac()
704 struct fcoe_interface *fcoe; in fcoe_netdev_config() local
710 fcoe = port->priv; in fcoe_netdev_config()
711 ctlr = fcoe_to_ctlr(fcoe); in fcoe_netdev_config()
808 struct fcoe_interface *fcoe; in fcoe_fdmi_info() local
814 fcoe = port->priv; in fcoe_fdmi_info()
815 realdev = fcoe->realdev; in fcoe_fdmi_info()
923 struct fcoe_interface *fcoe = port->priv; in fcoe_em_config() local
943 if (is_vlan_dev(fcoe->netdev)) in fcoe_em_config()
944 cur_real_dev = vlan_dev_real_dev(fcoe->netdev); in fcoe_em_config()
946 cur_real_dev = fcoe->netdev; in fcoe_em_config()
955 fcoe->oem = oldfcoe->oem; in fcoe_em_config()
960 if (fcoe->oem) { in fcoe_em_config()
961 if (!fc_exch_mgr_add(lport, fcoe->oem, fcoe_oem_match)) { in fcoe_em_config()
964 fcoe->oem, fcoe->netdev->name); in fcoe_em_config()
968 fcoe->oem = fc_exch_mgr_alloc(lport, FC_CLASS_3, in fcoe_em_config()
971 if (!fcoe->oem) { in fcoe_em_config()
974 fcoe->netdev->name); in fcoe_em_config()
987 "allocate em on interface %s\n", fcoe->netdev->name); in fcoe_em_config()
1004 struct fcoe_interface *fcoe = port->priv; in fcoe_if_destroy() local
1005 struct net_device *netdev = fcoe->netdev; in fcoe_if_destroy()
1026 fcoe_interface_remove(fcoe); in fcoe_if_destroy()
1122 static struct fc_lport *fcoe_if_create(struct fcoe_interface *fcoe, in fcoe_if_create() argument
1125 struct fcoe_ctlr *ctlr = fcoe_to_ctlr(fcoe); in fcoe_if_create()
1126 struct net_device *netdev = fcoe->netdev; in fcoe_if_create()
1151 port->priv = fcoe; in fcoe_if_create()
1320 struct fcoe_interface *fcoe; in fcoe_rcv() local
1326 fcoe = container_of(ptype, struct fcoe_interface, fcoe_packet_type); in fcoe_rcv()
1327 ctlr = fcoe_to_ctlr(fcoe); in fcoe_rcv()
1462 struct fcoe_interface *fcoe = port->priv; in fcoe_xmit() local
1463 struct fcoe_ctlr *ctlr = fcoe_to_ctlr(fcoe); in fcoe_xmit()
1528 skb->priority = fcoe->priority; in fcoe_xmit()
1530 if (is_vlan_dev(fcoe->netdev) && in fcoe_xmit()
1531 fcoe->realdev->features & NETIF_F_HW_VLAN_CTAG_TX) { in fcoe_xmit()
1533 skb->dev = fcoe->realdev; in fcoe_xmit()
1535 vlan_dev_vlan_id(fcoe->netdev)); in fcoe_xmit()
1537 skb->dev = fcoe->netdev; in fcoe_xmit()
1586 struct fcoe_interface *fcoe; in fcoe_filter_frames() local
1604 fcoe = ((struct fcoe_port *)lport_priv(lport))->priv; in fcoe_filter_frames()
1605 ctlr = fcoe_to_ctlr(fcoe); in fcoe_filter_frames()
1747 struct fcoe_interface *fcoe; in fcoe_hostlist_lookup_realdev_port() local
1750 list_for_each_entry(fcoe, &fcoe_hostlist, list) { in fcoe_hostlist_lookup_realdev_port()
1751 if (is_vlan_dev(fcoe->netdev)) in fcoe_hostlist_lookup_realdev_port()
1752 real_dev = vlan_dev_real_dev(fcoe->netdev); in fcoe_hostlist_lookup_realdev_port()
1754 real_dev = fcoe->netdev; in fcoe_hostlist_lookup_realdev_port()
1757 return fcoe; in fcoe_hostlist_lookup_realdev_port()
1767 struct fcoe_interface *fcoe; in fcoe_dcb_app_notification() local
1778 fcoe = fcoe_hostlist_lookup_realdev_port(netdev); in fcoe_dcb_app_notification()
1780 if (!fcoe) in fcoe_dcb_app_notification()
1783 ctlr = fcoe_to_ctlr(fcoe); in fcoe_dcb_app_notification()
1798 fcoe->priority = prio; in fcoe_dcb_app_notification()
1820 struct fcoe_interface *fcoe; in fcoe_device_notification() local
1825 list_for_each_entry(fcoe, &fcoe_hostlist, list) { in fcoe_device_notification()
1826 if (fcoe->netdev == netdev) { in fcoe_device_notification()
1827 ctlr = fcoe_to_ctlr(fcoe); in fcoe_device_notification()
1856 list_del(&fcoe->list); in fcoe_device_notification()
1860 if (!fcoe->removed) in fcoe_device_notification()
1861 fcoe_interface_remove(fcoe); in fcoe_device_notification()
1862 fcoe_interface_cleanup(fcoe); in fcoe_device_notification()
1915 struct fcoe_interface *fcoe; in fcoe_disable() local
1921 fcoe = fcoe_hostlist_lookup_port(netdev); in fcoe_disable()
1924 if (fcoe) { in fcoe_disable()
1925 ctlr = fcoe_to_ctlr(fcoe); in fcoe_disable()
1946 struct fcoe_interface *fcoe; in fcoe_enable() local
1951 fcoe = fcoe_hostlist_lookup_port(netdev); in fcoe_enable()
1954 if (!fcoe) { in fcoe_enable()
1959 ctlr = fcoe_to_ctlr(fcoe); in fcoe_enable()
2007 struct fcoe_interface *fcoe = fcoe_ctlr_priv(ctlr); in fcoe_ctlr_mode() local
2011 dev_mc_del(fcoe->netdev, FIP_ALL_ENODE_MACS); in fcoe_ctlr_mode()
2012 dev_mc_add(fcoe->netdev, FIP_ALL_VN2VN_MACS); in fcoe_ctlr_mode()
2013 dev_mc_add(fcoe->netdev, FIP_ALL_P2P_MACS); in fcoe_ctlr_mode()
2015 dev_mc_del(fcoe->netdev, FIP_ALL_VN2VN_MACS); in fcoe_ctlr_mode()
2016 dev_mc_del(fcoe->netdev, FIP_ALL_P2P_MACS); in fcoe_ctlr_mode()
2017 dev_mc_add(fcoe->netdev, FIP_ALL_ENODE_MACS); in fcoe_ctlr_mode()
2033 struct fcoe_interface *fcoe; in fcoe_destroy() local
2040 fcoe = fcoe_hostlist_lookup_port(netdev); in fcoe_destroy()
2041 if (!fcoe) { in fcoe_destroy()
2045 ctlr = fcoe_to_ctlr(fcoe); in fcoe_destroy()
2048 list_del(&fcoe->list); in fcoe_destroy()
2065 struct fcoe_interface *fcoe; in fcoe_destroy_work() local
2073 fcoe = port->priv; in fcoe_destroy_work()
2074 ctlr = fcoe_to_ctlr(fcoe); in fcoe_destroy_work()
2079 if (!fcoe->removed) in fcoe_destroy_work()
2080 fcoe_interface_remove(fcoe); in fcoe_destroy_work()
2082 fcoe_interface_cleanup(fcoe); in fcoe_destroy_work()
2107 static void fcoe_dcb_create(struct fcoe_interface *fcoe) in fcoe_dcb_create() argument
2111 struct fcoe_ctlr *ctlr = fcoe_to_ctlr(fcoe); in fcoe_dcb_create()
2115 struct net_device *netdev = fcoe->realdev; in fcoe_dcb_create()
2141 fcoe->priority = fcoe_prio; in fcoe_dcb_create()
2169 struct fcoe_interface *fcoe; in _fcoe_create() local
2181 fcoe = fcoe_interface_create(netdev, fip_mode); in _fcoe_create()
2182 if (IS_ERR(fcoe)) { in _fcoe_create()
2183 rc = PTR_ERR(fcoe); in _fcoe_create()
2187 ctlr = fcoe_to_ctlr(fcoe); in _fcoe_create()
2189 lport = fcoe_if_create(fcoe, &ctlr_dev->dev, 0); in _fcoe_create()
2194 if (!fcoe->removed) in _fcoe_create()
2195 fcoe_interface_remove(fcoe); in _fcoe_create()
2197 fcoe_interface_cleanup(fcoe); in _fcoe_create()
2207 fcoe_dcb_create(fcoe); in _fcoe_create()
2324 struct fcoe_interface *fcoe = port->priv; in fcoe_reset() local
2325 struct fcoe_ctlr *ctlr = fcoe_to_ctlr(fcoe); in fcoe_reset()
2348 struct fcoe_interface *fcoe; in fcoe_hostlist_lookup_port() local
2350 list_for_each_entry(fcoe, &fcoe_hostlist, list) { in fcoe_hostlist_lookup_port()
2351 if (fcoe->netdev == netdev) in fcoe_hostlist_lookup_port()
2352 return fcoe; in fcoe_hostlist_lookup_port()
2369 struct fcoe_interface *fcoe; in fcoe_hostlist_lookup() local
2371 fcoe = fcoe_hostlist_lookup_port(netdev); in fcoe_hostlist_lookup()
2372 ctlr = fcoe_to_ctlr(fcoe); in fcoe_hostlist_lookup()
2373 return (fcoe) ? ctlr->lp : NULL; in fcoe_hostlist_lookup()
2387 struct fcoe_interface *fcoe; in fcoe_hostlist_add() local
2390 fcoe = fcoe_hostlist_lookup_port(fcoe_netdev(lport)); in fcoe_hostlist_add()
2391 if (!fcoe) { in fcoe_hostlist_add()
2393 fcoe = port->priv; in fcoe_hostlist_add()
2394 list_add_tail(&fcoe->list, &fcoe_hostlist); in fcoe_hostlist_add()
2409 struct fcoe_interface *fcoe; in fcoe_hostlist_del() local
2413 fcoe = port->priv; in fcoe_hostlist_del()
2414 list_del(&fcoe->list); in fcoe_hostlist_del()
2488 struct fcoe_interface *fcoe, *tmp; in fcoe_exit() local
2499 list_for_each_entry_safe(fcoe, tmp, &fcoe_hostlist, list) { in fcoe_exit()
2500 ctlr = fcoe_to_ctlr(fcoe); in fcoe_exit()
2595 struct fcoe_interface *fcoe = port->priv; in fcoe_elsct_send() local
2596 struct fcoe_ctlr *fip = fcoe_to_ctlr(fcoe); in fcoe_elsct_send()
2628 struct fcoe_interface *fcoe = port->priv; in fcoe_vport_create() local
2629 struct net_device *netdev = fcoe->netdev; in fcoe_vport_create()
2645 vn_port = fcoe_if_create(fcoe, &vport->dev, 1); in fcoe_vport_create()
2778 struct fcoe_interface *fcoe = fcoe_ctlr_priv(ctlr); in fcoe_fcf_get_vlan_id() local
2780 fcf_dev->vlan_id = vlan_dev_vlan_id(fcoe->netdev); in fcoe_fcf_get_vlan_id()
2799 struct fcoe_interface *fcoe = port->priv; in fcoe_set_port_id() local
2800 struct fcoe_ctlr *ctlr = fcoe_to_ctlr(fcoe); in fcoe_set_port_id()