uio_dfl.c 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Generic DFL driver for Userspace I/O devicess
  4. *
  5. * Copyright (C) 2021 Intel Corporation, Inc.
  6. */
  7. #include <linux/dfl.h>
  8. #include <linux/errno.h>
  9. #include <linux/module.h>
  10. #include <linux/uio_driver.h>
  11. #define DRIVER_NAME "uio_dfl"
  12. static int uio_dfl_probe(struct dfl_device *ddev)
  13. {
  14. struct resource *r = &ddev->mmio_res;
  15. struct device *dev = &ddev->dev;
  16. struct uio_info *uioinfo;
  17. struct uio_mem *uiomem;
  18. int ret;
  19. uioinfo = devm_kzalloc(dev, sizeof(struct uio_info), GFP_KERNEL);
  20. if (!uioinfo)
  21. return -ENOMEM;
  22. uioinfo->name = DRIVER_NAME;
  23. uioinfo->version = "0";
  24. uiomem = &uioinfo->mem[0];
  25. uiomem->memtype = UIO_MEM_PHYS;
  26. uiomem->addr = r->start & PAGE_MASK;
  27. uiomem->offs = r->start & ~PAGE_MASK;
  28. uiomem->size = (uiomem->offs + resource_size(r)
  29. + PAGE_SIZE - 1) & PAGE_MASK;
  30. uiomem->name = r->name;
  31. /* Irq is yet to be supported */
  32. uioinfo->irq = UIO_IRQ_NONE;
  33. ret = devm_uio_register_device(dev, uioinfo);
  34. if (ret)
  35. dev_err(dev, "unable to register uio device\n");
  36. return ret;
  37. }
  38. #define FME_FEATURE_ID_ETH_GROUP 0x10
  39. #define FME_FEATURE_ID_HSSI_SUBSYS 0x15
  40. #define PORT_FEATURE_ID_IOPLL_USRCLK 0x14
  41. static const struct dfl_device_id uio_dfl_ids[] = {
  42. { FME_ID, FME_FEATURE_ID_ETH_GROUP },
  43. { FME_ID, FME_FEATURE_ID_HSSI_SUBSYS },
  44. { PORT_ID, PORT_FEATURE_ID_IOPLL_USRCLK },
  45. { }
  46. };
  47. MODULE_DEVICE_TABLE(dfl, uio_dfl_ids);
  48. static struct dfl_driver uio_dfl_driver = {
  49. .drv = {
  50. .name = DRIVER_NAME,
  51. },
  52. .id_table = uio_dfl_ids,
  53. .probe = uio_dfl_probe,
  54. };
  55. module_dfl_driver(uio_dfl_driver);
  56. MODULE_DESCRIPTION("Generic DFL driver for Userspace I/O devices");
  57. MODULE_AUTHOR("Intel Corporation");
  58. MODULE_LICENSE("GPL v2");