sdhci-pci.c 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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/irq.h"
  21. #include "hw/qdev-properties.h"
  22. #include "hw/sd/sdhci.h"
  23. #include "sdhci-internal.h"
  24. static const Property sdhci_pci_properties[] = {
  25. DEFINE_SDHCI_COMMON_PROPERTIES(SDHCIState),
  26. };
  27. static void sdhci_pci_realize(PCIDevice *dev, Error **errp)
  28. {
  29. ERRP_GUARD();
  30. SDHCIState *s = PCI_SDHCI(dev);
  31. sdhci_initfn(s);
  32. sdhci_common_realize(s, errp);
  33. if (*errp) {
  34. return;
  35. }
  36. dev->config[PCI_CLASS_PROG] = 0x01; /* Standard Host supported DMA */
  37. dev->config[PCI_INTERRUPT_PIN] = 0x01; /* interrupt pin A */
  38. s->irq = pci_allocate_irq(dev);
  39. s->dma_as = pci_get_address_space(dev);
  40. pci_register_bar(dev, 0, PCI_BASE_ADDRESS_SPACE_MEMORY, &s->iomem);
  41. }
  42. static void sdhci_pci_exit(PCIDevice *dev)
  43. {
  44. SDHCIState *s = PCI_SDHCI(dev);
  45. qemu_free_irq(s->irq);
  46. sdhci_common_unrealize(s);
  47. sdhci_uninitfn(s);
  48. }
  49. static void sdhci_pci_class_init(ObjectClass *klass, void *data)
  50. {
  51. DeviceClass *dc = DEVICE_CLASS(klass);
  52. PCIDeviceClass *k = PCI_DEVICE_CLASS(klass);
  53. k->realize = sdhci_pci_realize;
  54. k->exit = sdhci_pci_exit;
  55. k->vendor_id = PCI_VENDOR_ID_REDHAT;
  56. k->device_id = PCI_DEVICE_ID_REDHAT_SDHCI;
  57. k->class_id = PCI_CLASS_SYSTEM_SDHCI;
  58. device_class_set_props(dc, sdhci_pci_properties);
  59. sdhci_common_class_init(klass, data);
  60. }
  61. static const TypeInfo sdhci_pci_types[] = {
  62. {
  63. .name = TYPE_PCI_SDHCI,
  64. .parent = TYPE_PCI_DEVICE,
  65. .instance_size = sizeof(SDHCIState),
  66. .class_init = sdhci_pci_class_init,
  67. .interfaces = (InterfaceInfo[]) {
  68. { INTERFACE_CONVENTIONAL_PCI_DEVICE },
  69. { },
  70. },
  71. },
  72. };
  73. DEFINE_TYPES(sdhci_pci_types)