1 // SPDX-License-Identifier: GPL-2.0
3 * Sandbox driver for interrupts
5 * Copyright 2019 Google LLC
11 #include <acpi/acpi_device.h>
15 static int sandbox_set_polarity(struct udevice *dev, uint irq, bool active_low)
23 static int sandbox_route_pmc_gpio_gpe(struct udevice *dev, uint pmc_gpe_num)
28 return pmc_gpe_num + 1;
31 static int sandbox_snapshot_polarities(struct udevice *dev)
36 static int sandbox_restore_polarities(struct udevice *dev)
41 static int sandbox_irq_read_and_clear(struct irq *irq)
43 struct sandbox_irq_priv *priv = dev_get_priv(irq->dev);
45 if (irq->id != SANDBOX_IRQN_PEND)
49 priv->pending = false;
53 if (!(priv->count % 3))
59 static int sandbox_irq_of_xlate(struct irq *irq,
60 struct ofnode_phandle_args *args)
62 irq->id = args->args[0];
67 static __maybe_unused int sandbox_get_acpi(const struct irq *irq,
68 struct acpi_irq *acpi_irq)
70 acpi_irq->pin = irq->id;
71 acpi_irq->mode = ACPI_IRQ_LEVEL_TRIGGERED;
72 acpi_irq->polarity = ACPI_IRQ_ACTIVE_HIGH;
73 acpi_irq->shared = ACPI_IRQ_SHARED;
74 acpi_irq->wake = ACPI_IRQ_WAKE;
79 static const struct irq_ops sandbox_irq_ops = {
80 .route_pmc_gpio_gpe = sandbox_route_pmc_gpio_gpe,
81 .set_polarity = sandbox_set_polarity,
82 .snapshot_polarities = sandbox_snapshot_polarities,
83 .restore_polarities = sandbox_restore_polarities,
84 .read_and_clear = sandbox_irq_read_and_clear,
85 .of_xlate = sandbox_irq_of_xlate,
86 #if CONFIG_IS_ENABLED(ACPIGEN)
87 .get_acpi = sandbox_get_acpi,
91 static const struct udevice_id sandbox_irq_ids[] = {
92 { .compatible = "sandbox,irq", SANDBOX_IRQT_BASE },
96 U_BOOT_DRIVER(sandbox_irq) = {
97 .name = "sandbox_irq",
99 .of_match = sandbox_irq_ids,
100 .ops = &sandbox_irq_ops,
101 .priv_auto = sizeof(struct sandbox_irq_priv),
102 DM_HEADER(<asm/irq.h>)