Lines Matching full:netdev

84 	struct net_device *netdev;  member
116 struct net_device *netdev = priv->netdev; in ftgmac100_reset_mac() local
133 netdev_err(netdev, "Hardware reset failed\n"); in ftgmac100_reset_mac()
154 netdev_err(priv->netdev, "Unknown speed %d !\n", in ftgmac100_reset_and_config_mac()
187 err = of_get_ethdev_address(priv->dev->of_node, priv->netdev); in ftgmac100_initial_mac()
192 priv->netdev->dev_addr); in ftgmac100_initial_mac()
207 eth_hw_addr_set(priv->netdev, mac); in ftgmac100_initial_mac()
210 eth_hw_addr_random(priv->netdev); in ftgmac100_initial_mac()
212 priv->netdev->dev_addr); in ftgmac100_initial_mac()
272 ftgmac100_write_mac_addr(priv, priv->netdev->dev_addr); in ftgmac100_init_hw()
331 if (priv->netdev->flags & IFF_PROMISC) in ftgmac100_start_hw()
333 if (priv->netdev->flags & IFF_ALLMULTI) in ftgmac100_start_hw()
335 else if (netdev_mc_count(priv->netdev)) in ftgmac100_start_hw()
339 if (priv->netdev->features & NETIF_F_HW_VLAN_CTAG_RX) in ftgmac100_start_hw()
357 netdev_for_each_mc_addr(ha, priv->netdev) { in ftgmac100_calc_mc_hash()
368 static void ftgmac100_set_rx_mode(struct net_device *netdev) in ftgmac100_set_rx_mode() argument
370 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_set_rx_mode()
376 if (!netif_running(netdev)) in ftgmac100_set_rx_mode()
390 struct net_device *netdev = priv->netdev; in ftgmac100_alloc_rx_buf() local
395 skb = netdev_alloc_skb_ip_align(netdev, RX_BUF_SIZE); in ftgmac100_alloc_rx_buf()
398 netdev_warn(netdev, "failed to allocate rx skb\n"); in ftgmac100_alloc_rx_buf()
406 netdev_err(netdev, "failed to map rx page\n"); in ftgmac100_alloc_rx_buf()
440 struct net_device *netdev = priv->netdev; in ftgmac100_rx_packet_error() local
443 netdev->stats.rx_errors++; in ftgmac100_rx_packet_error()
446 netdev->stats.rx_crc_errors++; in ftgmac100_rx_packet_error()
451 netdev->stats.rx_length_errors++; in ftgmac100_rx_packet_error()
456 struct net_device *netdev = priv->netdev; in ftgmac100_rx_packet() local
515 netdev->stats.multicast++; in ftgmac100_rx_packet()
523 if (netdev->features & NETIF_F_RXCSUM) { in ftgmac100_rx_packet()
538 if ((netdev->features & NETIF_F_HW_VLAN_CTAG_RX) && in ftgmac100_rx_packet()
561 skb->protocol = eth_type_trans(skb, netdev); in ftgmac100_rx_packet()
563 netdev->stats.rx_packets++; in ftgmac100_rx_packet()
564 netdev->stats.rx_bytes += size; in ftgmac100_rx_packet()
579 netdev->stats.rx_dropped++; in ftgmac100_rx_packet()
640 struct net_device *netdev = priv->netdev; in ftgmac100_tx_complete_packet() local
654 netdev->stats.tx_packets++; in ftgmac100_tx_complete_packet()
655 netdev->stats.tx_bytes += skb->len; in ftgmac100_tx_complete_packet()
666 struct net_device *netdev = priv->netdev; in ftgmac100_tx_complete() local
675 if (unlikely(netif_queue_stopped(netdev) && in ftgmac100_tx_complete()
679 txq = netdev_get_tx_queue(netdev, 0); in ftgmac100_tx_complete()
681 if (netif_queue_stopped(netdev) && in ftgmac100_tx_complete()
683 netif_wake_queue(netdev); in ftgmac100_tx_complete()
709 struct net_device *netdev) in ftgmac100_hard_start_xmit() argument
711 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_hard_start_xmit()
719 netdev->stats.tx_dropped++; in ftgmac100_hard_start_xmit()
726 netdev_dbg(netdev, "tx packet too big\n"); in ftgmac100_hard_start_xmit()
754 netdev_err(netdev, "map tx packet head failed\n"); in ftgmac100_hard_start_xmit()
820 netif_stop_queue(netdev); in ftgmac100_hard_start_xmit()
824 netif_wake_queue(netdev); in ftgmac100_hard_start_xmit()
834 netdev_err(netdev, "map tx fragment failed\n"); in ftgmac100_hard_start_xmit()
857 netdev->stats.tx_dropped++; in ftgmac100_hard_start_xmit()
1000 struct net_device *netdev = bus->priv; in ftgmac100_mdiobus_read() local
1001 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_mdiobus_read()
1029 netdev_err(netdev, "mdio read timed out\n"); in ftgmac100_mdiobus_read()
1036 struct net_device *netdev = bus->priv; in ftgmac100_mdiobus_write() local
1037 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_mdiobus_write()
1065 netdev_err(netdev, "mdio write timed out\n"); in ftgmac100_mdiobus_write()
1069 static void ftgmac100_get_drvinfo(struct net_device *netdev, in ftgmac100_get_drvinfo() argument
1073 strscpy(info->bus_info, dev_name(&netdev->dev), sizeof(info->bus_info)); in ftgmac100_get_drvinfo()
1077 ftgmac100_get_ringparam(struct net_device *netdev, in ftgmac100_get_ringparam() argument
1082 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_get_ringparam()
1092 ftgmac100_set_ringparam(struct net_device *netdev, in ftgmac100_set_ringparam() argument
1097 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_set_ringparam()
1109 if (netif_running(netdev)) in ftgmac100_set_ringparam()
1115 static void ftgmac100_get_pauseparam(struct net_device *netdev, in ftgmac100_get_pauseparam() argument
1118 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_get_pauseparam()
1125 static int ftgmac100_set_pauseparam(struct net_device *netdev, in ftgmac100_set_pauseparam() argument
1128 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_set_pauseparam()
1129 struct phy_device *phydev = netdev->phydev; in ftgmac100_set_pauseparam()
1138 if (netif_running(netdev)) { in ftgmac100_set_pauseparam()
1160 struct net_device *netdev = dev_id; in ftgmac100_interrupt() local
1161 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_interrupt()
1171 netdev->stats.rx_over_errors++; in ftgmac100_interrupt()
1175 netdev->stats.rx_fifo_errors++; in ftgmac100_interrupt()
1179 netdev->stats.tx_fifo_errors++; in ftgmac100_interrupt()
1184 netdev_warn(netdev, in ftgmac100_interrupt()
1300 netif_start_queue(priv->netdev); in ftgmac100_init_all()
1310 struct net_device *netdev = priv->netdev; in ftgmac100_reset() local
1313 netdev_dbg(netdev, "Resetting NIC...\n"); in ftgmac100_reset()
1317 if (netdev->phydev) in ftgmac100_reset()
1318 mutex_lock(&netdev->phydev->lock); in ftgmac100_reset()
1324 if (!netif_running(netdev)) in ftgmac100_reset()
1328 netif_trans_update(netdev); in ftgmac100_reset()
1330 netif_tx_disable(netdev); in ftgmac100_reset()
1337 netdev_err(netdev, "attempting to continue...\n"); in ftgmac100_reset()
1346 netdev_dbg(netdev, "Reset done !\n"); in ftgmac100_reset()
1350 if (netdev->phydev) in ftgmac100_reset()
1351 mutex_unlock(&netdev->phydev->lock); in ftgmac100_reset()
1363 static void ftgmac100_adjust_link(struct net_device *netdev) in ftgmac100_adjust_link() argument
1365 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_adjust_link()
1366 struct phy_device *phydev = netdev->phydev; in ftgmac100_adjust_link()
1414 if (netdev->phydev) in ftgmac100_adjust_link()
1415 mutex_unlock(&netdev->phydev->lock); in ftgmac100_adjust_link()
1419 if (netdev->phydev) in ftgmac100_adjust_link()
1420 mutex_lock(&netdev->phydev->lock); in ftgmac100_adjust_link()
1424 static int ftgmac100_mii_probe(struct net_device *netdev) in ftgmac100_mii_probe() argument
1426 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_mii_probe()
1453 netdev_warn(netdev, in ftgmac100_mii_probe()
1460 netdev_info(netdev, "%s: no PHY found\n", netdev->name); in ftgmac100_mii_probe()
1464 phydev = phy_connect(netdev, phydev_name(phydev), in ftgmac100_mii_probe()
1468 netdev_err(netdev, "%s: Could not attach to PHY\n", netdev->name); in ftgmac100_mii_probe()
1483 static int ftgmac100_open(struct net_device *netdev) in ftgmac100_open() argument
1485 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_open()
1491 netdev_err(netdev, "Failed to allocate descriptors\n"); in ftgmac100_open()
1515 netif_napi_add(netdev, &priv->napi, ftgmac100_poll); in ftgmac100_open()
1518 err = request_irq(netdev->irq, ftgmac100_interrupt, 0, netdev->name, netdev); in ftgmac100_open()
1520 netdev_err(netdev, "failed to request irq %d\n", netdev->irq); in ftgmac100_open()
1527 netdev_err(netdev, "Failed to allocate packet buffers\n"); in ftgmac100_open()
1531 if (netdev->phydev) { in ftgmac100_open()
1533 phy_start(netdev->phydev); in ftgmac100_open()
1536 netif_carrier_on(netdev); in ftgmac100_open()
1548 netif_stop_queue(netdev); in ftgmac100_open()
1551 free_irq(netdev->irq, netdev); in ftgmac100_open()
1560 static int ftgmac100_stop(struct net_device *netdev) in ftgmac100_stop() argument
1562 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_stop()
1575 netif_stop_queue(netdev); in ftgmac100_stop()
1578 if (netdev->phydev) in ftgmac100_stop()
1579 phy_stop(netdev->phydev); in ftgmac100_stop()
1584 free_irq(netdev->irq, netdev); in ftgmac100_stop()
1591 static void ftgmac100_tx_timeout(struct net_device *netdev, unsigned int txqueue) in ftgmac100_tx_timeout() argument
1593 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_tx_timeout()
1602 static int ftgmac100_set_features(struct net_device *netdev, in ftgmac100_set_features() argument
1605 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_set_features()
1606 netdev_features_t changed = netdev->features ^ features; in ftgmac100_set_features()
1608 if (!netif_running(netdev)) in ftgmac100_set_features()
1616 if (priv->netdev->features & NETIF_F_HW_VLAN_CTAG_RX) in ftgmac100_set_features()
1627 static void ftgmac100_poll_controller(struct net_device *netdev) in ftgmac100_poll_controller() argument
1632 ftgmac100_interrupt(netdev->irq, netdev); in ftgmac100_poll_controller()
1654 static int ftgmac100_setup_mdio(struct net_device *netdev) in ftgmac100_setup_mdio() argument
1656 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_setup_mdio()
1684 priv->mii_bus->priv = priv->netdev; in ftgmac100_setup_mdio()
1708 static void ftgmac100_phy_disconnect(struct net_device *netdev) in ftgmac100_phy_disconnect() argument
1710 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_phy_disconnect()
1712 if (!netdev->phydev) in ftgmac100_phy_disconnect()
1715 phy_disconnect(netdev->phydev); in ftgmac100_phy_disconnect()
1720 static void ftgmac100_destroy_mdio(struct net_device *netdev) in ftgmac100_destroy_mdio() argument
1722 struct ftgmac100 *priv = netdev_priv(netdev); in ftgmac100_destroy_mdio()
1794 struct net_device *netdev; in ftgmac100_probe() local
1808 netdev = alloc_etherdev(sizeof(*priv)); in ftgmac100_probe()
1809 if (!netdev) { in ftgmac100_probe()
1814 SET_NETDEV_DEV(netdev, &pdev->dev); in ftgmac100_probe()
1816 netdev->ethtool_ops = &ftgmac100_ethtool_ops; in ftgmac100_probe()
1817 netdev->netdev_ops = &ftgmac100_netdev_ops; in ftgmac100_probe()
1818 netdev->watchdog_timeo = 5 * HZ; in ftgmac100_probe()
1820 platform_set_drvdata(pdev, netdev); in ftgmac100_probe()
1823 priv = netdev_priv(netdev); in ftgmac100_probe()
1824 priv->netdev = netdev; in ftgmac100_probe()
1844 netdev->irq = irq; in ftgmac100_probe()
1877 priv->ndev = ncsi_register_dev(netdev, ftgmac100_ncsi_handler); in ftgmac100_probe()
1891 phy = of_phy_get_and_connect(priv->netdev, np, in ftgmac100_probe()
1911 err = ftgmac100_setup_mdio(netdev); in ftgmac100_probe()
1916 phy = of_phy_get_and_connect(priv->netdev, np, in ftgmac100_probe()
1938 err = ftgmac100_setup_mdio(netdev); in ftgmac100_probe()
1942 err = ftgmac100_mii_probe(netdev); in ftgmac100_probe()
1966 netdev->hw_features = NETIF_F_RXCSUM | NETIF_F_HW_CSUM | in ftgmac100_probe()
1971 netdev->hw_features |= NETIF_F_HW_VLAN_CTAG_FILTER; in ftgmac100_probe()
1975 netdev->hw_features &= ~NETIF_F_HW_CSUM; in ftgmac100_probe()
1979 netdev->hw_features &= ~NETIF_F_HW_CSUM; in ftgmac100_probe()
1982 netdev->hw_features &= ~(NETIF_F_HW_CSUM | NETIF_F_RXCSUM); in ftgmac100_probe()
1983 netdev->features |= netdev->hw_features; in ftgmac100_probe()
1986 err = register_netdev(netdev); in ftgmac100_probe()
1988 dev_err(&pdev->dev, "Failed to register netdev\n"); in ftgmac100_probe()
1992 netdev_info(netdev, "irq %d, mapped at %p\n", netdev->irq, priv->base); in ftgmac100_probe()
2000 ftgmac100_phy_disconnect(netdev); in ftgmac100_probe()
2004 ftgmac100_destroy_mdio(netdev); in ftgmac100_probe()
2010 free_netdev(netdev); in ftgmac100_probe()
2017 struct net_device *netdev; in ftgmac100_remove() local
2020 netdev = platform_get_drvdata(pdev); in ftgmac100_remove()
2021 priv = netdev_priv(netdev); in ftgmac100_remove()
2025 unregister_netdev(netdev); in ftgmac100_remove()
2035 ftgmac100_phy_disconnect(netdev); in ftgmac100_remove()
2036 ftgmac100_destroy_mdio(netdev); in ftgmac100_remove()
2042 free_netdev(netdev); in ftgmac100_remove()