Prev: [PATCH] net/neighbour.h: fix typo
Next: gpio: introduce f71808e_gpio driver for F71808E Super I/O chip.
From: Mark Brown on 30 Jun 2010 12:40 On Tue, Jun 29, 2010 at 02:16:55PM +0100, David Dajun Chen wrote: > RTC module of the device driver for DA9052 PMIC device from Dialog > Semiconductor. Adding Alessandro and the RTC list. As you have been reminded repeatedly you should CC all the relevant maintainers and lists on patches. > +config RTC_DRV_DA9052 > + tristate "Support RTC on Dialog Semiconductor DA9052 PMIC" > + depends on PMIC_DA9052 > + help > + Say y here to support the RTC found on > + Dialog Semiconductor DA9052 PMIC. Kconfig and Makefile entries should be sorted. > + if (msg.data & DA9052_ALARMMI_ALARMTYPE) > + printk(KERN_INFO "RTC: TIMER ALARM\n"); > + else > + printk(KERN_INFO "RTC: TICK ALARM\n"); This logging seems inappropriate - you should be notifying the RTC subsystem of the events rather than logging them (loudly). > +static int da9052_rtc_validate_parameters(struct rtc_time *rtc_tm) > +{ > + > + if (rtc_tm->tm_sec > DA9052_RTC_SECONDS_LIMIT) > + return DA9052_RTC_INVALID_SECONDS; Are these limits different to those enforced by rtc_valid_tm()? If there are any additional restrictions it'd be better to call that and only implement the additional checks that are required by the specific chip. If checks apply to all times then adding them to rtc_valid_tm() would be better. > + if (ENABLE == flag) > + msg.data = msg.data | DA9052_ALARMY_ALARMON; > + else if (DISABLE == flag) > + msg.data = msg.data & ~(DA9052_ALARMY_ALARMON); This can just be written as if (flag) ... else ... which is much more idiomatic. > + da9052_lock(da9052); > + ret = da9052->read(da9052, &ssc_msg); > + if (ret) { > + da9052_unlock(da9052); > + return ret; > + } > + da9052_unlock(da9052); > + > + data = ret; > + > + ssc_msg.data = data &= ~DA9052_IRQMASKA_MALRAM; > + > + da9052_lock(da9052); > + ret = da9052->write(da9052, &ssc_msg); > + da9052_unlock(da9052); This has the locking problem with read/modify/write sequences I mentioned in reply to the regulator driver. > +static int da9052_rtc_class_ops_settime(struct device *dev, struct > rtc_time *tm) > +{ > + int ret; > + struct da9052_rtc *priv = dev_get_drvdata(dev); > + > + ret = da9052_rtc_settime(priv->da9052, tm); > + > + return ret; > +} Separating the class operations and the actual implementations like this looks a bit odd - what does it add? > +/* Months */ > +#define FEBRUARY (2) > +#define APRIL (4) > +#define JUNE (6) > +#define SEPTEMBER (9) > +#define NOVEMBER (11) These are *very* generic things to be defining in a driver specific header with no namespacing, and it seems odd that you'd need them at all. > +/* RTC error codes */ > +#define DA9052_RTC_INVALID_SECONDS (3) > +#define DA9052_RTC_INVALID_MINUTES (4) > +#define DA9052_RTC_INVALID_HOURS (5) > +#define DA9052_RTC_INVALID_DAYS (6) > +#define DA9052_RTC_INVALID_MONTHS (7) > +#define DA9052_RTC_INVALID_YEARS (8) > +#define DA9052_RTC_INVALID_EVENT (9) > +#define DA9052_RTC_INVALID_IOCTL (10) > +#define DA9052_RTC_INVALID_SETTING (11) > +#define DA9052_RTC_EVENT_ALREADY_REGISTERED (12) > +#define DA9052_RTC_EVENT_UNREGISTERED (13) > +#define DA9052_RTC_EVENT_REGISTRATION_FAILED (14) > +#define DA9052_RTC_EVENT_UNREGISTRATION_FAILED (15) Rather than defining custom error codes you should use standard Linux error codes. These also overlap with the standard Linux codes. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |