aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s390/scsi/zfcp_qdio.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/s390/scsi/zfcp_qdio.c')
-rw-r--r--drivers/s390/scsi/zfcp_qdio.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/drivers/s390/scsi/zfcp_qdio.c b/drivers/s390/scsi/zfcp_qdio.c
index 2b499e28ff1f..6c5228b627fc 100644
--- a/drivers/s390/scsi/zfcp_qdio.c
+++ b/drivers/s390/scsi/zfcp_qdio.c
@@ -56,16 +56,15 @@ static void zfcp_qdio_zero_sbals(struct qdio_buffer *sbal[], int first, int cnt)
56} 56}
57 57
58/* this needs to be called prior to updating the queue fill level */ 58/* this needs to be called prior to updating the queue fill level */
59static void zfcp_qdio_account(struct zfcp_qdio *qdio) 59static inline void zfcp_qdio_account(struct zfcp_qdio *qdio)
60{ 60{
61 ktime_t now; 61 unsigned long long now, span;
62 s64 span;
63 int free, used; 62 int free, used;
64 63
65 spin_lock(&qdio->stat_lock); 64 spin_lock(&qdio->stat_lock);
66 now = ktime_get(); 65 now = get_clock_monotonic();
67 span = ktime_us_delta(now, qdio->req_q_time); 66 span = (now - qdio->req_q_time) >> 12;
68 free = max(0, atomic_read(&qdio->req_q.count)); 67 free = atomic_read(&qdio->req_q.count);
69 used = QDIO_MAX_BUFFERS_PER_Q - free; 68 used = QDIO_MAX_BUFFERS_PER_Q - free;
70 qdio->req_q_util += used * span; 69 qdio->req_q_util += used * span;
71 qdio->req_q_time = now; 70 qdio->req_q_time = now;