Re: [PATCH] libata: kill sector_buf temporary buffer

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Aug 16 2007, Jeff Garzik wrote:
> 
> Rather than carrying around this buffer all the time, for rare
> circumstances, it seems that we can easily alloc/free a temp buffer as
> needed.
> 
> Saves a big chunk of per-port memory.
> 
> I forget the justification for what it was in ata_port to begin with,
> but the code uses don't see to justify any need.
> 
> diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c
> index 735f74b..5e9049f 100644
> --- a/drivers/ata/libata-core.c
> +++ b/drivers/ata/libata-core.c
> @@ -3679,20 +3679,29 @@ static int ata_dev_same_device(struct ata_device *dev, unsigned int new_class,
>  int ata_dev_reread_id(struct ata_device *dev, unsigned int readid_flags)
>  {
>  	unsigned int class = dev->class;
> -	u16 *id = (void *)dev->link->ap->sector_buf;
> -	int rc;
> +	u16 *id;
> +	int rc = 0;
> +
> +	id = kzalloc(ATA_SECT_SIZE, GFP_KERNEL);
> +	if (!id)
> +		return -ENOMEM;
>  
>  	/* read ID data */
>  	rc = ata_dev_read_id(dev, &class, readid_flags, id);
>  	if (rc)
> -		return rc;
> +		goto out;
>  
>  	/* is the device still there? */
> -	if (!ata_dev_same_device(dev, class, id))
> -		return -ENODEV;
> +	if (!ata_dev_same_device(dev, class, id)) {
> +		rc = -ENODEV;
> +		goto out;
> +	}
>  
>  	memcpy(dev->id, id, sizeof(id[0]) * ATA_ID_WORDS);
> -	return 0;
> +
> +out:
> +	kfree(id);
> +	return rc;
>  }
>  
>  /**
> diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c
> index 2ddc2ed..fc731e2 100644
> --- a/drivers/ata/libata-eh.c
> +++ b/drivers/ata/libata-eh.c
> @@ -1133,14 +1133,20 @@ static unsigned int ata_read_log_page(struct ata_device *dev,
>  static int ata_eh_read_log_10h(struct ata_device *dev,
>  			       int *tag, struct ata_taskfile *tf)
>  {
> -	u8 *buf = dev->link->ap->sector_buf;
> +	u8 *buf;
>  	unsigned int err_mask;
>  	u8 csum;
> -	int i;
> +	int i, rc = 0;
> +
> +	buf = kzalloc(ATA_SECT_SIZE, GFP_KERNEL);
> +	if (!buf)
> +		return -ENOMEM;

How can this work? If we're issuing this log page read, we cannot do any
IO to the device. So this allocation must not generate any IO. And if we
fail in allocating memory and just return, the device wont talk to us in
the future.

-- 
Jens Axboe

-
To unsubscribe from this list: send the line "unsubscribe linux-ide" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Filesystems]     [Linux SCSI]     [Linux RAID]     [Git]     [Kernel Newbies]     [Linux Newbie]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Samba]     [Device Mapper]

  Powered by Linux