From: Roland Dreier <rdreier-FYB4Gu1CFyUAvxtiuMwx3w@public.gmane.org>
To: Ralph Campbell <ralph.campbell-h88ZbnxC6KDQT0dZR+AlfA@public.gmane.org>
Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: [PATCH v2 38/51] IB/qib: Add qib_sysfs.c
Date: Thu, 08 Apr 2010 13:50:52 -0700 [thread overview]
Message-ID: <adaiq81wtw3.fsf@roland-alpha.cisco.com> (raw)
In-Reply-To: <20091203190624.29507.22110.stgit-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org> (Ralph Campbell's message of "Thu, 03 Dec 2009 11:06:24 -0800")
I didn't audit everything (so there may be more problems here too), but
certainly this violates the "one value per sysfs file" rule rather
egregiously:
> +static ssize_t show_stats(struct device *device, struct device_attribute *attr,
> + char *buf)
> +{
> + struct qib_ibdev *dev =
> + container_of(device, struct qib_ibdev, ibdev.dev);
> + struct qib_devdata *dd = dd_from_dev(dev);
> + unsigned pidx;
> + unsigned i;
> + int len = 0;
> + unsigned long flags;
> +
> + for (pidx = 0; pidx < dd->num_pports; ++pidx) {
> + struct qib_ibport *ibp = &dd->pport[pidx].ibport_data;
> +
> + len += sprintf(buf + len,
> + "Port %d:\n"
> + "RC timeouts %d\n"
> + "RC resends %d\n"
> + "RC QACKs %d\n"
> + "RC SEQ NAKs %d\n"
> + "RC RDMA seq %d\n"
> + "RC RNR NAKs %d\n"
> + "RC OTH NAKs %d\n"
> + "RC DComp %d\n"
> + "RCr dup req %d\n"
> + "RCr SEQ NAK %d\n"
> + "wait piobuf %d\n"
> + "wait DMA %d\n"
> + "wait TX %d\n"
> + "unaligned %d\n"
> + "loop pkts %d\n"
> + "PKT drops %d\n",
> + dd->pport[pidx].port,
> + ibp->n_timeouts, ibp->n_rc_resends,
> + ibp->n_rc_qacks, ibp->n_seq_naks,
> + ibp->n_rdma_seq, ibp->n_rnr_naks,
> + ibp->n_other_naks, ibp->n_rc_delayed_comp,
> + ibp->n_rc_dupreq, ibp->n_rc_seqnak,
> + dev->n_piowait, ibp->n_dmawait, dev->n_txwait,
> + ibp->n_unaligned, ibp->n_loop_pkts,
> + ibp->n_pkt_drops);
> + for (i = 0; i < ARRAY_SIZE(ibp->opstats); i++) {
> + const struct qib_opcode_stats *si = &ibp->opstats[i];
> +
> + if (!si->n_packets && !si->n_bytes)
> + continue;
> + len += sprintf(buf + len, "%02x %llu/%llu\n", i,
> + (unsigned long long) si->n_packets,
> + (unsigned long long) si->n_bytes);
> + }
> + }
> + len += sprintf(buf + len, "Ctx:npkts");
> + for (i = 0; i < dd->first_user_ctxt; i++) {
> + if (!dd->rcd[i])
> + continue;
> + len += sprintf(buf + len, " %u:%u", i,
> + dd->rcd[i]->pkt_count);
> + }
> + len += sprintf(buf + len, "\n");
> + spin_lock_irqsave(&dev->qpt_lock, flags);
> + for (i = 0; i < dev->qp_table_size; i++) {
> + struct qib_qp *qp;
> + for (qp = dev->qp_table[i]; qp != NULL; qp = qp->next) {
> + struct qib_swqe *wqe;
> +
> + if (qp->s_last == qp->s_acked &&
> + qp->s_acked == qp->s_cur &&
> + qp->s_cur == qp->s_tail &&
> + qp->s_tail == qp->s_head)
> + continue;
> + if (len + 128 >= PAGE_SIZE)
> + break;
> + wqe = get_swqe_ptr(qp, qp->s_last);
> + len += sprintf(buf + len,
> + "QP%u %s %u %u %u f=%x %u %u %u %u %u "
> + "PSN %x %x %x %x %x "
> + "(%u %u %u %u %u %u) QP%u LID %x\n",
> + qp->ibqp.qp_num,
> + qp_type_str[qp->ibqp.qp_type],
> + qp->state,
> + wqe->wr.opcode,
> + qp->s_hdrwords,
> + qp->s_flags,
> + atomic_read(&qp->s_dma_busy),
> + !list_empty(&qp->iowait),
> + qp->timeout,
> + wqe->ssn,
> + qp->s_lsn,
> + qp->s_last_psn,
> + qp->s_psn, qp->s_next_psn,
> + qp->s_sending_psn, qp->s_sending_hpsn,
> + qp->s_last, qp->s_acked, qp->s_cur,
> + qp->s_tail, qp->s_head, qp->s_size,
> + qp->remote_qpn,
> + qp->remote_ah_attr.dlid);
> + }
> + }
> + spin_unlock_irqrestore(&dev->qpt_lock, flags);
> + return len;
> +}
--
Roland Dreier <rolandd-FYB4Gu1CFyUAvxtiuMwx3w@public.gmane.org> || For corporate legal information go to:
http://www.cisco.com/web/about/doing_business/legal/cri/index.html
--
To unsubscribe from this list: send the line "unsubscribe linux-rdma" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2010-04-08 20:50 UTC|newest]
Thread overview: 79+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-12-03 19:03 [PATCH v2 0/51] updated patches for adding QIB driver Ralph Campbell
[not found] ` <20091203190305.29507.58158.stgit-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2009-12-03 19:03 ` [PATCH v2 01/51] IB/qib: Add Kconfig Ralph Campbell
[not found] ` <20091203190311.29507.83034.stgit-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-05-05 22:21 ` Roland Dreier
[not found] ` <adar5lqat2q.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-05-05 22:28 ` Ralph Campbell
[not found] ` <1273098480.28097.280.camel-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-05-05 22:29 ` Roland Dreier
2009-12-03 19:03 ` [PATCH v2 02/51] IB/qib: Add Makefile Ralph Campbell
2009-12-03 19:03 ` [PATCH v2 03/51] IB/qib: Add qib.h Ralph Campbell
2009-12-03 19:03 ` [PATCH v2 04/51] IB/qib: Add qib_6120_regs.h Ralph Campbell
2009-12-03 19:03 ` [PATCH v2 05/51] IB/qib: Add qib_7220.h Ralph Campbell
2009-12-03 19:03 ` [PATCH v2 06/51] IB/qib: Add qib_7220_regs.h Ralph Campbell
2009-12-03 19:03 ` [PATCH v2 08/51] IB/qib: Add qib_common.h Ralph Campbell
2009-12-03 19:03 ` [PATCH v2 09/51] IB/qib: Add qib_cq.c Ralph Campbell
2009-12-03 19:03 ` [PATCH v2 10/51] IB/qib: Add qib_debug.h Ralph Campbell
2009-12-03 19:04 ` [PATCH v2 11/51] IB/qib: Add qib_diag.c Ralph Campbell
2009-12-03 19:04 ` [PATCH v2 12/51] IB/qib: Add qib_dma.c Ralph Campbell
[not found] ` <20091203190408.29507.27708.stgit-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2009-12-10 0:09 ` Roland Dreier
2010-03-31 23:18 ` Roland Dreier
[not found] ` <adaljcz43n9.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-04-08 20:40 ` Ralph Campbell
2009-12-03 19:04 ` [PATCH v2 13/51] IB/qib: Add qib_driver.c Ralph Campbell
2010-03-31 23:20 ` Roland Dreier
[not found] ` <adafx3743n6.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-04-07 19:24 ` Steve Wise
[not found] ` <4BBCDBD6.8010809-7bPotxP6k4+P2YhJcF5u+vpXobYPEAuW@public.gmane.org>
2010-04-07 19:33 ` Roland Dreier
[not found] ` <ada7hoj2h35.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-04-07 22:58 ` John A. Gregor
2010-03-31 23:23 ` Roland Dreier
2009-12-03 19:04 ` [PATCH v2 14/51] IB/qib: Add qib_eeprom.c Ralph Campbell
2009-12-03 19:04 ` [PATCH v2 15/51] IB/qib: Add qib_file_ops.c Ralph Campbell
2009-12-03 19:04 ` [PATCH v2 16/51] IB/qib: Add qib_fs.c Ralph Campbell
2009-12-03 19:04 ` [PATCH v2 20/51] IB/qib: Add qib_init.c Ralph Campbell
2009-12-03 19:04 ` [PATCH v2 21/51] IB/qib: Add qib_intr.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 22/51] IB/qib: Add qib_keys.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 23/51] IB/qib: Add qib_mad.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 24/51] IB/qib: Add qib_mad.h Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 25/51] IB/qib: Add qib_mmap.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 26/51] IB/qib: Add qib_mr.c Ralph Campbell
[not found] ` <20091203190521.29507.6261.stgit-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-04-07 4:15 ` Roland Dreier
[not found] ` <adapr2b6gqa.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-04-09 19:04 ` Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 27/51] IB/qib: Add qib_pcie.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 28/51] IB/qib: Add qib_pio_copy.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 29/51] IB/qib: Add qib_qp.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 30/51] IB/qib: Add qib_qsfp.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 31/51] IB/qib: Add qib_qsfp.h Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 32/51] IB/qib: Add qib_rc.c Ralph Campbell
2009-12-03 19:05 ` [PATCH v2 33/51] IB/qib: Add qib_ruc.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 34/51] IB/qib: Add qib_sd7220.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 35/51] IB/qib: Add qib_sd7220_img.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 36/51] IB/qib: Add qib_sdma.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 37/51] IB/qib: Add qib_srq.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 38/51] IB/qib: Add qib_sysfs.c Ralph Campbell
[not found] ` <20091203190624.29507.22110.stgit-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-04-08 20:50 ` Roland Dreier [this message]
[not found] ` <adaiq81wtw3.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-04-08 21:29 ` Ralph Campbell
[not found] ` <1270762193.2278.25.camel-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-04-08 21:33 ` Roland Dreier
[not found] ` <adask75vdbs.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-04-08 22:12 ` Ira Weiny
[not found] ` <20100408151234.43f4bfc6.weiny2-i2BcT+NCU+M@public.gmane.org>
2010-04-08 23:29 ` Roland Dreier
[not found] ` <adapr29ttfh.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2010-04-08 23:42 ` Ralph Campbell
2010-04-08 23:53 ` Ira Weiny
2010-04-10 0:13 ` Ralph Campbell
[not found] ` <1270858404.2278.64.camel-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-04-10 0:27 ` Jason Gunthorpe
[not found] ` <20100410002705.GQ15629-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2010-04-12 17:21 ` Ralph Campbell
2010-04-08 22:08 ` Jason Gunthorpe
[not found] ` <20100408220840.GO9769-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2010-04-08 22:26 ` Ralph Campbell
[not found] ` <1270765601.2278.31.camel-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-04-08 22:50 ` Jason Gunthorpe
[not found] ` <20100408225002.GS9769-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2010-04-08 23:05 ` Ralph Campbell
2010-04-09 23:31 ` Ralph Campbell
[not found] ` <1270855886.2278.52.camel-/vjeY7uYZjrPXfVEPVhPGq6RkeBMCJyt@public.gmane.org>
2010-04-10 0:21 ` Jason Gunthorpe
2009-12-03 19:06 ` [PATCH v2 39/51] IB/qib: Add qib_twsi.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 40/51] IB/qib: Add qib_tx.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 41/51] IB/qib: Add qib_uc.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 42/51] IB/qib: Add qib_ud.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 43/51] IB/qib: Add qib_user_pages.c Ralph Campbell
2009-12-03 19:06 ` [PATCH v2 44/51] IB/qib: Add qib_user_sdma.c Ralph Campbell
2009-12-03 19:07 ` [PATCH v2 45/51] IB/qib: Add qib_user_sdma.h Ralph Campbell
2009-12-03 19:07 ` [PATCH v2 46/51] IB/qib: Add qib_verbs.c Ralph Campbell
2009-12-03 19:07 ` [PATCH v2 47/51] IB/qib: Add qib_verbs.h Ralph Campbell
2009-12-03 19:07 ` [PATCH v2 48/51] IB/qib: Add qib_verbs_mcast.c Ralph Campbell
2009-12-03 19:07 ` [PATCH v2 49/51] IB/qib: Add qib_wc_ppc64.c Ralph Campbell
2009-12-03 19:07 ` [PATCH v2 50/51] IB/qib: Add qib_wc_x86_64.c Ralph Campbell
2009-12-03 19:07 ` [PATCH v2 51/51] IB/qib: Hooks for adding the QIB driver into the framework Ralph Campbell
2009-12-09 22:47 ` [PATCH v2 0/51] updated patches for adding QIB driver Roland Dreier
[not found] ` <adahbrzpxx0.fsf-BjVyx320WGW9gfZ95n9DRSW4+XlvGpQz@public.gmane.org>
2009-12-09 22:58 ` Ralph Campbell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=adaiq81wtw3.fsf@roland-alpha.cisco.com \
--to=rdreier-fyb4gu1cfyuavxtiumwx3w@public.gmane.org \
--cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=ralph.campbell-h88ZbnxC6KDQT0dZR+AlfA@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox