Commit f8109d9e authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Jason Gunthorpe

infiniband: cxgb4: use ktime_get for timestamps

The debugfs file prints the difference between host timestamps as a
seconds/nanoseconds tuple, along with a 64-bit nanoseconds hardware
timestamp. The host time is read using getnstimeofday() which is
deprecated because of the y2038 overflow, and it suffers from time jumps
during settimeofday() and leap seconds.

Converting to ktime_get_ts64() would solve those two, but I'm going
a little further here by changing to ktime_get() and printing 64-bit
nanoseconds on both host and hw timestamps.  This simplifies the code
further and makes the output easier to understand.

The format of the debugfs file obviously changes here, but this should
only be read by humans and not scripts, so I assume it's fine.
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Acked-by: default avatarSteve Wise <swise@opengridcomputing.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@mellanox.com>
parent 302d6424
...@@ -108,19 +108,19 @@ void c4iw_log_wr_stats(struct t4_wq *wq, struct t4_cqe *cqe) ...@@ -108,19 +108,19 @@ void c4iw_log_wr_stats(struct t4_wq *wq, struct t4_cqe *cqe)
idx = (atomic_inc_return(&wq->rdev->wr_log_idx) - 1) & idx = (atomic_inc_return(&wq->rdev->wr_log_idx) - 1) &
(wq->rdev->wr_log_size - 1); (wq->rdev->wr_log_size - 1);
le.poll_sge_ts = cxgb4_read_sge_timestamp(wq->rdev->lldi.ports[0]); le.poll_sge_ts = cxgb4_read_sge_timestamp(wq->rdev->lldi.ports[0]);
getnstimeofday(&le.poll_host_ts); le.poll_host_time = ktime_get();
le.valid = 1; le.valid = 1;
le.cqe_sge_ts = CQE_TS(cqe); le.cqe_sge_ts = CQE_TS(cqe);
if (SQ_TYPE(cqe)) { if (SQ_TYPE(cqe)) {
le.qid = wq->sq.qid; le.qid = wq->sq.qid;
le.opcode = CQE_OPCODE(cqe); le.opcode = CQE_OPCODE(cqe);
le.post_host_ts = wq->sq.sw_sq[wq->sq.cidx].host_ts; le.post_host_time = wq->sq.sw_sq[wq->sq.cidx].host_time;
le.post_sge_ts = wq->sq.sw_sq[wq->sq.cidx].sge_ts; le.post_sge_ts = wq->sq.sw_sq[wq->sq.cidx].sge_ts;
le.wr_id = CQE_WRID_SQ_IDX(cqe); le.wr_id = CQE_WRID_SQ_IDX(cqe);
} else { } else {
le.qid = wq->rq.qid; le.qid = wq->rq.qid;
le.opcode = FW_RI_RECEIVE; le.opcode = FW_RI_RECEIVE;
le.post_host_ts = wq->rq.sw_rq[wq->rq.cidx].host_ts; le.post_host_time = wq->rq.sw_rq[wq->rq.cidx].host_time;
le.post_sge_ts = wq->rq.sw_rq[wq->rq.cidx].sge_ts; le.post_sge_ts = wq->rq.sw_rq[wq->rq.cidx].sge_ts;
le.wr_id = CQE_WRID_MSN(cqe); le.wr_id = CQE_WRID_MSN(cqe);
} }
...@@ -130,9 +130,9 @@ void c4iw_log_wr_stats(struct t4_wq *wq, struct t4_cqe *cqe) ...@@ -130,9 +130,9 @@ void c4iw_log_wr_stats(struct t4_wq *wq, struct t4_cqe *cqe)
static int wr_log_show(struct seq_file *seq, void *v) static int wr_log_show(struct seq_file *seq, void *v)
{ {
struct c4iw_dev *dev = seq->private; struct c4iw_dev *dev = seq->private;
struct timespec prev_ts = {0, 0}; ktime_t prev_time;
struct wr_log_entry *lep; struct wr_log_entry *lep;
int prev_ts_set = 0; int prev_time_set = 0;
int idx, end; int idx, end;
#define ts2ns(ts) div64_u64((ts) * dev->rdev.lldi.cclk_ps, 1000) #define ts2ns(ts) div64_u64((ts) * dev->rdev.lldi.cclk_ps, 1000)
...@@ -145,33 +145,29 @@ static int wr_log_show(struct seq_file *seq, void *v) ...@@ -145,33 +145,29 @@ static int wr_log_show(struct seq_file *seq, void *v)
lep = &dev->rdev.wr_log[idx]; lep = &dev->rdev.wr_log[idx];
while (idx != end) { while (idx != end) {
if (lep->valid) { if (lep->valid) {
if (!prev_ts_set) { if (!prev_time_set) {
prev_ts_set = 1; prev_time_set = 1;
prev_ts = lep->poll_host_ts; prev_time = lep->poll_host_time;
} }
seq_printf(seq, "%04u: sec %lu nsec %lu qid %u opcode " seq_printf(seq, "%04u: nsec %llu qid %u opcode "
"%u %s 0x%x host_wr_delta sec %lu nsec %lu " "%u %s 0x%x host_wr_delta nsec %llu "
"post_sge_ts 0x%llx cqe_sge_ts 0x%llx " "post_sge_ts 0x%llx cqe_sge_ts 0x%llx "
"poll_sge_ts 0x%llx post_poll_delta_ns %llu " "poll_sge_ts 0x%llx post_poll_delta_ns %llu "
"cqe_poll_delta_ns %llu\n", "cqe_poll_delta_ns %llu\n",
idx, idx,
timespec_sub(lep->poll_host_ts, ktime_to_ns(ktime_sub(lep->poll_host_time,
prev_ts).tv_sec, prev_time)),
timespec_sub(lep->poll_host_ts,
prev_ts).tv_nsec,
lep->qid, lep->opcode, lep->qid, lep->opcode,
lep->opcode == FW_RI_RECEIVE ? lep->opcode == FW_RI_RECEIVE ?
"msn" : "wrid", "msn" : "wrid",
lep->wr_id, lep->wr_id,
timespec_sub(lep->poll_host_ts, ktime_to_ns(ktime_sub(lep->poll_host_time,
lep->post_host_ts).tv_sec, lep->post_host_time)),
timespec_sub(lep->poll_host_ts,
lep->post_host_ts).tv_nsec,
lep->post_sge_ts, lep->cqe_sge_ts, lep->post_sge_ts, lep->cqe_sge_ts,
lep->poll_sge_ts, lep->poll_sge_ts,
ts2ns(lep->poll_sge_ts - lep->post_sge_ts), ts2ns(lep->poll_sge_ts - lep->post_sge_ts),
ts2ns(lep->poll_sge_ts - lep->cqe_sge_ts)); ts2ns(lep->poll_sge_ts - lep->cqe_sge_ts));
prev_ts = lep->poll_host_ts; prev_time = lep->poll_host_time;
} }
idx++; idx++;
if (idx > (dev->rdev.wr_log_size - 1)) if (idx > (dev->rdev.wr_log_size - 1))
......
...@@ -153,8 +153,8 @@ struct c4iw_hw_queue { ...@@ -153,8 +153,8 @@ struct c4iw_hw_queue {
}; };
struct wr_log_entry { struct wr_log_entry {
struct timespec post_host_ts; ktime_t post_host_time;
struct timespec poll_host_ts; ktime_t poll_host_time;
u64 post_sge_ts; u64 post_sge_ts;
u64 cqe_sge_ts; u64 cqe_sge_ts;
u64 poll_sge_ts; u64 poll_sge_ts;
......
...@@ -975,7 +975,7 @@ int c4iw_post_send(struct ib_qp *ibqp, struct ib_send_wr *wr, ...@@ -975,7 +975,7 @@ int c4iw_post_send(struct ib_qp *ibqp, struct ib_send_wr *wr,
if (c4iw_wr_log) { if (c4iw_wr_log) {
swsqe->sge_ts = cxgb4_read_sge_timestamp( swsqe->sge_ts = cxgb4_read_sge_timestamp(
qhp->rhp->rdev.lldi.ports[0]); qhp->rhp->rdev.lldi.ports[0]);
getnstimeofday(&swsqe->host_ts); swsqe->host_time = ktime_get();
} }
init_wr_hdr(wqe, qhp->wq.sq.pidx, fw_opcode, fw_flags, len16); init_wr_hdr(wqe, qhp->wq.sq.pidx, fw_opcode, fw_flags, len16);
...@@ -1045,8 +1045,8 @@ int c4iw_post_receive(struct ib_qp *ibqp, struct ib_recv_wr *wr, ...@@ -1045,8 +1045,8 @@ int c4iw_post_receive(struct ib_qp *ibqp, struct ib_recv_wr *wr,
qhp->wq.rq.sw_rq[qhp->wq.rq.pidx].sge_ts = qhp->wq.rq.sw_rq[qhp->wq.rq.pidx].sge_ts =
cxgb4_read_sge_timestamp( cxgb4_read_sge_timestamp(
qhp->rhp->rdev.lldi.ports[0]); qhp->rhp->rdev.lldi.ports[0]);
getnstimeofday( qhp->wq.rq.sw_rq[qhp->wq.rq.pidx].host_time =
&qhp->wq.rq.sw_rq[qhp->wq.rq.pidx].host_ts); ktime_get();
} }
wqe->recv.opcode = FW_RI_RECV_WR; wqe->recv.opcode = FW_RI_RECV_WR;
......
...@@ -271,7 +271,7 @@ struct t4_swsqe { ...@@ -271,7 +271,7 @@ struct t4_swsqe {
int signaled; int signaled;
u16 idx; u16 idx;
int flushed; int flushed;
struct timespec host_ts; ktime_t host_time;
u64 sge_ts; u64 sge_ts;
}; };
...@@ -312,7 +312,7 @@ struct t4_sq { ...@@ -312,7 +312,7 @@ struct t4_sq {
struct t4_swrqe { struct t4_swrqe {
u64 wr_id; u64 wr_id;
struct timespec host_ts; ktime_t host_time;
u64 sge_ts; u64 sge_ts;
}; };
......
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