sdhci-pci.c 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * SDHCI device on PCI
  3. *
  4. * This program is free software; you can redistribute it and/or modify it
  5. * under the terms of the GNU General Public License as published by the
  6. * Free Software Foundation; either version 2 of the License, or (at your
  7. * option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  12. * See the GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License along
  15. * with this program; if not, see <http://www.gnu.org/licenses/>.
  16. */
  17. #include "qemu/osdep.h"
  18. #include "qapi/error.h"
  19. #include "qemu/module.h"
  20. #include "hw/qdev-properties.h"
  21. #include "hw/sd/sdhci.h"
  22. #include "sdhci-internal.h"
  23. static const Property sdhci_pci_properties[] = {
  24. DEFINE_SDHCI_COMMON_PROPERTIES(SDHCIState),
  25. };
  26. static void sdhci_pci_realize(PCIDevice *dev, Error **errp)
  27. {
  28. ERRP_GUARD();
  29. SDHCIState *s = PCI_SDHCI(dev);
  30. sdhci_initfn(s);
  31. sdhci_common_realize(s, errp);
  32. if (*errp) {
  33. return;
  34. }
  35. dev->config[PCI_CLASS_PROG] = 0x01; /* Standard Host supported DMA */
  36. dev->config[PCI_INTERRUPT_PIN] = 0x01; /* interrupt pin A */
  37. s->irq = pci_allocate_irq(dev);
  38. s->dma_as = pci_get_address_space(dev);
  39. pci_register_bar(dev, 0, PCI_BASE_ADDRESS_SPACE_MEMORY, &s->iomem);
  40. }
  41. static void sdhci_pci_exit(PCIDevice *dev)
  42. {
  43. SDHCIState *s = PCI_SDHCI(dev);
  44. sdhci_common_unrealize(s);
  45. sdhci_uninitfn(s);
  46. }
  47. static void sdhci_pci_class_init(ObjectClass *klass, void *data)
  48. {
  49. DeviceClass *dc = DEVICE_CLASS(klass);
  50. PCIDeviceClass *k = PCI_DEVICE_CLASS(klass);
  51. k->realize = sdhci_pci_realize;
  52. k->exit = sdhci_pci_exit;
  53. k->vendor_id = PCI_VENDOR_ID_REDHAT;
  54. k->device_id = PCI_DEVICE_ID_REDHAT_SDHCI;
  55. k->class_id = PCI_CLASS_SYSTEM_SDHCI;
  56. device_class_set_props(dc, sdhci_pci_properties);
  57. sdhci_common_class_init(klass, data);
  58. }
  59. static const TypeInfo sdhci_pci_types[] = {
  60. {
  61. .name = TYPE_PCI_SDHCI,
  62. .parent = TYPE_PCI_DEVICE,
  63. .instance_size = sizeof(SDHCIState),
  64. .class_init = sdhci_pci_class_init,
  65. .interfaces = (InterfaceInfo[]) {
  66. { INTERFACE_CONVENTIONAL_PCI_DEVICE },
  67. { },
  68. },
  69. },
  70. };
  71. DEFINE_TYPES(sdhci_pci_types)