diff options
Diffstat (limited to 'drivers/rtc/rtc-ds3232.c')
| -rw-r--r-- | drivers/rtc/rtc-ds3232.c | 34 | 
1 files changed, 10 insertions, 24 deletions
| diff --git a/drivers/rtc/rtc-ds3232.c b/drivers/rtc/rtc-ds3232.c index 57063552d3b..27b7bf672ac 100644 --- a/drivers/rtc/rtc-ds3232.c +++ b/drivers/rtc/rtc-ds3232.c @@ -1,7 +1,7 @@  /*   * RTC client/driver for the Maxim/Dallas DS3232 Real-Time Clock over I2C   * - * Copyright (C) 2009-2010 Freescale Semiconductor. + * Copyright (C) 2009-2011 Freescale Semiconductor.   * Author: Jack Lan <jack.lan@freescale.com>   *   * This program is free software; you can redistribute  it and/or modify it @@ -141,9 +141,11 @@ static int ds3232_read_time(struct device *dev, struct rtc_time *time)  		time->tm_hour = bcd2bin(hour);  	} -	time->tm_wday = bcd2bin(week); +	/* Day of the week in linux range is 0~6 while 1~7 in RTC chip */ +	time->tm_wday = bcd2bin(week) - 1;  	time->tm_mday = bcd2bin(day); -	time->tm_mon = bcd2bin(month & 0x7F); +	/* linux tm_mon range:0~11, while month range is 1~12 in RTC chip */ +	time->tm_mon = bcd2bin(month & 0x7F) - 1;  	if (century)  		add_century = 100; @@ -162,9 +164,11 @@ static int ds3232_set_time(struct device *dev, struct rtc_time *time)  	buf[0] = bin2bcd(time->tm_sec);  	buf[1] = bin2bcd(time->tm_min);  	buf[2] = bin2bcd(time->tm_hour); -	buf[3] = bin2bcd(time->tm_wday); /* Day of the week */ +	/* Day of the week in linux range is 0~6 while 1~7 in RTC chip */ +	buf[3] = bin2bcd(time->tm_wday + 1);  	buf[4] = bin2bcd(time->tm_mday); /* Date */ -	buf[5] = bin2bcd(time->tm_mon); +	/* linux tm_mon range:0~11, while month range is 1~12 in RTC chip */ +	buf[5] = bin2bcd(time->tm_mon + 1);  	if (time->tm_year >= 100) {  		buf[5] |= 0x80;  		buf[6] = bin2bcd(time->tm_year - 100); @@ -335,23 +339,6 @@ static int ds3232_alarm_irq_enable(struct device *dev, unsigned int enabled)  	return 0;  } -static int ds3232_update_irq_enable(struct device *dev, unsigned int enabled) -{ -	struct i2c_client *client = to_i2c_client(dev); -	struct ds3232 *ds3232 = i2c_get_clientdata(client); - -	if (client->irq <= 0) -		return -EINVAL; - -	if (enabled) -		ds3232->rtc->irq_data |= RTC_UF; -	else -		ds3232->rtc->irq_data &= ~RTC_UF; - -	ds3232_update_alarm(client); -	return 0; -} -  static irqreturn_t ds3232_irq(int irq, void *dev_id)  {  	struct i2c_client *client = dev_id; @@ -402,7 +389,6 @@ static const struct rtc_class_ops ds3232_rtc_ops = {  	.read_alarm = ds3232_read_alarm,  	.set_alarm = ds3232_set_alarm,  	.alarm_irq_enable = ds3232_alarm_irq_enable, -	.update_irq_enable = ds3232_update_irq_enable,  };  static int __devinit ds3232_probe(struct i2c_client *client, @@ -463,7 +449,7 @@ static int __devexit ds3232_remove(struct i2c_client *client)  		mutex_unlock(&ds3232->mutex);  		free_irq(client->irq, client); -		flush_scheduled_work(); +		cancel_work_sync(&ds3232->work);  	}  	rtc_device_unregister(ds3232->rtc); | 
