Module Name: src
Committed By: jdolecek
Date: Mon Aug 6 20:07:05 UTC 2018
Modified Files:
src/sys/dev/ata: ata_subr.c atavar.h wd.c
Log Message:
add wddebug() which dumps some status for attached disks; indended for
debugging of PR kern/52783
To generate a diff of this commit:
cvs rdiff -u -r1.4 -r1.5 src/sys/dev/ata/ata_subr.c
cvs rdiff -u -r1.97 -r1.98 src/sys/dev/ata/atavar.h
cvs rdiff -u -r1.439 -r1.440 src/sys/dev/ata/wd.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/dev/ata/ata_subr.c
diff -u src/sys/dev/ata/ata_subr.c:1.4 src/sys/dev/ata/ata_subr.c:1.5
--- src/sys/dev/ata/ata_subr.c:1.4 Fri Oct 20 07:06:07 2017
+++ src/sys/dev/ata/ata_subr.c Mon Aug 6 20:07:05 2018
@@ -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 @@ ata_channel_lock_owned(struct ata_channe
{
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 */
Index: src/sys/dev/ata/atavar.h
diff -u src/sys/dev/ata/atavar.h:1.97 src/sys/dev/ata/atavar.h:1.98
--- src/sys/dev/ata/atavar.h:1.97 Fri Jun 1 18:13:30 2018
+++ src/sys/dev/ata/atavar.h Mon Aug 6 20:07:05 2018
@@ -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 @@ bool ata_waitdrain_xfer_check(struct ata
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_ */
Index: src/sys/dev/ata/wd.c
diff -u src/sys/dev/ata/wd.c:1.439 src/sys/dev/ata/wd.c:1.440
--- src/sys/dev/ata/wd.c:1.439 Sun Jun 3 18:38:35 2018
+++ src/sys/dev/ata/wd.c Mon Aug 6 20:07:05 2018
@@ -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 @@ wd_sysctl_detach(struct wd_softc *wd)
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 */