pci-host-generic.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2022-10-24 GuEe-GUI first version
  9. */
  10. #include <rtthread.h>
  11. #include "../ecam.h"
  12. static const struct pci_ecam_ops gen_pci_cfg_cam_bus_ops =
  13. {
  14. .bus_shift = 16,
  15. .pci_ops =
  16. {
  17. .map = pci_ecam_map,
  18. .read = rt_pci_bus_read_config_uxx,
  19. .write = rt_pci_bus_write_config_uxx,
  20. }
  21. };
  22. static void *pci_dw_ecam_map_bus(struct rt_pci_bus *bus, rt_uint32_t devfn, int where)
  23. {
  24. struct pci_ecam_config_window *conf_win = bus->sysdata;
  25. if (bus->number == conf_win->bus_range[0] && RT_PCI_SLOT(devfn) > 0)
  26. {
  27. return RT_NULL;
  28. }
  29. return pci_ecam_map(bus, devfn, where);
  30. }
  31. static const struct pci_ecam_ops pci_dw_ecam_bus_ops =
  32. {
  33. .pci_ops =
  34. {
  35. .map = pci_dw_ecam_map_bus,
  36. .read = rt_pci_bus_read_config_uxx,
  37. .write = rt_pci_bus_write_config_uxx,
  38. }
  39. };
  40. static const struct rt_ofw_node_id gen_pci_ofw_ids[] =
  41. {
  42. { .compatible = "pci-host-cam-generic", .data = &gen_pci_cfg_cam_bus_ops },
  43. { .compatible = "pci-host-ecam-generic", .data = &pci_generic_ecam_ops },
  44. { .compatible = "marvell,armada8k-pcie-ecam", .data = &pci_dw_ecam_bus_ops },
  45. { .compatible = "socionext,synquacer-pcie-ecam", .data = &pci_dw_ecam_bus_ops },
  46. { .compatible = "snps,dw-pcie-ecam", .data = &pci_dw_ecam_bus_ops },
  47. { /* sentinel */ }
  48. };
  49. static struct rt_platform_driver gen_pci_driver =
  50. {
  51. .name = "pci-host-generic",
  52. .ids = gen_pci_ofw_ids,
  53. .probe = pci_host_common_probe,
  54. .remove = pci_host_common_remove,
  55. };
  56. RT_PLATFORM_DRIVER_EXPORT(gen_pci_driver);