LCOV - code coverage report
Current view: top level - drivers/rtc - rtc-cmos.c (source / functions) Hit Total Coverage
Test: combined.info Lines: 137 575 23.8 %
Date: 2022-04-01 14:35:51 Functions: 10 35 28.6 %
Branches: 61 392 15.6 %

           Branch data     Line data    Source code
       1                 :            : // SPDX-License-Identifier: GPL-2.0-or-later
       2                 :            : /*
       3                 :            :  * RTC class driver for "CMOS RTC":  PCs, ACPI, etc
       4                 :            :  *
       5                 :            :  * Copyright (C) 1996 Paul Gortmaker (drivers/char/rtc.c)
       6                 :            :  * Copyright (C) 2006 David Brownell (convert to new framework)
       7                 :            :  */
       8                 :            : 
       9                 :            : /*
      10                 :            :  * The original "cmos clock" chip was an MC146818 chip, now obsolete.
      11                 :            :  * That defined the register interface now provided by all PCs, some
      12                 :            :  * non-PC systems, and incorporated into ACPI.  Modern PC chipsets
      13                 :            :  * integrate an MC146818 clone in their southbridge, and boards use
      14                 :            :  * that instead of discrete clones like the DS12887 or M48T86.  There
      15                 :            :  * are also clones that connect using the LPC bus.
      16                 :            :  *
      17                 :            :  * That register API is also used directly by various other drivers
      18                 :            :  * (notably for integrated NVRAM), infrastructure (x86 has code to
      19                 :            :  * bypass the RTC framework, directly reading the RTC during boot
      20                 :            :  * and updating minutes/seconds for systems using NTP synch) and
      21                 :            :  * utilities (like userspace 'hwclock', if no /dev node exists).
      22                 :            :  *
      23                 :            :  * So **ALL** calls to CMOS_READ and CMOS_WRITE must be done with
      24                 :            :  * interrupts disabled, holding the global rtc_lock, to exclude those
      25                 :            :  * other drivers and utilities on correctly configured systems.
      26                 :            :  */
      27                 :            : 
      28                 :            : #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
      29                 :            : 
      30                 :            : #include <linux/kernel.h>
      31                 :            : #include <linux/module.h>
      32                 :            : #include <linux/init.h>
      33                 :            : #include <linux/interrupt.h>
      34                 :            : #include <linux/spinlock.h>
      35                 :            : #include <linux/platform_device.h>
      36                 :            : #include <linux/log2.h>
      37                 :            : #include <linux/pm.h>
      38                 :            : #include <linux/of.h>
      39                 :            : #include <linux/of_platform.h>
      40                 :            : #ifdef CONFIG_X86
      41                 :            : #include <asm/i8259.h>
      42                 :            : #include <asm/processor.h>
      43                 :            : #include <linux/dmi.h>
      44                 :            : #endif
      45                 :            : 
      46                 :            : /* this is for "generic access to PC-style RTC" using CMOS_READ/CMOS_WRITE */
      47                 :            : #include <linux/mc146818rtc.h>
      48                 :            : 
      49                 :            : #ifdef CONFIG_ACPI
      50                 :            : /*
      51                 :            :  * Use ACPI SCI to replace HPET interrupt for RTC Alarm event
      52                 :            :  *
      53                 :            :  * If cleared, ACPI SCI is only used to wake up the system from suspend
      54                 :            :  *
      55                 :            :  * If set, ACPI SCI is used to handle UIE/AIE and system wakeup
      56                 :            :  */
      57                 :            : 
      58                 :            : static bool use_acpi_alarm;
      59                 :            : module_param(use_acpi_alarm, bool, 0444);
      60                 :            : 
      61                 :        147 : static inline int cmos_use_acpi_alarm(void)
      62                 :            : {
      63                 :        147 :         return use_acpi_alarm;
      64                 :            : }
      65                 :            : #else /* !CONFIG_ACPI */
      66                 :            : 
      67                 :            : static inline int cmos_use_acpi_alarm(void)
      68                 :            : {
      69                 :            :         return 0;
      70                 :            : }
      71                 :            : #endif
      72                 :            : 
      73                 :            : struct cmos_rtc {
      74                 :            :         struct rtc_device       *rtc;
      75                 :            :         struct device           *dev;
      76                 :            :         int                     irq;
      77                 :            :         struct resource         *iomem;
      78                 :            :         time64_t                alarm_expires;
      79                 :            : 
      80                 :            :         void                    (*wake_on)(struct device *);
      81                 :            :         void                    (*wake_off)(struct device *);
      82                 :            : 
      83                 :            :         u8                      enabled_wake;
      84                 :            :         u8                      suspend_ctrl;
      85                 :            : 
      86                 :            :         /* newer hardware extends the original register set */
      87                 :            :         u8                      day_alrm;
      88                 :            :         u8                      mon_alrm;
      89                 :            :         u8                      century;
      90                 :            : 
      91                 :            :         struct rtc_wkalrm       saved_wkalrm;
      92                 :            : };
      93                 :            : 
      94                 :            : /* both platform and pnp busses use negative numbers for invalid irqs */
      95                 :            : #define is_valid_irq(n)         ((n) > 0)
      96                 :            : 
      97                 :            : static const char driver_name[] = "rtc_cmos";
      98                 :            : 
      99                 :            : /* The RTC_INTR register may have e.g. RTC_PF set even if RTC_PIE is clear;
     100                 :            :  * always mask it against the irq enable bits in RTC_CONTROL.  Bit values
     101                 :            :  * are the same: PF==PIE, AF=AIE, UF=UIE; so RTC_IRQMASK works with both.
     102                 :            :  */
     103                 :            : #define RTC_IRQMASK     (RTC_PF | RTC_AF | RTC_UF)
     104                 :            : 
     105                 :          0 : static inline int is_intr(u8 rtc_intr)
     106                 :            : {
     107         [ #  # ]:          0 :         if (!(rtc_intr & RTC_IRQF))
     108                 :            :                 return 0;
     109                 :          0 :         return rtc_intr & RTC_IRQMASK;
     110                 :            : }
     111                 :            : 
     112                 :            : /*----------------------------------------------------------------*/
     113                 :            : 
     114                 :            : /* Much modern x86 hardware has HPETs (10+ MHz timers) which, because
     115                 :            :  * many BIOS programmers don't set up "sane mode" IRQ routing, are mostly
     116                 :            :  * used in a broken "legacy replacement" mode.  The breakage includes
     117                 :            :  * HPET #1 hijacking the IRQ for this RTC, and being unavailable for
     118                 :            :  * other (better) use.
     119                 :            :  *
     120                 :            :  * When that broken mode is in use, platform glue provides a partial
     121                 :            :  * emulation of hardware RTC IRQ facilities using HPET #1.  We don't
     122                 :            :  * want to use HPET for anything except those IRQs though...
     123                 :            :  */
     124                 :            : #ifdef CONFIG_HPET_EMULATE_RTC
     125                 :            : #include <asm/hpet.h>
     126                 :            : #else
     127                 :            : 
     128                 :            : static inline int is_hpet_enabled(void)
     129                 :            : {
     130                 :            :         return 0;
     131                 :            : }
     132                 :            : 
     133                 :            : static inline int hpet_mask_rtc_irq_bit(unsigned long mask)
     134                 :            : {
     135                 :            :         return 0;
     136                 :            : }
     137                 :            : 
     138                 :            : static inline int hpet_set_rtc_irq_bit(unsigned long mask)
     139                 :            : {
     140                 :            :         return 0;
     141                 :            : }
     142                 :            : 
     143                 :            : static inline int
     144                 :            : hpet_set_alarm_time(unsigned char hrs, unsigned char min, unsigned char sec)
     145                 :            : {
     146                 :            :         return 0;
     147                 :            : }
     148                 :            : 
     149                 :            : static inline int hpet_set_periodic_freq(unsigned long freq)
     150                 :            : {
     151                 :            :         return 0;
     152                 :            : }
     153                 :            : 
     154                 :            : static inline int hpet_rtc_dropped_irq(void)
     155                 :            : {
     156                 :            :         return 0;
     157                 :            : }
     158                 :            : 
     159                 :            : static inline int hpet_rtc_timer_init(void)
     160                 :            : {
     161                 :            :         return 0;
     162                 :            : }
     163                 :            : 
     164                 :            : extern irq_handler_t hpet_rtc_interrupt;
     165                 :            : 
     166                 :            : static inline int hpet_register_irq_handler(irq_handler_t handler)
     167                 :            : {
     168                 :            :         return 0;
     169                 :            : }
     170                 :            : 
     171                 :            : static inline int hpet_unregister_irq_handler(irq_handler_t handler)
     172                 :            : {
     173                 :            :         return 0;
     174                 :            : }
     175                 :            : 
     176                 :            : #endif
     177                 :            : 
     178                 :            : /* Don't use HPET for RTC Alarm event if ACPI Fixed event is used */
     179                 :        126 : static inline int use_hpet_alarm(void)
     180                 :            : {
     181   [ -  -  -  -  :        126 :         return is_hpet_enabled() && !cmos_use_acpi_alarm();
          -  -  -  -  -  
          -  -  -  -  -  
          -  -  -  -  -  
          -  +  -  +  -  
          +  -  +  -  +  
          -  +  -  +  -  
          +  -  -  -  -  
          -  -  -  -  -  
          -  -  -  -  -  
          -  -  -  +  -  
          +  -  -  -  -  
             -  +  -  -  
                      + ]
     182                 :            : }
     183                 :            : 
     184                 :            : /*----------------------------------------------------------------*/
     185                 :            : 
     186                 :            : #ifdef RTC_PORT
     187                 :            : 
     188                 :            : /* Most newer x86 systems have two register banks, the first used
     189                 :            :  * for RTC and NVRAM and the second only for NVRAM.  Caller must
     190                 :            :  * own rtc_lock ... and we won't worry about access during NMI.
     191                 :            :  */
     192                 :            : #define can_bank2       true
     193                 :            : 
     194                 :          0 : static inline unsigned char cmos_read_bank2(unsigned char addr)
     195                 :            : {
     196                 :          0 :         outb(addr, RTC_PORT(2));
     197                 :          0 :         return inb(RTC_PORT(3));
     198                 :            : }
     199                 :            : 
     200                 :          0 : static inline void cmos_write_bank2(unsigned char val, unsigned char addr)
     201                 :            : {
     202                 :          0 :         outb(addr, RTC_PORT(2));
     203                 :          0 :         outb(val, RTC_PORT(3));
     204                 :          0 : }
     205                 :            : 
     206                 :            : #else
     207                 :            : 
     208                 :            : #define can_bank2       false
     209                 :            : 
     210                 :            : static inline unsigned char cmos_read_bank2(unsigned char addr)
     211                 :            : {
     212                 :            :         return 0;
     213                 :            : }
     214                 :            : 
     215                 :            : static inline void cmos_write_bank2(unsigned char val, unsigned char addr)
     216                 :            : {
     217                 :            : }
     218                 :            : 
     219                 :            : #endif
     220                 :            : 
     221                 :            : /*----------------------------------------------------------------*/
     222                 :            : 
     223                 :         63 : static int cmos_read_time(struct device *dev, struct rtc_time *t)
     224                 :            : {
     225                 :            :         /*
     226                 :            :          * If pm_trace abused the RTC for storage, set the timespec to 0,
     227                 :            :          * which tells the caller that this RTC value is unusable.
     228                 :            :          */
     229         [ +  - ]:         63 :         if (!pm_trace_rtc_valid())
     230                 :            :                 return -EIO;
     231                 :            : 
     232                 :            :         /* REVISIT:  if the clock has a "century" register, use
     233                 :            :          * that instead of the heuristic in mc146818_get_time().
     234                 :            :          * That'll make Y3K compatility (year > 2070) easy!
     235                 :            :          */
     236                 :         63 :         mc146818_get_time(t);
     237                 :         63 :         return 0;
     238                 :            : }
     239                 :            : 
     240                 :          0 : static int cmos_set_time(struct device *dev, struct rtc_time *t)
     241                 :            : {
     242                 :            :         /* REVISIT:  set the "century" register if available
     243                 :            :          *
     244                 :            :          * NOTE: this ignores the issue whereby updating the seconds
     245                 :            :          * takes effect exactly 500ms after we write the register.
     246                 :            :          * (Also queueing and other delays before we get this far.)
     247                 :            :          */
     248                 :          0 :         return mc146818_set_time(t);
     249                 :            : }
     250                 :            : 
     251                 :         21 : static int cmos_read_alarm(struct device *dev, struct rtc_wkalrm *t)
     252                 :            : {
     253         [ +  - ]:         21 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     254                 :         21 :         unsigned char   rtc_control;
     255                 :            : 
     256                 :            :         /* This not only a rtc_op, but also called directly */
     257         [ +  - ]:         21 :         if (!is_valid_irq(cmos->irq))
     258                 :            :                 return -EIO;
     259                 :            : 
     260                 :            :         /* Basic alarms only support hour, minute, and seconds fields.
     261                 :            :          * Some also support day and month, for alarms up to a year in
     262                 :            :          * the future.
     263                 :            :          */
     264                 :            : 
     265                 :         21 :         spin_lock_irq(&rtc_lock);
     266                 :         21 :         t->time.tm_sec = CMOS_READ(RTC_SECONDS_ALARM);
     267                 :         21 :         t->time.tm_min = CMOS_READ(RTC_MINUTES_ALARM);
     268                 :         21 :         t->time.tm_hour = CMOS_READ(RTC_HOURS_ALARM);
     269                 :            : 
     270         [ -  + ]:         21 :         if (cmos->day_alrm) {
     271                 :            :                 /* ignore upper bits on readback per ACPI spec */
     272                 :          0 :                 t->time.tm_mday = CMOS_READ(cmos->day_alrm) & 0x3f;
     273         [ #  # ]:          0 :                 if (!t->time.tm_mday)
     274                 :          0 :                         t->time.tm_mday = -1;
     275                 :            : 
     276         [ #  # ]:          0 :                 if (cmos->mon_alrm) {
     277                 :          0 :                         t->time.tm_mon = CMOS_READ(cmos->mon_alrm);
     278         [ #  # ]:          0 :                         if (!t->time.tm_mon)
     279                 :          0 :                                 t->time.tm_mon = -1;
     280                 :            :                 }
     281                 :            :         }
     282                 :            : 
     283                 :         21 :         rtc_control = CMOS_READ(RTC_CONTROL);
     284                 :         21 :         spin_unlock_irq(&rtc_lock);
     285                 :            : 
     286                 :         21 :         if (!(rtc_control & RTC_DM_BINARY) || RTC_ALWAYS_BCD) {
     287         [ +  - ]:         21 :                 if (((unsigned)t->time.tm_sec) < 0x60)
     288         [ -  + ]:         21 :                         t->time.tm_sec = bcd2bin(t->time.tm_sec);
     289                 :            :                 else
     290                 :          0 :                         t->time.tm_sec = -1;
     291         [ +  - ]:         21 :                 if (((unsigned)t->time.tm_min) < 0x60)
     292         [ -  + ]:         21 :                         t->time.tm_min = bcd2bin(t->time.tm_min);
     293                 :            :                 else
     294                 :          0 :                         t->time.tm_min = -1;
     295         [ +  - ]:         21 :                 if (((unsigned)t->time.tm_hour) < 0x24)
     296         [ -  + ]:         21 :                         t->time.tm_hour = bcd2bin(t->time.tm_hour);
     297                 :            :                 else
     298                 :          0 :                         t->time.tm_hour = -1;
     299                 :            : 
     300         [ -  + ]:         21 :                 if (cmos->day_alrm) {
     301         [ #  # ]:          0 :                         if (((unsigned)t->time.tm_mday) <= 0x31)
     302         [ #  # ]:          0 :                                 t->time.tm_mday = bcd2bin(t->time.tm_mday);
     303                 :            :                         else
     304                 :          0 :                                 t->time.tm_mday = -1;
     305                 :            : 
     306         [ #  # ]:          0 :                         if (cmos->mon_alrm) {
     307         [ #  # ]:          0 :                                 if (((unsigned)t->time.tm_mon) <= 0x12)
     308         [ #  # ]:          0 :                                         t->time.tm_mon = bcd2bin(t->time.tm_mon)-1;
     309                 :            :                                 else
     310                 :          0 :                                         t->time.tm_mon = -1;
     311                 :            :                         }
     312                 :            :                 }
     313                 :            :         }
     314                 :            : 
     315                 :         21 :         t->enabled = !!(rtc_control & RTC_AIE);
     316                 :         21 :         t->pending = 0;
     317                 :            : 
     318                 :         21 :         return 0;
     319                 :            : }
     320                 :            : 
     321                 :         21 : static void cmos_checkintr(struct cmos_rtc *cmos, unsigned char rtc_control)
     322                 :            : {
     323                 :         21 :         unsigned char   rtc_intr;
     324                 :            : 
     325                 :            :         /* NOTE after changing RTC_xIE bits we always read INTR_FLAGS;
     326                 :            :          * allegedly some older rtcs need that to handle irqs properly
     327                 :            :          */
     328                 :         21 :         rtc_intr = CMOS_READ(RTC_INTR_FLAGS);
     329                 :            : 
     330                 :         21 :         if (use_hpet_alarm())
     331                 :            :                 return;
     332                 :            : 
     333                 :          0 :         rtc_intr &= (rtc_control & RTC_IRQMASK) | RTC_IRQF;
     334   [ #  #  #  # ]:          0 :         if (is_intr(rtc_intr))
     335                 :          0 :                 rtc_update_irq(cmos->rtc, 1, rtc_intr);
     336                 :            : }
     337                 :            : 
     338                 :          0 : static void cmos_irq_enable(struct cmos_rtc *cmos, unsigned char mask)
     339                 :            : {
     340                 :          0 :         unsigned char   rtc_control;
     341                 :            : 
     342                 :            :         /* flush any pending IRQ status, notably for update irqs,
     343                 :            :          * before we enable new IRQs
     344                 :            :          */
     345                 :          0 :         rtc_control = CMOS_READ(RTC_CONTROL);
     346                 :          0 :         cmos_checkintr(cmos, rtc_control);
     347                 :            : 
     348                 :          0 :         rtc_control |= mask;
     349                 :          0 :         CMOS_WRITE(rtc_control, RTC_CONTROL);
     350                 :          0 :         if (use_hpet_alarm())
     351                 :          0 :                 hpet_set_rtc_irq_bit(mask);
     352                 :            : 
     353   [ #  #  #  # ]:          0 :         if ((mask & RTC_AIE) && cmos_use_acpi_alarm()) {
     354         [ #  # ]:          0 :                 if (cmos->wake_on)
     355                 :          0 :                         cmos->wake_on(cmos->dev);
     356                 :            :         }
     357                 :            : 
     358                 :          0 :         cmos_checkintr(cmos, rtc_control);
     359                 :          0 : }
     360                 :            : 
     361                 :         21 : static void cmos_irq_disable(struct cmos_rtc *cmos, unsigned char mask)
     362                 :            : {
     363                 :         21 :         unsigned char   rtc_control;
     364                 :            : 
     365                 :         21 :         rtc_control = CMOS_READ(RTC_CONTROL);
     366                 :         21 :         rtc_control &= ~mask;
     367                 :         21 :         CMOS_WRITE(rtc_control, RTC_CONTROL);
     368                 :         21 :         if (use_hpet_alarm())
     369                 :         21 :                 hpet_mask_rtc_irq_bit(mask);
     370                 :            : 
     371   [ +  -  -  + ]:         21 :         if ((mask & RTC_AIE) && cmos_use_acpi_alarm()) {
     372         [ #  # ]:          0 :                 if (cmos->wake_off)
     373                 :          0 :                         cmos->wake_off(cmos->dev);
     374                 :            :         }
     375                 :            : 
     376                 :         21 :         cmos_checkintr(cmos, rtc_control);
     377                 :         21 : }
     378                 :            : 
     379                 :          0 : static int cmos_validate_alarm(struct device *dev, struct rtc_wkalrm *t)
     380                 :            : {
     381         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     382                 :          0 :         struct rtc_time now;
     383                 :            : 
     384         [ #  # ]:          0 :         cmos_read_time(dev, &now);
     385                 :            : 
     386         [ #  # ]:          0 :         if (!cmos->day_alrm) {
     387                 :          0 :                 time64_t t_max_date;
     388                 :          0 :                 time64_t t_alrm;
     389                 :            : 
     390                 :          0 :                 t_max_date = rtc_tm_to_time64(&now);
     391                 :          0 :                 t_max_date += 24 * 60 * 60 - 1;
     392                 :          0 :                 t_alrm = rtc_tm_to_time64(&t->time);
     393         [ #  # ]:          0 :                 if (t_alrm > t_max_date) {
     394                 :          0 :                         dev_err(dev,
     395                 :            :                                 "Alarms can be up to one day in the future\n");
     396                 :          0 :                         return -EINVAL;
     397                 :            :                 }
     398         [ #  # ]:          0 :         } else if (!cmos->mon_alrm) {
     399                 :          0 :                 struct rtc_time max_date = now;
     400                 :          0 :                 time64_t t_max_date;
     401                 :          0 :                 time64_t t_alrm;
     402                 :          0 :                 int max_mday;
     403                 :            : 
     404         [ #  # ]:          0 :                 if (max_date.tm_mon == 11) {
     405                 :          0 :                         max_date.tm_mon = 0;
     406                 :          0 :                         max_date.tm_year += 1;
     407                 :            :                 } else {
     408                 :          0 :                         max_date.tm_mon += 1;
     409                 :            :                 }
     410                 :          0 :                 max_mday = rtc_month_days(max_date.tm_mon, max_date.tm_year);
     411         [ #  # ]:          0 :                 if (max_date.tm_mday > max_mday)
     412                 :          0 :                         max_date.tm_mday = max_mday;
     413                 :            : 
     414                 :          0 :                 t_max_date = rtc_tm_to_time64(&max_date);
     415                 :          0 :                 t_max_date -= 1;
     416                 :          0 :                 t_alrm = rtc_tm_to_time64(&t->time);
     417         [ #  # ]:          0 :                 if (t_alrm > t_max_date) {
     418                 :          0 :                         dev_err(dev,
     419                 :            :                                 "Alarms can be up to one month in the future\n");
     420                 :          0 :                         return -EINVAL;
     421                 :            :                 }
     422                 :            :         } else {
     423                 :          0 :                 struct rtc_time max_date = now;
     424                 :          0 :                 time64_t t_max_date;
     425                 :          0 :                 time64_t t_alrm;
     426                 :          0 :                 int max_mday;
     427                 :            : 
     428                 :          0 :                 max_date.tm_year += 1;
     429                 :          0 :                 max_mday = rtc_month_days(max_date.tm_mon, max_date.tm_year);
     430         [ #  # ]:          0 :                 if (max_date.tm_mday > max_mday)
     431                 :          0 :                         max_date.tm_mday = max_mday;
     432                 :            : 
     433                 :          0 :                 t_max_date = rtc_tm_to_time64(&max_date);
     434                 :          0 :                 t_max_date -= 1;
     435                 :          0 :                 t_alrm = rtc_tm_to_time64(&t->time);
     436         [ #  # ]:          0 :                 if (t_alrm > t_max_date) {
     437                 :          0 :                         dev_err(dev,
     438                 :            :                                 "Alarms can be up to one year in the future\n");
     439                 :          0 :                         return -EINVAL;
     440                 :            :                 }
     441                 :            :         }
     442                 :            : 
     443                 :            :         return 0;
     444                 :            : }
     445                 :            : 
     446                 :          0 : static int cmos_set_alarm(struct device *dev, struct rtc_wkalrm *t)
     447                 :            : {
     448         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     449                 :          0 :         unsigned char mon, mday, hrs, min, sec, rtc_control;
     450                 :          0 :         int ret;
     451                 :            : 
     452                 :            :         /* This not only a rtc_op, but also called directly */
     453         [ #  # ]:          0 :         if (!is_valid_irq(cmos->irq))
     454                 :            :                 return -EIO;
     455                 :            : 
     456                 :          0 :         ret = cmos_validate_alarm(dev, t);
     457         [ #  # ]:          0 :         if (ret < 0)
     458                 :            :                 return ret;
     459                 :            : 
     460                 :          0 :         mon = t->time.tm_mon + 1;
     461                 :          0 :         mday = t->time.tm_mday;
     462                 :          0 :         hrs = t->time.tm_hour;
     463                 :          0 :         min = t->time.tm_min;
     464                 :          0 :         sec = t->time.tm_sec;
     465                 :            : 
     466                 :          0 :         rtc_control = CMOS_READ(RTC_CONTROL);
     467                 :          0 :         if (!(rtc_control & RTC_DM_BINARY) || RTC_ALWAYS_BCD) {
     468                 :            :                 /* Writing 0xff means "don't care" or "match all".  */
     469   [ #  #  #  # ]:          0 :                 mon = (mon <= 12) ? bin2bcd(mon) : 0xff;
     470   [ #  #  #  # ]:          0 :                 mday = (mday >= 1 && mday <= 31) ? bin2bcd(mday) : 0xff;
     471   [ #  #  #  # ]:          0 :                 hrs = (hrs < 24) ? bin2bcd(hrs) : 0xff;
     472   [ #  #  #  # ]:          0 :                 min = (min < 60) ? bin2bcd(min) : 0xff;
     473   [ #  #  #  # ]:          0 :                 sec = (sec < 60) ? bin2bcd(sec) : 0xff;
     474                 :            :         }
     475                 :            : 
     476                 :          0 :         spin_lock_irq(&rtc_lock);
     477                 :            : 
     478                 :            :         /* next rtc irq must not be from previous alarm setting */
     479                 :          0 :         cmos_irq_disable(cmos, RTC_AIE);
     480                 :            : 
     481                 :            :         /* update alarm */
     482                 :          0 :         CMOS_WRITE(hrs, RTC_HOURS_ALARM);
     483                 :          0 :         CMOS_WRITE(min, RTC_MINUTES_ALARM);
     484                 :          0 :         CMOS_WRITE(sec, RTC_SECONDS_ALARM);
     485                 :            : 
     486                 :            :         /* the system may support an "enhanced" alarm */
     487         [ #  # ]:          0 :         if (cmos->day_alrm) {
     488                 :          0 :                 CMOS_WRITE(mday, cmos->day_alrm);
     489         [ #  # ]:          0 :                 if (cmos->mon_alrm)
     490                 :          0 :                         CMOS_WRITE(mon, cmos->mon_alrm);
     491                 :            :         }
     492                 :            : 
     493                 :          0 :         if (use_hpet_alarm()) {
     494                 :            :                 /*
     495                 :            :                  * FIXME the HPET alarm glue currently ignores day_alrm
     496                 :            :                  * and mon_alrm ...
     497                 :            :                  */
     498                 :          0 :                 hpet_set_alarm_time(t->time.tm_hour, t->time.tm_min,
     499                 :          0 :                                     t->time.tm_sec);
     500                 :            :         }
     501                 :            : 
     502         [ #  # ]:          0 :         if (t->enabled)
     503                 :          0 :                 cmos_irq_enable(cmos, RTC_AIE);
     504                 :            : 
     505                 :          0 :         spin_unlock_irq(&rtc_lock);
     506                 :            : 
     507                 :          0 :         cmos->alarm_expires = rtc_tm_to_time64(&t->time);
     508                 :            : 
     509                 :          0 :         return 0;
     510                 :            : }
     511                 :            : 
     512                 :          0 : static int cmos_alarm_irq_enable(struct device *dev, unsigned int enabled)
     513                 :            : {
     514                 :          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     515                 :          0 :         unsigned long   flags;
     516                 :            : 
     517                 :          0 :         spin_lock_irqsave(&rtc_lock, flags);
     518                 :            : 
     519         [ #  # ]:          0 :         if (enabled)
     520                 :          0 :                 cmos_irq_enable(cmos, RTC_AIE);
     521                 :            :         else
     522                 :          0 :                 cmos_irq_disable(cmos, RTC_AIE);
     523                 :            : 
     524                 :          0 :         spin_unlock_irqrestore(&rtc_lock, flags);
     525                 :          0 :         return 0;
     526                 :            : }
     527                 :            : 
     528                 :            : #if IS_ENABLED(CONFIG_RTC_INTF_PROC)
     529                 :            : 
     530                 :          0 : static int cmos_procfs(struct device *dev, struct seq_file *seq)
     531                 :            : {
     532                 :          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     533                 :          0 :         unsigned char   rtc_control, valid;
     534                 :            : 
     535                 :          0 :         spin_lock_irq(&rtc_lock);
     536                 :          0 :         rtc_control = CMOS_READ(RTC_CONTROL);
     537                 :          0 :         valid = CMOS_READ(RTC_VALID);
     538                 :          0 :         spin_unlock_irq(&rtc_lock);
     539                 :            : 
     540                 :            :         /* NOTE:  at least ICH6 reports battery status using a different
     541                 :            :          * (non-RTC) bit; and SQWE is ignored on many current systems.
     542                 :            :          */
     543   [ #  #  #  #  :          0 :         seq_printf(seq,
                   #  # ]
     544                 :            :                    "periodic_IRQ\t: %s\n"
     545                 :            :                    "update_IRQ\t: %s\n"
     546                 :            :                    "HPET_emulated\t: %s\n"
     547                 :            :                    // "square_wave\t: %s\n"
     548                 :            :                    "BCD\t\t: %s\n"
     549                 :            :                    "DST_enable\t: %s\n"
     550                 :            :                    "periodic_freq\t: %d\n"
     551                 :            :                    "batt_status\t: %s\n",
     552                 :            :                    (rtc_control & RTC_PIE) ? "yes" : "no",
     553                 :            :                    (rtc_control & RTC_UIE) ? "yes" : "no",
     554                 :            :                    use_hpet_alarm() ? "yes" : "no",
     555                 :            :                    // (rtc_control & RTC_SQWE) ? "yes" : "no",
     556                 :            :                    (rtc_control & RTC_DM_BINARY) ? "no" : "yes",
     557                 :            :                    (rtc_control & RTC_DST_EN) ? "yes" : "no",
     558         [ #  # ]:          0 :                    cmos->rtc->irq_freq,
     559         [ #  # ]:          0 :                    (valid & RTC_VRT) ? "okay" : "dead");
     560                 :            : 
     561                 :          0 :         return 0;
     562                 :            : }
     563                 :            : 
     564                 :            : #else
     565                 :            : #define cmos_procfs     NULL
     566                 :            : #endif
     567                 :            : 
     568                 :            : static const struct rtc_class_ops cmos_rtc_ops = {
     569                 :            :         .read_time              = cmos_read_time,
     570                 :            :         .set_time               = cmos_set_time,
     571                 :            :         .read_alarm             = cmos_read_alarm,
     572                 :            :         .set_alarm              = cmos_set_alarm,
     573                 :            :         .proc                   = cmos_procfs,
     574                 :            :         .alarm_irq_enable       = cmos_alarm_irq_enable,
     575                 :            : };
     576                 :            : 
     577                 :            : static const struct rtc_class_ops cmos_rtc_ops_no_alarm = {
     578                 :            :         .read_time              = cmos_read_time,
     579                 :            :         .set_time               = cmos_set_time,
     580                 :            :         .proc                   = cmos_procfs,
     581                 :            : };
     582                 :            : 
     583                 :            : /*----------------------------------------------------------------*/
     584                 :            : 
     585                 :            : /*
     586                 :            :  * All these chips have at least 64 bytes of address space, shared by
     587                 :            :  * RTC registers and NVRAM.  Most of those bytes of NVRAM are used
     588                 :            :  * by boot firmware.  Modern chips have 128 or 256 bytes.
     589                 :            :  */
     590                 :            : 
     591                 :            : #define NVRAM_OFFSET    (RTC_REG_D + 1)
     592                 :            : 
     593                 :          0 : static int cmos_nvram_read(void *priv, unsigned int off, void *val,
     594                 :            :                            size_t count)
     595                 :            : {
     596                 :          0 :         unsigned char *buf = val;
     597                 :          0 :         int     retval;
     598                 :            : 
     599                 :          0 :         off += NVRAM_OFFSET;
     600                 :          0 :         spin_lock_irq(&rtc_lock);
     601         [ #  # ]:          0 :         for (retval = 0; count; count--, off++, retval++) {
     602         [ #  # ]:          0 :                 if (off < 128)
     603                 :          0 :                         *buf++ = CMOS_READ(off);
     604                 :          0 :                 else if (can_bank2)
     605                 :          0 :                         *buf++ = cmos_read_bank2(off);
     606                 :            :                 else
     607                 :            :                         break;
     608                 :            :         }
     609                 :          0 :         spin_unlock_irq(&rtc_lock);
     610                 :            : 
     611                 :          0 :         return retval;
     612                 :            : }
     613                 :            : 
     614                 :          0 : static int cmos_nvram_write(void *priv, unsigned int off, void *val,
     615                 :            :                             size_t count)
     616                 :            : {
     617                 :          0 :         struct cmos_rtc *cmos = priv;
     618                 :          0 :         unsigned char   *buf = val;
     619                 :          0 :         int             retval;
     620                 :            : 
     621                 :            :         /* NOTE:  on at least PCs and Ataris, the boot firmware uses a
     622                 :            :          * checksum on part of the NVRAM data.  That's currently ignored
     623                 :            :          * here.  If userspace is smart enough to know what fields of
     624                 :            :          * NVRAM to update, updating checksums is also part of its job.
     625                 :            :          */
     626                 :          0 :         off += NVRAM_OFFSET;
     627                 :          0 :         spin_lock_irq(&rtc_lock);
     628         [ #  # ]:          0 :         for (retval = 0; count; count--, off++, retval++) {
     629                 :            :                 /* don't trash RTC registers */
     630         [ #  # ]:          0 :                 if (off == cmos->day_alrm
     631         [ #  # ]:          0 :                                 || off == cmos->mon_alrm
     632         [ #  # ]:          0 :                                 || off == cmos->century)
     633                 :          0 :                         buf++;
     634         [ #  # ]:          0 :                 else if (off < 128)
     635                 :          0 :                         CMOS_WRITE(*buf++, off);
     636                 :          0 :                 else if (can_bank2)
     637                 :          0 :                         cmos_write_bank2(*buf++, off);
     638                 :            :                 else
     639                 :            :                         break;
     640                 :            :         }
     641                 :          0 :         spin_unlock_irq(&rtc_lock);
     642                 :            : 
     643                 :          0 :         return retval;
     644                 :            : }
     645                 :            : 
     646                 :            : /*----------------------------------------------------------------*/
     647                 :            : 
     648                 :            : static struct cmos_rtc  cmos_rtc;
     649                 :            : 
     650                 :          0 : static irqreturn_t cmos_interrupt(int irq, void *p)
     651                 :            : {
     652                 :          0 :         u8              irqstat;
     653                 :          0 :         u8              rtc_control;
     654                 :            : 
     655                 :          0 :         spin_lock(&rtc_lock);
     656                 :            : 
     657                 :            :         /* When the HPET interrupt handler calls us, the interrupt
     658                 :            :          * status is passed as arg1 instead of the irq number.  But
     659                 :            :          * always clear irq status, even when HPET is in the way.
     660                 :            :          *
     661                 :            :          * Note that HPET and RTC are almost certainly out of phase,
     662                 :            :          * giving different IRQ status ...
     663                 :            :          */
     664                 :          0 :         irqstat = CMOS_READ(RTC_INTR_FLAGS);
     665                 :          0 :         rtc_control = CMOS_READ(RTC_CONTROL);
     666                 :          0 :         if (use_hpet_alarm())
     667                 :          0 :                 irqstat = (unsigned long)irq & 0xF0;
     668                 :            : 
     669                 :            :         /* If we were suspended, RTC_CONTROL may not be accurate since the
     670                 :            :          * bios may have cleared it.
     671                 :            :          */
     672         [ #  # ]:          0 :         if (!cmos_rtc.suspend_ctrl)
     673                 :          0 :                 irqstat &= (rtc_control & RTC_IRQMASK) | RTC_IRQF;
     674                 :            :         else
     675                 :          0 :                 irqstat &= (cmos_rtc.suspend_ctrl & RTC_IRQMASK) | RTC_IRQF;
     676                 :            : 
     677                 :            :         /* All Linux RTC alarms should be treated as if they were oneshot.
     678                 :            :          * Similar code may be needed in system wakeup paths, in case the
     679                 :            :          * alarm woke the system.
     680                 :            :          */
     681         [ #  # ]:          0 :         if (irqstat & RTC_AIE) {
     682                 :          0 :                 cmos_rtc.suspend_ctrl &= ~RTC_AIE;
     683                 :          0 :                 rtc_control &= ~RTC_AIE;
     684                 :          0 :                 CMOS_WRITE(rtc_control, RTC_CONTROL);
     685                 :          0 :                 if (use_hpet_alarm())
     686                 :          0 :                         hpet_mask_rtc_irq_bit(RTC_AIE);
     687                 :          0 :                 CMOS_READ(RTC_INTR_FLAGS);
     688                 :            :         }
     689                 :          0 :         spin_unlock(&rtc_lock);
     690                 :            : 
     691   [ #  #  #  # ]:          0 :         if (is_intr(irqstat)) {
     692                 :          0 :                 rtc_update_irq(p, 1, irqstat);
     693                 :          0 :                 return IRQ_HANDLED;
     694                 :            :         } else
     695                 :            :                 return IRQ_NONE;
     696                 :            : }
     697                 :            : 
     698                 :            : #ifdef  CONFIG_PNP
     699                 :            : #define INITSECTION
     700                 :            : 
     701                 :            : #else
     702                 :            : #define INITSECTION     __init
     703                 :            : #endif
     704                 :            : 
     705                 :            : static int INITSECTION
     706                 :         21 : cmos_do_probe(struct device *dev, struct resource *ports, int rtc_irq)
     707                 :            : {
     708         [ +  - ]:         21 :         struct cmos_rtc_board_info      *info = dev_get_platdata(dev);
     709                 :         21 :         int                             retval = 0;
     710                 :         21 :         unsigned char                   rtc_control;
     711                 :         21 :         unsigned                        address_space;
     712                 :         21 :         u32                             flags = 0;
     713                 :         21 :         struct nvmem_config nvmem_cfg = {
     714                 :            :                 .name = "cmos_nvram",
     715                 :            :                 .word_size = 1,
     716                 :            :                 .stride = 1,
     717                 :            :                 .reg_read = cmos_nvram_read,
     718                 :            :                 .reg_write = cmos_nvram_write,
     719                 :            :                 .priv = &cmos_rtc,
     720                 :            :         };
     721                 :            : 
     722                 :            :         /* there can be only one ... */
     723         [ +  - ]:         21 :         if (cmos_rtc.dev)
     724                 :            :                 return -EBUSY;
     725                 :            : 
     726         [ +  - ]:         21 :         if (!ports)
     727                 :            :                 return -ENODEV;
     728                 :            : 
     729                 :            :         /* Claim I/O ports ASAP, minimizing conflict with legacy driver.
     730                 :            :          *
     731                 :            :          * REVISIT non-x86 systems may instead use memory space resources
     732                 :            :          * (needing ioremap etc), not i/o space resources like this ...
     733                 :            :          */
     734                 :         21 :         if (RTC_IOMAPPED)
     735                 :         21 :                 ports = request_region(ports->start, resource_size(ports),
     736                 :            :                                        driver_name);
     737                 :            :         else
     738                 :            :                 ports = request_mem_region(ports->start, resource_size(ports),
     739                 :            :                                            driver_name);
     740         [ +  - ]:         21 :         if (!ports) {
     741                 :            :                 dev_dbg(dev, "i/o registers already in use\n");
     742                 :            :                 return -EBUSY;
     743                 :            :         }
     744                 :            : 
     745                 :         21 :         cmos_rtc.irq = rtc_irq;
     746                 :         21 :         cmos_rtc.iomem = ports;
     747                 :            : 
     748                 :            :         /* Heuristic to deduce NVRAM size ... do what the legacy NVRAM
     749                 :            :          * driver did, but don't reject unknown configs.   Old hardware
     750                 :            :          * won't address 128 bytes.  Newer chips have multiple banks,
     751                 :            :          * though they may not be listed in one I/O resource.
     752                 :            :          */
     753                 :            : #if     defined(CONFIG_ATARI)
     754                 :            :         address_space = 64;
     755                 :            : #elif defined(__i386__) || defined(__x86_64__) || defined(__arm__) \
     756                 :            :                         || defined(__sparc__) || defined(__mips__) \
     757                 :            :                         || defined(__powerpc__)
     758                 :         21 :         address_space = 128;
     759                 :            : #else
     760                 :            : #warning Assuming 128 bytes of RTC+NVRAM address space, not 64 bytes.
     761                 :            :         address_space = 128;
     762                 :            : #endif
     763         [ -  + ]:         21 :         if (can_bank2 && ports->end > (ports->start + 1))
     764                 :          0 :                 address_space = 256;
     765                 :            : 
     766                 :            :         /* For ACPI systems extension info comes from the FADT.  On others,
     767                 :            :          * board specific setup provides it as appropriate.  Systems where
     768                 :            :          * the alarm IRQ isn't automatically a wakeup IRQ (like ACPI, and
     769                 :            :          * some almost-clones) can provide hooks to make that behave.
     770                 :            :          *
     771                 :            :          * Note that ACPI doesn't preclude putting these registers into
     772                 :            :          * "extended" areas of the chip, including some that we won't yet
     773                 :            :          * expect CMOS_READ and friends to handle.
     774                 :            :          */
     775         [ +  - ]:         21 :         if (info) {
     776                 :         21 :                 if (info->flags)
     777                 :            :                         flags = info->flags;
     778         [ -  + ]:         21 :                 if (info->address_space)
     779                 :          0 :                         address_space = info->address_space;
     780                 :            : 
     781         [ -  + ]:         21 :                 if (info->rtc_day_alarm && info->rtc_day_alarm < 128)
     782                 :          0 :                         cmos_rtc.day_alrm = info->rtc_day_alarm;
     783         [ -  + ]:         21 :                 if (info->rtc_mon_alarm && info->rtc_mon_alarm < 128)
     784                 :          0 :                         cmos_rtc.mon_alrm = info->rtc_mon_alarm;
     785         [ +  - ]:         21 :                 if (info->rtc_century && info->rtc_century < 128)
     786                 :         21 :                         cmos_rtc.century = info->rtc_century;
     787                 :            : 
     788   [ +  -  +  - ]:         21 :                 if (info->wake_on && info->wake_off) {
     789                 :         21 :                         cmos_rtc.wake_on = info->wake_on;
     790                 :         21 :                         cmos_rtc.wake_off = info->wake_off;
     791                 :            :                 }
     792                 :            :         }
     793                 :            : 
     794                 :         21 :         cmos_rtc.dev = dev;
     795                 :         21 :         dev_set_drvdata(dev, &cmos_rtc);
     796                 :            : 
     797                 :         21 :         cmos_rtc.rtc = devm_rtc_allocate_device(dev);
     798         [ -  + ]:         21 :         if (IS_ERR(cmos_rtc.rtc)) {
     799                 :          0 :                 retval = PTR_ERR(cmos_rtc.rtc);
     800                 :          0 :                 goto cleanup0;
     801                 :            :         }
     802                 :            : 
     803         [ +  - ]:         21 :         rename_region(ports, dev_name(&cmos_rtc.rtc->dev));
     804                 :            : 
     805                 :         21 :         spin_lock_irq(&rtc_lock);
     806                 :            : 
     807         [ +  - ]:         21 :         if (!(flags & CMOS_RTC_FLAGS_NOFREQ)) {
     808                 :            :                 /* force periodic irq to CMOS reset default of 1024Hz;
     809                 :            :                  *
     810                 :            :                  * REVISIT it's been reported that at least one x86_64 ALI
     811                 :            :                  * mobo doesn't use 32KHz here ... for portability we might
     812                 :            :                  * need to do something about other clock frequencies.
     813                 :            :                  */
     814                 :         21 :                 cmos_rtc.rtc->irq_freq = 1024;
     815                 :         21 :                 if (use_hpet_alarm())
     816                 :         21 :                         hpet_set_periodic_freq(cmos_rtc.rtc->irq_freq);
     817                 :         21 :                 CMOS_WRITE(RTC_REF_CLCK_32KHZ | 0x06, RTC_FREQ_SELECT);
     818                 :            :         }
     819                 :            : 
     820                 :            :         /* disable irqs */
     821         [ +  - ]:         21 :         if (is_valid_irq(rtc_irq))
     822                 :         21 :                 cmos_irq_disable(&cmos_rtc, RTC_PIE | RTC_AIE | RTC_UIE);
     823                 :            : 
     824                 :         21 :         rtc_control = CMOS_READ(RTC_CONTROL);
     825                 :            : 
     826                 :         21 :         spin_unlock_irq(&rtc_lock);
     827                 :            : 
     828   [ +  -  -  + ]:         21 :         if (is_valid_irq(rtc_irq) && !(rtc_control & RTC_24H)) {
     829                 :          0 :                 dev_warn(dev, "only 24-hr supported\n");
     830                 :          0 :                 retval = -ENXIO;
     831                 :          0 :                 goto cleanup1;
     832                 :            :         }
     833                 :            : 
     834                 :         21 :         if (use_hpet_alarm())
     835                 :         21 :                 hpet_rtc_timer_init();
     836                 :            : 
     837         [ +  - ]:         21 :         if (is_valid_irq(rtc_irq)) {
     838                 :         21 :                 irq_handler_t rtc_cmos_int_handler;
     839                 :            : 
     840                 :         21 :                 if (use_hpet_alarm()) {
     841                 :         21 :                         rtc_cmos_int_handler = hpet_rtc_interrupt;
     842                 :         21 :                         retval = hpet_register_irq_handler(cmos_interrupt);
     843         [ -  + ]:         21 :                         if (retval) {
     844                 :          0 :                                 hpet_mask_rtc_irq_bit(RTC_IRQMASK);
     845                 :          0 :                                 dev_warn(dev, "hpet_register_irq_handler "
     846                 :            :                                                 " failed in rtc_init().");
     847                 :          0 :                                 goto cleanup1;
     848                 :            :                         }
     849                 :            :                 } else
     850                 :            :                         rtc_cmos_int_handler = cmos_interrupt;
     851                 :            : 
     852                 :         21 :                 retval = request_irq(rtc_irq, rtc_cmos_int_handler,
     853                 :            :                                 0, dev_name(&cmos_rtc.rtc->dev),
     854         [ +  - ]:         21 :                                 cmos_rtc.rtc);
     855         [ -  + ]:         21 :                 if (retval < 0) {
     856                 :          0 :                         dev_dbg(dev, "IRQ %d is already in use\n", rtc_irq);
     857                 :          0 :                         goto cleanup1;
     858                 :            :                 }
     859                 :            : 
     860                 :         21 :                 cmos_rtc.rtc->ops = &cmos_rtc_ops;
     861                 :            :         } else {
     862                 :          0 :                 cmos_rtc.rtc->ops = &cmos_rtc_ops_no_alarm;
     863                 :            :         }
     864                 :            : 
     865                 :         21 :         cmos_rtc.rtc->nvram_old_abi = true;
     866                 :         21 :         retval = rtc_register_device(cmos_rtc.rtc);
     867         [ -  + ]:         21 :         if (retval)
     868                 :          0 :                 goto cleanup2;
     869                 :            : 
     870                 :            :         /* export at least the first block of NVRAM */
     871                 :         21 :         nvmem_cfg.size = address_space - NVRAM_OFFSET;
     872         [ -  + ]:         21 :         if (rtc_nvmem_register(cmos_rtc.rtc, &nvmem_cfg))
     873                 :          0 :                 dev_err(dev, "nvmem registration failed\n");
     874                 :            : 
     875   [ -  +  +  -  :         42 :         dev_info(dev, "%s%s, %d bytes nvram%s\n",
             +  -  +  - ]
     876                 :            :                  !is_valid_irq(rtc_irq) ? "no alarms" :
     877                 :            :                  cmos_rtc.mon_alrm ? "alarms up to one year" :
     878                 :            :                  cmos_rtc.day_alrm ? "alarms up to one month" :
     879                 :            :                  "alarms up to one day",
     880                 :            :                  cmos_rtc.century ? ", y3k" : "",
     881                 :            :                  nvmem_cfg.size,
     882                 :            :                  use_hpet_alarm() ? ", hpet irqs" : "");
     883                 :            : 
     884                 :         21 :         return 0;
     885                 :            : 
     886                 :            : cleanup2:
     887         [ #  # ]:          0 :         if (is_valid_irq(rtc_irq))
     888                 :          0 :                 free_irq(rtc_irq, cmos_rtc.rtc);
     889                 :          0 : cleanup1:
     890                 :          0 :         cmos_rtc.dev = NULL;
     891                 :          0 : cleanup0:
     892                 :          0 :         if (RTC_IOMAPPED)
     893                 :          0 :                 release_region(ports->start, resource_size(ports));
     894                 :            :         else
     895                 :            :                 release_mem_region(ports->start, resource_size(ports));
     896                 :          0 :         return retval;
     897                 :            : }
     898                 :            : 
     899                 :          0 : static void cmos_do_shutdown(int rtc_irq)
     900                 :            : {
     901                 :          0 :         spin_lock_irq(&rtc_lock);
     902         [ #  # ]:          0 :         if (is_valid_irq(rtc_irq))
     903                 :          0 :                 cmos_irq_disable(&cmos_rtc, RTC_IRQMASK);
     904                 :          0 :         spin_unlock_irq(&rtc_lock);
     905                 :          0 : }
     906                 :            : 
     907                 :          0 : static void cmos_do_remove(struct device *dev)
     908                 :            : {
     909                 :          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     910                 :          0 :         struct resource *ports;
     911                 :            : 
     912                 :          0 :         cmos_do_shutdown(cmos->irq);
     913                 :            : 
     914         [ #  # ]:          0 :         if (is_valid_irq(cmos->irq)) {
     915                 :          0 :                 free_irq(cmos->irq, cmos->rtc);
     916                 :          0 :                 if (use_hpet_alarm())
     917                 :          0 :                         hpet_unregister_irq_handler(cmos_interrupt);
     918                 :            :         }
     919                 :            : 
     920                 :          0 :         cmos->rtc = NULL;
     921                 :            : 
     922                 :          0 :         ports = cmos->iomem;
     923                 :          0 :         if (RTC_IOMAPPED)
     924                 :          0 :                 release_region(ports->start, resource_size(ports));
     925                 :            :         else
     926                 :            :                 release_mem_region(ports->start, resource_size(ports));
     927                 :          0 :         cmos->iomem = NULL;
     928                 :            : 
     929                 :          0 :         cmos->dev = NULL;
     930                 :          0 : }
     931                 :            : 
     932                 :          0 : static int cmos_aie_poweroff(struct device *dev)
     933                 :            : {
     934         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     935                 :          0 :         struct rtc_time now;
     936                 :          0 :         time64_t t_now;
     937                 :          0 :         int retval = 0;
     938                 :          0 :         unsigned char rtc_control;
     939                 :            : 
     940         [ #  # ]:          0 :         if (!cmos->alarm_expires)
     941                 :            :                 return -EINVAL;
     942                 :            : 
     943                 :          0 :         spin_lock_irq(&rtc_lock);
     944                 :          0 :         rtc_control = CMOS_READ(RTC_CONTROL);
     945                 :          0 :         spin_unlock_irq(&rtc_lock);
     946                 :            : 
     947                 :            :         /* We only care about the situation where AIE is disabled. */
     948         [ #  # ]:          0 :         if (rtc_control & RTC_AIE)
     949                 :            :                 return -EBUSY;
     950                 :            : 
     951         [ #  # ]:          0 :         cmos_read_time(dev, &now);
     952                 :          0 :         t_now = rtc_tm_to_time64(&now);
     953                 :            : 
     954                 :            :         /*
     955                 :            :          * When enabling "RTC wake-up" in BIOS setup, the machine reboots
     956                 :            :          * automatically right after shutdown on some buggy boxes.
     957                 :            :          * This automatic rebooting issue won't happen when the alarm
     958                 :            :          * time is larger than now+1 seconds.
     959                 :            :          *
     960                 :            :          * If the alarm time is equal to now+1 seconds, the issue can be
     961                 :            :          * prevented by cancelling the alarm.
     962                 :            :          */
     963         [ #  # ]:          0 :         if (cmos->alarm_expires == t_now + 1) {
     964                 :          0 :                 struct rtc_wkalrm alarm;
     965                 :            : 
     966                 :            :                 /* Cancel the AIE timer by configuring the past time. */
     967                 :          0 :                 rtc_time64_to_tm(t_now - 1, &alarm.time);
     968                 :          0 :                 alarm.enabled = 0;
     969                 :          0 :                 retval = cmos_set_alarm(dev, &alarm);
     970         [ #  # ]:          0 :         } else if (cmos->alarm_expires > t_now + 1) {
     971                 :          0 :                 retval = -EBUSY;
     972                 :            :         }
     973                 :            : 
     974                 :            :         return retval;
     975                 :            : }
     976                 :            : 
     977                 :          0 : static int cmos_suspend(struct device *dev)
     978                 :            : {
     979                 :          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
     980                 :          0 :         unsigned char   tmp;
     981                 :            : 
     982                 :            :         /* only the alarm might be a wakeup event source */
     983                 :          0 :         spin_lock_irq(&rtc_lock);
     984                 :          0 :         cmos->suspend_ctrl = tmp = CMOS_READ(RTC_CONTROL);
     985         [ #  # ]:          0 :         if (tmp & (RTC_PIE|RTC_AIE|RTC_UIE)) {
     986                 :          0 :                 unsigned char   mask;
     987                 :            : 
     988   [ #  #  #  # ]:          0 :                 if (device_may_wakeup(dev))
     989                 :            :                         mask = RTC_IRQMASK & ~RTC_AIE;
     990                 :            :                 else
     991                 :          0 :                         mask = RTC_IRQMASK;
     992                 :          0 :                 tmp &= ~mask;
     993                 :          0 :                 CMOS_WRITE(tmp, RTC_CONTROL);
     994                 :          0 :                 if (use_hpet_alarm())
     995                 :          0 :                         hpet_mask_rtc_irq_bit(mask);
     996                 :          0 :                 cmos_checkintr(cmos, tmp);
     997                 :            :         }
     998                 :          0 :         spin_unlock_irq(&rtc_lock);
     999                 :            : 
    1000   [ #  #  #  # ]:          0 :         if ((tmp & RTC_AIE) && !cmos_use_acpi_alarm()) {
    1001                 :          0 :                 cmos->enabled_wake = 1;
    1002         [ #  # ]:          0 :                 if (cmos->wake_on)
    1003                 :          0 :                         cmos->wake_on(dev);
    1004                 :            :                 else
    1005                 :          0 :                         enable_irq_wake(cmos->irq);
    1006                 :            :         }
    1007                 :            : 
    1008                 :          0 :         cmos_read_alarm(dev, &cmos->saved_wkalrm);
    1009                 :            : 
    1010                 :          0 :         dev_dbg(dev, "suspend%s, ctrl %02x\n",
    1011                 :            :                         (tmp & RTC_AIE) ? ", alarm may wake" : "",
    1012                 :            :                         tmp);
    1013                 :            : 
    1014                 :          0 :         return 0;
    1015                 :            : }
    1016                 :            : 
    1017                 :            : /* We want RTC alarms to wake us from e.g. ACPI G2/S5 "soft off", even
    1018                 :            :  * after a detour through G3 "mechanical off", although the ACPI spec
    1019                 :            :  * says wakeup should only work from G1/S4 "hibernate".  To most users,
    1020                 :            :  * distinctions between S4 and S5 are pointless.  So when the hardware
    1021                 :            :  * allows, don't draw that distinction.
    1022                 :            :  */
    1023                 :          0 : static inline int cmos_poweroff(struct device *dev)
    1024                 :            : {
    1025                 :          0 :         if (!IS_ENABLED(CONFIG_PM))
    1026                 :            :                 return -ENOSYS;
    1027                 :            : 
    1028                 :          0 :         return cmos_suspend(dev);
    1029                 :            : }
    1030                 :            : 
    1031                 :          0 : static void cmos_check_wkalrm(struct device *dev)
    1032                 :            : {
    1033         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
    1034                 :          0 :         struct rtc_wkalrm current_alarm;
    1035                 :          0 :         time64_t t_now;
    1036                 :          0 :         time64_t t_current_expires;
    1037                 :          0 :         time64_t t_saved_expires;
    1038                 :          0 :         struct rtc_time now;
    1039                 :            : 
    1040                 :            :         /* Check if we have RTC Alarm armed */
    1041         [ #  # ]:          0 :         if (!(cmos->suspend_ctrl & RTC_AIE))
    1042                 :          0 :                 return;
    1043                 :            : 
    1044         [ #  # ]:          0 :         cmos_read_time(dev, &now);
    1045                 :          0 :         t_now = rtc_tm_to_time64(&now);
    1046                 :            : 
    1047                 :            :         /*
    1048                 :            :          * ACPI RTC wake event is cleared after resume from STR,
    1049                 :            :          * ACK the rtc irq here
    1050                 :            :          */
    1051   [ #  #  #  # ]:          0 :         if (t_now >= cmos->alarm_expires && cmos_use_acpi_alarm()) {
    1052                 :          0 :                 cmos_interrupt(0, (void *)cmos->rtc);
    1053                 :          0 :                 return;
    1054                 :            :         }
    1055                 :            : 
    1056                 :          0 :         cmos_read_alarm(dev, &current_alarm);
    1057                 :          0 :         t_current_expires = rtc_tm_to_time64(&current_alarm.time);
    1058                 :          0 :         t_saved_expires = rtc_tm_to_time64(&cmos->saved_wkalrm.time);
    1059         [ #  # ]:          0 :         if (t_current_expires != t_saved_expires ||
    1060         [ #  # ]:          0 :             cmos->saved_wkalrm.enabled != current_alarm.enabled) {
    1061                 :          0 :                 cmos_set_alarm(dev, &cmos->saved_wkalrm);
    1062                 :            :         }
    1063                 :            : }
    1064                 :            : 
    1065                 :            : static void cmos_check_acpi_rtc_status(struct device *dev,
    1066                 :            :                                        unsigned char *rtc_control);
    1067                 :            : 
    1068                 :          0 : static int __maybe_unused cmos_resume(struct device *dev)
    1069                 :            : {
    1070         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
    1071                 :          0 :         unsigned char tmp;
    1072                 :            : 
    1073   [ #  #  #  # ]:          0 :         if (cmos->enabled_wake && !cmos_use_acpi_alarm()) {
    1074         [ #  # ]:          0 :                 if (cmos->wake_off)
    1075                 :          0 :                         cmos->wake_off(dev);
    1076                 :            :                 else
    1077                 :          0 :                         disable_irq_wake(cmos->irq);
    1078                 :          0 :                 cmos->enabled_wake = 0;
    1079                 :            :         }
    1080                 :            : 
    1081                 :            :         /* The BIOS might have changed the alarm, restore it */
    1082                 :          0 :         cmos_check_wkalrm(dev);
    1083                 :            : 
    1084                 :          0 :         spin_lock_irq(&rtc_lock);
    1085                 :          0 :         tmp = cmos->suspend_ctrl;
    1086                 :          0 :         cmos->suspend_ctrl = 0;
    1087                 :            :         /* re-enable any irqs previously active */
    1088         [ #  # ]:          0 :         if (tmp & RTC_IRQMASK) {
    1089                 :          0 :                 unsigned char   mask;
    1090                 :            : 
    1091   [ #  #  #  # ]:          0 :                 if (device_may_wakeup(dev) && use_hpet_alarm())
    1092                 :          0 :                         hpet_rtc_timer_init();
    1093                 :            : 
    1094                 :          0 :                 do {
    1095                 :          0 :                         CMOS_WRITE(tmp, RTC_CONTROL);
    1096                 :          0 :                         if (use_hpet_alarm())
    1097                 :          0 :                                 hpet_set_rtc_irq_bit(tmp & RTC_IRQMASK);
    1098                 :            : 
    1099                 :          0 :                         mask = CMOS_READ(RTC_INTR_FLAGS);
    1100                 :          0 :                         mask &= (tmp & RTC_IRQMASK) | RTC_IRQF;
    1101         [ #  # ]:          0 :                         if (!use_hpet_alarm() || !is_intr(mask))
    1102                 :            :                                 break;
    1103                 :            : 
    1104                 :            :                         /* force one-shot behavior if HPET blocked
    1105                 :            :                          * the wake alarm's irq
    1106                 :            :                          */
    1107                 :          0 :                         rtc_update_irq(cmos->rtc, 1, mask);
    1108                 :          0 :                         tmp &= ~RTC_AIE;
    1109                 :          0 :                         hpet_mask_rtc_irq_bit(RTC_AIE);
    1110         [ #  # ]:          0 :                 } while (mask & RTC_AIE);
    1111                 :            : 
    1112         [ #  # ]:          0 :                 if (tmp & RTC_AIE)
    1113                 :          0 :                         cmos_check_acpi_rtc_status(dev, &tmp);
    1114                 :            :         }
    1115                 :          0 :         spin_unlock_irq(&rtc_lock);
    1116                 :            : 
    1117                 :          0 :         dev_dbg(dev, "resume, ctrl %02x\n", tmp);
    1118                 :            : 
    1119                 :          0 :         return 0;
    1120                 :            : }
    1121                 :            : 
    1122                 :            : static SIMPLE_DEV_PM_OPS(cmos_pm_ops, cmos_suspend, cmos_resume);
    1123                 :            : 
    1124                 :            : /*----------------------------------------------------------------*/
    1125                 :            : 
    1126                 :            : /* On non-x86 systems, a "CMOS" RTC lives most naturally on platform_bus.
    1127                 :            :  * ACPI systems always list these as PNPACPI devices, and pre-ACPI PCs
    1128                 :            :  * probably list them in similar PNPBIOS tables; so PNP is more common.
    1129                 :            :  *
    1130                 :            :  * We don't use legacy "poke at the hardware" probing.  Ancient PCs that
    1131                 :            :  * predate even PNPBIOS should set up platform_bus devices.
    1132                 :            :  */
    1133                 :            : 
    1134                 :            : #ifdef  CONFIG_ACPI
    1135                 :            : 
    1136                 :            : #include <linux/acpi.h>
    1137                 :            : 
    1138                 :          0 : static u32 rtc_handler(void *context)
    1139                 :            : {
    1140                 :          0 :         struct device *dev = context;
    1141         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
    1142                 :          0 :         unsigned char rtc_control = 0;
    1143                 :          0 :         unsigned char rtc_intr;
    1144                 :          0 :         unsigned long flags;
    1145                 :            : 
    1146                 :            : 
    1147                 :            :         /*
    1148                 :            :          * Always update rtc irq when ACPI is used as RTC Alarm.
    1149                 :            :          * Or else, ACPI SCI is enabled during suspend/resume only,
    1150                 :            :          * update rtc irq in that case.
    1151                 :            :          */
    1152         [ #  # ]:          0 :         if (cmos_use_acpi_alarm())
    1153                 :          0 :                 cmos_interrupt(0, (void *)cmos->rtc);
    1154                 :            :         else {
    1155                 :            :                 /* Fix me: can we use cmos_interrupt() here as well? */
    1156                 :          0 :                 spin_lock_irqsave(&rtc_lock, flags);
    1157         [ #  # ]:          0 :                 if (cmos_rtc.suspend_ctrl)
    1158                 :          0 :                         rtc_control = CMOS_READ(RTC_CONTROL);
    1159         [ #  # ]:          0 :                 if (rtc_control & RTC_AIE) {
    1160                 :          0 :                         cmos_rtc.suspend_ctrl &= ~RTC_AIE;
    1161                 :          0 :                         CMOS_WRITE(rtc_control, RTC_CONTROL);
    1162                 :          0 :                         rtc_intr = CMOS_READ(RTC_INTR_FLAGS);
    1163                 :          0 :                         rtc_update_irq(cmos->rtc, 1, rtc_intr);
    1164                 :            :                 }
    1165                 :          0 :                 spin_unlock_irqrestore(&rtc_lock, flags);
    1166                 :            :         }
    1167                 :            : 
    1168                 :          0 :         pm_wakeup_hard_event(dev);
    1169                 :          0 :         acpi_clear_event(ACPI_EVENT_RTC);
    1170                 :          0 :         acpi_disable_event(ACPI_EVENT_RTC, 0);
    1171                 :          0 :         return ACPI_INTERRUPT_HANDLED;
    1172                 :            : }
    1173                 :            : 
    1174                 :         21 : static inline void rtc_wake_setup(struct device *dev)
    1175                 :            : {
    1176                 :         21 :         acpi_install_fixed_event_handler(ACPI_EVENT_RTC, rtc_handler, dev);
    1177                 :            :         /*
    1178                 :            :          * After the RTC handler is installed, the Fixed_RTC event should
    1179                 :            :          * be disabled. Only when the RTC alarm is set will it be enabled.
    1180                 :            :          */
    1181                 :         21 :         acpi_clear_event(ACPI_EVENT_RTC);
    1182                 :         21 :         acpi_disable_event(ACPI_EVENT_RTC, 0);
    1183                 :         21 : }
    1184                 :            : 
    1185                 :          0 : static void rtc_wake_on(struct device *dev)
    1186                 :            : {
    1187                 :          0 :         acpi_clear_event(ACPI_EVENT_RTC);
    1188                 :          0 :         acpi_enable_event(ACPI_EVENT_RTC, 0);
    1189                 :          0 : }
    1190                 :            : 
    1191                 :          0 : static void rtc_wake_off(struct device *dev)
    1192                 :            : {
    1193                 :          0 :         acpi_disable_event(ACPI_EVENT_RTC, 0);
    1194                 :          0 : }
    1195                 :            : 
    1196                 :            : #ifdef CONFIG_X86
    1197                 :            : /* Enable use_acpi_alarm mode for Intel platforms no earlier than 2015 */
    1198                 :         21 : static void use_acpi_alarm_quirks(void)
    1199                 :            : {
    1200         [ -  + ]:         21 :         if (boot_cpu_data.x86_vendor != X86_VENDOR_INTEL)
    1201                 :            :                 return;
    1202                 :            : 
    1203         [ #  # ]:          0 :         if (!(acpi_gbl_FADT.flags & ACPI_FADT_LOW_POWER_S0))
    1204                 :            :                 return;
    1205                 :            : 
    1206         [ #  # ]:          0 :         if (!is_hpet_enabled())
    1207                 :            :                 return;
    1208                 :            : 
    1209         [ #  # ]:          0 :         if (dmi_get_bios_year() < 2015)
    1210                 :            :                 return;
    1211                 :            : 
    1212                 :          0 :         use_acpi_alarm = true;
    1213                 :            : }
    1214                 :            : #else
    1215                 :            : static inline void use_acpi_alarm_quirks(void) { }
    1216                 :            : #endif
    1217                 :            : 
    1218                 :            : /* Every ACPI platform has a mc146818 compatible "cmos rtc".  Here we find
    1219                 :            :  * its device node and pass extra config data.  This helps its driver use
    1220                 :            :  * capabilities that the now-obsolete mc146818 didn't have, and informs it
    1221                 :            :  * that this board's RTC is wakeup-capable (per ACPI spec).
    1222                 :            :  */
    1223                 :            : static struct cmos_rtc_board_info acpi_rtc_info;
    1224                 :            : 
    1225                 :         21 : static void cmos_wake_setup(struct device *dev)
    1226                 :            : {
    1227         [ +  - ]:         21 :         if (acpi_disabled)
    1228                 :            :                 return;
    1229                 :            : 
    1230                 :         21 :         use_acpi_alarm_quirks();
    1231                 :            : 
    1232                 :         21 :         rtc_wake_setup(dev);
    1233                 :         21 :         acpi_rtc_info.wake_on = rtc_wake_on;
    1234                 :         21 :         acpi_rtc_info.wake_off = rtc_wake_off;
    1235                 :            : 
    1236                 :            :         /* workaround bug in some ACPI tables */
    1237   [ -  +  -  - ]:         21 :         if (acpi_gbl_FADT.month_alarm && !acpi_gbl_FADT.day_alarm) {
    1238                 :          0 :                 dev_dbg(dev, "bogus FADT month_alarm (%d)\n",
    1239                 :            :                         acpi_gbl_FADT.month_alarm);
    1240                 :          0 :                 acpi_gbl_FADT.month_alarm = 0;
    1241                 :            :         }
    1242                 :            : 
    1243                 :         21 :         acpi_rtc_info.rtc_day_alarm = acpi_gbl_FADT.day_alarm;
    1244                 :         21 :         acpi_rtc_info.rtc_mon_alarm = acpi_gbl_FADT.month_alarm;
    1245                 :         21 :         acpi_rtc_info.rtc_century = acpi_gbl_FADT.century;
    1246                 :            : 
    1247                 :            :         /* NOTE:  S4_RTC_WAKE is NOT currently useful to Linux */
    1248         [ +  - ]:         21 :         if (acpi_gbl_FADT.flags & ACPI_FADT_S4_RTC_WAKE)
    1249                 :         21 :                 dev_info(dev, "RTC can wake from S4\n");
    1250                 :            : 
    1251                 :         21 :         dev->platform_data = &acpi_rtc_info;
    1252                 :            : 
    1253                 :            :         /* RTC always wakes from S1/S2/S3, and often S4/STD */
    1254                 :         21 :         device_init_wakeup(dev, 1);
    1255                 :            : }
    1256                 :            : 
    1257                 :          0 : static void cmos_check_acpi_rtc_status(struct device *dev,
    1258                 :            :                                        unsigned char *rtc_control)
    1259                 :            : {
    1260         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
    1261                 :          0 :         acpi_event_status rtc_status;
    1262                 :          0 :         acpi_status status;
    1263                 :            : 
    1264         [ #  # ]:          0 :         if (acpi_gbl_FADT.flags & ACPI_FADT_FIXED_RTC)
    1265                 :          0 :                 return;
    1266                 :            : 
    1267                 :          0 :         status = acpi_get_event_status(ACPI_EVENT_RTC, &rtc_status);
    1268         [ #  # ]:          0 :         if (ACPI_FAILURE(status)) {
    1269                 :          0 :                 dev_err(dev, "Could not get RTC status\n");
    1270         [ #  # ]:          0 :         } else if (rtc_status & ACPI_EVENT_FLAG_SET) {
    1271                 :          0 :                 unsigned char mask;
    1272                 :          0 :                 *rtc_control &= ~RTC_AIE;
    1273                 :          0 :                 CMOS_WRITE(*rtc_control, RTC_CONTROL);
    1274                 :          0 :                 mask = CMOS_READ(RTC_INTR_FLAGS);
    1275                 :          0 :                 rtc_update_irq(cmos->rtc, 1, mask);
    1276                 :            :         }
    1277                 :            : }
    1278                 :            : 
    1279                 :            : #else
    1280                 :            : 
    1281                 :            : static void cmos_wake_setup(struct device *dev)
    1282                 :            : {
    1283                 :            : }
    1284                 :            : 
    1285                 :            : static void cmos_check_acpi_rtc_status(struct device *dev,
    1286                 :            :                                        unsigned char *rtc_control)
    1287                 :            : {
    1288                 :            : }
    1289                 :            : 
    1290                 :            : #endif
    1291                 :            : 
    1292                 :            : #ifdef  CONFIG_PNP
    1293                 :            : 
    1294                 :            : #include <linux/pnp.h>
    1295                 :            : 
    1296                 :         21 : static int cmos_pnp_probe(struct pnp_dev *pnp, const struct pnp_device_id *id)
    1297                 :            : {
    1298                 :         21 :         cmos_wake_setup(&pnp->dev);
    1299                 :            : 
    1300         [ +  - ]:         42 :         if (pnp_port_start(pnp, 0) == 0x70 && !pnp_irq_valid(pnp, 0)) {
    1301                 :          0 :                 unsigned int irq = 0;
    1302                 :            : #ifdef CONFIG_X86
    1303                 :            :                 /* Some machines contain a PNP entry for the RTC, but
    1304                 :            :                  * don't define the IRQ. It should always be safe to
    1305                 :            :                  * hardcode it on systems with a legacy PIC.
    1306                 :            :                  */
    1307         [ #  # ]:          0 :                 if (nr_legacy_irqs())
    1308                 :          0 :                         irq = RTC_IRQ;
    1309                 :            : #endif
    1310                 :          0 :                 return cmos_do_probe(&pnp->dev,
    1311                 :            :                                 pnp_get_resource(pnp, IORESOURCE_IO, 0), irq);
    1312                 :            :         } else {
    1313                 :         42 :                 return cmos_do_probe(&pnp->dev,
    1314                 :            :                                 pnp_get_resource(pnp, IORESOURCE_IO, 0),
    1315                 :            :                                 pnp_irq(pnp, 0));
    1316                 :            :         }
    1317                 :            : }
    1318                 :            : 
    1319                 :          0 : static void cmos_pnp_remove(struct pnp_dev *pnp)
    1320                 :            : {
    1321                 :          0 :         cmos_do_remove(&pnp->dev);
    1322                 :          0 : }
    1323                 :            : 
    1324                 :          0 : static void cmos_pnp_shutdown(struct pnp_dev *pnp)
    1325                 :            : {
    1326                 :          0 :         struct device *dev = &pnp->dev;
    1327         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
    1328                 :            : 
    1329         [ #  # ]:          0 :         if (system_state == SYSTEM_POWER_OFF) {
    1330                 :          0 :                 int retval = cmos_poweroff(dev);
    1331                 :            : 
    1332   [ #  #  #  # ]:          0 :                 if (cmos_aie_poweroff(dev) < 0 && !retval)
    1333                 :            :                         return;
    1334                 :            :         }
    1335                 :            : 
    1336                 :          0 :         cmos_do_shutdown(cmos->irq);
    1337                 :            : }
    1338                 :            : 
    1339                 :            : static const struct pnp_device_id rtc_ids[] = {
    1340                 :            :         { .id = "PNP0b00", },
    1341                 :            :         { .id = "PNP0b01", },
    1342                 :            :         { .id = "PNP0b02", },
    1343                 :            :         { },
    1344                 :            : };
    1345                 :            : MODULE_DEVICE_TABLE(pnp, rtc_ids);
    1346                 :            : 
    1347                 :            : static struct pnp_driver cmos_pnp_driver = {
    1348                 :            :         .name           = (char *) driver_name,
    1349                 :            :         .id_table       = rtc_ids,
    1350                 :            :         .probe          = cmos_pnp_probe,
    1351                 :            :         .remove         = cmos_pnp_remove,
    1352                 :            :         .shutdown       = cmos_pnp_shutdown,
    1353                 :            : 
    1354                 :            :         /* flag ensures resume() gets called, and stops syslog spam */
    1355                 :            :         .flags          = PNP_DRIVER_RES_DO_NOT_CHANGE,
    1356                 :            :         .driver         = {
    1357                 :            :                         .pm = &cmos_pm_ops,
    1358                 :            :         },
    1359                 :            : };
    1360                 :            : 
    1361                 :            : #endif  /* CONFIG_PNP */
    1362                 :            : 
    1363                 :            : #ifdef CONFIG_OF
    1364                 :            : static const struct of_device_id of_cmos_match[] = {
    1365                 :            :         {
    1366                 :            :                 .compatible = "motorola,mc146818",
    1367                 :            :         },
    1368                 :            :         { },
    1369                 :            : };
    1370                 :            : MODULE_DEVICE_TABLE(of, of_cmos_match);
    1371                 :            : 
    1372                 :            : static __init void cmos_of_init(struct platform_device *pdev)
    1373                 :            : {
    1374                 :            :         struct device_node *node = pdev->dev.of_node;
    1375                 :            :         const __be32 *val;
    1376                 :            : 
    1377                 :            :         if (!node)
    1378                 :            :                 return;
    1379                 :            : 
    1380                 :            :         val = of_get_property(node, "ctrl-reg", NULL);
    1381                 :            :         if (val)
    1382                 :            :                 CMOS_WRITE(be32_to_cpup(val), RTC_CONTROL);
    1383                 :            : 
    1384                 :            :         val = of_get_property(node, "freq-reg", NULL);
    1385                 :            :         if (val)
    1386                 :            :                 CMOS_WRITE(be32_to_cpup(val), RTC_FREQ_SELECT);
    1387                 :            : }
    1388                 :            : #else
    1389                 :          0 : static inline void cmos_of_init(struct platform_device *pdev) {}
    1390                 :            : #endif
    1391                 :            : /*----------------------------------------------------------------*/
    1392                 :            : 
    1393                 :            : /* Platform setup should have set up an RTC device, when PNP is
    1394                 :            :  * unavailable ... this could happen even on (older) PCs.
    1395                 :            :  */
    1396                 :            : 
    1397                 :          0 : static int __init cmos_platform_probe(struct platform_device *pdev)
    1398                 :            : {
    1399                 :          0 :         struct resource *resource;
    1400                 :          0 :         int irq;
    1401                 :            : 
    1402                 :          0 :         cmos_of_init(pdev);
    1403                 :          0 :         cmos_wake_setup(&pdev->dev);
    1404                 :            : 
    1405                 :          0 :         if (RTC_IOMAPPED)
    1406                 :          0 :                 resource = platform_get_resource(pdev, IORESOURCE_IO, 0);
    1407                 :            :         else
    1408                 :            :                 resource = platform_get_resource(pdev, IORESOURCE_MEM, 0);
    1409                 :          0 :         irq = platform_get_irq(pdev, 0);
    1410                 :          0 :         if (irq < 0)
    1411                 :            :                 irq = -1;
    1412                 :            : 
    1413                 :          0 :         return cmos_do_probe(&pdev->dev, resource, irq);
    1414                 :            : }
    1415                 :            : 
    1416                 :          0 : static int cmos_platform_remove(struct platform_device *pdev)
    1417                 :            : {
    1418                 :          0 :         cmos_do_remove(&pdev->dev);
    1419                 :          0 :         return 0;
    1420                 :            : }
    1421                 :            : 
    1422                 :          0 : static void cmos_platform_shutdown(struct platform_device *pdev)
    1423                 :            : {
    1424                 :          0 :         struct device *dev = &pdev->dev;
    1425         [ #  # ]:          0 :         struct cmos_rtc *cmos = dev_get_drvdata(dev);
    1426                 :            : 
    1427         [ #  # ]:          0 :         if (system_state == SYSTEM_POWER_OFF) {
    1428                 :          0 :                 int retval = cmos_poweroff(dev);
    1429                 :            : 
    1430   [ #  #  #  # ]:          0 :                 if (cmos_aie_poweroff(dev) < 0 && !retval)
    1431                 :            :                         return;
    1432                 :            :         }
    1433                 :            : 
    1434                 :          0 :         cmos_do_shutdown(cmos->irq);
    1435                 :            : }
    1436                 :            : 
    1437                 :            : /* work with hotplug and coldplug */
    1438                 :            : MODULE_ALIAS("platform:rtc_cmos");
    1439                 :            : 
    1440                 :            : static struct platform_driver cmos_platform_driver = {
    1441                 :            :         .remove         = cmos_platform_remove,
    1442                 :            :         .shutdown       = cmos_platform_shutdown,
    1443                 :            :         .driver = {
    1444                 :            :                 .name           = driver_name,
    1445                 :            :                 .pm             = &cmos_pm_ops,
    1446                 :            :                 .of_match_table = of_match_ptr(of_cmos_match),
    1447                 :            :         }
    1448                 :            : };
    1449                 :            : 
    1450                 :            : #ifdef CONFIG_PNP
    1451                 :            : static bool pnp_driver_registered;
    1452                 :            : #endif
    1453                 :            : static bool platform_driver_registered;
    1454                 :            : 
    1455                 :         21 : static int __init cmos_init(void)
    1456                 :            : {
    1457                 :         21 :         int retval = 0;
    1458                 :            : 
    1459                 :            : #ifdef  CONFIG_PNP
    1460                 :         21 :         retval = pnp_register_driver(&cmos_pnp_driver);
    1461         [ +  - ]:         21 :         if (retval == 0)
    1462                 :         21 :                 pnp_driver_registered = true;
    1463                 :            : #endif
    1464                 :            : 
    1465         [ -  + ]:         21 :         if (!cmos_rtc.dev) {
    1466                 :          0 :                 retval = platform_driver_probe(&cmos_platform_driver,
    1467                 :            :                                                cmos_platform_probe);
    1468         [ #  # ]:          0 :                 if (retval == 0)
    1469                 :          0 :                         platform_driver_registered = true;
    1470                 :            :         }
    1471                 :            : 
    1472         [ -  + ]:         21 :         if (retval == 0)
    1473                 :            :                 return 0;
    1474                 :            : 
    1475                 :            : #ifdef  CONFIG_PNP
    1476         [ #  # ]:          0 :         if (pnp_driver_registered)
    1477                 :          0 :                 pnp_unregister_driver(&cmos_pnp_driver);
    1478                 :            : #endif
    1479                 :            :         return retval;
    1480                 :            : }
    1481                 :            : module_init(cmos_init);
    1482                 :            : 
    1483                 :          0 : static void __exit cmos_exit(void)
    1484                 :            : {
    1485                 :            : #ifdef  CONFIG_PNP
    1486         [ #  # ]:          0 :         if (pnp_driver_registered)
    1487                 :          0 :                 pnp_unregister_driver(&cmos_pnp_driver);
    1488                 :            : #endif
    1489         [ #  # ]:          0 :         if (platform_driver_registered)
    1490                 :          0 :                 platform_driver_unregister(&cmos_platform_driver);
    1491                 :          0 : }
    1492                 :            : module_exit(cmos_exit);
    1493                 :            : 
    1494                 :            : 
    1495                 :            : MODULE_AUTHOR("David Brownell");
    1496                 :            : MODULE_DESCRIPTION("Driver for PC-style 'CMOS' RTCs");
    1497                 :            : MODULE_LICENSE("GPL");

Generated by: LCOV version 1.14