Re: [PATHC] [2.6.19-rc4-mm2] driver/base/memory.c :: remove warnings of sysfs_create_file()

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

 



On Wed, 8 Nov 2006 13:38:59 -0800
Andrew Morton <akpm@osdl.org> wrote:
> I think the below is better?
> 
Ah yes. It seems better. Thank you.

-Kame

> From: Andrew Morton <akpm@osdl.org>
> 
> Do proper error-checking and propagation in drivers/base/memory.c, hence fix
> __must_check warnings.
> 
> Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
> Signed-off-by: Andrew Morton <akpm@osdl.org>
> ---
> 
>  drivers/base/memory.c |   34 +++++++++++++++++++++++-----------
>  1 files changed, 23 insertions(+), 11 deletions(-)
> 
> diff -puN drivers/base/memory.c~driver-base-memoryc-remove-warnings-of drivers/base/memory.c
> --- a/drivers/base/memory.c~driver-base-memoryc-remove-warnings-of
> +++ a/drivers/base/memory.c
> @@ -290,9 +290,8 @@ static CLASS_ATTR(block_size_bytes, 0444
>  
>  static int block_size_init(void)
>  {
> -	sysfs_create_file(&memory_sysdev_class.kset.kobj,
> -		&class_attr_block_size_bytes.attr);
> -	return 0;
> +	return sysfs_create_file(&memory_sysdev_class.kset.kobj,
> +				&class_attr_block_size_bytes.attr);
>  }
>  
>  /*
> @@ -323,12 +322,14 @@ static CLASS_ATTR(probe, 0700, NULL, mem
>  
>  static int memory_probe_init(void)
>  {
> -	sysfs_create_file(&memory_sysdev_class.kset.kobj,
> -		&class_attr_probe.attr);
> -	return 0;
> +	return sysfs_create_file(&memory_sysdev_class.kset.kobj,
> +				&class_attr_probe.attr);
>  }
>  #else
> -#define memory_probe_init(...)	do {} while (0)
> +static inline int memory_probe_init(void)
> +{
> +	return 0;
> +}
>  #endif
>  
>  /*
> @@ -431,9 +432,12 @@ int __init memory_dev_init(void)
>  {
>  	unsigned int i;
>  	int ret;
> +	int err;
>  
>  	memory_sysdev_class.kset.uevent_ops = &memory_uevent_ops;
>  	ret = sysdev_class_register(&memory_sysdev_class);
> +	if (ret)
> +		goto out;
>  
>  	/*
>  	 * Create entries for memory sections that were found
> @@ -442,11 +446,19 @@ int __init memory_dev_init(void)
>  	for (i = 0; i < NR_MEM_SECTIONS; i++) {
>  		if (!valid_section_nr(i))
>  			continue;
> -		add_memory_block(0, __nr_to_section(i), MEM_ONLINE, 0);
> +		err = add_memory_block(0, __nr_to_section(i), MEM_ONLINE, 0);
> +		if (!ret)
> +			ret = err;
>  	}
>  
> -	memory_probe_init();
> -	block_size_init();
> -
> +	err = memory_probe_init();
> +	if (!ret)
> +		ret = err;
> +	err = block_size_init();
> +	if (!ret)
> +		ret = err;
> +out:
> +	if (ret)
> +		printk(KERN_ERR "%s() failed: %d\n", __FUNCTION__, ret);
>  	return ret;
>  }
> _
> 
> -
> 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/
> 

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

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux