9a4da8a5b1
Support PCI adapter interrupts using the Single-IRQ-mode. Single-IRQ-mode disables an adapter IRQ automatically after delivering it until the SIC instruction enables it again. This is used to reduce the number of IRQs for streaming workloads. Up to 64 MSI handlers can be registered per PCI function. A hash table is used to map interrupt numbers to MSI descriptors. The interrupt vector is scanned using the flogr instruction. Only MSI/MSI-X interrupts are supported, no legacy INTs. Signed-off-by: Jan Glauber <jang@linux.vnet.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
28 lines
897 B
C
28 lines
897 B
C
#ifndef _ASM_S390_ISC_H
|
|
#define _ASM_S390_ISC_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
/*
|
|
* I/O interruption subclasses used by drivers.
|
|
* Please add all used iscs here so that it is possible to distribute
|
|
* isc usage between drivers.
|
|
* Reminder: 0 is highest priority, 7 lowest.
|
|
*/
|
|
#define MAX_ISC 7
|
|
|
|
/* Regular I/O interrupts. */
|
|
#define IO_SCH_ISC 3 /* regular I/O subchannels */
|
|
#define CONSOLE_ISC 1 /* console I/O subchannel */
|
|
#define EADM_SCH_ISC 4 /* EADM subchannels */
|
|
#define CHSC_SCH_ISC 7 /* CHSC subchannels */
|
|
/* Adapter interrupts. */
|
|
#define QDIO_AIRQ_ISC IO_SCH_ISC /* I/O subchannel in qdio mode */
|
|
#define PCI_ISC 2 /* PCI I/O subchannels */
|
|
#define AP_ISC 6 /* adjunct processor (crypto) devices */
|
|
|
|
/* Functions for registration of I/O interruption subclasses */
|
|
void isc_register(unsigned int isc);
|
|
void isc_unregister(unsigned int isc);
|
|
|
|
#endif /* _ASM_S390_ISC_H */
|