On 07/03/2018 at 08:19:15 +0000, Denis OSTERLAND wrote: > > > +/* event section */ > > > +#define ISL1208_REG_SCT 0x14 > > > +#define ISL1208_REG_MNT 0x15 > > > +#define ISL1208_REG_HRT 0x16 > > > +#define ISL1208_REG_DTT 0x17 > > > +#define ISL1208_REG_MOT 0x18 > > > +#define ISL1208_REG_YRT 0x19 > > > +#define ISL1208_EVT_SECTION_LEN 6 > > > + > > Because they are not available on ISL1208, maybe it would be better to > > prefix them with ISL1219. > I see. Yes, this would clarify that they are only available on isl1219. > Shall we rename isl1208_rtc_event_show_timestamp/isl1208_rtc_event_clear > to isl1219_rtc_event_show_timestamp/isl1219_rtc_event_clear, too? That could be done too, yes. > > > > > > > > + > > > + tv64.tv_sec = rtc_tm_to_time64(&tm); > > Why not using an unsigned long long directly here? time64_t is not the > > correct type. > Do you mean timespec64 is not the correct type here? > Then yes, sould be time64_t. > If you mean time64_t is not the correct type here, > then can you give me some detail why there is no rtc_tm_to_u64, > or something like that? The rtc subsystem forbids negative times, the proper type should be unsigned. > sprintf(buf, "%lld\n", rtc_tm_to_time64(&tm)) seems correct to me. > By the way, is it needed to check for seconds < 0 and return error? Indeed, you shoud check the tm with rtc_valid_tm before calling rtc_tm_to_time64. > > > - rc = sysfs_create_group(&client->dev.kobj, &isl1208_rtc_sysfs_files); > > > + if (id->driver_data == TYPE_ISL1219) { > > > + rc = i2c_smbus_write_byte_data(client, ISL1208_REG_09, 0x10); > > > + if (rc < 0) { > > > + dev_err(&client->dev, "could not enable tamper detection\n"); > > > + return rc; > > > + } > > > + isl1208->sysfs_files = &isl1219_rtc_sysfs_files; > > > + } else { > > > + isl1208->sysfs_files = &isl1208_rtc_sysfs_files; > > > + } > > > + > > I don't think the whole isl1208 is necessary. You should probably use > > the .is_visible callback of isl1219_rtc_sysfs_files. This will make the > > changelog quite smaller. > > > Well, I don´t know how to access i2c_device_id from kobject. > rtc_attr_is_visible shows how to convert kobject to device and rtc_device, > but how to do (id->driver_data == TYPE_ISL1219) here? I'd use i2c_set_clientdata/i2c_get_clientdata but I agree that then it is basically the same as having isl1208->sysfs_files. but this makes me realize that the timestamp file doesn't end up at the correct location. What you do now is placing it under the i2c device while it should be placed under the rtc device (i.e. in /sys/class/rtc/rtcX/). This was a mistake made back in 2006. I guess you'll have to add a new group instead of adding to the current one. -- Alexandre Belloni, Bootlin (formerly Free Electrons) Embedded Linux and Kernel engineering https://bootlin.com