Commit 062f0024 authored by Matthew Rosato's avatar Matthew Rosato Committed by Christian Borntraeger

s390/pci: externalize the SIC operation controls and routine

A subsequent patch will be issuing SIC from KVM -- export the necessary
routine and make the operation control definitions available from a header.
Because the routine will now be exported, let's rename __zpci_set_irq_ctrl
to zpci_set_irq_ctrl and get rid of the zero'd iib wrapper function of
the same name.
Reviewed-by: default avatarNiklas Schnelle <schnelle@linux.ibm.com>
Reviewed-by: default avatarClaudio Imbrenda <imbrenda@linux.ibm.com>
Reviewed-by: default avatarPierre Morel <pmorel@linux.ibm.com>
Signed-off-by: default avatarMatthew Rosato <mjrosato@linux.ibm.com>
Link: https://lore.kernel.org/r/20220606203325.110625-8-mjrosato@linux.ibm.comSigned-off-by: default avatarChristian Borntraeger <borntraeger@linux.ibm.com>
parent 932b6467
...@@ -98,6 +98,14 @@ struct zpci_fib { ...@@ -98,6 +98,14 @@ struct zpci_fib {
u32 gd; u32 gd;
} __packed __aligned(8); } __packed __aligned(8);
/* Set Interruption Controls Operation Controls */
#define SIC_IRQ_MODE_ALL 0
#define SIC_IRQ_MODE_SINGLE 1
#define SIC_IRQ_MODE_DIRECT 4
#define SIC_IRQ_MODE_D_ALL 16
#define SIC_IRQ_MODE_D_SINGLE 17
#define SIC_IRQ_MODE_SET_CPU 18
/* directed interruption information block */ /* directed interruption information block */
struct zpci_diib { struct zpci_diib {
u32 : 1; u32 : 1;
...@@ -134,13 +142,6 @@ int __zpci_store(u64 data, u64 req, u64 offset); ...@@ -134,13 +142,6 @@ int __zpci_store(u64 data, u64 req, u64 offset);
int zpci_store(const volatile void __iomem *addr, u64 data, unsigned long len); int zpci_store(const volatile void __iomem *addr, u64 data, unsigned long len);
int __zpci_store_block(const u64 *data, u64 req, u64 offset); int __zpci_store_block(const u64 *data, u64 req, u64 offset);
void zpci_barrier(void); void zpci_barrier(void);
int __zpci_set_irq_ctrl(u16 ctl, u8 isc, union zpci_sic_iib *iib); int zpci_set_irq_ctrl(u16 ctl, u8 isc, union zpci_sic_iib *iib);
static inline int zpci_set_irq_ctrl(u16 ctl, u8 isc)
{
union zpci_sic_iib iib = {{0}};
return __zpci_set_irq_ctrl(ctl, isc, &iib);
}
#endif #endif
...@@ -138,7 +138,7 @@ int zpci_refresh_trans(u64 fn, u64 addr, u64 range) ...@@ -138,7 +138,7 @@ int zpci_refresh_trans(u64 fn, u64 addr, u64 range)
} }
/* Set Interruption Controls */ /* Set Interruption Controls */
int __zpci_set_irq_ctrl(u16 ctl, u8 isc, union zpci_sic_iib *iib) int zpci_set_irq_ctrl(u16 ctl, u8 isc, union zpci_sic_iib *iib)
{ {
if (!test_facility(72)) if (!test_facility(72))
return -EIO; return -EIO;
...@@ -149,6 +149,7 @@ int __zpci_set_irq_ctrl(u16 ctl, u8 isc, union zpci_sic_iib *iib) ...@@ -149,6 +149,7 @@ int __zpci_set_irq_ctrl(u16 ctl, u8 isc, union zpci_sic_iib *iib)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(zpci_set_irq_ctrl);
/* PCI Load */ /* PCI Load */
static inline int ____pcilg(u64 *data, u64 req, u64 offset, u8 *status) static inline int ____pcilg(u64 *data, u64 req, u64 offset, u8 *status)
......
...@@ -15,13 +15,6 @@ ...@@ -15,13 +15,6 @@
static enum {FLOATING, DIRECTED} irq_delivery; static enum {FLOATING, DIRECTED} irq_delivery;
#define SIC_IRQ_MODE_ALL 0
#define SIC_IRQ_MODE_SINGLE 1
#define SIC_IRQ_MODE_DIRECT 4
#define SIC_IRQ_MODE_D_ALL 16
#define SIC_IRQ_MODE_D_SINGLE 17
#define SIC_IRQ_MODE_SET_CPU 18
/* /*
* summary bit vector * summary bit vector
* FLOATING - summary bit per function * FLOATING - summary bit per function
...@@ -154,6 +147,7 @@ static struct irq_chip zpci_irq_chip = { ...@@ -154,6 +147,7 @@ static struct irq_chip zpci_irq_chip = {
static void zpci_handle_cpu_local_irq(bool rescan) static void zpci_handle_cpu_local_irq(bool rescan)
{ {
struct airq_iv *dibv = zpci_ibv[smp_processor_id()]; struct airq_iv *dibv = zpci_ibv[smp_processor_id()];
union zpci_sic_iib iib = {{0}};
unsigned long bit; unsigned long bit;
int irqs_on = 0; int irqs_on = 0;
...@@ -165,7 +159,7 @@ static void zpci_handle_cpu_local_irq(bool rescan) ...@@ -165,7 +159,7 @@ static void zpci_handle_cpu_local_irq(bool rescan)
/* End of second scan with interrupts on. */ /* End of second scan with interrupts on. */
break; break;
/* First scan complete, reenable interrupts. */ /* First scan complete, reenable interrupts. */
if (zpci_set_irq_ctrl(SIC_IRQ_MODE_D_SINGLE, PCI_ISC)) if (zpci_set_irq_ctrl(SIC_IRQ_MODE_D_SINGLE, PCI_ISC, &iib))
break; break;
bit = 0; bit = 0;
continue; continue;
...@@ -193,6 +187,7 @@ static void zpci_handle_remote_irq(void *data) ...@@ -193,6 +187,7 @@ static void zpci_handle_remote_irq(void *data)
static void zpci_handle_fallback_irq(void) static void zpci_handle_fallback_irq(void)
{ {
struct cpu_irq_data *cpu_data; struct cpu_irq_data *cpu_data;
union zpci_sic_iib iib = {{0}};
unsigned long cpu; unsigned long cpu;
int irqs_on = 0; int irqs_on = 0;
...@@ -203,7 +198,7 @@ static void zpci_handle_fallback_irq(void) ...@@ -203,7 +198,7 @@ static void zpci_handle_fallback_irq(void)
/* End of second scan with interrupts on. */ /* End of second scan with interrupts on. */
break; break;
/* First scan complete, reenable interrupts. */ /* First scan complete, reenable interrupts. */
if (zpci_set_irq_ctrl(SIC_IRQ_MODE_SINGLE, PCI_ISC)) if (zpci_set_irq_ctrl(SIC_IRQ_MODE_SINGLE, PCI_ISC, &iib))
break; break;
cpu = 0; cpu = 0;
continue; continue;
...@@ -234,6 +229,7 @@ static void zpci_directed_irq_handler(struct airq_struct *airq, ...@@ -234,6 +229,7 @@ static void zpci_directed_irq_handler(struct airq_struct *airq,
static void zpci_floating_irq_handler(struct airq_struct *airq, static void zpci_floating_irq_handler(struct airq_struct *airq,
struct tpi_info *tpi_info) struct tpi_info *tpi_info)
{ {
union zpci_sic_iib iib = {{0}};
unsigned long si, ai; unsigned long si, ai;
struct airq_iv *aibv; struct airq_iv *aibv;
int irqs_on = 0; int irqs_on = 0;
...@@ -247,7 +243,7 @@ static void zpci_floating_irq_handler(struct airq_struct *airq, ...@@ -247,7 +243,7 @@ static void zpci_floating_irq_handler(struct airq_struct *airq,
/* End of second scan with interrupts on. */ /* End of second scan with interrupts on. */
break; break;
/* First scan complete, reenable interrupts. */ /* First scan complete, reenable interrupts. */
if (zpci_set_irq_ctrl(SIC_IRQ_MODE_SINGLE, PCI_ISC)) if (zpci_set_irq_ctrl(SIC_IRQ_MODE_SINGLE, PCI_ISC, &iib))
break; break;
si = 0; si = 0;
continue; continue;
...@@ -407,11 +403,12 @@ static struct airq_struct zpci_airq = { ...@@ -407,11 +403,12 @@ static struct airq_struct zpci_airq = {
static void __init cpu_enable_directed_irq(void *unused) static void __init cpu_enable_directed_irq(void *unused)
{ {
union zpci_sic_iib iib = {{0}}; union zpci_sic_iib iib = {{0}};
union zpci_sic_iib ziib = {{0}};
iib.cdiib.dibv_addr = (u64) zpci_ibv[smp_processor_id()]->vector; iib.cdiib.dibv_addr = (u64) zpci_ibv[smp_processor_id()]->vector;
__zpci_set_irq_ctrl(SIC_IRQ_MODE_SET_CPU, 0, &iib); zpci_set_irq_ctrl(SIC_IRQ_MODE_SET_CPU, 0, &iib);
zpci_set_irq_ctrl(SIC_IRQ_MODE_D_SINGLE, PCI_ISC); zpci_set_irq_ctrl(SIC_IRQ_MODE_D_SINGLE, PCI_ISC, &ziib);
} }
static int __init zpci_directed_irq_init(void) static int __init zpci_directed_irq_init(void)
...@@ -426,7 +423,7 @@ static int __init zpci_directed_irq_init(void) ...@@ -426,7 +423,7 @@ static int __init zpci_directed_irq_init(void)
iib.diib.isc = PCI_ISC; iib.diib.isc = PCI_ISC;
iib.diib.nr_cpus = num_possible_cpus(); iib.diib.nr_cpus = num_possible_cpus();
iib.diib.disb_addr = virt_to_phys(zpci_sbv->vector); iib.diib.disb_addr = virt_to_phys(zpci_sbv->vector);
__zpci_set_irq_ctrl(SIC_IRQ_MODE_DIRECT, 0, &iib); zpci_set_irq_ctrl(SIC_IRQ_MODE_DIRECT, 0, &iib);
zpci_ibv = kcalloc(num_possible_cpus(), sizeof(*zpci_ibv), zpci_ibv = kcalloc(num_possible_cpus(), sizeof(*zpci_ibv),
GFP_KERNEL); GFP_KERNEL);
...@@ -471,6 +468,7 @@ static int __init zpci_floating_irq_init(void) ...@@ -471,6 +468,7 @@ static int __init zpci_floating_irq_init(void)
int __init zpci_irq_init(void) int __init zpci_irq_init(void)
{ {
union zpci_sic_iib iib = {{0}};
int rc; int rc;
irq_delivery = sclp.has_dirq ? DIRECTED : FLOATING; irq_delivery = sclp.has_dirq ? DIRECTED : FLOATING;
...@@ -502,7 +500,7 @@ int __init zpci_irq_init(void) ...@@ -502,7 +500,7 @@ int __init zpci_irq_init(void)
* Enable floating IRQs (with suppression after one IRQ). When using * Enable floating IRQs (with suppression after one IRQ). When using
* directed IRQs this enables the fallback path. * directed IRQs this enables the fallback path.
*/ */
zpci_set_irq_ctrl(SIC_IRQ_MODE_SINGLE, PCI_ISC); zpci_set_irq_ctrl(SIC_IRQ_MODE_SINGLE, PCI_ISC, &iib);
return 0; return 0;
out_airq: out_airq:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment