Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/ata add wddebug() which dumps some status for attach...



details:   https://anonhg.NetBSD.org/src/rev/868eb1c7b17a
branches:  trunk
changeset: 363680:868eb1c7b17a
user:      jdolecek <jdolecek%NetBSD.org@localhost>
date:      Mon Aug 06 20:07:05 2018 +0000

description:
add wddebug() which dumps some status for attached disks; indended for
debugging of PR kern/52783

diffstat:

 sys/dev/ata/ata_subr.c |  32 ++++++++++++++++++++++++++++++--
 sys/dev/ata/atavar.h   |   6 +++++-
 sys/dev/ata/wd.c       |  27 +++++++++++++++++++++++++--
 3 files changed, 60 insertions(+), 5 deletions(-)

diffs (115 lines):

diff -r 50f8f4dd6ea0 -r 868eb1c7b17a sys/dev/ata/ata_subr.c
--- a/sys/dev/ata/ata_subr.c    Mon Aug 06 20:05:26 2018 +0000
+++ b/sys/dev/ata/ata_subr.c    Mon Aug 06 20:07:05 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ata_subr.c,v 1.4 2017/10/20 07:06:07 jdolecek Exp $    */
+/*     $NetBSD: ata_subr.c,v 1.5 2018/08/06 20:07:05 jdolecek Exp $    */
 
 /*
  * Copyright (c) 1998, 2001 Manuel Bouyer.  All rights reserved.
@@ -25,7 +25,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ata_subr.c,v 1.4 2017/10/20 07:06:07 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ata_subr.c,v 1.5 2018/08/06 20:07:05 jdolecek Exp $");
 
 #include "opt_ata.h"
 
@@ -436,3 +436,31 @@
 {
        KASSERT(mutex_owned(&chp->ch_lock));
 }
+
+#ifdef ATADEBUG
+void
+atachannel_debug(struct ata_channel *chp)
+{
+       struct ata_queue *chq = chp->ch_queue;
+
+       printf("  ch %s flags 0x%x ndrives %d\n",
+           device_xname(chp->atabus), chp->ch_flags, chp->ch_ndrives);
+       printf("  que: flags 0x%x avail 0x%x used 0x%x\n",
+           chq->queue_flags, chq->queue_xfers_avail, chq->active_xfers_used);
+       printf("        act %d freez %d open %u\n",
+           chq->queue_active, chq->queue_freeze, chq->queue_openings);
+
+#if 0
+       printf("  xfers:\n");
+       for(int i=0; i < chq->queue_openings; i++) {
+               struct ata_xfer *xfer = &chq->queue_xfers[i];
+
+               printf("    #%d sl %d drv %d retr %d fl %x",
+                   i, xfer->c_slot, xfer->c_drive, xfer->c_retries,
+                   xfer->c_flags);
+               printf(" data %p bcount %d skip %d\n",
+                   xfer->c_databuf, xfer->c_bcount, xfer->c_skip);
+       }
+#endif
+}
+#endif /* ATADEBUG */
diff -r 50f8f4dd6ea0 -r 868eb1c7b17a sys/dev/ata/atavar.h
--- a/sys/dev/ata/atavar.h      Mon Aug 06 20:05:26 2018 +0000
+++ b/sys/dev/ata/atavar.h      Mon Aug 06 20:07:05 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: atavar.h,v 1.97 2018/06/01 18:13:30 macallan Exp $     */
+/*     $NetBSD: atavar.h,v 1.98 2018/08/06 20:07:05 jdolecek Exp $     */
 
 /*
  * Copyright (c) 1998, 2001 Manuel Bouyer.
@@ -575,6 +575,10 @@
 void   atacmd_toncq(struct ata_xfer *, uint8_t *, uint16_t *, uint16_t *,
            uint8_t *);
 
+#ifdef ATADEBUG
+void   atachannel_debug(struct ata_channel *);
+#endif
+
 #endif /* _KERNEL */
 
 #endif /* _DEV_ATA_ATAVAR_H_ */
diff -r 50f8f4dd6ea0 -r 868eb1c7b17a sys/dev/ata/wd.c
--- a/sys/dev/ata/wd.c  Mon Aug 06 20:05:26 2018 +0000
+++ b/sys/dev/ata/wd.c  Mon Aug 06 20:07:05 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: wd.c,v 1.439 2018/06/03 18:38:35 jdolecek Exp $ */
+/*     $NetBSD: wd.c,v 1.440 2018/08/06 20:07:05 jdolecek Exp $ */
 
 /*
  * Copyright (c) 1998, 2001 Manuel Bouyer.  All rights reserved.
@@ -54,7 +54,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.439 2018/06/03 18:38:35 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.440 2018/08/06 20:07:05 jdolecek Exp $");
 
 #include "opt_ata.h"
 #include "opt_wd.h"
@@ -2162,3 +2162,26 @@
        sysctl_teardown(&wd->nodelog);
 }
 
+#ifdef ATADEBUG
+int wddebug(void);
+
+int
+wddebug(void)
+{
+       struct wd_softc *wd;
+         struct dk_softc *dksc;
+         int unit;
+
+         for (unit = 0; unit <= 3; unit++) {
+                   wd = device_lookup_private(&wd_cd, unit);
+                   if (wd == NULL)
+                               continue;
+                   dksc = &wd->sc_dksc;
+               printf("%s fl %x bufq %p:\n",
+                   dksc->sc_xname, wd->sc_flags, bufq_peek(dksc->sc_bufq));
+
+               atachannel_debug(wd->drvp->chnl_softc);
+       }
+       return 0;
+}
+#endif /* ATADEBUG */



Home | Main Index | Thread Index | Old Index