diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/s390/cio/qdio_main.c | 46 | ||||
-rw-r--r-- | drivers/s390/net/qeth_core_main.c | 17 |
2 files changed, 13 insertions, 50 deletions
diff --git a/drivers/s390/cio/qdio_main.c b/drivers/s390/cio/qdio_main.c index dafb3e5bdad7..00520f9a7a8e 100644 --- a/drivers/s390/cio/qdio_main.c +++ b/drivers/s390/cio/qdio_main.c | |||
@@ -1023,30 +1023,6 @@ int qdio_get_ssqd_desc(struct ccw_device *cdev, | |||
1023 | } | 1023 | } |
1024 | EXPORT_SYMBOL_GPL(qdio_get_ssqd_desc); | 1024 | EXPORT_SYMBOL_GPL(qdio_get_ssqd_desc); |
1025 | 1025 | ||
1026 | /** | ||
1027 | * qdio_cleanup - shutdown queues and free data structures | ||
1028 | * @cdev: associated ccw device | ||
1029 | * @how: use halt or clear to shutdown | ||
1030 | * | ||
1031 | * This function calls qdio_shutdown() for @cdev with method @how. | ||
1032 | * and qdio_free(). The qdio_free() return value is ignored since | ||
1033 | * !irq_ptr is already checked. | ||
1034 | */ | ||
1035 | int qdio_cleanup(struct ccw_device *cdev, int how) | ||
1036 | { | ||
1037 | struct qdio_irq *irq_ptr = cdev->private->qdio_data; | ||
1038 | int rc; | ||
1039 | |||
1040 | if (!irq_ptr) | ||
1041 | return -ENODEV; | ||
1042 | |||
1043 | rc = qdio_shutdown(cdev, how); | ||
1044 | |||
1045 | qdio_free(cdev); | ||
1046 | return rc; | ||
1047 | } | ||
1048 | EXPORT_SYMBOL_GPL(qdio_cleanup); | ||
1049 | |||
1050 | static void qdio_shutdown_queues(struct ccw_device *cdev) | 1026 | static void qdio_shutdown_queues(struct ccw_device *cdev) |
1051 | { | 1027 | { |
1052 | struct qdio_irq *irq_ptr = cdev->private->qdio_data; | 1028 | struct qdio_irq *irq_ptr = cdev->private->qdio_data; |
@@ -1164,28 +1140,6 @@ int qdio_free(struct ccw_device *cdev) | |||
1164 | EXPORT_SYMBOL_GPL(qdio_free); | 1140 | EXPORT_SYMBOL_GPL(qdio_free); |
1165 | 1141 | ||
1166 | /** | 1142 | /** |
1167 | * qdio_initialize - allocate and establish queues for a qdio subchannel | ||
1168 | * @init_data: initialization data | ||
1169 | * | ||
1170 | * This function first allocates queues via qdio_allocate() and on success | ||
1171 | * establishes them via qdio_establish(). | ||
1172 | */ | ||
1173 | int qdio_initialize(struct qdio_initialize *init_data) | ||
1174 | { | ||
1175 | int rc; | ||
1176 | |||
1177 | rc = qdio_allocate(init_data); | ||
1178 | if (rc) | ||
1179 | return rc; | ||
1180 | |||
1181 | rc = qdio_establish(init_data); | ||
1182 | if (rc) | ||
1183 | qdio_free(init_data->cdev); | ||
1184 | return rc; | ||
1185 | } | ||
1186 | EXPORT_SYMBOL_GPL(qdio_initialize); | ||
1187 | |||
1188 | /** | ||
1189 | * qdio_allocate - allocate qdio queues and associated data | 1143 | * qdio_allocate - allocate qdio queues and associated data |
1190 | * @init_data: initialization data | 1144 | * @init_data: initialization data |
1191 | */ | 1145 | */ |
diff --git a/drivers/s390/net/qeth_core_main.c b/drivers/s390/net/qeth_core_main.c index 3ba738b2e271..28f71349fdec 100644 --- a/drivers/s390/net/qeth_core_main.c +++ b/drivers/s390/net/qeth_core_main.c | |||
@@ -1292,13 +1292,14 @@ int qeth_qdio_clear_card(struct qeth_card *card, int use_halt) | |||
1292 | QETH_QDIO_CLEANING)) { | 1292 | QETH_QDIO_CLEANING)) { |
1293 | case QETH_QDIO_ESTABLISHED: | 1293 | case QETH_QDIO_ESTABLISHED: |
1294 | if (card->info.type == QETH_CARD_TYPE_IQD) | 1294 | if (card->info.type == QETH_CARD_TYPE_IQD) |
1295 | rc = qdio_cleanup(CARD_DDEV(card), | 1295 | rc = qdio_shutdown(CARD_DDEV(card), |
1296 | QDIO_FLAG_CLEANUP_USING_HALT); | 1296 | QDIO_FLAG_CLEANUP_USING_HALT); |
1297 | else | 1297 | else |
1298 | rc = qdio_cleanup(CARD_DDEV(card), | 1298 | rc = qdio_shutdown(CARD_DDEV(card), |
1299 | QDIO_FLAG_CLEANUP_USING_CLEAR); | 1299 | QDIO_FLAG_CLEANUP_USING_CLEAR); |
1300 | if (rc) | 1300 | if (rc) |
1301 | QETH_DBF_TEXT_(TRACE, 3, "1err%d", rc); | 1301 | QETH_DBF_TEXT_(TRACE, 3, "1err%d", rc); |
1302 | qdio_free(CARD_DDEV(card)); | ||
1302 | atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED); | 1303 | atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED); |
1303 | break; | 1304 | break; |
1304 | case QETH_QDIO_CLEANING: | 1305 | case QETH_QDIO_CLEANING: |
@@ -3810,10 +3811,18 @@ static int qeth_qdio_establish(struct qeth_card *card) | |||
3810 | 3811 | ||
3811 | if (atomic_cmpxchg(&card->qdio.state, QETH_QDIO_ALLOCATED, | 3812 | if (atomic_cmpxchg(&card->qdio.state, QETH_QDIO_ALLOCATED, |
3812 | QETH_QDIO_ESTABLISHED) == QETH_QDIO_ALLOCATED) { | 3813 | QETH_QDIO_ESTABLISHED) == QETH_QDIO_ALLOCATED) { |
3813 | rc = qdio_initialize(&init_data); | 3814 | rc = qdio_allocate(&init_data); |
3814 | if (rc) | 3815 | if (rc) { |
3816 | atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED); | ||
3817 | goto out; | ||
3818 | } | ||
3819 | rc = qdio_establish(&init_data); | ||
3820 | if (rc) { | ||
3815 | atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED); | 3821 | atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED); |
3822 | qdio_free(CARD_DDEV(card)); | ||
3823 | } | ||
3816 | } | 3824 | } |
3825 | out: | ||
3817 | kfree(out_sbal_ptrs); | 3826 | kfree(out_sbal_ptrs); |
3818 | kfree(in_sbal_ptrs); | 3827 | kfree(in_sbal_ptrs); |
3819 | kfree(qib_param_field); | 3828 | kfree(qib_param_field); |