enet.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * Applied Micro X-Gene SoC Ethernet v2 Driver
  4. *
  5. * Copyright (c) 2017, Applied Micro Circuits Corporation
  6. * Author(s): Iyappan Subramanian <[email protected]>
  7. * Keyur Chudgar <[email protected]>
  8. */
  9. #include "main.h"
  10. void xge_wr_csr(struct xge_pdata *pdata, u32 offset, u32 val)
  11. {
  12. void __iomem *addr = pdata->resources.base_addr + offset;
  13. iowrite32(val, addr);
  14. }
  15. u32 xge_rd_csr(struct xge_pdata *pdata, u32 offset)
  16. {
  17. void __iomem *addr = pdata->resources.base_addr + offset;
  18. return ioread32(addr);
  19. }
  20. int xge_port_reset(struct net_device *ndev)
  21. {
  22. struct xge_pdata *pdata = netdev_priv(ndev);
  23. struct device *dev = &pdata->pdev->dev;
  24. u32 data, wait = 10;
  25. xge_wr_csr(pdata, ENET_CLKEN, 0x3);
  26. xge_wr_csr(pdata, ENET_SRST, 0xf);
  27. xge_wr_csr(pdata, ENET_SRST, 0);
  28. xge_wr_csr(pdata, CFG_MEM_RAM_SHUTDOWN, 1);
  29. xge_wr_csr(pdata, CFG_MEM_RAM_SHUTDOWN, 0);
  30. do {
  31. usleep_range(100, 110);
  32. data = xge_rd_csr(pdata, BLOCK_MEM_RDY);
  33. } while (data != MEM_RDY && wait--);
  34. if (data != MEM_RDY) {
  35. dev_err(dev, "ECC init failed: %x\n", data);
  36. return -ETIMEDOUT;
  37. }
  38. xge_wr_csr(pdata, ENET_SHIM, DEVM_ARAUX_COH | DEVM_AWAUX_COH);
  39. return 0;
  40. }
  41. static void xge_traffic_resume(struct net_device *ndev)
  42. {
  43. struct xge_pdata *pdata = netdev_priv(ndev);
  44. xge_wr_csr(pdata, CFG_FORCE_LINK_STATUS_EN, 1);
  45. xge_wr_csr(pdata, FORCE_LINK_STATUS, 1);
  46. xge_wr_csr(pdata, CFG_LINK_AGGR_RESUME, 1);
  47. xge_wr_csr(pdata, RX_DV_GATE_REG, 1);
  48. }
  49. void xge_port_init(struct net_device *ndev)
  50. {
  51. struct xge_pdata *pdata = netdev_priv(ndev);
  52. pdata->phy_speed = SPEED_1000;
  53. xge_mac_init(pdata);
  54. xge_traffic_resume(ndev);
  55. }