Commit 3050f022 authored by Julian Wiedmann's avatar Julian Wiedmann Committed by Vasily Gorbik

s390/qdio: consolidate thinint init/exit

Wrap the init/exit steps for thinint into a single helper that follows
the established naming scheme.
Signed-off-by: default avatarJulian Wiedmann <jwi@linux.ibm.com>
Reviewed-by: default avatarSteffen Maier <maier@linux.ibm.com>
Reviewed-by: default avatarBenjamin Block <bblock@linux.ibm.com>
Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
parent 75e82bec
...@@ -369,10 +369,8 @@ void qdio_shutdown_thinint(struct qdio_irq *irq_ptr); ...@@ -369,10 +369,8 @@ void qdio_shutdown_thinint(struct qdio_irq *irq_ptr);
void tiqdio_add_device(struct qdio_irq *irq_ptr); void tiqdio_add_device(struct qdio_irq *irq_ptr);
void tiqdio_remove_device(struct qdio_irq *irq_ptr); void tiqdio_remove_device(struct qdio_irq *irq_ptr);
void tiqdio_inbound_processing(unsigned long q); void tiqdio_inbound_processing(unsigned long q);
int tiqdio_allocate_memory(void); int qdio_thinint_init(void);
void tiqdio_free_memory(void); void qdio_thinint_exit(void);
int tiqdio_register_thinints(void);
void tiqdio_unregister_thinints(void);
int test_nonshared_ind(struct qdio_irq *); int test_nonshared_ind(struct qdio_irq *);
/* prototypes for setup */ /* prototypes for setup */
......
...@@ -1861,16 +1861,11 @@ static int __init init_QDIO(void) ...@@ -1861,16 +1861,11 @@ static int __init init_QDIO(void)
rc = qdio_setup_init(); rc = qdio_setup_init();
if (rc) if (rc)
goto out_debug; goto out_debug;
rc = tiqdio_allocate_memory(); rc = qdio_thinint_init();
if (rc) if (rc)
goto out_cache; goto out_cache;
rc = tiqdio_register_thinints();
if (rc)
goto out_ti;
return 0; return 0;
out_ti:
tiqdio_free_memory();
out_cache: out_cache:
qdio_setup_exit(); qdio_setup_exit();
out_debug: out_debug:
...@@ -1880,8 +1875,7 @@ static int __init init_QDIO(void) ...@@ -1880,8 +1875,7 @@ static int __init init_QDIO(void)
static void __exit exit_QDIO(void) static void __exit exit_QDIO(void)
{ {
tiqdio_unregister_thinints(); qdio_thinint_exit();
tiqdio_free_memory();
qdio_setup_exit(); qdio_setup_exit();
qdio_debug_exit(); qdio_debug_exit();
} }
......
...@@ -197,34 +197,6 @@ static int set_subchannel_ind(struct qdio_irq *irq_ptr, int reset) ...@@ -197,34 +197,6 @@ static int set_subchannel_ind(struct qdio_irq *irq_ptr, int reset)
return rc; return rc;
} }
/* allocate non-shared indicators and shared indicator */
int __init tiqdio_allocate_memory(void)
{
q_indicators = kcalloc(TIQDIO_NR_INDICATORS,
sizeof(struct indicator_t),
GFP_KERNEL);
if (!q_indicators)
return -ENOMEM;
return 0;
}
void tiqdio_free_memory(void)
{
kfree(q_indicators);
}
int __init tiqdio_register_thinints(void)
{
int rc;
rc = register_adapter_interrupt(&tiqdio_airq);
if (rc) {
DBF_EVENT("RTI:%x", rc);
return rc;
}
return 0;
}
int qdio_establish_thinint(struct qdio_irq *irq_ptr) int qdio_establish_thinint(struct qdio_irq *irq_ptr)
{ {
int rc; int rc;
...@@ -252,8 +224,27 @@ void qdio_shutdown_thinint(struct qdio_irq *irq_ptr) ...@@ -252,8 +224,27 @@ void qdio_shutdown_thinint(struct qdio_irq *irq_ptr)
put_indicator(irq_ptr->dsci); put_indicator(irq_ptr->dsci);
} }
void __exit tiqdio_unregister_thinints(void) int __init qdio_thinint_init(void)
{
int rc;
q_indicators = kcalloc(TIQDIO_NR_INDICATORS, sizeof(struct indicator_t),
GFP_KERNEL);
if (!q_indicators)
return -ENOMEM;
rc = register_adapter_interrupt(&tiqdio_airq);
if (rc) {
DBF_EVENT("RTI:%x", rc);
kfree(q_indicators);
return rc;
}
return 0;
}
void __exit qdio_thinint_exit(void)
{ {
WARN_ON(!list_empty(&tiq_list)); WARN_ON(!list_empty(&tiq_list));
unregister_adapter_interrupt(&tiqdio_airq); unregister_adapter_interrupt(&tiqdio_airq);
kfree(q_indicators);
} }
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