1. 22 5月, 2015 3 次提交
  2. 28 4月, 2015 1 次提交
  3. 11 4月, 2015 1 次提交
  4. 10 4月, 2015 2 次提交
    • H
      regulator: output current-limit for all regulators in summary · 23296099
      Heiko Stübner 提交于
      Voltage regulators can have (unregulated) current limits too, so we should
      probably output both voltage and current for all regulators.
      
      Holding the rdev->mutex actually conflicts with _regulator_get_current_limit
      but also is not really necessary, as the global regulator_list_mutex already
      protects us from the regulator vanishing while we go through the list.
      
      On the rk3288-firefly the summary now looks like:
      
       regulator                      use open bypass voltage current     min     max
      -------------------------------------------------------------------------------
       vcc_sys                          0   12      0  5000mV     0mA  5000mV  5000mV
          vcc_lan                       1    1      0  3300mV     0mA  3300mV  3300mV
             ff290000.ethernet                                            0mV     0mV
          vcca_33                       0    0      0  3300mV     0mA  3300mV  3300mV
          vcca_18                       0    0      0  1800mV     0mA  1800mV  1800mV
          vdd10_lcd                     0    0      0  1000mV     0mA  1000mV  1000mV
       [...]
      Suggested-by: NMark Brown <broonie@kernel.org>
      Signed-off-by: NHeiko Stuebner <heiko@sntech.de>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      23296099
    • H
      regulator: add a summary tree in debugfs · 7c225ec9
      Heiko Stübner 提交于
      On modern systems the regulator hierarchy can get quite long and nested
      with regulators supplying other regulators. In some cases when debugging
      it might be nice to get a tree of these regulators, their consumers
      and the regulation constraints in one go.
      
      To achieve this add a regulator_summary sysfs node, similar to
      clk_summary in the common clock framework, that walks the regulator
      list and creates a tree out of the regulators, their consumers and
      core per-regulator settings.
      
      On a rk3288-firefly the regulator_summary would for example look
      something like:
      
       regulator                      use open bypass   value     min     max
      -----------------------------------------------------------------------
       vcc_sys                          0   12      0  5000mV  5000mV  5000mV
          vcc_lan                       1    1      0  3300mV  3300mV  3300mV
             ff290000.ethernet                                    0mV     0mV
          vcca_33                       0    0      0  3300mV  3300mV  3300mV
          vcca_18                       0    0      0  1800mV  1800mV  1800mV
          vdd10_lcd                     0    0      0  1000mV  1000mV  1000mV
          vccio_sd                      0    0      0  3300mV  3300mV  3300mV
          vcc_20                        0    3      0  2000mV  2000mV  2000mV
             vcc18_lcd                  0    0      0  1800mV  1800mV  1800mV
             vcc_18                     0    2      0  1800mV  1800mV  1800mV
                ff100000.saradc                                   0mV     0mV
                ff0d0000.dwmmc                                 1650mV  1950mV
             vdd_10                     0    0      0  1000mV  1000mV  1000mV
          vdd_log                       0    0      0  1100mV  1100mV  1100mV
          vcc_io                        0    3      0  3300mV  3300mV  3300mV
             ff0f0000.dwmmc                                    3300mV  3400mV
             vcc_flash                  1    1      0  1800mV  1800mV  1800mV
                ff0f0000.dwmmc                                 1700mV  1950mV
             vcc_sd                     1    1      0  3300mV  3300mV  3300mV
                ff0c0000.dwmmc                                 3300mV  3400mV
          vcc_ddr                       0    0      0  1200mV  1200mV  1200mV
          vdd_gpu                       0    0      0  1000mV   850mV  1350mV
          vdd_cpu                       0    1      0   900mV   850mV  1350mV
             cpu0                                               900mV   900mV
          vcc_5v                        0    2      0  5000mV  5000mV  5000mV
             vcc_otg_5v                 0    0      0  5000mV  5000mV  5000mV
             vcc_host_5v                0    0      0  5000mV  5000mV  5000mV
       regulator-dummy                  0    0      0     0mV     0mV     0mV
      Signed-off-by: NHeiko Stuebner <heiko@sntech.de>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      7c225ec9
  5. 08 4月, 2015 5 次提交
  6. 02 4月, 2015 1 次提交
  7. 30 3月, 2015 1 次提交
  8. 28 3月, 2015 1 次提交
    • G
      regulator: Ensure unique regulator debugfs directory names · a9eaa813
      Guenter Roeck 提交于
      If multiple regulator devices of the same type exist in a system,
      the regulator driver assigns generic names for the regulators it
      provides, and debugfs is enabled, the regulator subsystem attempts
      to create multiple entries with the same name in the regulator debugfs
      directory. This fails for all but the first regulator, resulting in
      multiple "Failed to create debugfs directory" log entries.
      
      To avoid the problem, prepend the debugfs directory name for a regulator
      with its parent device name if available, but only if no explicit
      regulator name was provided.
      
      Cc: Alan Tull <atull@opensource.altera.com>
      Signed-off-by: NGuenter Roeck <linux@roeck-us.net>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      a9eaa813
  9. 21 3月, 2015 1 次提交
  10. 17 3月, 2015 3 次提交
  11. 16 3月, 2015 1 次提交
    • G
      regulator: tps65910: Add missing #include <linux/of.h> · d16da513
      Geert Uytterhoeven 提交于
      drivers/regulator/tps65910-regulator.c: In function ‘tps65910_parse_dt_reg_data’:
      drivers/regulator/tps65910-regulator.c:1018: error: implicit declaration of function ‘of_get_child_by_name’
      drivers/regulator/tps65910-regulator.c:1018: warning: assignment makes pointer from integer without a cast
      drivers/regulator/tps65910-regulator.c:1034: error: implicit declaration of function ‘of_node_put’
      drivers/regulator/tps65910-regulator.c:1056: error: implicit declaration of function ‘of_property_read_u32’
      Signed-off-by: NGeert Uytterhoeven <geert@linux-m68k.org>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      d16da513
  12. 10 3月, 2015 1 次提交
  13. 09 3月, 2015 2 次提交
    • D
      regulator: core: Fix enable GPIO reference counting · 29d62ec5
      Doug Anderson 提交于
      Normally _regulator_do_enable() isn't called on an already-enabled
      rdev.  That's because the main caller, _regulator_enable() always
      calls _regulator_is_enabled() and only calls _regulator_do_enable() if
      the rdev was not already enabled.
      
      However, there is one caller of _regulator_do_enable() that doesn't
      check: regulator_suspend_finish().  While we might want to make
      regulator_suspend_finish() behave more like _regulator_enable(), it's
      probably also a good idea to make _regulator_do_enable() robust if it
      is called on an already enabled rdev.
      
      At the moment, _regulator_do_enable() is _not_ robust for already
      enabled rdevs if we're using an ena_pin.  Each time
      _regulator_do_enable() is called for an rdev using an ena_pin the
      reference count of the ena_pin is incremented even if the rdev was
      already enabled.  This is not as intended because the ena_pin is for
      something else: for keeping track of how many active rdevs there are
      sharing the same ena_pin.
      
      Here's how the reference counting works here:
      
      * Each time _regulator_enable() is called we increment
        rdev->use_count, so _regulator_enable() calls need to be balanced
        with _regulator_disable() calls.
      
      * There is no explicit reference counting in _regulator_do_enable()
        which is normally just a warapper around rdev->desc->ops->enable()
        with code for supporting delays.  It's not expected that the
        "ops->enable()" call do reference counting.
      
      * Since regulator_ena_gpio_ctrl() does have reference counting
        (handling the sharing of the pin amongst multiple rdevs), we
        shouldn't call it if the current rdev is already enabled.
      
      Note that as part of this we cleanup (remove) the initting of
      ena_gpio_state in regulator_register().  In _regulator_do_enable(),
      _regulator_do_disable() and _regulator_is_enabled() is is clear that
      ena_gpio_state should be the state of whether this particular rdev has
      requested the GPIO be enabled.  regulator_register() was initting it
      as the actual state of the pin.
      
      Fixes: 967cfb18 ("regulator: core: manage enable GPIO list")
      Signed-off-by: NDoug Anderson <dianders@chromium.org>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      Cc: stable@vger.kernel.org
      29d62ec5
    • J
      regulator: Only enable disabled regulators on resume · 0548bf4f
      Javier Martinez Canillas 提交于
      The _regulator_do_enable() call ought to be a no-op when called on an
      already-enabled regulator.  However, as an optimization
      _regulator_enable() doesn't call _regulator_do_enable() on an already
      enabled regulator.  That means we never test the case of calling
      _regulator_do_enable() during normal usage and there may be hidden
      bugs or warnings.  We have seen warnings issued by the tps65090 driver
      and bugs when using the GPIO enable pin.
      
      Let's match the same optimization that _regulator_enable() in
      regulator_suspend_finish().  That may speed up suspend/resume and also
      avoids exposing hidden bugs.
      
      [Use much clearer commit message from Doug Anderson]
      Signed-off-by: NJavier Martinez Canillas <javier.martinez@collabora.co.uk>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      Cc: stable@vger.kernel.org
      0548bf4f
  14. 08 3月, 2015 1 次提交
    • H
      regulator: act8865: add input supply handling · c8b263cc
      Heiko Stuebner 提交于
      The act88600/act8846/act8865 regulators have a number of input supplies
      supplying the individual regulators. This may even be recursively like on
      most Rockchip boards using the act8846 where REG4 is most of the time
      connected to the inl1-supply.
      
      Therefore add the ability to specify the input supplies for the individual inputs.
      The input-names are taken from the datasheets of act8600, act8846 and act8865.
      On the act8600 some regulators do not have separate input supplies.
      Signed-off-by: NHeiko Stuebner <heiko@sntech.de>
      Signed-off-by: NMark Brown <broonie@kernel.org>
      c8b263cc
  15. 07 3月, 2015 1 次提交
  16. 06 3月, 2015 2 次提交
  17. 04 3月, 2015 1 次提交
  18. 26 2月, 2015 1 次提交
  19. 24 2月, 2015 4 次提交
  20. 23 2月, 2015 2 次提交
  21. 21 2月, 2015 3 次提交
  22. 17 2月, 2015 1 次提交
  23. 06 2月, 2015 1 次提交