LCOV - code coverage report
Current view: top level - drivers/base/power - sysfs.c (source / functions) Hit Total Coverage
Test: coverage.info Lines: 27 241 11.2 %
Date: 2023-07-19 18:55:55 Functions: 5 35 14.3 %

          Line data    Source code
       1             : // SPDX-License-Identifier: GPL-2.0
       2             : /* sysfs entries for device PM */
       3             : #include <linux/device.h>
       4             : #include <linux/kobject.h>
       5             : #include <linux/string.h>
       6             : #include <linux/export.h>
       7             : #include <linux/pm_qos.h>
       8             : #include <linux/pm_runtime.h>
       9             : #include <linux/pm_wakeup.h>
      10             : #include <linux/atomic.h>
      11             : #include <linux/jiffies.h>
      12             : #include "power.h"
      13             : 
      14             : /*
      15             :  *      control - Report/change current runtime PM setting of the device
      16             :  *
      17             :  *      Runtime power management of a device can be blocked with the help of
      18             :  *      this attribute.  All devices have one of the following two values for
      19             :  *      the power/control file:
      20             :  *
      21             :  *       + "auto\n" to allow the device to be power managed at run time;
      22             :  *       + "on\n" to prevent the device from being power managed at run time;
      23             :  *
      24             :  *      The default for all devices is "auto", which means that devices may be
      25             :  *      subject to automatic power management, depending on their drivers.
      26             :  *      Changing this attribute to "on" prevents the driver from power managing
      27             :  *      the device at run time.  Doing that while the device is suspended causes
      28             :  *      it to be woken up.
      29             :  *
      30             :  *      wakeup - Report/change current wakeup option for device
      31             :  *
      32             :  *      Some devices support "wakeup" events, which are hardware signals
      33             :  *      used to activate devices from suspended or low power states.  Such
      34             :  *      devices have one of three values for the sysfs power/wakeup file:
      35             :  *
      36             :  *       + "enabled\n" to issue the events;
      37             :  *       + "disabled\n" not to do so; or
      38             :  *       + "\n" for temporary or permanent inability to issue wakeup.
      39             :  *
      40             :  *      (For example, unconfigured USB devices can't issue wakeups.)
      41             :  *
      42             :  *      Familiar examples of devices that can issue wakeup events include
      43             :  *      keyboards and mice (both PS2 and USB styles), power buttons, modems,
      44             :  *      "Wake-On-LAN" Ethernet links, GPIO lines, and more.  Some events
      45             :  *      will wake the entire system from a suspend state; others may just
      46             :  *      wake up the device (if the system as a whole is already active).
      47             :  *      Some wakeup events use normal IRQ lines; other use special out
      48             :  *      of band signaling.
      49             :  *
      50             :  *      It is the responsibility of device drivers to enable (or disable)
      51             :  *      wakeup signaling as part of changing device power states, respecting
      52             :  *      the policy choices provided through the driver model.
      53             :  *
      54             :  *      Devices may not be able to generate wakeup events from all power
      55             :  *      states.  Also, the events may be ignored in some configurations;
      56             :  *      for example, they might need help from other devices that aren't
      57             :  *      active, or which may have wakeup disabled.  Some drivers rely on
      58             :  *      wakeup events internally (unless they are disabled), keeping
      59             :  *      their hardware in low power modes whenever they're unused.  This
      60             :  *      saves runtime power, without requiring system-wide sleep states.
      61             :  *
      62             :  *      async - Report/change current async suspend setting for the device
      63             :  *
      64             :  *      Asynchronous suspend and resume of the device during system-wide power
      65             :  *      state transitions can be enabled by writing "enabled" to this file.
      66             :  *      Analogously, if "disabled" is written to this file, the device will be
      67             :  *      suspended and resumed synchronously.
      68             :  *
      69             :  *      All devices have one of the following two values for power/async:
      70             :  *
      71             :  *       + "enabled\n" to permit the asynchronous suspend/resume of the device;
      72             :  *       + "disabled\n" to forbid it;
      73             :  *
      74             :  *      NOTE: It generally is unsafe to permit the asynchronous suspend/resume
      75             :  *      of a device unless it is certain that all of the PM dependencies of the
      76             :  *      device are known to the PM core.  However, for some devices this
      77             :  *      attribute is set to "enabled" by bus type code or device drivers and in
      78             :  *      that cases it should be safe to leave the default value.
      79             :  *
      80             :  *      autosuspend_delay_ms - Report/change a device's autosuspend_delay value
      81             :  *
      82             :  *      Some drivers don't want to carry out a runtime suspend as soon as a
      83             :  *      device becomes idle; they want it always to remain idle for some period
      84             :  *      of time before suspending it.  This period is the autosuspend_delay
      85             :  *      value (expressed in milliseconds) and it can be controlled by the user.
      86             :  *      If the value is negative then the device will never be runtime
      87             :  *      suspended.
      88             :  *
      89             :  *      NOTE: The autosuspend_delay_ms attribute and the autosuspend_delay
      90             :  *      value are used only if the driver calls pm_runtime_use_autosuspend().
      91             :  *
      92             :  *      wakeup_count - Report the number of wakeup events related to the device
      93             :  */
      94             : 
      95             : const char power_group_name[] = "power";
      96             : EXPORT_SYMBOL_GPL(power_group_name);
      97             : 
      98             : static const char ctrl_auto[] = "auto";
      99             : static const char ctrl_on[] = "on";
     100             : 
     101           0 : static ssize_t control_show(struct device *dev, struct device_attribute *attr,
     102             :                             char *buf)
     103             : {
     104           0 :         return sysfs_emit(buf, "%s\n",
     105           0 :                           dev->power.runtime_auto ? ctrl_auto : ctrl_on);
     106             : }
     107             : 
     108           0 : static ssize_t control_store(struct device * dev, struct device_attribute *attr,
     109             :                              const char * buf, size_t n)
     110             : {
     111           0 :         device_lock(dev);
     112           0 :         if (sysfs_streq(buf, ctrl_auto))
     113           0 :                 pm_runtime_allow(dev);
     114           0 :         else if (sysfs_streq(buf, ctrl_on))
     115           0 :                 pm_runtime_forbid(dev);
     116             :         else
     117             :                 n = -EINVAL;
     118           0 :         device_unlock(dev);
     119           0 :         return n;
     120             : }
     121             : 
     122             : static DEVICE_ATTR_RW(control);
     123             : 
     124           0 : static ssize_t runtime_active_time_show(struct device *dev,
     125             :                                         struct device_attribute *attr,
     126             :                                         char *buf)
     127             : {
     128           0 :         u64 tmp = pm_runtime_active_time(dev);
     129             : 
     130           0 :         do_div(tmp, NSEC_PER_MSEC);
     131             : 
     132           0 :         return sysfs_emit(buf, "%llu\n", tmp);
     133             : }
     134             : 
     135             : static DEVICE_ATTR_RO(runtime_active_time);
     136             : 
     137           0 : static ssize_t runtime_suspended_time_show(struct device *dev,
     138             :                                            struct device_attribute *attr,
     139             :                                            char *buf)
     140             : {
     141           0 :         u64 tmp = pm_runtime_suspended_time(dev);
     142             : 
     143           0 :         do_div(tmp, NSEC_PER_MSEC);
     144             : 
     145           0 :         return sysfs_emit(buf, "%llu\n", tmp);
     146             : }
     147             : 
     148             : static DEVICE_ATTR_RO(runtime_suspended_time);
     149             : 
     150           0 : static ssize_t runtime_status_show(struct device *dev,
     151             :                                    struct device_attribute *attr, char *buf)
     152             : {
     153             :         const char *output;
     154             : 
     155           0 :         if (dev->power.runtime_error) {
     156             :                 output = "error";
     157           0 :         } else if (dev->power.disable_depth) {
     158             :                 output = "unsupported";
     159             :         } else {
     160           0 :                 switch (dev->power.runtime_status) {
     161             :                 case RPM_SUSPENDED:
     162             :                         output = "suspended";
     163             :                         break;
     164             :                 case RPM_SUSPENDING:
     165           0 :                         output = "suspending";
     166           0 :                         break;
     167             :                 case RPM_RESUMING:
     168           0 :                         output = "resuming";
     169           0 :                         break;
     170             :                 case RPM_ACTIVE:
     171           0 :                         output = "active";
     172           0 :                         break;
     173             :                 default:
     174             :                         return -EIO;
     175             :                 }
     176             :         }
     177           0 :         return sysfs_emit(buf, "%s\n", output);
     178             : }
     179             : 
     180             : static DEVICE_ATTR_RO(runtime_status);
     181             : 
     182           0 : static ssize_t autosuspend_delay_ms_show(struct device *dev,
     183             :                                          struct device_attribute *attr,
     184             :                                          char *buf)
     185             : {
     186           0 :         if (!dev->power.use_autosuspend)
     187             :                 return -EIO;
     188             : 
     189           0 :         return sysfs_emit(buf, "%d\n", dev->power.autosuspend_delay);
     190             : }
     191             : 
     192           0 : static ssize_t autosuspend_delay_ms_store(struct device *dev,
     193             :                 struct device_attribute *attr, const char *buf, size_t n)
     194             : {
     195             :         long delay;
     196             : 
     197           0 :         if (!dev->power.use_autosuspend)
     198             :                 return -EIO;
     199             : 
     200           0 :         if (kstrtol(buf, 10, &delay) != 0 || delay != (int) delay)
     201             :                 return -EINVAL;
     202             : 
     203           0 :         device_lock(dev);
     204           0 :         pm_runtime_set_autosuspend_delay(dev, delay);
     205           0 :         device_unlock(dev);
     206           0 :         return n;
     207             : }
     208             : 
     209             : static DEVICE_ATTR_RW(autosuspend_delay_ms);
     210             : 
     211           0 : static ssize_t pm_qos_resume_latency_us_show(struct device *dev,
     212             :                                              struct device_attribute *attr,
     213             :                                              char *buf)
     214             : {
     215           0 :         s32 value = dev_pm_qos_requested_resume_latency(dev);
     216             : 
     217           0 :         if (value == 0)
     218           0 :                 return sysfs_emit(buf, "n/a\n");
     219           0 :         if (value == PM_QOS_RESUME_LATENCY_NO_CONSTRAINT)
     220           0 :                 value = 0;
     221             : 
     222           0 :         return sysfs_emit(buf, "%d\n", value);
     223             : }
     224             : 
     225           0 : static ssize_t pm_qos_resume_latency_us_store(struct device *dev,
     226             :                                               struct device_attribute *attr,
     227             :                                               const char *buf, size_t n)
     228             : {
     229             :         s32 value;
     230             :         int ret;
     231             : 
     232           0 :         if (!kstrtos32(buf, 0, &value)) {
     233             :                 /*
     234             :                  * Prevent users from writing negative or "no constraint" values
     235             :                  * directly.
     236             :                  */
     237           0 :                 if (value < 0 || value == PM_QOS_RESUME_LATENCY_NO_CONSTRAINT)
     238             :                         return -EINVAL;
     239             : 
     240           0 :                 if (value == 0)
     241           0 :                         value = PM_QOS_RESUME_LATENCY_NO_CONSTRAINT;
     242           0 :         } else if (sysfs_streq(buf, "n/a")) {
     243           0 :                 value = 0;
     244             :         } else {
     245             :                 return -EINVAL;
     246             :         }
     247             : 
     248           0 :         ret = dev_pm_qos_update_request(dev->power.qos->resume_latency_req,
     249             :                                         value);
     250           0 :         return ret < 0 ? ret : n;
     251             : }
     252             : 
     253             : static DEVICE_ATTR_RW(pm_qos_resume_latency_us);
     254             : 
     255           0 : static ssize_t pm_qos_latency_tolerance_us_show(struct device *dev,
     256             :                                                 struct device_attribute *attr,
     257             :                                                 char *buf)
     258             : {
     259           0 :         s32 value = dev_pm_qos_get_user_latency_tolerance(dev);
     260             : 
     261           0 :         if (value < 0)
     262           0 :                 return sysfs_emit(buf, "%s\n", "auto");
     263           0 :         if (value == PM_QOS_LATENCY_ANY)
     264           0 :                 return sysfs_emit(buf, "%s\n", "any");
     265             : 
     266           0 :         return sysfs_emit(buf, "%d\n", value);
     267             : }
     268             : 
     269           0 : static ssize_t pm_qos_latency_tolerance_us_store(struct device *dev,
     270             :                                                  struct device_attribute *attr,
     271             :                                                  const char *buf, size_t n)
     272             : {
     273             :         s32 value;
     274             :         int ret;
     275             : 
     276           0 :         if (kstrtos32(buf, 0, &value) == 0) {
     277             :                 /* Users can't write negative values directly */
     278           0 :                 if (value < 0)
     279             :                         return -EINVAL;
     280             :         } else {
     281           0 :                 if (sysfs_streq(buf, "auto"))
     282           0 :                         value = PM_QOS_LATENCY_TOLERANCE_NO_CONSTRAINT;
     283           0 :                 else if (sysfs_streq(buf, "any"))
     284           0 :                         value = PM_QOS_LATENCY_ANY;
     285             :                 else
     286             :                         return -EINVAL;
     287             :         }
     288           0 :         ret = dev_pm_qos_update_user_latency_tolerance(dev, value);
     289           0 :         return ret < 0 ? ret : n;
     290             : }
     291             : 
     292             : static DEVICE_ATTR_RW(pm_qos_latency_tolerance_us);
     293             : 
     294           0 : static ssize_t pm_qos_no_power_off_show(struct device *dev,
     295             :                                         struct device_attribute *attr,
     296             :                                         char *buf)
     297             : {
     298           0 :         return sysfs_emit(buf, "%d\n", !!(dev_pm_qos_requested_flags(dev)
     299           0 :                                           & PM_QOS_FLAG_NO_POWER_OFF));
     300             : }
     301             : 
     302           0 : static ssize_t pm_qos_no_power_off_store(struct device *dev,
     303             :                                          struct device_attribute *attr,
     304             :                                          const char *buf, size_t n)
     305             : {
     306             :         int ret;
     307             : 
     308           0 :         if (kstrtoint(buf, 0, &ret))
     309             :                 return -EINVAL;
     310             : 
     311           0 :         if (ret != 0 && ret != 1)
     312             :                 return -EINVAL;
     313             : 
     314           0 :         ret = dev_pm_qos_update_flags(dev, PM_QOS_FLAG_NO_POWER_OFF, ret);
     315           0 :         return ret < 0 ? ret : n;
     316             : }
     317             : 
     318             : static DEVICE_ATTR_RW(pm_qos_no_power_off);
     319             : 
     320             : #ifdef CONFIG_PM_SLEEP
     321             : static const char _enabled[] = "enabled";
     322             : static const char _disabled[] = "disabled";
     323             : 
     324           0 : static ssize_t wakeup_show(struct device *dev, struct device_attribute *attr,
     325             :                            char *buf)
     326             : {
     327           0 :         return sysfs_emit(buf, "%s\n", device_can_wakeup(dev)
     328           0 :                           ? (device_may_wakeup(dev) ? _enabled : _disabled)
     329             :                           : "");
     330             : }
     331             : 
     332           0 : static ssize_t wakeup_store(struct device *dev, struct device_attribute *attr,
     333             :                             const char *buf, size_t n)
     334             : {
     335           0 :         if (!device_can_wakeup(dev))
     336             :                 return -EINVAL;
     337             : 
     338           0 :         if (sysfs_streq(buf, _enabled))
     339           0 :                 device_set_wakeup_enable(dev, 1);
     340           0 :         else if (sysfs_streq(buf, _disabled))
     341           0 :                 device_set_wakeup_enable(dev, 0);
     342             :         else
     343             :                 return -EINVAL;
     344           0 :         return n;
     345             : }
     346             : 
     347             : static DEVICE_ATTR_RW(wakeup);
     348             : 
     349           0 : static ssize_t wakeup_count_show(struct device *dev,
     350             :                                  struct device_attribute *attr, char *buf)
     351             : {
     352             :         unsigned long count;
     353           0 :         bool enabled = false;
     354             : 
     355           0 :         spin_lock_irq(&dev->power.lock);
     356           0 :         if (dev->power.wakeup) {
     357           0 :                 count = dev->power.wakeup->wakeup_count;
     358           0 :                 enabled = true;
     359             :         }
     360           0 :         spin_unlock_irq(&dev->power.lock);
     361             : 
     362           0 :         if (!enabled)
     363           0 :                 return sysfs_emit(buf, "\n");
     364           0 :         return sysfs_emit(buf, "%lu\n", count);
     365             : }
     366             : 
     367             : static DEVICE_ATTR_RO(wakeup_count);
     368             : 
     369           0 : static ssize_t wakeup_active_count_show(struct device *dev,
     370             :                                         struct device_attribute *attr,
     371             :                                         char *buf)
     372             : {
     373             :         unsigned long count;
     374           0 :         bool enabled = false;
     375             : 
     376           0 :         spin_lock_irq(&dev->power.lock);
     377           0 :         if (dev->power.wakeup) {
     378           0 :                 count = dev->power.wakeup->active_count;
     379           0 :                 enabled = true;
     380             :         }
     381           0 :         spin_unlock_irq(&dev->power.lock);
     382             : 
     383           0 :         if (!enabled)
     384           0 :                 return sysfs_emit(buf, "\n");
     385           0 :         return sysfs_emit(buf, "%lu\n", count);
     386             : }
     387             : 
     388             : static DEVICE_ATTR_RO(wakeup_active_count);
     389             : 
     390           0 : static ssize_t wakeup_abort_count_show(struct device *dev,
     391             :                                        struct device_attribute *attr,
     392             :                                        char *buf)
     393             : {
     394             :         unsigned long count;
     395           0 :         bool enabled = false;
     396             : 
     397           0 :         spin_lock_irq(&dev->power.lock);
     398           0 :         if (dev->power.wakeup) {
     399           0 :                 count = dev->power.wakeup->wakeup_count;
     400           0 :                 enabled = true;
     401             :         }
     402           0 :         spin_unlock_irq(&dev->power.lock);
     403             : 
     404           0 :         if (!enabled)
     405           0 :                 return sysfs_emit(buf, "\n");
     406           0 :         return sysfs_emit(buf, "%lu\n", count);
     407             : }
     408             : 
     409             : static DEVICE_ATTR_RO(wakeup_abort_count);
     410             : 
     411           0 : static ssize_t wakeup_expire_count_show(struct device *dev,
     412             :                                         struct device_attribute *attr,
     413             :                                         char *buf)
     414             : {
     415             :         unsigned long count;
     416           0 :         bool enabled = false;
     417             : 
     418           0 :         spin_lock_irq(&dev->power.lock);
     419           0 :         if (dev->power.wakeup) {
     420           0 :                 count = dev->power.wakeup->expire_count;
     421           0 :                 enabled = true;
     422             :         }
     423           0 :         spin_unlock_irq(&dev->power.lock);
     424             : 
     425           0 :         if (!enabled)
     426           0 :                 return sysfs_emit(buf, "\n");
     427           0 :         return sysfs_emit(buf, "%lu\n", count);
     428             : }
     429             : 
     430             : static DEVICE_ATTR_RO(wakeup_expire_count);
     431             : 
     432           0 : static ssize_t wakeup_active_show(struct device *dev,
     433             :                                   struct device_attribute *attr, char *buf)
     434             : {
     435             :         unsigned int active;
     436           0 :         bool enabled = false;
     437             : 
     438           0 :         spin_lock_irq(&dev->power.lock);
     439           0 :         if (dev->power.wakeup) {
     440           0 :                 active = dev->power.wakeup->active;
     441           0 :                 enabled = true;
     442             :         }
     443           0 :         spin_unlock_irq(&dev->power.lock);
     444             : 
     445           0 :         if (!enabled)
     446           0 :                 return sysfs_emit(buf, "\n");
     447           0 :         return sysfs_emit(buf, "%u\n", active);
     448             : }
     449             : 
     450             : static DEVICE_ATTR_RO(wakeup_active);
     451             : 
     452           0 : static ssize_t wakeup_total_time_ms_show(struct device *dev,
     453             :                                          struct device_attribute *attr,
     454             :                                          char *buf)
     455             : {
     456             :         s64 msec;
     457           0 :         bool enabled = false;
     458             : 
     459           0 :         spin_lock_irq(&dev->power.lock);
     460           0 :         if (dev->power.wakeup) {
     461           0 :                 msec = ktime_to_ms(dev->power.wakeup->total_time);
     462           0 :                 enabled = true;
     463             :         }
     464           0 :         spin_unlock_irq(&dev->power.lock);
     465             : 
     466           0 :         if (!enabled)
     467           0 :                 return sysfs_emit(buf, "\n");
     468           0 :         return sysfs_emit(buf, "%lld\n", msec);
     469             : }
     470             : 
     471             : static DEVICE_ATTR_RO(wakeup_total_time_ms);
     472             : 
     473           0 : static ssize_t wakeup_max_time_ms_show(struct device *dev,
     474             :                                        struct device_attribute *attr, char *buf)
     475             : {
     476             :         s64 msec;
     477           0 :         bool enabled = false;
     478             : 
     479           0 :         spin_lock_irq(&dev->power.lock);
     480           0 :         if (dev->power.wakeup) {
     481           0 :                 msec = ktime_to_ms(dev->power.wakeup->max_time);
     482           0 :                 enabled = true;
     483             :         }
     484           0 :         spin_unlock_irq(&dev->power.lock);
     485             : 
     486           0 :         if (!enabled)
     487           0 :                 return sysfs_emit(buf, "\n");
     488           0 :         return sysfs_emit(buf, "%lld\n", msec);
     489             : }
     490             : 
     491             : static DEVICE_ATTR_RO(wakeup_max_time_ms);
     492             : 
     493           0 : static ssize_t wakeup_last_time_ms_show(struct device *dev,
     494             :                                         struct device_attribute *attr,
     495             :                                         char *buf)
     496             : {
     497             :         s64 msec;
     498           0 :         bool enabled = false;
     499             : 
     500           0 :         spin_lock_irq(&dev->power.lock);
     501           0 :         if (dev->power.wakeup) {
     502           0 :                 msec = ktime_to_ms(dev->power.wakeup->last_time);
     503           0 :                 enabled = true;
     504             :         }
     505           0 :         spin_unlock_irq(&dev->power.lock);
     506             : 
     507           0 :         if (!enabled)
     508           0 :                 return sysfs_emit(buf, "\n");
     509           0 :         return sysfs_emit(buf, "%lld\n", msec);
     510             : }
     511             : 
     512             : static inline int dpm_sysfs_wakeup_change_owner(struct device *dev, kuid_t kuid,
     513             :                                                 kgid_t kgid)
     514             : {
     515           0 :         if (dev->power.wakeup && dev->power.wakeup->dev)
     516           0 :                 return device_change_owner(dev->power.wakeup->dev, kuid, kgid);
     517             :         return 0;
     518             : }
     519             : 
     520             : static DEVICE_ATTR_RO(wakeup_last_time_ms);
     521             : 
     522             : #ifdef CONFIG_PM_AUTOSLEEP
     523             : static ssize_t wakeup_prevent_sleep_time_ms_show(struct device *dev,
     524             :                                                  struct device_attribute *attr,
     525             :                                                  char *buf)
     526             : {
     527             :         s64 msec;
     528             :         bool enabled = false;
     529             : 
     530             :         spin_lock_irq(&dev->power.lock);
     531             :         if (dev->power.wakeup) {
     532             :                 msec = ktime_to_ms(dev->power.wakeup->prevent_sleep_time);
     533             :                 enabled = true;
     534             :         }
     535             :         spin_unlock_irq(&dev->power.lock);
     536             : 
     537             :         if (!enabled)
     538             :                 return sysfs_emit(buf, "\n");
     539             :         return sysfs_emit(buf, "%lld\n", msec);
     540             : }
     541             : 
     542             : static DEVICE_ATTR_RO(wakeup_prevent_sleep_time_ms);
     543             : #endif /* CONFIG_PM_AUTOSLEEP */
     544             : #else /* CONFIG_PM_SLEEP */
     545             : static inline int dpm_sysfs_wakeup_change_owner(struct device *dev, kuid_t kuid,
     546             :                                                 kgid_t kgid)
     547             : {
     548             :         return 0;
     549             : }
     550             : #endif
     551             : 
     552             : #ifdef CONFIG_PM_ADVANCED_DEBUG
     553             : static ssize_t runtime_usage_show(struct device *dev,
     554             :                                   struct device_attribute *attr, char *buf)
     555             : {
     556             :         return sysfs_emit(buf, "%d\n", atomic_read(&dev->power.usage_count));
     557             : }
     558             : static DEVICE_ATTR_RO(runtime_usage);
     559             : 
     560             : static ssize_t runtime_active_kids_show(struct device *dev,
     561             :                                         struct device_attribute *attr,
     562             :                                         char *buf)
     563             : {
     564             :         return sysfs_emit(buf, "%d\n", dev->power.ignore_children ?
     565             :                           0 : atomic_read(&dev->power.child_count));
     566             : }
     567             : static DEVICE_ATTR_RO(runtime_active_kids);
     568             : 
     569             : static ssize_t runtime_enabled_show(struct device *dev,
     570             :                                     struct device_attribute *attr, char *buf)
     571             : {
     572             :         const char *output;
     573             : 
     574             :         if (dev->power.disable_depth && !dev->power.runtime_auto)
     575             :                 output = "disabled & forbidden";
     576             :         else if (dev->power.disable_depth)
     577             :                 output = "disabled";
     578             :         else if (!dev->power.runtime_auto)
     579             :                 output = "forbidden";
     580             :         else
     581             :                 output = "enabled";
     582             : 
     583             :         return sysfs_emit(buf, "%s\n", output);
     584             : }
     585             : static DEVICE_ATTR_RO(runtime_enabled);
     586             : 
     587             : #ifdef CONFIG_PM_SLEEP
     588             : static ssize_t async_show(struct device *dev, struct device_attribute *attr,
     589             :                           char *buf)
     590             : {
     591             :         return sysfs_emit(buf, "%s\n",
     592             :                           device_async_suspend_enabled(dev) ?
     593             :                           _enabled : _disabled);
     594             : }
     595             : 
     596             : static ssize_t async_store(struct device *dev, struct device_attribute *attr,
     597             :                            const char *buf, size_t n)
     598             : {
     599             :         if (sysfs_streq(buf, _enabled))
     600             :                 device_enable_async_suspend(dev);
     601             :         else if (sysfs_streq(buf, _disabled))
     602             :                 device_disable_async_suspend(dev);
     603             :         else
     604             :                 return -EINVAL;
     605             :         return n;
     606             : }
     607             : 
     608             : static DEVICE_ATTR_RW(async);
     609             : 
     610             : #endif /* CONFIG_PM_SLEEP */
     611             : #endif /* CONFIG_PM_ADVANCED_DEBUG */
     612             : 
     613             : static struct attribute *power_attrs[] = {
     614             : #ifdef CONFIG_PM_ADVANCED_DEBUG
     615             : #ifdef CONFIG_PM_SLEEP
     616             :         &dev_attr_async.attr,
     617             : #endif
     618             :         &dev_attr_runtime_status.attr,
     619             :         &dev_attr_runtime_usage.attr,
     620             :         &dev_attr_runtime_active_kids.attr,
     621             :         &dev_attr_runtime_enabled.attr,
     622             : #endif /* CONFIG_PM_ADVANCED_DEBUG */
     623             :         NULL,
     624             : };
     625             : static const struct attribute_group pm_attr_group = {
     626             :         .name   = power_group_name,
     627             :         .attrs  = power_attrs,
     628             : };
     629             : 
     630             : static struct attribute *wakeup_attrs[] = {
     631             : #ifdef CONFIG_PM_SLEEP
     632             :         &dev_attr_wakeup.attr,
     633             :         &dev_attr_wakeup_count.attr,
     634             :         &dev_attr_wakeup_active_count.attr,
     635             :         &dev_attr_wakeup_abort_count.attr,
     636             :         &dev_attr_wakeup_expire_count.attr,
     637             :         &dev_attr_wakeup_active.attr,
     638             :         &dev_attr_wakeup_total_time_ms.attr,
     639             :         &dev_attr_wakeup_max_time_ms.attr,
     640             :         &dev_attr_wakeup_last_time_ms.attr,
     641             : #ifdef CONFIG_PM_AUTOSLEEP
     642             :         &dev_attr_wakeup_prevent_sleep_time_ms.attr,
     643             : #endif
     644             : #endif
     645             :         NULL,
     646             : };
     647             : static const struct attribute_group pm_wakeup_attr_group = {
     648             :         .name   = power_group_name,
     649             :         .attrs  = wakeup_attrs,
     650             : };
     651             : 
     652             : static struct attribute *runtime_attrs[] = {
     653             : #ifndef CONFIG_PM_ADVANCED_DEBUG
     654             :         &dev_attr_runtime_status.attr,
     655             : #endif
     656             :         &dev_attr_control.attr,
     657             :         &dev_attr_runtime_suspended_time.attr,
     658             :         &dev_attr_runtime_active_time.attr,
     659             :         &dev_attr_autosuspend_delay_ms.attr,
     660             :         NULL,
     661             : };
     662             : static const struct attribute_group pm_runtime_attr_group = {
     663             :         .name   = power_group_name,
     664             :         .attrs  = runtime_attrs,
     665             : };
     666             : 
     667             : static struct attribute *pm_qos_resume_latency_attrs[] = {
     668             :         &dev_attr_pm_qos_resume_latency_us.attr,
     669             :         NULL,
     670             : };
     671             : static const struct attribute_group pm_qos_resume_latency_attr_group = {
     672             :         .name   = power_group_name,
     673             :         .attrs  = pm_qos_resume_latency_attrs,
     674             : };
     675             : 
     676             : static struct attribute *pm_qos_latency_tolerance_attrs[] = {
     677             :         &dev_attr_pm_qos_latency_tolerance_us.attr,
     678             :         NULL,
     679             : };
     680             : static const struct attribute_group pm_qos_latency_tolerance_attr_group = {
     681             :         .name   = power_group_name,
     682             :         .attrs  = pm_qos_latency_tolerance_attrs,
     683             : };
     684             : 
     685             : static struct attribute *pm_qos_flags_attrs[] = {
     686             :         &dev_attr_pm_qos_no_power_off.attr,
     687             :         NULL,
     688             : };
     689             : static const struct attribute_group pm_qos_flags_attr_group = {
     690             :         .name   = power_group_name,
     691             :         .attrs  = pm_qos_flags_attrs,
     692             : };
     693             : 
     694         559 : int dpm_sysfs_add(struct device *dev)
     695             : {
     696             :         int rc;
     697             : 
     698             :         /* No need to create PM sysfs if explicitly disabled. */
     699         559 :         if (device_pm_not_required(dev))
     700             :                 return 0;
     701             : 
     702         559 :         rc = sysfs_create_group(&dev->kobj, &pm_attr_group);
     703         559 :         if (rc)
     704             :                 return rc;
     705             : 
     706         559 :         if (!pm_runtime_has_no_callbacks(dev)) {
     707         559 :                 rc = sysfs_merge_group(&dev->kobj, &pm_runtime_attr_group);
     708         559 :                 if (rc)
     709             :                         goto err_out;
     710             :         }
     711         559 :         if (device_can_wakeup(dev)) {
     712           0 :                 rc = sysfs_merge_group(&dev->kobj, &pm_wakeup_attr_group);
     713           0 :                 if (rc)
     714             :                         goto err_runtime;
     715             :         }
     716         559 :         if (dev->power.set_latency_tolerance) {
     717           0 :                 rc = sysfs_merge_group(&dev->kobj,
     718             :                                        &pm_qos_latency_tolerance_attr_group);
     719           0 :                 if (rc)
     720             :                         goto err_wakeup;
     721             :         }
     722         559 :         rc = pm_wakeup_source_sysfs_add(dev);
     723         559 :         if (rc)
     724             :                 goto err_latency;
     725             :         return 0;
     726             : 
     727             :  err_latency:
     728           0 :         sysfs_unmerge_group(&dev->kobj, &pm_qos_latency_tolerance_attr_group);
     729             :  err_wakeup:
     730           0 :         sysfs_unmerge_group(&dev->kobj, &pm_wakeup_attr_group);
     731             :  err_runtime:
     732           0 :         sysfs_unmerge_group(&dev->kobj, &pm_runtime_attr_group);
     733             :  err_out:
     734           0 :         sysfs_remove_group(&dev->kobj, &pm_attr_group);
     735           0 :         return rc;
     736             : }
     737             : 
     738           0 : int dpm_sysfs_change_owner(struct device *dev, kuid_t kuid, kgid_t kgid)
     739             : {
     740             :         int rc;
     741             : 
     742           0 :         if (device_pm_not_required(dev))
     743             :                 return 0;
     744             : 
     745           0 :         rc = sysfs_group_change_owner(&dev->kobj, &pm_attr_group, kuid, kgid);
     746           0 :         if (rc)
     747             :                 return rc;
     748             : 
     749           0 :         if (!pm_runtime_has_no_callbacks(dev)) {
     750           0 :                 rc = sysfs_group_change_owner(
     751             :                         &dev->kobj, &pm_runtime_attr_group, kuid, kgid);
     752           0 :                 if (rc)
     753             :                         return rc;
     754             :         }
     755             : 
     756           0 :         if (device_can_wakeup(dev)) {
     757           0 :                 rc = sysfs_group_change_owner(&dev->kobj, &pm_wakeup_attr_group,
     758             :                                               kuid, kgid);
     759           0 :                 if (rc)
     760             :                         return rc;
     761             : 
     762           0 :                 rc = dpm_sysfs_wakeup_change_owner(dev, kuid, kgid);
     763           0 :                 if (rc)
     764             :                         return rc;
     765             :         }
     766             : 
     767           0 :         if (dev->power.set_latency_tolerance) {
     768           0 :                 rc = sysfs_group_change_owner(
     769             :                         &dev->kobj, &pm_qos_latency_tolerance_attr_group, kuid,
     770             :                         kgid);
     771           0 :                 if (rc)
     772             :                         return rc;
     773             :         }
     774             :         return 0;
     775             : }
     776             : 
     777           0 : int wakeup_sysfs_add(struct device *dev)
     778             : {
     779           0 :         int ret = sysfs_merge_group(&dev->kobj, &pm_wakeup_attr_group);
     780             : 
     781           0 :         if (!ret)
     782           0 :                 kobject_uevent(&dev->kobj, KOBJ_CHANGE);
     783             : 
     784           0 :         return ret;
     785             : }
     786             : 
     787           0 : void wakeup_sysfs_remove(struct device *dev)
     788             : {
     789           0 :         sysfs_unmerge_group(&dev->kobj, &pm_wakeup_attr_group);
     790           0 :         kobject_uevent(&dev->kobj, KOBJ_CHANGE);
     791           0 : }
     792             : 
     793           1 : int pm_qos_sysfs_add_resume_latency(struct device *dev)
     794             : {
     795           1 :         return sysfs_merge_group(&dev->kobj, &pm_qos_resume_latency_attr_group);
     796             : }
     797             : 
     798          23 : void pm_qos_sysfs_remove_resume_latency(struct device *dev)
     799             : {
     800          23 :         sysfs_unmerge_group(&dev->kobj, &pm_qos_resume_latency_attr_group);
     801          23 : }
     802             : 
     803           0 : int pm_qos_sysfs_add_flags(struct device *dev)
     804             : {
     805           0 :         return sysfs_merge_group(&dev->kobj, &pm_qos_flags_attr_group);
     806             : }
     807             : 
     808          23 : void pm_qos_sysfs_remove_flags(struct device *dev)
     809             : {
     810          23 :         sysfs_unmerge_group(&dev->kobj, &pm_qos_flags_attr_group);
     811          23 : }
     812             : 
     813           0 : int pm_qos_sysfs_add_latency_tolerance(struct device *dev)
     814             : {
     815           0 :         return sysfs_merge_group(&dev->kobj,
     816             :                                  &pm_qos_latency_tolerance_attr_group);
     817             : }
     818             : 
     819           0 : void pm_qos_sysfs_remove_latency_tolerance(struct device *dev)
     820             : {
     821           0 :         sysfs_unmerge_group(&dev->kobj, &pm_qos_latency_tolerance_attr_group);
     822           0 : }
     823             : 
     824           0 : void rpm_sysfs_remove(struct device *dev)
     825             : {
     826          23 :         sysfs_unmerge_group(&dev->kobj, &pm_runtime_attr_group);
     827           0 : }
     828             : 
     829          23 : void dpm_sysfs_remove(struct device *dev)
     830             : {
     831          23 :         if (device_pm_not_required(dev))
     832             :                 return;
     833          23 :         sysfs_unmerge_group(&dev->kobj, &pm_qos_latency_tolerance_attr_group);
     834          23 :         dev_pm_qos_constraints_destroy(dev);
     835          23 :         rpm_sysfs_remove(dev);
     836          23 :         sysfs_unmerge_group(&dev->kobj, &pm_wakeup_attr_group);
     837          23 :         sysfs_remove_group(&dev->kobj, &pm_attr_group);
     838             : }

Generated by: LCOV version 1.14