Date: Fri, 18 Jul 2008 11:44:40 -0700 (PDT) From: Pedro Giffuni <pfgshield-freebsd@yahoo.com> To: freebsd-scsi@FreeBSD.org Subject: CAM bugs found in DragonFly Message-ID: <37593.67811.qm@web32702.mail.mud.yahoo.com>
next in thread | raw e-mail | index | archive | help
(I sent some private mail about this but maybe it is of more general interest) Hi; Matt Dillon has been doing some robustness "don't try this at home" experiments with his new filesystem : basically unplugging the USB cord while making use of it. Our code has diverged a lot but surely some of his enhancements would improve FreeBSD too: http://leaf.dragonflybsd.org/mailarchive/commits/2008-07/msg00242.html ___________ dillon 2008/07/17 17:07:23 PDT DragonFly src repository Modified files: sys/bus/cam cam_periph.c cam_periph.h cam_sim.c cam_sim.h cam_xpt.c sys/bus/cam/scsi scsi_cd.c scsi_ch.c scsi_da.c scsi_sa.c scsi_target.c Log: Fix multiple bugs in CAM related devices which go away unexpectedly. This fixes numerous panics when pulling a USB mass media device in the midst of heavy I/O. * The SIM lock was being unlocked via the periph->sim path after periph was unheld. periph can become free and blow up the unlock, so get the sim into a local variable first, then release periph. * The code which waits for CCB completion needs to be a while loop, not an if. It worked anyway, but wasn't very robust. * Add CAM_SIM_DEREGISTERED to flag when a sim is undergoing deregistration. * Beef up cam_dead_sim so it works more like a real sim. * Properly install &cam_dead_sim in the device and periph structures related to a SCSI bus, when deregistering the bus. * Disallow the addition of new devices when deregistering a bus. * NULL out periph->softc when freeing it. Revision Changes Path 1.41 +13 -6 src/sys/bus/cam/cam_periph.c 1.12 +1 -1 src/sys/bus/cam/cam_periph.h 1.13 +18 -4 src/sys/bus/cam/cam_sim.c 1.9 +2 -0 src/sys/bus/cam/cam_sim.h 1.67 +96 -24 src/sys/bus/cam/cam_xpt.c 1.44 +5 -11 src/sys/bus/cam/scsi/scsi_cd.c 1.28 +4 -6 src/sys/bus/cam/scsi/scsi_ch.c 1.58 +4 -5 src/sys/bus/cam/scsi/scsi_da.c 1.36 +14 -18 src/sys/bus/cam/scsi/scsi_sa.c 1.20 +1 -1 src/sys/bus/cam/scsi/scsi_target.c Posta, news, sport, oroscopo: tutto in una sola pagina. Crea l'home page che piace a te! www.yahoo.it/latuapagina
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?37593.67811.qm>
