#include "rtc-core.h"
 
-
 static DEFINE_IDA(rtc_ida);
 struct class *rtc_class;
 
 static void rtc_device_release(struct device *dev)
 {
        struct rtc_device *rtc = to_rtc_device(dev);
+
        ida_simple_remove(&rtc_ida, rtc->id);
        kfree(rtc);
 }
 
 static struct timespec64 old_rtc, old_system, old_delta;
 
-
 static int rtc_suspend(struct device *dev)
 {
        struct rtc_device       *rtc = to_rtc_device(dev);
        ktime_get_real_ts64(&old_system);
        old_rtc.tv_sec = rtc_tm_to_time64(&tm);
 
-
        /*
         * To avoid drift caused by repeated suspend/resumes,
         * which each can add ~1 second drift error,
        if (delta_delta.tv_sec < -2 || delta_delta.tv_sec >= 2) {
                /*
                 * if delta_delta is too large, assume time correction
-                * has occured and set old_delta to the current delta.
+                * has occurred and set old_delta to the current delta.
                 */
                old_delta = delta;
        } else {
         * to keep things accurate.
         */
        sleep_time = timespec64_sub(sleep_time,
-                       timespec64_sub(new_system, old_system));
+                                   timespec64_sub(new_system, old_system));
 
        if (sleep_time.tv_sec >= 0)
                timekeeping_inject_sleeptime64(&sleep_time);
  * rtc_register_device instead
  */
 struct rtc_device *devm_rtc_device_register(struct device *dev,
-                                       const char *name,
-                                       const struct rtc_class_ops *ops,
-                                       struct module *owner)
+                                           const char *name,
+                                           const struct rtc_class_ops *ops,
+                                           struct module *owner)
 {
        struct rtc_device *rtc;
        int err;
 
        } else if (rtc->oldsecs != tm.tm_sec) {
                num = (tm.tm_sec + 60 - rtc->oldsecs) % 60;
                rtc->oldsecs = tm.tm_sec;
-               rtc->uie_timer.expires = jiffies + HZ - (HZ/10);
+               rtc->uie_timer.expires = jiffies + HZ - (HZ / 10);
                rtc->uie_timer_active = 1;
                rtc->uie_task_active = 0;
                add_timer(&rtc->uie_timer);
        if (num)
                rtc_handle_legacy_irq(rtc, num, RTC_UF);
 }
+
 static void rtc_uie_timer(struct timer_list *t)
 {
        struct rtc_device *rtc = from_timer(rtc, t, uie_timer);
 }
 
 static long rtc_dev_ioctl(struct file *file,
-               unsigned int cmd, unsigned long arg)
+                         unsigned int cmd, unsigned long arg)
 {
        int err = 0;
        struct rtc_device *rtc = file->private_data;
        const struct rtc_class_ops *ops = rtc->ops;
        struct rtc_time tm;
        struct rtc_wkalrm alarm;
-       void __user *uarg = (void __user *) arg;
+       void __user *uarg = (void __user *)arg;
 
        err = mutex_lock_interruptible(&rtc->ops_lock);
        if (err)
 
        case RTC_PIE_ON:
                if (rtc->irq_freq > rtc->max_user_freq &&
-                               !capable(CAP_SYS_RESOURCE))
+                   !capable(CAP_SYS_RESOURCE))
                        err = -EACCES;
                break;
        }
                        err = ops->ioctl(rtc->dev.parent, cmd, arg);
                        if (err == -ENOIOCTLCMD)
                                err = -ENOTTY;
-               } else
+               } else {
                        err = -ENOTTY;
+               }
                break;
        }
 
 static int rtc_dev_fasync(int fd, struct file *file, int on)
 {
        struct rtc_device *rtc = file->private_data;
+
        return fasync_helper(fd, file, on, &rtc->async_queue);
 }
 
 
        };
        struct rtc_device *rtc = rtc_class_open(CONFIG_RTC_HCTOSYS_DEVICE);
 
-       if (rtc == NULL) {
+       if (!rtc) {
                pr_info("unable to open rtc device (%s)\n",
                        CONFIG_RTC_HCTOSYS_DEVICE);
                goto err_open;
                dev_err(rtc->dev.parent,
                        "hctosys: unable to read the hardware clock\n");
                goto err_read;
-
        }
 
        tv64.tv_sec = rtc_tm_to_time64(&tm);
 
 static int __rtc_read_time(struct rtc_device *rtc, struct rtc_time *tm)
 {
        int err;
-       if (!rtc->ops)
+
+       if (!rtc->ops) {
                err = -ENODEV;
-       else if (!rtc->ops->read_time)
+       } else if (!rtc->ops->read_time) {
                err = -EINVAL;
-       else {
+       } else {
                memset(tm, 0, sizeof(struct rtc_time));
                err = rtc->ops->read_time(rtc->dev.parent, tm);
                if (err < 0) {
                err = -ENODEV;
        else if (rtc->ops->set_time)
                err = rtc->ops->set_time(rtc->dev.parent, tm);
-       else if (rtc->ops->set_mmss64) {
-               time64_t secs64 = rtc_tm_to_time64(tm);
-
-               err = rtc->ops->set_mmss64(rtc->dev.parent, secs64);
-       } else if (rtc->ops->set_mmss) {
-               time64_t secs64 = rtc_tm_to_time64(tm);
-               err = rtc->ops->set_mmss(rtc->dev.parent, secs64);
-       } else
+       else if (rtc->ops->set_mmss64)
+               err = rtc->ops->set_mmss64(rtc->dev.parent,
+                                          rtc_tm_to_time64(tm));
+       else if (rtc->ops->set_mmss)
+               err = rtc->ops->set_mmss(rtc->dev.parent,
+                                        rtc_tm_to_time64(tm));
+       else
                err = -EINVAL;
 
        pm_stay_awake(rtc->dev.parent);
 }
 EXPORT_SYMBOL_GPL(rtc_set_time);
 
-static int rtc_read_alarm_internal(struct rtc_device *rtc, struct rtc_wkalrm *alarm)
+static int rtc_read_alarm_internal(struct rtc_device *rtc,
+                                  struct rtc_wkalrm *alarm)
 {
        int err;
 
        if (err)
                return err;
 
-       if (rtc->ops == NULL)
+       if (!rtc->ops) {
                err = -ENODEV;
-       else if (!rtc->ops->read_alarm)
+       } else if (!rtc->ops->read_alarm) {
                err = -EINVAL;
-       else {
+       } else {
                alarm->enabled = 0;
                alarm->pending = 0;
                alarm->time.tm_sec = -1;
        int first_time = 1;
        time64_t t_now, t_alm;
        enum { none, day, month, year } missing = none;
-       unsigned days;
+       unsigned int days;
 
        /* The lower level RTC driver may return -1 in some fields,
         * creating invalid alarm->time values, for reasons like:
                        return err;
 
                /* note that tm_sec is a "don't care" value here: */
-       } while (   before.tm_min   != now.tm_min
-                || before.tm_hour  != now.tm_hour
-                || before.tm_mon   != now.tm_mon
-                || before.tm_year  != now.tm_year);
+       } while (before.tm_min  != now.tm_min ||
+                before.tm_hour != now.tm_hour ||
+                before.tm_mon  != now.tm_mon ||
+                before.tm_year != now.tm_year);
 
        /* Fill in the missing alarm fields using the timestamp; we
         * know there's at least one since alarm->time is invalid.
                alarm->time.tm_mday = now.tm_mday;
                missing = day;
        }
-       if ((unsigned)alarm->time.tm_mon >= 12) {
+       if ((unsigned int)alarm->time.tm_mon >= 12) {
                alarm->time.tm_mon = now.tm_mon;
                if (missing == none)
                        missing = month;
                goto done;
 
        switch (missing) {
-
        /* 24 hour rollover ... if it's now 10am Monday, an alarm that
         * that will trigger at 5am will do so at 5am Tuesday, which
         * could also be in the next month or year.  This is a common
        case month:
                dev_dbg(&rtc->dev, "alarm rollover: %s\n", "month");
                do {
-                       if (alarm->time.tm_mon < 11)
+                       if (alarm->time.tm_mon < 11) {
                                alarm->time.tm_mon++;
-                       else {
+                       } else {
                                alarm->time.tm_mon = 0;
                                alarm->time.tm_year++;
                        }
                        days = rtc_month_days(alarm->time.tm_mon,
-                                       alarm->time.tm_year);
+                                             alarm->time.tm_year);
                } while (days < alarm->time.tm_mday);
                break;
 
                dev_dbg(&rtc->dev, "alarm rollover: %s\n", "year");
                do {
                        alarm->time.tm_year++;
-               } while (!is_leap_year(alarm->time.tm_year + 1900)
-                       && rtc_valid_tm(&alarm->time) != 0);
+               } while (!is_leap_year(alarm->time.tm_year + 1900) &&
+                        rtc_valid_tm(&alarm->time) != 0);
                break;
 
        default:
 
 done:
        if (err)
-               dev_warn(&rtc->dev, "invalid alarm value: %ptR\n", &alarm->time);
+               dev_warn(&rtc->dev, "invalid alarm value: %ptR\n",
+                        &alarm->time);
 
        return err;
 }
        err = mutex_lock_interruptible(&rtc->ops_lock);
        if (err)
                return err;
-       if (rtc->ops == NULL)
+       if (!rtc->ops) {
                err = -ENODEV;
-       else if (!rtc->ops->read_alarm)
+       } else if (!rtc->ops->read_alarm) {
                err = -EINVAL;
-       else {
+       } else {
                memset(alarm, 0, sizeof(struct rtc_wkalrm));
                alarm->enabled = rtc->aie_timer.enabled;
                alarm->time = rtc_ktime_to_tm(rtc->aie_timer.node.expires);
        /* Alarm has to be enabled & in the future for us to enqueue it */
        if (alarm->enabled && (rtc_tm_to_ktime(now) <
                         rtc->aie_timer.node.expires)) {
-
                rtc->aie_timer.enabled = 1;
                timerqueue_add(&rtc->timerqueue, &rtc->aie_timer.node);
                trace_rtc_timer_enqueue(&rtc->aie_timer);
 
 int rtc_alarm_irq_enable(struct rtc_device *rtc, unsigned int enabled)
 {
-       int err = mutex_lock_interruptible(&rtc->ops_lock);
+       int err;
+
+       err = mutex_lock_interruptible(&rtc->ops_lock);
        if (err)
                return err;
 
 
 int rtc_update_irq_enable(struct rtc_device *rtc, unsigned int enabled)
 {
-       int err = mutex_lock_interruptible(&rtc->ops_lock);
+       int err;
+
+       err = mutex_lock_interruptible(&rtc->ops_lock);
        if (err)
                return err;
 
                rtc->uie_rtctimer.node.expires = ktime_add(now, onesec);
                rtc->uie_rtctimer.period = ktime_set(1, 0);
                err = rtc_timer_enqueue(rtc, &rtc->uie_rtctimer);
-       } else
+       } else {
                rtc_timer_remove(rtc, &rtc->uie_rtctimer);
+       }
 
 out:
        mutex_unlock(&rtc->ops_lock);
                err = rtc_dev_update_irq_enable_emul(rtc, enabled);
 #endif
        return err;
-
 }
 EXPORT_SYMBOL_GPL(rtc_update_irq_enable);
 
-
 /**
  * rtc_handle_legacy_irq - AIE, UIE and PIE event hook
  * @rtc: pointer to the rtc device
 
        /* mark one irq of the appropriate mode */
        spin_lock_irqsave(&rtc->irq_lock, flags);
-       rtc->irq_data = (rtc->irq_data + (num << 8)) | (RTC_IRQF|mode);
+       rtc->irq_data = (rtc->irq_data + (num << 8)) | (RTC_IRQF | mode);
        spin_unlock_irqrestore(&rtc->irq_lock, flags);
 
        wake_up_interruptible(&rtc->irq_queue);
        kill_fasync(&rtc->async_queue, SIGIO, POLL_IN);
 }
 
-
 /**
  * rtc_aie_update_irq - AIE mode rtctimer hook
  * @rtc: pointer to the rtc_device
        rtc_handle_legacy_irq(rtc, 1, RTC_AF);
 }
 
-
 /**
  * rtc_uie_update_irq - UIE mode rtctimer hook
  * @rtc: pointer to the rtc_device
        rtc_handle_legacy_irq(rtc, 1,  RTC_UF);
 }
 
-
 /**
  * rtc_pie_update_irq - PIE mode hrtimer hook
  * @timer: pointer to the pie mode hrtimer
        struct rtc_device *rtc;
        ktime_t period;
        int count;
+
        rtc = container_of(timer, struct rtc_device, pie_timer);
 
        period = NSEC_PER_SEC / rtc->irq_freq;
  * Context: any
  */
 void rtc_update_irq(struct rtc_device *rtc,
-               unsigned long num, unsigned long events)
+                   unsigned long num, unsigned long events)
 {
        if (IS_ERR_OR_NULL(rtc))
                return;
        if (!next || ktime_before(timer->node.expires, next->expires)) {
                struct rtc_wkalrm alarm;
                int err;
+
                alarm.time = rtc_ktime_to_tm(timer->node.expires);
                alarm.enabled = 1;
                err = __rtc_set_alarm(rtc, &alarm);
 static void rtc_timer_remove(struct rtc_device *rtc, struct rtc_timer *timer)
 {
        struct timerqueue_node *next = timerqueue_getnext(&rtc->timerqueue);
+
        timerqueue_del(&rtc->timerqueue, &timer->node);
        trace_rtc_timer_dequeue(timer);
        timer->enabled = 0;
        if (next == &timer->node) {
                struct rtc_wkalrm alarm;
                int err;
+
                next = timerqueue_getnext(&rtc->timerqueue);
                if (!next) {
                        rtc_alarm_disable(rtc);
                alarm.enabled = 1;
 reprogram:
                err = __rtc_set_alarm(rtc, &alarm);
-               if (err == -ETIME)
+               if (err == -ETIME) {
                        goto again;
-               else if (err) {
+               } else if (err) {
                        if (retry-- > 0)
                                goto reprogram;
 
                        dev_err(&rtc->dev, "__rtc_set_alarm: err=%d\n", err);
                        goto again;
                }
-       } else
+       } else {
                rtc_alarm_disable(rtc);
+       }
 
        pm_relax(rtc->dev.parent);
        mutex_unlock(&rtc->ops_lock);
 }
 
-
 /* rtc_timer_init - Initializes an rtc_timer
  * @timer: timer to be intiialized
  * @f: function pointer to be called when timer fires
  * Kernel interface to set an rtc_timer
  */
 int rtc_timer_start(struct rtc_device *rtc, struct rtc_timer *timer,
-                       ktime_t expires, ktime_t period)
+                   ktime_t expires, ktime_t period)
 {
        int ret = 0;
+
        mutex_lock(&rtc->ops_lock);
        if (timer->enabled)
                rtc_timer_remove(rtc, timer);
 
        { 0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366 }
 };
 
-#define LEAPS_THRU_END_OF(y) ((y)/4 - (y)/100 + (y)/400)
+#define LEAPS_THRU_END_OF(y) ((y) / 4 - (y) / 100 + (y) / 400)
 
 /*
  * The number of days in the month.
  */
 int rtc_year_days(unsigned int day, unsigned int month, unsigned int year)
 {
-       return rtc_ydays[is_leap_year(year)][month] + day-1;
+       return rtc_ydays[is_leap_year(year)][month] + day - 1;
 }
 EXPORT_SYMBOL(rtc_year_days);
 
-
 /*
  * rtc_time64_to_tm - Converts time64_t to rtc_time.
  * Convert seconds since 01-01-1970 00:00:00 to Gregorian date.
  */
 int rtc_valid_tm(struct rtc_time *tm)
 {
-       if (tm->tm_year < 70
-               || ((unsigned)tm->tm_mon) >= 12
-               || tm->tm_mday < 1
-               || tm->tm_mday > rtc_month_days(tm->tm_mon, ((unsigned)tm->tm_year + 1900))
-               || ((unsigned)tm->tm_hour) >= 24
-               || ((unsigned)tm->tm_min) >= 60
-               || ((unsigned)tm->tm_sec) >= 60)
+       if (tm->tm_year < 70 ||
+           ((unsigned int)tm->tm_mon) >= 12 ||
+           tm->tm_mday < 1 ||
+           tm->tm_mday > rtc_month_days(tm->tm_mon,
+                                        ((unsigned int)tm->tm_year + 1900)) ||
+           ((unsigned int)tm->tm_hour) >= 24 ||
+           ((unsigned int)tm->tm_min) >= 60 ||
+           ((unsigned int)tm->tm_sec) >= 60)
                return -EINVAL;
 
        return 0;
  */
 time64_t rtc_tm_to_time64(struct rtc_time *tm)
 {
-       return mktime64(((unsigned)tm->tm_year + 1900), tm->tm_mon + 1,
+       return mktime64(((unsigned int)tm->tm_year + 1900), tm->tm_mon + 1,
                        tm->tm_mday, tm->tm_hour, tm->tm_min, tm->tm_sec);
 }
 EXPORT_SYMBOL(rtc_tm_to_time64);
 
 {
        int err;
 
-       rtc->nvram = kzalloc(sizeof(struct bin_attribute), GFP_KERNEL);
+       rtc->nvram = kzalloc(sizeof(*rtc->nvram), GFP_KERNEL);
        if (!rtc->nvram)
                return -ENOMEM;
 
 
                seq_printf(seq, "alrm_time\t: %ptRt\n", &alrm.time);
                seq_printf(seq, "alrm_date\t: %ptRd\n", &alrm.time);
                seq_printf(seq, "alarm_IRQ\t: %s\n",
-                               alrm.enabled ? "yes" : "no");
+                          alrm.enabled ? "yes" : "no");
                seq_printf(seq, "alrm_pending\t: %s\n",
-                               alrm.pending ? "yes" : "no");
+                          alrm.pending ? "yes" : "no");
                seq_printf(seq, "update IRQ enabled\t: %s\n",
-                       (rtc->uie_rtctimer.enabled) ? "yes" : "no");
+                          (rtc->uie_rtctimer.enabled) ? "yes" : "no");
                seq_printf(seq, "periodic IRQ enabled\t: %s\n",
-                       (rtc->pie_enabled) ? "yes" : "no");
+                          (rtc->pie_enabled) ? "yes" : "no");
                seq_printf(seq, "periodic IRQ frequency\t: %d\n",
-                       rtc->irq_freq);
+                          rtc->irq_freq);
                seq_printf(seq, "max user IRQ frequency\t: %d\n",
-                       rtc->max_user_freq);
+                          rtc->max_user_freq);
        }
 
        seq_printf(seq, "24hr\t\t: yes\n");
 {
        if (is_rtc_hctosys(rtc))
                proc_create_single_data("driver/rtc", 0, NULL, rtc_proc_show,
-                               rtc);
+                                       rtc);
 }
 
 void rtc_proc_del_device(struct rtc_device *rtc)
 
 
 #include "rtc-core.h"
 
-
 /* device attributes */
 
 /*
 
 static ssize_t
 max_user_freq_store(struct device *dev, struct device_attribute *attr,
-               const char *buf, size_t n)
+                   const char *buf, size_t n)
 {
        struct rtc_device *rtc = to_rtc_device(dev);
        unsigned long val;
 {
 #ifdef CONFIG_RTC_HCTOSYS_DEVICE
        if (rtc_hctosys_ret == 0 &&
-                       strcmp(dev_name(&to_rtc_device(dev)->dev),
-                               CONFIG_RTC_HCTOSYS_DEVICE) == 0)
+           strcmp(dev_name(&to_rtc_device(dev)->dev),
+                  CONFIG_RTC_HCTOSYS_DEVICE) == 0)
                return sprintf(buf, "1\n");
-       else
 #endif
-               return sprintf(buf, "0\n");
+       return sprintf(buf, "0\n");
 }
 static DEVICE_ATTR_RO(hctosys);
 
                if (*buf_ptr == '=') {
                        buf_ptr++;
                        push = 1;
-               } else
+               } else {
                        adjust = 1;
+               }
        }
        retval = kstrtos64(buf_ptr, 0, &alarm);
        if (retval)
                return retval;
-       if (adjust) {
+       if (adjust)
                alarm += now;
-       }
        if (alarm > now || push) {
                /* Avoid accidentally clobbering active alarms; we can't
                 * entirely prevent that here, without even the minimal