On Fri, Jan 18, 2013 at 04:25:10PM -0500, Alan Stern wrote: > On Wed, 16 Jan 2013, Aaron Lu wrote: > > > From: Lin Ming <ming.m.lin@xxxxxxxxx> > > > > Uses block layer runtime pm helper functions in > > scsi_runtime_suspend/resume. > > Remove scsi_autopm_* from sd open/release path and check_events path. > > And remove the quiesce call in runtime suspend path, as we know there is > > no request to quiesce for the device. > > > > Signed-off-by: Lin Ming <ming.m.lin@xxxxxxxxx> > > Signed-off-by: Aaron Lu <aaron.lu@xxxxxxxxx> > > > --- a/drivers/scsi/scsi_sysfs.c > > +++ b/drivers/scsi/scsi_sysfs.c > > @@ -893,6 +893,8 @@ int scsi_sysfs_add_sdev(struct scsi_device *sdev) > > */ > > scsi_autopm_get_device(sdev); > > > > + blk_pm_runtime_init(rq, &sdev->sdev_gendev); > > + > > error = device_add(&sdev->sdev_gendev); > > if (error) { > > sdev_printk(KERN_INFO, sdev, > > Someone just asked about the default autosuspend delay, and I realized > your patch series doesn't set one. Since we don't know the properties > of the disk drive at this point (or even whether the device is a disk > drive), the only safe course is to call > > pm_runtime_set_autosuspend_delay(&sdev->sdev_gendev, -1); > > before calling blk_pm_runtime_init(). Then autosuspends will be > prevented until userspace writes a non-negative value into the device's > control/autosuspend_delay_ms file. Shall we do it inside blk_pm_runtime_init? This way, we do not need to do it for every driver. And for drivers that do know a proper value for autosuspend delay, they can call pm_runtime_set_autosuspend_delay somewhere after blk_pm_runtime_init. Thanks, Aaron -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html