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 */