Since I'm open for change anyway and it apprently doesn't hurt my
eyes ;-). I'm gald to include it. (God would I love to
delete the silly suspen partition on my noebook and suspend to
file instead!).
(I will just replace the panic check by a BUG_ON check...)
Tank you very much for your efforts to implement this!
> --- clean.pre/drivers/ide/ide-disk.c	Fri Mar  8 18:40:34 2002
> +++ linux-dm.pre/drivers/ide/ide-disk.c	Fri Mar  8 18:40:07 2002
> @@ -123,6 +123,8 @@
>   */
>  static ide_startstop_t do_rw_disk (ide_drive_t *drive, struct request *rq, unsigned long block)
>  {
> +	if (drive->blocked)
> +		panic("ide: Request while drive blocked? You don't like your data intact?");
>  	if (!(rq->flags & REQ_CMD)) {
>  		blk_dump_rq_flags(rq, "do_rw_disk, bad command");
>  		ide_end_request(drive, 0);
> @@ -910,13 +912,36 @@
>  	ide_add_setting(drive,	"max_failures",		SETTING_RW,					-1,			-1,			TYPE_INT,	0,	65535,				1,	1,	&drive->max_failures,		NULL);
>  }
>  
> +static int idedisk_suspend(struct device *dev, u32 state, u32 level)
> +{
> +	int i;
> +	ide_drive_t *drive = dev->driver_data;
> +
> +	printk("ide_disk_suspend()\n");
> +	while (HWGROUP(drive)->handler)
> +		schedule();
> +	drive->blocked = 1;
> +}
> +
> +static int idedisk_resume(struct device *dev, u32 level)
> +{
> +	ide_drive_t *drive = dev->driver_data;
> +	if (!drive->blocked)
> +		panic("ide: Resume but not suspended?\n");
> +	drive->blocked = 0;
> +}
> +
> +
>  /* This is just a hook for the overall driver tree.
>   *
>   * FIXME: This is soon goig to replace the custom linked list games played up
>   * to great extend between the different components of the IDE drivers.
>   */
>  
> -static struct device_driver idedisk_devdrv = {};
> +static struct device_driver idedisk_devdrv = {
> +	suspend: idedisk_suspend,
> +	resume: idedisk_resume,
> +};
>  
>  static void idedisk_setup(ide_drive_t *drive)
>  {
> @@ -963,6 +988,7 @@
>  	    sprintf(drive->device.name, "ide-disk");
>  	    drive->device.driver = &idedisk_devdrv;
>  	    drive->device.parent = &HWIF(drive)->device;
> +	    drive->device.driver_data = drive;
>  	    device_register(&drive->device);
>  	}
>  
> --- clean.pre/include/linux/ide.h	Fri Mar  8 18:40:38 2002
> +++ linux-dm.pre/include/linux/ide.h	Fri Mar  8 18:37:44 2002
> @@ -410,6 +410,7 @@
>  	unsigned autotune	: 2;	/* 1=autotune, 2=noautotune, 0=default */
>  	unsigned remap_0_to_1	: 2;	/* 0=remap if ezdrive, 1=remap, 2=noremap */
>  	unsigned ata_flash	: 1;	/* 1=present, 0=default */
> +	unsigned blocked        : 1;	/* 1=powermanagment told us not to do anything, so sleep nicely */
>  	unsigned	addressing;	/* : 2; 0=28-bit, 1=48-bit, 2=64-bit */
>  	byte		scsi;		/* 0=default, 1=skip current ide-subdriver for ide-scsi emulation */
>  	select_t	select;		/* basic drive/head select reg value */
> 
> 
-- - phone: +49 214 8656 283 - job: eVision-Ventures AG, LEV .de (MY OPINIONS ARE MY OWN!) - langs: de_DE.ISO8859-1, en_US, pl_PL.ISO8859-2, last ressort: ru_RU.KOI8-R- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/