diff options
author | Heiko Carstens <heiko.carstens@de.ibm.com> | 2006-09-18 16:28:49 -0400 |
---|---|---|
committer | James Bottomley <jejb@mulgrave.il.steeleye.com> | 2006-09-23 18:54:24 -0400 |
commit | dd52e0eaf891cd85bf2ca057c15ed6bfd76db4e6 (patch) | |
tree | dc457fe1b732716b715c05864ab02be767414cb4 /drivers/s390/scsi/zfcp_aux.c | |
parent | d136205182b1ea4897da31e325a296f8831a6796 (diff) |
[SCSI] zfcp: create private slab caches to guarantee proper data alignment
Create private slab caches in order to guarantee proper alignment of
data structures that get passed to hardware.
Sidenote: with this patch slab cache debugging will finally work on s390
(at least no known problems left).
Furthermore this patch does some minor cleanups:
- store ptr for transport template in struct zfcp_data
Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Andreas Herrmann <aherrman@de.ibm.com>
Compile fix ups and
Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
Diffstat (limited to 'drivers/s390/scsi/zfcp_aux.c')
-rw-r--r-- | drivers/s390/scsi/zfcp_aux.c | 76 |
1 files changed, 58 insertions, 18 deletions
diff --git a/drivers/s390/scsi/zfcp_aux.c b/drivers/s390/scsi/zfcp_aux.c index adc9d8f2c28f..d2b094d9c34f 100644 --- a/drivers/s390/scsi/zfcp_aux.c +++ b/drivers/s390/scsi/zfcp_aux.c | |||
@@ -299,11 +299,45 @@ zfcp_init_device_configure(void) | |||
299 | return; | 299 | return; |
300 | } | 300 | } |
301 | 301 | ||
302 | static int calc_alignment(int size) | ||
303 | { | ||
304 | int align = 1; | ||
305 | |||
306 | if (!size) | ||
307 | return 0; | ||
308 | |||
309 | while ((size - align) > 0) | ||
310 | align <<= 1; | ||
311 | |||
312 | return align; | ||
313 | } | ||
314 | |||
302 | static int __init | 315 | static int __init |
303 | zfcp_module_init(void) | 316 | zfcp_module_init(void) |
304 | { | 317 | { |
318 | int retval = -ENOMEM; | ||
319 | int size, align; | ||
320 | |||
321 | size = sizeof(struct zfcp_fsf_req_qtcb); | ||
322 | align = calc_alignment(size); | ||
323 | zfcp_data.fsf_req_qtcb_cache = | ||
324 | kmem_cache_create("zfcp_fsf", size, align, 0, NULL, NULL); | ||
325 | if (!zfcp_data.fsf_req_qtcb_cache) | ||
326 | goto out; | ||
305 | 327 | ||
306 | int retval = 0; | 328 | size = sizeof(struct fsf_status_read_buffer); |
329 | align = calc_alignment(size); | ||
330 | zfcp_data.sr_buffer_cache = | ||
331 | kmem_cache_create("zfcp_sr", size, align, 0, NULL, NULL); | ||
332 | if (!zfcp_data.sr_buffer_cache) | ||
333 | goto out_sr_cache; | ||
334 | |||
335 | size = sizeof(struct zfcp_gid_pn_data); | ||
336 | align = calc_alignment(size); | ||
337 | zfcp_data.gid_pn_cache = | ||
338 | kmem_cache_create("zfcp_gid", size, align, 0, NULL, NULL); | ||
339 | if (!zfcp_data.gid_pn_cache) | ||
340 | goto out_gid_cache; | ||
307 | 341 | ||
308 | atomic_set(&zfcp_data.loglevel, loglevel); | 342 | atomic_set(&zfcp_data.loglevel, loglevel); |
309 | 343 | ||
@@ -313,15 +347,16 @@ zfcp_module_init(void) | |||
313 | /* initialize adapters to be removed list head */ | 347 | /* initialize adapters to be removed list head */ |
314 | INIT_LIST_HEAD(&zfcp_data.adapter_remove_lh); | 348 | INIT_LIST_HEAD(&zfcp_data.adapter_remove_lh); |
315 | 349 | ||
316 | zfcp_transport_template = fc_attach_transport(&zfcp_transport_functions); | 350 | zfcp_data.scsi_transport_template = |
317 | if (!zfcp_transport_template) | 351 | fc_attach_transport(&zfcp_transport_functions); |
318 | return -ENODEV; | 352 | if (!zfcp_data.scsi_transport_template) |
353 | goto out_transport; | ||
319 | 354 | ||
320 | retval = misc_register(&zfcp_cfdc_misc); | 355 | retval = misc_register(&zfcp_cfdc_misc); |
321 | if (retval != 0) { | 356 | if (retval != 0) { |
322 | ZFCP_LOG_INFO("registration of misc device " | 357 | ZFCP_LOG_INFO("registration of misc device " |
323 | "zfcp_cfdc failed\n"); | 358 | "zfcp_cfdc failed\n"); |
324 | goto out; | 359 | goto out_misc; |
325 | } | 360 | } |
326 | 361 | ||
327 | ZFCP_LOG_TRACE("major/minor for zfcp_cfdc: %d/%d\n", | 362 | ZFCP_LOG_TRACE("major/minor for zfcp_cfdc: %d/%d\n", |
@@ -333,9 +368,6 @@ zfcp_module_init(void) | |||
333 | /* initialise configuration rw lock */ | 368 | /* initialise configuration rw lock */ |
334 | rwlock_init(&zfcp_data.config_lock); | 369 | rwlock_init(&zfcp_data.config_lock); |
335 | 370 | ||
336 | /* save address of data structure managing the driver module */ | ||
337 | zfcp_data.scsi_host_template.module = THIS_MODULE; | ||
338 | |||
339 | /* setup dynamic I/O */ | 371 | /* setup dynamic I/O */ |
340 | retval = zfcp_ccw_register(); | 372 | retval = zfcp_ccw_register(); |
341 | if (retval) { | 373 | if (retval) { |
@@ -350,6 +382,14 @@ zfcp_module_init(void) | |||
350 | 382 | ||
351 | out_ccw_register: | 383 | out_ccw_register: |
352 | misc_deregister(&zfcp_cfdc_misc); | 384 | misc_deregister(&zfcp_cfdc_misc); |
385 | out_misc: | ||
386 | fc_release_transport(zfcp_data.scsi_transport_template); | ||
387 | out_transport: | ||
388 | kmem_cache_destroy(zfcp_data.gid_pn_cache); | ||
389 | out_gid_cache: | ||
390 | kmem_cache_destroy(zfcp_data.sr_buffer_cache); | ||
391 | out_sr_cache: | ||
392 | kmem_cache_destroy(zfcp_data.fsf_req_qtcb_cache); | ||
353 | out: | 393 | out: |
354 | return retval; | 394 | return retval; |
355 | } | 395 | } |
@@ -935,20 +975,20 @@ static int | |||
935 | zfcp_allocate_low_mem_buffers(struct zfcp_adapter *adapter) | 975 | zfcp_allocate_low_mem_buffers(struct zfcp_adapter *adapter) |
936 | { | 976 | { |
937 | adapter->pool.fsf_req_erp = | 977 | adapter->pool.fsf_req_erp = |
938 | mempool_create_kmalloc_pool(ZFCP_POOL_FSF_REQ_ERP_NR, | 978 | mempool_create_slab_pool(ZFCP_POOL_FSF_REQ_ERP_NR, |
939 | sizeof(struct zfcp_fsf_req_pool_element)); | 979 | zfcp_data.fsf_req_qtcb_cache); |
940 | if (!adapter->pool.fsf_req_erp) | 980 | if (!adapter->pool.fsf_req_erp) |
941 | return -ENOMEM; | 981 | return -ENOMEM; |
942 | 982 | ||
943 | adapter->pool.fsf_req_scsi = | 983 | adapter->pool.fsf_req_scsi = |
944 | mempool_create_kmalloc_pool(ZFCP_POOL_FSF_REQ_SCSI_NR, | 984 | mempool_create_slab_pool(ZFCP_POOL_FSF_REQ_SCSI_NR, |
945 | sizeof(struct zfcp_fsf_req_pool_element)); | 985 | zfcp_data.fsf_req_qtcb_cache); |
946 | if (!adapter->pool.fsf_req_scsi) | 986 | if (!adapter->pool.fsf_req_scsi) |
947 | return -ENOMEM; | 987 | return -ENOMEM; |
948 | 988 | ||
949 | adapter->pool.fsf_req_abort = | 989 | adapter->pool.fsf_req_abort = |
950 | mempool_create_kmalloc_pool(ZFCP_POOL_FSF_REQ_ABORT_NR, | 990 | mempool_create_slab_pool(ZFCP_POOL_FSF_REQ_ABORT_NR, |
951 | sizeof(struct zfcp_fsf_req_pool_element)); | 991 | zfcp_data.fsf_req_qtcb_cache); |
952 | if (!adapter->pool.fsf_req_abort) | 992 | if (!adapter->pool.fsf_req_abort) |
953 | return -ENOMEM; | 993 | return -ENOMEM; |
954 | 994 | ||
@@ -959,14 +999,14 @@ zfcp_allocate_low_mem_buffers(struct zfcp_adapter *adapter) | |||
959 | return -ENOMEM; | 999 | return -ENOMEM; |
960 | 1000 | ||
961 | adapter->pool.data_status_read = | 1001 | adapter->pool.data_status_read = |
962 | mempool_create_kmalloc_pool(ZFCP_POOL_STATUS_READ_NR, | 1002 | mempool_create_slab_pool(ZFCP_POOL_STATUS_READ_NR, |
963 | sizeof(struct fsf_status_read_buffer)); | 1003 | zfcp_data.sr_buffer_cache); |
964 | if (!adapter->pool.data_status_read) | 1004 | if (!adapter->pool.data_status_read) |
965 | return -ENOMEM; | 1005 | return -ENOMEM; |
966 | 1006 | ||
967 | adapter->pool.data_gid_pn = | 1007 | adapter->pool.data_gid_pn = |
968 | mempool_create_kmalloc_pool(ZFCP_POOL_DATA_GID_PN_NR, | 1008 | mempool_create_slab_pool(ZFCP_POOL_DATA_GID_PN_NR, |
969 | sizeof(struct zfcp_gid_pn_data)); | 1009 | zfcp_data.gid_pn_cache); |
970 | if (!adapter->pool.data_gid_pn) | 1010 | if (!adapter->pool.data_gid_pn) |
971 | return -ENOMEM; | 1011 | return -ENOMEM; |
972 | 1012 | ||