]> git.dujemihanovic.xyz Git - linux.git/commitdiff
s390/airq: recognize directed interrupts
authorSebastian Ott <sebott@linux.ibm.com>
Sun, 28 Oct 2018 10:51:56 +0000 (11:51 +0100)
committerMartin Schwidefsky <schwidefsky@de.ibm.com>
Mon, 29 Apr 2019 08:47:01 +0000 (10:47 +0200)
Add an extra parameter for airq handlers to recognize
floating vs. directed interrupts.

Signed-off-by: Sebastian Ott <sebott@linux.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
arch/s390/include/asm/airq.h
arch/s390/kvm/interrupt.c
arch/s390/pci/pci_irq.c
drivers/s390/cio/airq.c
drivers/s390/cio/cio.h
drivers/s390/cio/qdio_thinint.c
drivers/s390/crypto/ap_bus.c
drivers/s390/virtio/virtio_ccw.c

index fcf539efb32fb802d7c46030bda0a74c8df77639..91e78df365c764d60d7779f3dd8add45fbcf50dc 100644 (file)
@@ -14,7 +14,7 @@
 
 struct airq_struct {
        struct hlist_node list;         /* Handler queueing. */
-       void (*handler)(struct airq_struct *);  /* Thin-interrupt handler */
+       void (*handler)(struct airq_struct *airq, bool floating);
        u8 *lsi_ptr;                    /* Local-Summary-Indicator pointer */
        u8 lsi_mask;                    /* Local-Summary-Indicator mask */
        u8 isc;                         /* Interrupt-subclass */
index 82162867f378d225ede29ff32adee1983072a7ac..37503ae62486cab04b418afeb488a93919313d9b 100644 (file)
@@ -3194,7 +3194,7 @@ out:
 }
 EXPORT_SYMBOL_GPL(kvm_s390_gisc_unregister);
 
-static void gib_alert_irq_handler(struct airq_struct *airq)
+static void gib_alert_irq_handler(struct airq_struct *airq, bool floating)
 {
        inc_irq_stat(IRQIO_GAL);
        process_gib_alert_list();
index 3b129cd35b6e5612d57a66afebdd005d4bd2b17c..55e22e3923761ae65c5ad766b3ec11de033d0471 100644 (file)
@@ -56,7 +56,7 @@ static struct irq_chip zpci_irq_chip = {
        .irq_mask = pci_msi_mask_irq,
 };
 
-static void zpci_irq_handler(struct airq_struct *airq)
+static void zpci_irq_handler(struct airq_struct *airq, bool floating)
 {
        unsigned long si, ai;
        struct airq_iv *aibv;
index a45011e4529e7dabd5c6da14190bf2a6b237e905..e045e79f061c592be9672a238caaeaef2620f270 100644 (file)
@@ -95,7 +95,7 @@ static irqreturn_t do_airq_interrupt(int irq, void *dummy)
        rcu_read_lock();
        hlist_for_each_entry_rcu(airq, head, list)
                if ((*airq->lsi_ptr & airq->lsi_mask) != 0)
-                       airq->handler(airq);
+                       airq->handler(airq, !tpi_info->directed_irq);
        rcu_read_unlock();
 
        return IRQ_HANDLED;
index 92eabbb5f18d44a0045b41e7147e487cafe802a4..06a91743335af0a6d1998ac139390417b16fb099 100644 (file)
@@ -51,7 +51,7 @@ struct tpi_info {
        struct subchannel_id schid;
        u32 intparm;
        u32 adapter_IO:1;
-       u32 :1;
+       u32 directed_irq:1;
        u32 isc:3;
        u32 :27;
        u32 type:3;
index 07dea602205bdf2a18bfe85fad5888cf2f91b4dd..28d59ac2204cc1d024deed7b41ec42b172df38f0 100644 (file)
@@ -40,7 +40,7 @@ static LIST_HEAD(tiq_list);
 static DEFINE_MUTEX(tiq_list_lock);
 
 /* Adapter interrupt definitions */
-static void tiqdio_thinint_handler(struct airq_struct *airq);
+static void tiqdio_thinint_handler(struct airq_struct *airq, bool floating);
 
 static struct airq_struct tiqdio_airq = {
        .handler = tiqdio_thinint_handler,
@@ -179,7 +179,7 @@ static inline void tiqdio_call_inq_handlers(struct qdio_irq *irq)
  * tiqdio_thinint_handler - thin interrupt handler for qdio
  * @airq: pointer to adapter interrupt descriptor
  */
-static void tiqdio_thinint_handler(struct airq_struct *airq)
+static void tiqdio_thinint_handler(struct airq_struct *airq, bool floating)
 {
        u32 si_used = clear_shared_ind();
        struct qdio_q *q;
index 1546389d71dbca7ebc1f2f103780182742226376..cc30e4f07fffabe0da6968dfa379c9ef9de843a3 100644 (file)
@@ -116,7 +116,7 @@ static int user_set_domain;
 static struct bus_type ap_bus_type;
 
 /* Adapter interrupt definitions */
-static void ap_interrupt_handler(struct airq_struct *airq);
+static void ap_interrupt_handler(struct airq_struct *airq, bool floating);
 
 static int ap_airq_flag;
 
@@ -393,7 +393,7 @@ static enum hrtimer_restart ap_poll_timeout(struct hrtimer *unused)
  * ap_interrupt_handler() - Schedule ap_tasklet on interrupt
  * @airq: pointer to adapter interrupt descriptor
  */
-static void ap_interrupt_handler(struct airq_struct *airq)
+static void ap_interrupt_handler(struct airq_struct *airq, bool floating)
 {
        inc_irq_stat(IRQIO_APB);
        if (!ap_suspend_flag)
index 74c328321889b1fa3265385ebe9d0a201a031b90..991420caa4f20c59d691fafa46e6d511bc151c12 100644 (file)
@@ -182,7 +182,7 @@ static void drop_airq_indicator(struct virtqueue *vq, struct airq_info *info)
        write_unlock_irqrestore(&info->lock, flags);
 }
 
-static void virtio_airq_handler(struct airq_struct *airq)
+static void virtio_airq_handler(struct airq_struct *airq, bool floating)
 {
        struct airq_info *info = container_of(airq, struct airq_info, airq);
        unsigned long ai;