struct hfi1_ibport *ibp = to_iport(ibdev, port);
        struct hfi1_pportdata *ppd = ppd_from_ibp(ibp);
        struct opa_hfi1_cong_log *cong_log = (struct opa_hfi1_cong_log *)data;
-       s64 ts;
+       u64 ts;
        int i;
 
        if (am || smp_length_check(sizeof(*cong_log), max_len)) {
               ppd->threshold_cong_event_map,
               sizeof(cong_log->threshold_cong_event_map));
        /* keep timestamp in units of 1.024 usec */
-       ts = ktime_to_ns(ktime_get()) / 1024;
+       ts = ktime_get_ns() / 1024;
        cong_log->current_time_stamp = cpu_to_be32(ts);
        for (i = 0; i < OPA_CONG_LOG_ELEMS; i++) {
                struct opa_hfi1_cong_log_event_internal *cce =
                 * required to wrap the counter are supposed to
                 * be zeroed (CA10-49 IBTA, release 1.2.1, V1).
                 */
-               if ((u64)(ts - cce->timestamp) > (2 * UINT_MAX))
+               if ((ts - cce->timestamp) / 2 > U32_MAX)
                        continue;
                memcpy(cong_log->events[i].local_qp_cn_entry, &cce->lqpn, 3);
                memcpy(cong_log->events[i].remote_qp_number_cn_entry,
 
        cc_event->svc_type = svc_type;
        cc_event->rlid = rlid;
        /* keep timestamp in units of 1.024 usec */
-       cc_event->timestamp = ktime_to_ns(ktime_get()) / 1024;
+       cc_event->timestamp = ktime_get_ns() / 1024;
 
        spin_unlock_irqrestore(&ppd->cc_log_lock, flags);
 }