diff options
Diffstat (limited to 'drivers/rtc')
| -rw-r--r-- | drivers/rtc/hctosys.c | 4 | ||||
| -rw-r--r-- | drivers/rtc/rtc-cmos.c | 16 | ||||
| -rw-r--r-- | drivers/rtc/rtc-hid-sensor-time.c | 2 | ||||
| -rw-r--r-- | drivers/rtc/rtc-pcf2127.c | 3 | 
4 files changed, 19 insertions, 6 deletions
diff --git a/drivers/rtc/hctosys.c b/drivers/rtc/hctosys.c index e79f2a181ad2..b9ec4a16db1f 100644 --- a/drivers/rtc/hctosys.c +++ b/drivers/rtc/hctosys.c @@ -50,8 +50,10 @@ static int __init rtc_hctosys(void)  	tv64.tv_sec = rtc_tm_to_time64(&tm);  #if BITS_PER_LONG == 32 -	if (tv64.tv_sec > INT_MAX) +	if (tv64.tv_sec > INT_MAX) { +		err = -ERANGE;  		goto err_read; +	}  #endif  	err = do_settimeofday64(&tv64); diff --git a/drivers/rtc/rtc-cmos.c b/drivers/rtc/rtc-cmos.c index df0c5776d49b..a5a19ff10535 100644 --- a/drivers/rtc/rtc-cmos.c +++ b/drivers/rtc/rtc-cmos.c @@ -257,6 +257,7 @@ static int cmos_read_alarm(struct device *dev, struct rtc_wkalrm *t)  	struct cmos_rtc	*cmos = dev_get_drvdata(dev);  	unsigned char	rtc_control; +	/* This not only a rtc_op, but also called directly */  	if (!is_valid_irq(cmos->irq))  		return -EIO; @@ -452,6 +453,7 @@ static int cmos_set_alarm(struct device *dev, struct rtc_wkalrm *t)  	unsigned char mon, mday, hrs, min, sec, rtc_control;  	int ret; +	/* This not only a rtc_op, but also called directly */  	if (!is_valid_irq(cmos->irq))  		return -EIO; @@ -516,9 +518,6 @@ static int cmos_alarm_irq_enable(struct device *dev, unsigned int enabled)  	struct cmos_rtc	*cmos = dev_get_drvdata(dev);  	unsigned long	flags; -	if (!is_valid_irq(cmos->irq)) -		return -EINVAL; -  	spin_lock_irqsave(&rtc_lock, flags);  	if (enabled) @@ -579,6 +578,12 @@ static const struct rtc_class_ops cmos_rtc_ops = {  	.alarm_irq_enable	= cmos_alarm_irq_enable,  }; +static const struct rtc_class_ops cmos_rtc_ops_no_alarm = { +	.read_time		= cmos_read_time, +	.set_time		= cmos_set_time, +	.proc			= cmos_procfs, +}; +  /*----------------------------------------------------------------*/  /* @@ -855,9 +860,12 @@ cmos_do_probe(struct device *dev, struct resource *ports, int rtc_irq)  			dev_dbg(dev, "IRQ %d is already in use\n", rtc_irq);  			goto cleanup1;  		} + +		cmos_rtc.rtc->ops = &cmos_rtc_ops; +	} else { +		cmos_rtc.rtc->ops = &cmos_rtc_ops_no_alarm;  	} -	cmos_rtc.rtc->ops = &cmos_rtc_ops;  	cmos_rtc.rtc->nvram_old_abi = true;  	retval = rtc_register_device(cmos_rtc.rtc);  	if (retval) diff --git a/drivers/rtc/rtc-hid-sensor-time.c b/drivers/rtc/rtc-hid-sensor-time.c index 2751dba850c6..3e1abb455472 100644 --- a/drivers/rtc/rtc-hid-sensor-time.c +++ b/drivers/rtc/rtc-hid-sensor-time.c @@ -213,7 +213,7 @@ static int hid_rtc_read_time(struct device *dev, struct rtc_time *tm)  	/* get a report with all values through requesting one value */  	sensor_hub_input_attr_get_raw_value(time_state->common_attributes.hsdev,  			HID_USAGE_SENSOR_TIME, hid_time_addresses[0], -			time_state->info[0].report_id, SENSOR_HUB_SYNC); +			time_state->info[0].report_id, SENSOR_HUB_SYNC, false);  	/* wait for all values (event) */  	ret = wait_for_completion_killable_timeout(  			&time_state->comp_last_time, HZ*6); diff --git a/drivers/rtc/rtc-pcf2127.c b/drivers/rtc/rtc-pcf2127.c index 9f99a0966550..7cb786d76e3c 100644 --- a/drivers/rtc/rtc-pcf2127.c +++ b/drivers/rtc/rtc-pcf2127.c @@ -303,6 +303,9 @@ static int pcf2127_i2c_gather_write(void *context,  	memcpy(buf + 1, val, val_size);  	ret = i2c_master_send(client, buf, val_size + 1); + +	kfree(buf); +  	if (ret != val_size + 1)  		return ret < 0 ? ret : -EIO;  |