diff options
author | frank.blaschka@de.ibm.com <frank.blaschka@de.ibm.com> | 2011-08-07 21:33:56 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-08-13 04:10:16 -0400 |
commit | 9cb7284f3058d272758ebaaa8f6f924cb99792bc (patch) | |
tree | a800cec83dcb89596108bbc75bfc6521c01c2b76 /drivers/s390 | |
parent | 104ea556ee7f40039c9c635d0c267b1fde084a81 (diff) |
qdio: support forced signal adapter indications
This patch ensures that signal adapter commands are issued if they are
indicated to be required.
Signed-off-by: Einar Lueck <elelueck@de.ibm.com>
Signed-off-by: Jan Glauber <jang@linux.vnet.ibm.com>
Signed-off-by: Frank Blaschka <frank.blaschka@de.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/s390')
-rw-r--r-- | drivers/s390/cio/qdio.h | 9 | ||||
-rw-r--r-- | drivers/s390/cio/qdio_main.c | 5 |
2 files changed, 1 insertions, 13 deletions
diff --git a/drivers/s390/cio/qdio.h b/drivers/s390/cio/qdio.h index 2b21f65a895..3dd86441da3 100644 --- a/drivers/s390/cio/qdio.h +++ b/drivers/s390/cio/qdio.h | |||
@@ -87,15 +87,6 @@ enum qdio_irq_states { | |||
87 | #define CHSC_FLAG_QDIO_CAPABILITY 0x80 | 87 | #define CHSC_FLAG_QDIO_CAPABILITY 0x80 |
88 | #define CHSC_FLAG_VALIDITY 0x40 | 88 | #define CHSC_FLAG_VALIDITY 0x40 |
89 | 89 | ||
90 | /* qdio adapter-characteristics-1 flag */ | ||
91 | #define AC1_SIGA_INPUT_NEEDED 0x40 /* process input queues */ | ||
92 | #define AC1_SIGA_OUTPUT_NEEDED 0x20 /* process output queues */ | ||
93 | #define AC1_SIGA_SYNC_NEEDED 0x10 /* ask hypervisor to sync */ | ||
94 | #define AC1_AUTOMATIC_SYNC_ON_THININT 0x08 /* set by hypervisor */ | ||
95 | #define AC1_AUTOMATIC_SYNC_ON_OUT_PCI 0x04 /* set by hypervisor */ | ||
96 | #define AC1_SC_QEBSM_AVAILABLE 0x02 /* available for subchannel */ | ||
97 | #define AC1_SC_QEBSM_ENABLED 0x01 /* enabled for subchannel */ | ||
98 | |||
99 | /* SIGA flags */ | 90 | /* SIGA flags */ |
100 | #define QDIO_SIGA_WRITE 0x00 | 91 | #define QDIO_SIGA_WRITE 0x00 |
101 | #define QDIO_SIGA_READ 0x01 | 92 | #define QDIO_SIGA_READ 0x01 |
diff --git a/drivers/s390/cio/qdio_main.c b/drivers/s390/cio/qdio_main.c index a7153f2f3af..9a122280246 100644 --- a/drivers/s390/cio/qdio_main.c +++ b/drivers/s390/cio/qdio_main.c | |||
@@ -1592,12 +1592,9 @@ set: | |||
1592 | used = atomic_add_return(count, &q->nr_buf_used) - count; | 1592 | used = atomic_add_return(count, &q->nr_buf_used) - count; |
1593 | BUG_ON(used + count > QDIO_MAX_BUFFERS_PER_Q); | 1593 | BUG_ON(used + count > QDIO_MAX_BUFFERS_PER_Q); |
1594 | 1594 | ||
1595 | /* no need to signal as long as the adapter had free buffers */ | ||
1596 | if (used) | ||
1597 | return 0; | ||
1598 | |||
1599 | if (need_siga_in(q)) | 1595 | if (need_siga_in(q)) |
1600 | return qdio_siga_input(q); | 1596 | return qdio_siga_input(q); |
1597 | |||
1601 | return 0; | 1598 | return 0; |
1602 | } | 1599 | } |
1603 | 1600 | ||