mdio-octeon.c 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) 2009-2015 Cavium, Inc.
  4. */
  5. #include <linux/gfp.h>
  6. #include <linux/io.h>
  7. #include <linux/module.h>
  8. #include <linux/of_address.h>
  9. #include <linux/of_mdio.h>
  10. #include <linux/phy.h>
  11. #include <linux/platform_device.h>
  12. #include "mdio-cavium.h"
  13. static int octeon_mdiobus_probe(struct platform_device *pdev)
  14. {
  15. struct cavium_mdiobus *bus;
  16. struct mii_bus *mii_bus;
  17. union cvmx_smix_en smi_en;
  18. int err;
  19. mii_bus = devm_mdiobus_alloc_size(&pdev->dev, sizeof(*bus));
  20. if (!mii_bus)
  21. return -ENOMEM;
  22. bus = mii_bus->priv;
  23. bus->mii_bus = mii_bus;
  24. bus->register_base = devm_platform_ioremap_resource(pdev, 0);
  25. if (IS_ERR(bus->register_base)) {
  26. dev_err(&pdev->dev, "dev_ioremap failed\n");
  27. return PTR_ERR(bus->register_base);
  28. }
  29. smi_en.u64 = 0;
  30. smi_en.s.en = 1;
  31. oct_mdio_writeq(smi_en.u64, bus->register_base + SMI_EN);
  32. bus->mii_bus->name = KBUILD_MODNAME;
  33. snprintf(bus->mii_bus->id, MII_BUS_ID_SIZE, "%px", bus->register_base);
  34. bus->mii_bus->parent = &pdev->dev;
  35. bus->mii_bus->read = cavium_mdiobus_read_c22;
  36. bus->mii_bus->write = cavium_mdiobus_write_c22;
  37. bus->mii_bus->read_c45 = cavium_mdiobus_read_c45;
  38. bus->mii_bus->write_c45 = cavium_mdiobus_write_c45;
  39. platform_set_drvdata(pdev, bus);
  40. err = of_mdiobus_register(bus->mii_bus, pdev->dev.of_node);
  41. if (err)
  42. goto fail_register;
  43. dev_info(&pdev->dev, "Probed\n");
  44. return 0;
  45. fail_register:
  46. smi_en.u64 = 0;
  47. oct_mdio_writeq(smi_en.u64, bus->register_base + SMI_EN);
  48. return err;
  49. }
  50. static void octeon_mdiobus_remove(struct platform_device *pdev)
  51. {
  52. struct cavium_mdiobus *bus;
  53. union cvmx_smix_en smi_en;
  54. bus = platform_get_drvdata(pdev);
  55. mdiobus_unregister(bus->mii_bus);
  56. smi_en.u64 = 0;
  57. oct_mdio_writeq(smi_en.u64, bus->register_base + SMI_EN);
  58. }
  59. static const struct of_device_id octeon_mdiobus_match[] = {
  60. {
  61. .compatible = "cavium,octeon-3860-mdio",
  62. },
  63. {},
  64. };
  65. MODULE_DEVICE_TABLE(of, octeon_mdiobus_match);
  66. static struct platform_driver octeon_mdiobus_driver = {
  67. .driver = {
  68. .name = KBUILD_MODNAME,
  69. .of_match_table = octeon_mdiobus_match,
  70. },
  71. .probe = octeon_mdiobus_probe,
  72. .remove = octeon_mdiobus_remove,
  73. };
  74. module_platform_driver(octeon_mdiobus_driver);
  75. MODULE_DESCRIPTION("Cavium OCTEON MDIO bus driver");
  76. MODULE_AUTHOR("David Daney");
  77. MODULE_LICENSE("GPL v2");