Re: [PATCH 04/11] RTC subsystem, sysfs interface

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

 



Hi Alessandro,

On Monday 13 February 2006 17:54, Alessandro Zummo wrote:
> +static ssize_t rtc_sysfs_show_date(struct class_device *dev, char *buf)
> +{
> +	ssize_t retval = -ENODEV;
> +	struct rtc_time tm;
> +
> +	if ((retval = rtc_read_time(dev, &tm)) == 0) {

Retval is set unconditionally here so there is no point in initializing
it to -ENODEV above.

> +		retval = sprintf(buf, "%04d-%02d-%02d\n",
> +			tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday);
> +	}
> +
> +	return retval;
> +}
> +static CLASS_DEVICE_ATTR(date, S_IRUGO, rtc_sysfs_show_date, NULL);
> +
> +static ssize_t rtc_sysfs_show_time(struct class_device *dev, char *buf)
> +{
> +	ssize_t retval = -ENODEV;
> +	struct rtc_time tm;
> +
> +	if ((retval = rtc_read_time(dev, &tm)) == 0) {

Same here.

> +		retval = sprintf(buf, "%02d:%02d:%02d\n",
> +			tm.tm_hour, tm.tm_min, tm.tm_sec);
> +	}
> +
> +	return retval;
> +}
> +static CLASS_DEVICE_ATTR(time, S_IRUGO, rtc_sysfs_show_time, NULL);
> +
> +static ssize_t rtc_sysfs_show_since_epoch(struct class_device *dev, char *buf)
> +{
> +	ssize_t retval = -ENODEV;
> +	struct rtc_time tm;
> +
> +	if ((retval = rtc_read_time(dev, &tm)) == 0) {

And here.

> +		unsigned long time;
> +		rtc_tm_to_time(&tm, &time);
> +		retval = sprintf(buf, "%lu\n", time);
> +	}
> +
> +	return retval;
> +}
> +static CLASS_DEVICE_ATTR(since_epoch, S_IRUGO, rtc_sysfs_show_since_epoch, NULL);
> +
> +/* insertion/removal hooks */
> +
> +static int __devinit rtc_sysfs_add_device(struct class_device *class_dev,
> +					   struct class_interface *class_intf)
> +{
> +	class_device_create_file(class_dev, &class_device_attr_name);
> +	class_device_create_file(class_dev, &class_device_attr_date);
> +	class_device_create_file(class_dev, &class_device_attr_time);
> +	class_device_create_file(class_dev, &class_device_attr_since_epoch);

Maybe using attribute group here will help and also allow easier error
hanling?

-- 
Dmitry
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
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