aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s390
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/s390')
-rw-r--r--drivers/s390/scsi/zfcp_def.h2
-rw-r--r--drivers/s390/scsi/zfcp_ext.h1
-rw-r--r--drivers/s390/scsi/zfcp_qdio.c27
3 files changed, 11 insertions, 19 deletions
diff --git a/drivers/s390/scsi/zfcp_def.h b/drivers/s390/scsi/zfcp_def.h
index 202f7e66c446..e8383b7331b4 100644
--- a/drivers/s390/scsi/zfcp_def.h
+++ b/drivers/s390/scsi/zfcp_def.h
@@ -100,8 +100,6 @@ zfcp_address_to_sg(void *address, struct scatterlist *list, unsigned int size)
100 100
101#define ZFCP_TYPE2_RECOVERY_TIME 8 /* seconds */ 101#define ZFCP_TYPE2_RECOVERY_TIME 8 /* seconds */
102 102
103#define QBUFF_PER_PAGE (PAGE_SIZE / sizeof(struct qdio_buffer))
104
105/********************* FSF SPECIFIC DEFINES *********************************/ 103/********************* FSF SPECIFIC DEFINES *********************************/
106 104
107#define ZFCP_ULP_INFO_VERSION 26 105#define ZFCP_ULP_INFO_VERSION 26
diff --git a/drivers/s390/scsi/zfcp_ext.h b/drivers/s390/scsi/zfcp_ext.h
index c3b51338abfa..368b304d1e3f 100644
--- a/drivers/s390/scsi/zfcp_ext.h
+++ b/drivers/s390/scsi/zfcp_ext.h
@@ -43,7 +43,6 @@ extern void _zfcp_scan_ports_later(struct work_struct *work);
43/******************************* S/390 IO ************************************/ 43/******************************* S/390 IO ************************************/
44extern int zfcp_ccw_register(void); 44extern int zfcp_ccw_register(void);
45 45
46extern void zfcp_qdio_zero_sbals(struct qdio_buffer **, int, int);
47extern int zfcp_qdio_allocate(struct zfcp_adapter *); 46extern int zfcp_qdio_allocate(struct zfcp_adapter *);
48extern void zfcp_qdio_free(struct zfcp_adapter *); 47extern void zfcp_qdio_free(struct zfcp_adapter *);
49extern int zfcp_qdio_send(struct zfcp_fsf_req *fsf_req); 48extern int zfcp_qdio_send(struct zfcp_fsf_req *fsf_req);
diff --git a/drivers/s390/scsi/zfcp_qdio.c b/drivers/s390/scsi/zfcp_qdio.c
index bd6561d53589..b8ed42bb5c9e 100644
--- a/drivers/s390/scsi/zfcp_qdio.c
+++ b/drivers/s390/scsi/zfcp_qdio.c
@@ -11,6 +11,7 @@
11/* FIXME(tune): free space should be one max. SBAL chain plus what? */ 11/* FIXME(tune): free space should be one max. SBAL chain plus what? */
12#define ZFCP_QDIO_PCI_INTERVAL (QDIO_MAX_BUFFERS_PER_Q \ 12#define ZFCP_QDIO_PCI_INTERVAL (QDIO_MAX_BUFFERS_PER_Q \
13 - (ZFCP_MAX_SBALS_PER_REQ + 4)) 13 - (ZFCP_MAX_SBALS_PER_REQ + 4))
14#define QBUFF_PER_PAGE (PAGE_SIZE / sizeof(struct qdio_buffer))
14 15
15static int zfcp_qdio_buffers_enqueue(struct qdio_buffer **sbal) 16static int zfcp_qdio_buffers_enqueue(struct qdio_buffer **sbal)
16{ 17{
@@ -63,6 +64,16 @@ static void zfcp_qdio_handler_error(struct zfcp_adapter *adapter, u8 id)
63 ZFCP_STATUS_COMMON_ERP_FAILED, id, NULL); 64 ZFCP_STATUS_COMMON_ERP_FAILED, id, NULL);
64} 65}
65 66
67static void zfcp_qdio_zero_sbals(struct qdio_buffer *sbal[], int first, int cnt)
68{
69 int i, sbal_idx;
70
71 for (i = first; i < first + cnt; i++) {
72 sbal_idx = i % QDIO_MAX_BUFFERS_PER_Q;
73 memset(sbal[sbal_idx], 0, sizeof(struct qdio_buffer));
74 }
75}
76
66static void zfcp_qdio_int_req(struct ccw_device *cdev, unsigned int status, 77static void zfcp_qdio_int_req(struct ccw_device *cdev, unsigned int status,
67 unsigned int qdio_err, unsigned int siga_err, 78 unsigned int qdio_err, unsigned int siga_err,
68 unsigned int queue_no, int first, int count, 79 unsigned int queue_no, int first, int count,
@@ -366,22 +377,6 @@ int zfcp_qdio_send(struct zfcp_fsf_req *fsf_req)
366} 377}
367 378
368/** 379/**
369 * zfcp_qdio_zero_sbals - zero all sbals of the specified area and queue
370 * @buf: pointer to array of SBALS
371 * @first: integer specifying the SBAL number to start
372 * @count: integer specifying the number of SBALS to process
373 */
374void zfcp_qdio_zero_sbals(struct qdio_buffer *sbal[], int first, int count)
375{
376 int i, sbal_idx;
377
378 for (i = first; i < first + count; i++) {
379 sbal_idx = i % QDIO_MAX_BUFFERS_PER_Q;
380 memset(sbal[sbal_idx], 0, sizeof(struct qdio_buffer));
381 }
382}
383
384/**
385 * zfcp_qdio_allocate - allocate queue memory and initialize QDIO data 380 * zfcp_qdio_allocate - allocate queue memory and initialize QDIO data
386 * @adapter: pointer to struct zfcp_adapter 381 * @adapter: pointer to struct zfcp_adapter
387 * Returns: -ENOMEM on memory allocation error or return value from 382 * Returns: -ENOMEM on memory allocation error or return value from