aboutsummaryrefslogtreecommitdiff
path: root/sys/arm64/arm64/gic_v3.c
diff options
context:
space:
mode:
authorWojciech Macek <wma@FreeBSD.org>2016-09-21 05:22:49 +0000
committerWojciech Macek <wma@FreeBSD.org>2016-09-21 05:22:49 +0000
commita134b98878a1b8031426df1c29e4cca3c8b3d261 (patch)
tree88d711f74b6ae5a8ef1a4e6719889aaba3fbca53 /sys/arm64/arm64/gic_v3.c
parent3502e7b37c91f9a8d3f6b796992797286a1dd015 (diff)
downloadsrc-a134b98878a1b8031426df1c29e4cca3c8b3d261.tar.gz
src-a134b98878a1b8031426df1c29e4cca3c8b3d261.zip
Notes
Diffstat (limited to 'sys/arm64/arm64/gic_v3.c')
-rw-r--r--sys/arm64/arm64/gic_v3.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/sys/arm64/arm64/gic_v3.c b/sys/arm64/arm64/gic_v3.c
index 85f58a98c956..0110ebd734f2 100644
--- a/sys/arm64/arm64/gic_v3.c
+++ b/sys/arm64/arm64/gic_v3.c
@@ -503,12 +503,33 @@ gic_map_fdt(device_t dev, u_int ncells, pcell_t *cells, u_int *irqp,
#endif
static int
+gic_map_msi(device_t dev, struct intr_map_data_msi *msi_data, u_int *irqp,
+ enum intr_polarity *polp, enum intr_trigger *trigp)
+{
+ struct gic_v3_irqsrc *gi;
+
+ /* SPI-mapped MSI */
+ gi = (struct gic_v3_irqsrc *)msi_data->isrc;
+ if (gi == NULL)
+ return (ENXIO);
+
+ *irqp = gi->gi_irq;
+
+ /* MSI/MSI-X interrupts are always edge triggered with high polarity */
+ *polp = INTR_POLARITY_HIGH;
+ *trigp = INTR_TRIGGER_EDGE;
+
+ return (0);
+}
+
+static int
do_gic_v3_map_intr(device_t dev, struct intr_map_data *data, u_int *irqp,
enum intr_polarity *polp, enum intr_trigger *trigp)
{
struct gic_v3_softc *sc;
enum intr_polarity pol;
enum intr_trigger trig;
+ struct intr_map_data_msi *dam;
#ifdef FDT
struct intr_map_data_fdt *daf;
#endif
@@ -525,6 +546,12 @@ do_gic_v3_map_intr(device_t dev, struct intr_map_data *data, u_int *irqp,
return (EINVAL);
break;
#endif
+ case INTR_MAP_DATA_MSI:
+ /* SPI-mapped MSI */
+ dam = (struct intr_map_data_msi *)data;
+ if (gic_map_msi(dev, dam, &irq, &pol, &trig) != 0)
+ return (EINVAL);
+ break;
default:
return (EINVAL);
}