irq_sandbox.c 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Sandbox driver for interrupts
  4. *
  5. * Copyright 2019 Google LLC
  6. */
  7. #include <common.h>
  8. #include <dm.h>
  9. #include <irq.h>
  10. #include <acpi/acpi_device.h>
  11. #include <asm/irq.h>
  12. #include <asm/test.h>
  13. static int sandbox_set_polarity(struct udevice *dev, uint irq, bool active_low)
  14. {
  15. if (irq > 10)
  16. return -EINVAL;
  17. return 0;
  18. }
  19. static int sandbox_route_pmc_gpio_gpe(struct udevice *dev, uint pmc_gpe_num)
  20. {
  21. if (pmc_gpe_num > 10)
  22. return -ENOENT;
  23. return pmc_gpe_num + 1;
  24. }
  25. static int sandbox_snapshot_polarities(struct udevice *dev)
  26. {
  27. return 0;
  28. }
  29. static int sandbox_restore_polarities(struct udevice *dev)
  30. {
  31. return 0;
  32. }
  33. static int sandbox_irq_read_and_clear(struct irq *irq)
  34. {
  35. struct sandbox_irq_priv *priv = dev_get_priv(irq->dev);
  36. if (irq->id != SANDBOX_IRQN_PEND)
  37. return -EINVAL;
  38. priv->count++;
  39. if (priv->pending) {
  40. priv->pending = false;
  41. return 1;
  42. }
  43. if (!(priv->count % 3))
  44. priv->pending = true;
  45. return 0;
  46. }
  47. static int sandbox_irq_of_xlate(struct irq *irq,
  48. struct ofnode_phandle_args *args)
  49. {
  50. irq->id = args->args[0];
  51. return 0;
  52. }
  53. static __maybe_unused int sandbox_get_acpi(const struct irq *irq,
  54. struct acpi_irq *acpi_irq)
  55. {
  56. acpi_irq->pin = irq->id;
  57. acpi_irq->mode = ACPI_IRQ_LEVEL_TRIGGERED;
  58. acpi_irq->polarity = ACPI_IRQ_ACTIVE_HIGH;
  59. acpi_irq->shared = ACPI_IRQ_SHARED;
  60. acpi_irq->wake = ACPI_IRQ_WAKE;
  61. return 0;
  62. }
  63. static const struct irq_ops sandbox_irq_ops = {
  64. .route_pmc_gpio_gpe = sandbox_route_pmc_gpio_gpe,
  65. .set_polarity = sandbox_set_polarity,
  66. .snapshot_polarities = sandbox_snapshot_polarities,
  67. .restore_polarities = sandbox_restore_polarities,
  68. .read_and_clear = sandbox_irq_read_and_clear,
  69. .of_xlate = sandbox_irq_of_xlate,
  70. #if CONFIG_IS_ENABLED(ACPIGEN)
  71. .get_acpi = sandbox_get_acpi,
  72. #endif
  73. };
  74. static const struct udevice_id sandbox_irq_ids[] = {
  75. { .compatible = "sandbox,irq", SANDBOX_IRQT_BASE },
  76. { }
  77. };
  78. U_BOOT_DRIVER(sandbox_irq) = {
  79. .name = "sandbox_irq",
  80. .id = UCLASS_IRQ,
  81. .of_match = sandbox_irq_ids,
  82. .ops = &sandbox_irq_ops,
  83. .priv_auto = sizeof(struct sandbox_irq_priv),
  84. DM_HEADER(<asm/irq.h>)
  85. };