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]