24 Feb, 2020

1 commit

  • [ Upstream commit ba0033192145cbd4e70ef64552958b13d597eb9e ]

    The static OPPs aren't getting freed properly, if errors occur while
    adding them. Fix that by calling _put_opp_list_kref() and putting their
    reference on failures.

    Fixes: 11e1a1648298 ("opp: Don't decrement uninitialized list_kref")
    Signed-off-by: Viresh Kumar
    Signed-off-by: Sasha Levin

    Viresh Kumar
     

23 Oct, 2019

1 commit

  • The list_kref reaches a count of 0 when all the static OPPs are removed,
    for example when dev_pm_opp_of_cpumask_remove_table() is called, though
    the actual OPP table may not get freed as it may still be referenced by
    other parts of the kernel, like from a call to
    dev_pm_opp_set_supported_hw(). And if we call
    dev_pm_opp_of_cpumask_add_table() again at this point, we must
    reinitialize the list_kref otherwise the kernel will hit a WARN() in
    kref infrastructure for incrementing a kref with value 0.

    Fixes: 11e1a1648298 ("opp: Don't decrement uninitialized list_kref")
    Reported-by: Dmitry Osipenko
    Tested-by: Dmitry Osipenko
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

10 Oct, 2019

1 commit

  • _find_opp_of_np() doesn't traverse the list of OPP tables but instead
    just the entries within an OPP table and so only requires to lock the
    OPP table itself.

    The lockdep_assert_held() was added there by mistake and isn't really
    required.

    Fixes: 5d6d106fa455 ("OPP: Populate required opp tables from "required-opps" property")
    Cc: v5.0+ # v5.0+
    Reported-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

26 Jul, 2019

2 commits

  • With property "opp-supported-hw" introduced, the OPP table
    in DT could be a large OPP table and ONLY a subset of OPPs
    are available, based on the version of the hardware running
    on. That introduces restriction of using "opp-suspend"
    property to define the suspend OPP, as we are NOT sure if the
    OPP containing "opp-suspend" property is available for the
    hardware running on, and the of opp core does NOT allow multiple
    suspend OPPs defined in DT OPP table.

    To eliminate this restrition, make of opp core allow multiple
    suspend OPPs defined in DT, and pick the OPP with highest rate
    and with "opp-suspend" property present to be suspend OPP, it
    can speed up the suspend/resume process.

    Signed-off-by: Anson Huang
    Signed-off-by: Viresh Kumar

    Anson Huang
     
  • The list_kref was added for static OPPs and to track their users. The
    kref is initialized while the static OPPs are added, but removed
    unconditionally even if the static OPPs were never added. This causes
    refcount mismatch warnings currently.

    Fix that by always initializing the kref when the OPP table is first
    initialized. The refcount is later incremented only for the second user
    onwards.

    Fixes: d0e8ae6c26da ("OPP: Create separate kref for static OPPs list")
    Reported-by: Rajendra Nayak
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

26 Jun, 2019

1 commit

  • Pull operating performance points (OPP) framework changes for v5.3
    from Viresh Kumar:

    "This pull request contains:

    - OPP core changes to support a wider range of devices, like IO
    devices (Rajendra Nayak and Stehpen Boyd).
    - Fixes around genpd_virt_devs (Viresh Kumar).
    - Fix for platform with set_opp() callback (Dmitry Osipenko)."

    * 'opp/linux-next' of git://git.kernel.org/pub/scm/linux/kernel/git/vireshk/pm:
    opp: Don't use IS_ERR on invalid supplies
    opp: Make dev_pm_opp_set_rate() handle freq = 0 to drop performance votes
    opp: Don't overwrite rounded clk rate
    opp: Allocate genpd_virt_devs from dev_pm_opp_attach_genpd()
    opp: Attach genpds to devices from within OPP core

    Rafael J. Wysocki
     

19 Jun, 2019

1 commit

  • Based on 2 normalized pattern(s):

    this program is free software you can redistribute it and or modify
    it under the terms of the gnu general public license version 2 as
    published by the free software foundation

    this program is free software you can redistribute it and or modify
    it under the terms of the gnu general public license version 2 as
    published by the free software foundation #

    extracted by the scancode license scanner the SPDX license identifier

    GPL-2.0-only

    has been chosen to replace the boilerplate/reference in 4122 file(s).

    Signed-off-by: Thomas Gleixner
    Reviewed-by: Enrico Weigelt
    Reviewed-by: Kate Stewart
    Reviewed-by: Allison Randal
    Cc: linux-spdx@vger.kernel.org
    Link: https://lkml.kernel.org/r/20190604081206.933168790@linutronix.de
    Signed-off-by: Greg Kroah-Hartman

    Thomas Gleixner
     

20 May, 2019

1 commit

  • Currently the space for the array of virtual devices is allocated along
    with the OPP table, but that isn't going to work well from now onwards.
    For single power domain case, a driver can either use the original
    device structure for setting the performance state (if genpd attached
    with dev_pm_domain_attach()) or use the virtual device structure (if
    genpd attached with dev_pm_domain_attach_by_name(), which returns the
    virtual device) and so we can't know in advance if we are going to need
    genpd_virt_devs array or not.

    Lets delay the allocation a bit and do it along with
    dev_pm_opp_attach_genpd() rather. The deallocation is done from
    dev_pm_opp_detach_genpd().

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

11 Mar, 2019

1 commit

  • We seem to rely on the number of phandles specified in the
    'required-opps' property to identify cases where a device is
    associated with multiple power domains and hence would have
    multiple virtual devices that have to be dealt with.

    In cases where we do have devices with multiple power domains
    but with only one of them being scalable, this logic seems to
    fail.

    Instead read the number of power domains from DT to identify
    such cases.

    Signed-off-by: Rajendra Nayak
    Reviewed-by: Stephen Boyd
    Acked-by: Viresh Kumar
    Signed-off-by: Rafael J. Wysocki

    Rajendra Nayak
     

07 Mar, 2019

1 commit

  • Pull power management updates from Rafael Wysocki:
    "These are PM-runtime framework changes to use ktime instead of jiffies
    for accounting, new PM core flag to mark devices that don't need any
    form of power management, cpuidle updates including driver API
    documentation and a new governor, cpufreq updates including a new
    driver for Armada 8K, thermal cleanups and more, some energy-aware
    scheduling (EAS) enabling changes, new chips support in the intel_idle
    and RAPL drivers and assorted cleanups in some other places.

    Specifics:

    - Update the PM-runtime framework to use ktime instead of jiffies for
    accounting (Thara Gopinath, Vincent Guittot)

    - Optimize the autosuspend code in the PM-runtime framework somewhat
    (Ladislav Michl)

    - Add a PM core flag to mark devices that don't need any form of
    power management (Sudeep Holla)

    - Introduce driver API documentation for cpuidle and add a new
    cpuidle governor for tickless systems (Rafael Wysocki)

    - Add Jacobsville support to the intel_idle driver (Zhang Rui)

    - Clean up a cpuidle core header file and the cpuidle-dt and ACPI
    processor-idle drivers (Yangtao Li, Joseph Lo, Yazen Ghannam)

    - Add new cpufreq driver for Armada 8K (Gregory Clement)

    - Fix and clean up cpufreq core (Rafael Wysocki, Viresh Kumar, Amit
    Kucheria)

    - Add support for light-weight tear-down and bring-up of CPUs to the
    cpufreq core and use it in the cpufreq-dt driver (Viresh Kumar)

    - Fix cpu_cooling Kconfig dependencies, add support for CPU cooling
    auto-registration to the cpufreq core and use it in multiple
    cpufreq drivers (Amit Kucheria)

    - Fix some minor issues and do some cleanups in the davinci,
    e_powersaver, ap806, s5pv210, qcom and kryo cpufreq drivers
    (Bartosz Golaszewski, Gustavo Silva, Julia Lawall, Paweł Chmiel,
    Taniya Das, Viresh Kumar)

    - Add a Hisilicon CPPC quirk to the cppc_cpufreq driver (Xiongfeng
    Wang)

    - Clean up the intel_pstate and acpi-cpufreq drivers (Erwan Velu,
    Rafael Wysocki)

    - Clean up multiple cpufreq drivers (Yangtao Li)

    - Update cpufreq-related MAINTAINERS entries (Baruch Siach, Lukas
    Bulwahn)

    - Add support for exposing the Energy Model via debugfs and make
    multiple cpufreq drivers register an Energy Model to support
    energy-aware scheduling (Quentin Perret, Dietmar Eggemann, Matthias
    Kaehlcke)

    - Add Ice Lake mobile and Jacobsville support to the Intel RAPL
    power-capping driver (Gayatri Kammela, Zhang Rui)

    - Add a power estimation helper to the operating performance points
    (OPP) framework and clean up a core function in it (Quentin Perret,
    Viresh Kumar)

    - Make minor improvements in the generic power domains (genpd), OPP
    and system suspend frameworks and in the PM core (Aditya Pakki,
    Douglas Anderson, Greg Kroah-Hartman, Rafael Wysocki, Yangtao Li)"

    * tag 'pm-5.1-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (80 commits)
    cpufreq: kryo: Release OPP tables on module removal
    cpufreq: ap806: add missing of_node_put after of_device_is_available
    cpufreq: acpi-cpufreq: Report if CPU doesn't support boost technologies
    cpufreq: Pass updated policy to driver ->setpolicy() callback
    cpufreq: Fix two debug messages in cpufreq_set_policy()
    cpufreq: Reorder and simplify cpufreq_update_policy()
    cpufreq: Add kerneldoc comments for two core functions
    PM / core: Add support to skip power management in device/driver model
    cpufreq: intel_pstate: Rework iowait boosting to be less aggressive
    cpufreq: intel_pstate: Eliminate intel_pstate_get_base_pstate()
    cpufreq: intel_pstate: Avoid redundant initialization of local vars
    powercap/intel_rapl: add Ice Lake mobile
    ACPI / processor: Set P_LVL{2,3} idle state descriptions
    cpufreq / cppc: Work around for Hisilicon CPPC cpufreq
    ACPI / CPPC: Add a helper to get desired performance
    cpufreq: davinci: move configuration to include/linux/platform_data
    cpufreq: speedstep: convert BUG() to BUG_ON()
    cpufreq: powernv: fix missing check of return value in init_powernv_pstates()
    cpufreq: longhaul: remove unneeded semicolon
    cpufreq: pcc-cpufreq: remove unneeded semicolon
    ..

    Linus Torvalds
     

07 Feb, 2019

1 commit

  • The Energy Model (EM) framework provides an API to let drivers register
    the active power of CPUs. The drivers are expected to provide a callback
    method which estimates the power consumed by a CPU at each available
    performance levels. How exactly this should be implemented, however,
    depends on the platform.

    On some systems, PM_OPP knows the voltage and frequency at which CPUs
    can run. When coupled with the CPU 'capacitance' (as provided by the
    'dynamic-power-coefficient' devicetree binding), it is possible to
    estimate the dynamic power consumption of a CPU as P = C * V^2 * f, with
    C its capacitance and V and f respectively the voltage and frequency of
    the OPP. The Intelligent Power Allocator (IPA) thermal governor already
    implements that estimation method, in the thermal framework.

    However, this power estimation method can be applied to any platform
    where all the parameters are known (C, V and f), and not only those
    suffering thermal issues. As such, the code implementing this feature
    can be re-used to also populate the EM framework now used by EAS.

    As a first step, introduce in PM_OPP a helper function which CPUFreq
    drivers can use to register into the EM framework. This duplicates the
    power estimation done in IPA until it can be migrated to using the EM
    framework. This will be done later, once the EM framework has support
    for at least all platforms currently supported by IPA.

    Signed-off-by: Quentin Perret
    Tested-by: Matthias Kaehlcke
    Reviewed-by: Matthias Kaehlcke
    Signed-off-by: Viresh Kumar

    Quentin Perret
     

23 Jan, 2019

1 commit

  • Now that the OPP bindings are updated to include an optional
    'opp-level' property, add support to parse it from device tree
    and store it as part of dev_pm_opp structure.
    Also add and export an helper 'dev_pm_opp_get_level()' that can be
    used to get the level value read from device tree when present.

    Reviewed-by: Stephen Boyd
    Acked-by: Viresh Kumar
    Signed-off-by: Rajendra Nayak
    Signed-off-by: Bjorn Andersson
    Signed-off-by: Andy Gross

    Rajendra Nayak
     

14 Dec, 2018

3 commits


11 Dec, 2018

1 commit

  • There is one case where we may end up with no "supply" directory for the
    OPPs in debugfs. That happens when the OPP core isn't managing the
    regulators for the device and the device's OPP do have microvolt
    property. It happens because the opp_table->regulator_count remains set
    to 0 and the debugfs routines don't add any supply directory in such a
    case.

    This commit fixes that by setting opp_table->regulator_count to 1 in
    that particular case. But to make everything work nicely and not break
    other parts of the core, regulator_count is defined as "int" now instead
    of "unsigned int" and it can have different special values now. It is
    set to -1 initially to mark it "uninitialized" and later only we set it
    to 0 or positive values after checking how many supplies are there.

    This also helps in finding the bugs where only few of the OPPs have the
    "opp-microvolt" property set and not all.

    Fixes: 1fae788ed640 ("PM / OPP: Don't create debugfs "supply-0" directory unnecessarily")
    Reported-by: Quentin Perret
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

23 Nov, 2018

1 commit


05 Nov, 2018

7 commits

  • This isn't used anymore, remove it.

    Reviewed-by: Ulf Hansson
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • The OPP core already has the performance state values for each of the
    genpd's OPPs and there is no need to call the genpd callback again to
    get the performance state for the case where the end device doesn't have
    an OPP table and has the "required-opps" property directly in its node.

    This commit renames of_genpd_opp_to_performance_state() as
    of_get_required_opp_performance_state() and moves it to the OPP core, as
    it is all about OPP stuff now.

    Reviewed-by: Ulf Hansson
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • Now that all the infrastructure is in place to support multiple required
    OPPs, lets switch over to using it.

    A new internal routine _set_required_opps() takes care of updating
    performance state for all the required OPPs. With this the performance
    state updates are supported even when the end device needs to configure
    regulators as well, that wasn't the case earlier.

    The pstates were earlier stored in the end device's OPP structures, that
    also changes now as those values are stored in the genpd's OPP
    structures. And so we switch over to using
    pm_genpd_opp_to_performance_state() instead of
    of_genpd_opp_to_performance_state() to get performance state for the
    genpd OPPs.

    The routine _generic_set_opp_domain() is not required anymore and is
    removed.

    On errors we don't try to recover by reverting to old settings as things
    are really complex now and the calls here should never really fail
    unless there is a bug. There is no point increasing the complexity, for
    code which will never be executed.

    Reviewed-by: Ulf Hansson
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • Multiple generic power domains for a consumer device are supported with
    the help of virtual devices, which are created for each consumer device
    - genpd pair. These are the device structures which are attached to the
    power domain and are required by the OPP core to set the performance
    state of the genpd.

    The helpers added by this commit are required to be called once for each
    of these virtual devices. These are required only if multiple domains
    are available for a device, otherwise the actual device structure will
    be used instead by the OPP core.

    The new helpers also support the complex cases where the consumer device
    wouldn't always require all the domains. For example, a camera may
    require only one power domain during normal operations but two during
    high resolution operations. The consumer driver can call
    dev_pm_opp_put_genpd_virt_dev(high_resolution_genpd_virt_dev) if it is
    currently operating in the normal mode and doesn't have any performance
    requirements from the genpd which manages high resolution power
    requirements. The consumer driver can later call
    dev_pm_opp_set_genpd_virt_dev(high_resolution_genpd_virt_dev) once it
    switches back to the high resolution mode.

    The new helpers differ from other OPP set/put helpers as the new ones
    can be called with OPPs initialized for the table as we may need to call
    them on the fly because of the complex case explained above. For this
    reason it is possible that the genpd virt_dev structure may be used in
    parallel while the new helpers are running and a new mutex is added to
    protect against that. We didn't use the existing opp_table->lock mutex
    as that is widely used in the OPP core and we will need this lock in the
    dev_pm_opp_set_rate() helper while changing OPP and we need to make sure
    there is not much contention while doing that as that's the hotpath.

    Reviewed-by: Ulf Hansson
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • An earlier commit populated the OPP tables from the "required-opps"
    property, this commit populates the individual OPPs. This is repeated
    for each OPP in the OPP table and these populated OPPs will be used by
    later commits.

    Reviewed-by: Ulf Hansson
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • The current implementation works only for the case where a single
    phandle is present in the "required-opps" property, while DT allows
    multiple phandles to be present there.

    This patch adds new infrastructure to parse all the phandles present in
    "required-opps" property and save pointers of the required OPP's OPP
    tables. These will be used by later commits.

    Reviewed-by: Ulf Hansson
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • We need to handle genpd OPP tables differently, this is already the case
    at one location and will be extended going forward. Add another field to
    the OPP table to check if the table belongs to a genpd or not.

    Reviewed-by: Ulf Hansson
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

04 Oct, 2018

2 commits

  • Currently the _of_add_opp_table_v2 call loops through the OPP nodes in
    the operating-points-v2 table in the device tree and calls
    _opp_add_static_v2 for each to add them to the table. It counts each
    iteration through this loop as an added OPP, however there are cases
    where _opp_add_static_v2() returns 0 but no new OPP is added to the
    list.

    This can happen while adding duplicate OPP or if the OPP isn't supported
    by hardware.

    Because of this the count variable will contain the number of OPP nodes
    in the table in device tree but not necessarily the ones that are
    actually added.

    As this count value is what is checked to determine if there are any
    valid OPPs, if a platform has an operating-points-v2 table with all OPP
    nodes containing opp-supported-hw values that are not currently
    supported, then _of_add_opp_table_v2 will fail to abort as it should due
    to an empty table.

    Additionally, since commit 3ba98324e81a ("PM / OPP: Get
    performance state using genpd helper"), the same count variable is
    compared against the number of OPPs containing performance states and
    requires that either all or none have pstates set, however in the case
    of any opp table that has any entries that do not get added by
    _opp_add_static_v2 due to incompatible opp-supported-hw fields, these
    numbers will not match and _of_add_opp_table_v2 will incorrectly fail.

    We need to clearly identify all the three cases (success, failure,
    unsupported/duplicate OPPs) and then increment count only on success
    case. Change return type of _opp_add_static_v2() to return the pointer
    to the newly added OPP instead of an integer. This routine now returns a
    valid pointer if the OPP is really added, NULL for unsupported or
    duplicate OPPs, and error value cased as a pointer on errors.

    Ideally the fixes tag in this commit should point back to the commit
    that introduced OPP v2 initially, as that's where we started incorrectly
    accounting for duplicate OPPs:

    commit 274659029c9d ("PM / OPP: Add support to parse "operating-points-v2" bindings")

    But it wasn't a real problem until recently as the count was only used
    to check if any OPPs are added or not. And so this commit points to a
    rather recent commit where we added more code that depends on the value
    of "count".

    Fixes: 3ba98324e81a ("PM / OPP: Get performance state using genpd helper")
    Reported-by: Dave Gerlach
    Reported-by: Niklas Cassel
    Tested-by: Niklas Cassel
    Signed-off-by: Dave Gerlach
    Signed-off-by: Viresh Kumar

    Dave Gerlach
     
  • The error handling wasn't appropriate in
    dev_pm_opp_of_cpumask_add_table(). For example it returns 0 on success
    and also for the case where cpumask is empty or cpu_device wasn't found
    for any of the CPUs.

    It should really return error on such cases, so that the callers can be
    aware of the outcome.

    Fix it.

    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

01 Oct, 2018

2 commits

  • Both _of_add_opp_table_v1() and _of_add_opp_table_v2() contain similar
    code to get the OPP table and their parent routine also parses the DT to
    find the OPP table's node pointer. This can be simplified by getting the
    OPP table in advance and then passing it as argument to these routines.

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • When two or more devices are sharing their clock and voltage rails, they
    share the same OPP table. But there are some corner cases where the OPP
    core incorrectly creates separate OPP tables for them.

    For example, CPU 0 and 1 share clock/voltage rails. The platform
    specific code calls dev_pm_opp_set_regulators() for CPU0 and the OPP
    core creates an OPP table for it (the individual OPPs aren't initialized
    as of now). The same is repeated for CPU1 then. Because
    _opp_get_opp_table() doesn't compare DT node pointers currently, it
    fails to find the link between CPU0 and CPU1 and so creates a new OPP
    table.

    Fix this by calling _managed_opp() from _opp_get_opp_table().
    _managed_opp() gain an additional argument (index) to get the right node
    pointer. This resulted in simplifying code in _of_add_opp_table_v2() as
    well.

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

20 Sep, 2018

7 commits

  • Currently there are two separate ways to free the OPP table based on how
    it is created in the first place.

    We call _dev_pm_opp_remove_table() to free the static and/or dynamic
    OPP, OPP list devices, etc. This is done for the case where the OPP
    table is added while initializing the OPPs, like via the path
    dev_pm_opp_of_add_table().

    We also call dev_pm_opp_put_opp_table() in some cases which eventually
    frees the OPP table structure once the reference count reaches 0. This
    is used by the first case as well as other cases like
    dev_pm_opp_set_regulators() where the OPPs aren't necessarily
    initialized at this point.

    This whole thing is a bit unclear and messy and obstruct any further
    cleanup/fixup of OPP core.

    This patch tries to streamline this by keeping a single path for OPP
    table destruction, i.e. dev_pm_opp_put_opp_table().

    All the cleanup happens in _opp_table_kref_release() now after the
    reference count reaches 0. _dev_pm_opp_remove_table() is removed as it
    isn't required anymore.

    We don't drop the reference to the OPP table after creating it from
    _of_add_opp_table_v{1|2}() anymore and the same is dropped only when we
    try to remove them.

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • Only one platform was depending on this feature and it is already
    updated now. Stop removing dynamic OPPs from _dev_pm_opp_remove_table().
    This simplifies lot of paths and removes unnecessary parameters.

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • The static OPPs don't always get freed with the OPP table, it can happen
    before that as well. For example, if the OPP table is first created
    using helpers like dev_pm_opp_set_supported_hw() and the OPPs are
    created at a later point. Now when the OPPs are removed, the OPP table
    stays until the time dev_pm_opp_put_supported_hw() is called.

    Later patches will streamline the freeing of OPP table and that requires
    the static OPPs to get freed with help of a separate kernel reference.
    This patch prepares for that by creating a separate kref for static OPPs
    list.

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • Parse the DT properties present in the OPP table from
    _of_init_opp_table(), which is a dedicated routine for DT parsing.

    Minor relocation of helpers is required for this.

    It is possible now for _managed_opp() to return a partially initialized
    OPP table if the OPP table is created via the helpers like
    dev_pm_opp_set_supported_hw() and we need another flag to indicate if
    the static OPP are already parsed or not to make sure we don't
    incorrectly skip initializing the static OPPs.

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • This is a preparatory patch required for the next commit which will
    start using OPP table's node pointer in _of_init_opp_table(), which
    requires the index in order to read the OPP table's phandle.

    This commit adds the index argument in the call chains in order to get
    it delivered to _of_init_opp_table().

    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • dev_pm_opp_of_cpumask_add_table() creates the OPP table for all CPUs
    present in the cpumask and on errors it should revert all changes it has
    done.

    It actually is doing a bit more than that. On errors, it tries to free
    all the OPP tables, even the one it hasn't created yet. This may also
    end up freeing the OPP tables which were created from separate path,
    like dev_pm_opp_set_supported_hw().

    Reported-and-tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     
  • The OPP table was freed, but not the individual OPPs which is done from
    _dev_pm_opp_remove_table(). Fix it by calling _dev_pm_opp_remove_table()
    as well.

    Cc: 4.18 # v4.18
    Fixes: 3ba98324e81a ("PM / OPP: Get performance state using genpd helper")
    Tested-by: Niklas Cassel
    Signed-off-by: Viresh Kumar

    Viresh Kumar
     

30 May, 2018

1 commit

  • The OPP binding says:

    Property: operating-points-v2

    ...

    This can contain more than one phandle for power domain
    providers that provide multiple power domains. That is, one
    phandle for each power domain. If only one phandle is available,
    then the same OPP table will be used for all power domains
    provided by the power domain provider.

    But the OPP core isn't allowing the same OPP table to be used for
    multiple domains. Update dev_pm_opp_of_add_table_indexed() to allow
    that.

    Signed-off-by: Viresh Kumar
    Tested-by: Rajendra Nayak

    Viresh Kumar
     

16 May, 2018

1 commit

  • Smatch complains that it's possible we print "rate" in the debug output
    when it hasn't been initialized. It should be zero on that path.

    Fixes: a1e8c13600bf ("PM / OPP: "opp-hz" is optional for power domains")
    [ Viresh: Added the Fixes tag ]
    Signed-off-by: Dan Carpenter
    Signed-off-by: Viresh Kumar

    Dan Carpenter
     

09 May, 2018

3 commits