]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
bnx2x: Implementation for netdev->ndo_fcoe_get_wwn
authorVladislav Zolotarov <vladz@broadcom.com>
Thu, 21 Jul 2011 07:56:51 +0000 (07:56 +0000)
committerBob Picco <bob.picco@oracle.com>
Fri, 3 Feb 2012 18:19:22 +0000 (13:19 -0500)
(
note this was hand merged. should we need ndo_setup_tc then
revert/reapply and/or merge away.
)

Signed-off-by: Vladislav Zolotarov <vladz@broadcom.com>
Signed-off-by: Eilon Greenstein <eilong@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/bnx2x/bnx2x_cmn.c
drivers/net/bnx2x/bnx2x_cmn.h
drivers/net/bnx2x/bnx2x_main.c
drivers/net/cnic_if.h

index 787835e5a7721fcef3112dbce08739f3f2ccfee8..9137b0afa5a6ae771e2609388cc2cb1e117a5e5d 100644 (file)
@@ -3153,6 +3153,29 @@ int bnx2x_get_link_cfg_idx(struct bnx2x *bp)
        return LINK_CONFIG_IDX(sel_phy_idx);
 }
 
+#if defined(NETDEV_FCOE_WWNN) && defined(BCM_CNIC)
+int bnx2x_fcoe_get_wwn(struct net_device *dev, u64 *wwn, int type)
+{
+       struct bnx2x *bp = netdev_priv(dev);
+       struct cnic_eth_dev *cp = &bp->cnic_eth_dev;
+
+       switch (type) {
+       case NETDEV_FCOE_WWNN:
+               *wwn = HILO_U64(cp->fcoe_wwn_node_name_hi,
+                               cp->fcoe_wwn_node_name_lo);
+               break;
+       case NETDEV_FCOE_WWPN:
+               *wwn = HILO_U64(cp->fcoe_wwn_port_name_hi,
+                               cp->fcoe_wwn_port_name_lo);
+               break;
+       default:
+               return -EINVAL;
+       }
+
+       return 0;
+}
+#endif
+
 /* called with rtnl_lock */
 int bnx2x_change_mtu(struct net_device *dev, int new_mtu)
 {
index c016e20c5c2b1b32188c8f09e056d35204709e77..057d9826555a226288bf1596014d2588686e8362 100644 (file)
@@ -519,6 +519,17 @@ void bnx2x_free_mem_bp(struct bnx2x *bp);
  */
 int bnx2x_change_mtu(struct net_device *dev, int new_mtu);
 
+#if defined(BCM_CNIC) && (defined(CONFIG_FCOE) || defined(CONFIG_FCOE_MODULE))
+/**
+ * bnx2x_fcoe_get_wwn - return the requested WWN value for this port
+ *
+ * @dev:       net_device
+ * @wwn:       output buffer
+ * @type:      WWN type: NETDEV_FCOE_WWNN (node) or NETDEV_FCOE_WWPN (port)
+ *
+ */
+int bnx2x_fcoe_get_wwn(struct net_device *dev, u64 *wwn, int type);
+#endif
 u32 bnx2x_fix_features(struct net_device *dev, u32 features);
 int bnx2x_set_features(struct net_device *dev, u32 features);
 
index 6d31666e634f7248151097247977be396e2e6342..1bfd57c231d0cd403dc46955674363f3c24d457b 100644 (file)
@@ -8802,10 +8802,13 @@ static void __devinit bnx2x_get_port_hwinfo(struct bnx2x *bp)
 #ifdef BCM_CNIC
 static void __devinit bnx2x_get_cnic_info(struct bnx2x *bp)
 {
+       int port = BP_PORT(bp);
+       int func = BP_ABS_FUNC(bp);
+
        u32 max_iscsi_conn = FW_ENCODE_32BIT_PATTERN ^ SHMEM_RD(bp,
-                               drv_lic_key[BP_PORT(bp)].max_iscsi_conn);
+                               drv_lic_key[port].max_iscsi_conn);
        u32 max_fcoe_conn = FW_ENCODE_32BIT_PATTERN ^ SHMEM_RD(bp,
-                               drv_lic_key[BP_PORT(bp)].max_fcoe_conn);
+                               drv_lic_key[port].max_fcoe_conn);
 
        /* Get the number of maximum allowed iSCSI and FCoE connections */
        bp->cnic_eth_dev.max_iscsi_conn =
@@ -8816,11 +8819,59 @@ static void __devinit bnx2x_get_cnic_info(struct bnx2x *bp)
                (max_fcoe_conn & BNX2X_MAX_FCOE_INIT_CONN_MASK) >>
                BNX2X_MAX_FCOE_INIT_CONN_SHIFT;
 
+       /* Read the WWN: */
+       if (!IS_MF(bp)) {
+               /* Port info */
+               bp->cnic_eth_dev.fcoe_wwn_port_name_hi =
+                       SHMEM_RD(bp,
+                               dev_info.port_hw_config[port].
+                                fcoe_wwn_port_name_upper);
+               bp->cnic_eth_dev.fcoe_wwn_port_name_lo =
+                       SHMEM_RD(bp,
+                               dev_info.port_hw_config[port].
+                                fcoe_wwn_port_name_lower);
+
+               /* Node info */
+               bp->cnic_eth_dev.fcoe_wwn_node_name_hi =
+                       SHMEM_RD(bp,
+                               dev_info.port_hw_config[port].
+                                fcoe_wwn_node_name_upper);
+               bp->cnic_eth_dev.fcoe_wwn_node_name_lo =
+                       SHMEM_RD(bp,
+                               dev_info.port_hw_config[port].
+                                fcoe_wwn_node_name_lower);
+       } else if (!IS_MF_SD(bp)) {
+               u32 cfg = MF_CFG_RD(bp, func_ext_config[func].func_cfg);
+
+               /*
+                * Read the WWN info only if the FCoE feature is enabled for
+                * this function.
+                */
+               if (cfg & MACP_FUNC_CFG_FLAGS_FCOE_OFFLOAD) {
+                       /* Port info */
+                       bp->cnic_eth_dev.fcoe_wwn_port_name_hi =
+                               MF_CFG_RD(bp, func_ext_config[func].
+                                               fcoe_wwn_port_name_upper);
+                       bp->cnic_eth_dev.fcoe_wwn_port_name_lo =
+                               MF_CFG_RD(bp, func_ext_config[func].
+                                               fcoe_wwn_port_name_lower);
+
+                       /* Node info */
+                       bp->cnic_eth_dev.fcoe_wwn_node_name_hi =
+                               MF_CFG_RD(bp, func_ext_config[func].
+                                               fcoe_wwn_node_name_upper);
+                       bp->cnic_eth_dev.fcoe_wwn_node_name_lo =
+                               MF_CFG_RD(bp, func_ext_config[func].
+                                               fcoe_wwn_node_name_lower);
+               }
+       }
+
        BNX2X_DEV_INFO("max_iscsi_conn 0x%x max_fcoe_conn 0x%x\n",
                       bp->cnic_eth_dev.max_iscsi_conn,
                       bp->cnic_eth_dev.max_fcoe_conn);
 
-       /* If mamimum allowed number of connections is zero -
+       /*
+        * If maximum allowed number of connections is zero -
         * disable the feature.
         */
        if (!bp->cnic_eth_dev.max_iscsi_conn)
@@ -9682,6 +9733,9 @@ static const struct net_device_ops bnx2x_netdev_ops = {
 #ifdef CONFIG_NET_POLL_CONTROLLER
        .ndo_poll_controller    = poll_bnx2x,
 #endif
+#if defined(NETDEV_FCOE_WWNN) && defined(BCM_CNIC)
+       .ndo_fcoe_get_wwn       = bnx2x_fcoe_get_wwn,
+#endif
 };
 
 static inline int bnx2x_set_coherency_mask(struct bnx2x *bp)
index 642b9d56a1c60d34e53afef9f72561440237e5ba..8a1ffbe123bbbb3845e3c050aca19f92a39d289c 100644 (file)
@@ -181,6 +181,11 @@ struct cnic_eth_dev {
        u32             max_fcoe_conn;
        u32             max_rdma_conn;
        u32             fcoe_init_cid;
+       u32             fcoe_wwn_port_name_hi;
+       u32             fcoe_wwn_port_name_lo;
+       u32             fcoe_wwn_node_name_hi;
+       u32             fcoe_wwn_node_name_lo;
+
        u16             iscsi_l2_client_id;
        u16             iscsi_l2_cid;
        u8              iscsi_mac[ETH_ALEN];