Commit 440f9d47 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki

Merge branches 'pm-cpuidle', 'pm-sleep' and 'pm-powercap'

Merge cpuidle updates, changes related to system sleep and power capping
updates for 6.10:

 - Fix kerneldoc description of ladder_do_selection() (Jeff Johnson).

 - Convert the cpuidle kirkwood driver to platform remove callback
   returning void (Yangtao Li).

 - Replace deprecated strncpy() with strscpy() in the hibernation core
   code (Justin Stitt).

 - Use %ps to simplify debug output in the core system-wide suspend and
   resume code (Len Brown).

 - Remove unnecessary else from device_init_wakeup() and make
   device_wakeup_disable() return void (Dhruva Gole).

 - Enable PMU support in the Intel TPMI RAPL driver (Zhang Rui).

 - Add support for ArrowLake-H platform to the Intel RAPL driver (Zhang
   Rui).

 - Avoid explicit cpumask allocation on stack in DTPM (Dawei Li).

* pm-cpuidle:
  cpuidle: ladder: fix ladder_do_selection() kernel-doc
  cpuidle: kirkwood: Convert to platform remove callback returning void

* pm-sleep:
  PM: hibernate: replace deprecated strncpy() with strscpy()
  PM: sleep: Take advantage of %ps to simplify debug output
  PM: wakeup: Remove unnecessary else from device_init_wakeup()
  PM: wakeup: make device_wakeup_disable() return void

* pm-powercap:
  powercap: intel_rapl_tpmi: Enable PMU support
  powercap: intel_rapl: Introduce APIs for PMU support
  powercap: intel_rapl: Sort header files
  powercap: intel_rapl: Add support for ArrowLake-H platform
  powercap: DTPM: Avoid explicit cpumask allocation on stack
...@@ -208,7 +208,7 @@ static ktime_t initcall_debug_start(struct device *dev, void *cb) ...@@ -208,7 +208,7 @@ static ktime_t initcall_debug_start(struct device *dev, void *cb)
if (!pm_print_times_enabled) if (!pm_print_times_enabled)
return 0; return 0;
dev_info(dev, "calling %pS @ %i, parent: %s\n", cb, dev_info(dev, "calling %ps @ %i, parent: %s\n", cb,
task_pid_nr(current), task_pid_nr(current),
dev->parent ? dev_name(dev->parent) : "none"); dev->parent ? dev_name(dev->parent) : "none");
return ktime_get(); return ktime_get();
...@@ -223,7 +223,7 @@ static void initcall_debug_report(struct device *dev, ktime_t calltime, ...@@ -223,7 +223,7 @@ static void initcall_debug_report(struct device *dev, ktime_t calltime,
return; return;
rettime = ktime_get(); rettime = ktime_get();
dev_info(dev, "%pS returned %d after %Ld usecs\n", cb, error, dev_info(dev, "%ps returned %d after %Ld usecs\n", cb, error,
(unsigned long long)ktime_us_delta(rettime, calltime)); (unsigned long long)ktime_us_delta(rettime, calltime));
} }
...@@ -1927,7 +1927,7 @@ EXPORT_SYMBOL_GPL(dpm_suspend_start); ...@@ -1927,7 +1927,7 @@ EXPORT_SYMBOL_GPL(dpm_suspend_start);
void __suspend_report_result(const char *function, struct device *dev, void *fn, int ret) void __suspend_report_result(const char *function, struct device *dev, void *fn, int ret)
{ {
if (ret) if (ret)
dev_err(dev, "%s(): %pS returns %d\n", function, fn, ret); dev_err(dev, "%s(): %ps returns %d\n", function, fn, ret);
} }
EXPORT_SYMBOL_GPL(__suspend_report_result); EXPORT_SYMBOL_GPL(__suspend_report_result);
......
...@@ -451,16 +451,15 @@ static struct wakeup_source *device_wakeup_detach(struct device *dev) ...@@ -451,16 +451,15 @@ static struct wakeup_source *device_wakeup_detach(struct device *dev)
* Detach the @dev's wakeup source object from it, unregister this wakeup source * Detach the @dev's wakeup source object from it, unregister this wakeup source
* object and destroy it. * object and destroy it.
*/ */
int device_wakeup_disable(struct device *dev) void device_wakeup_disable(struct device *dev)
{ {
struct wakeup_source *ws; struct wakeup_source *ws;
if (!dev || !dev->power.can_wakeup) if (!dev || !dev->power.can_wakeup)
return -EINVAL; return;
ws = device_wakeup_detach(dev); ws = device_wakeup_detach(dev);
wakeup_source_unregister(ws); wakeup_source_unregister(ws);
return 0;
} }
EXPORT_SYMBOL_GPL(device_wakeup_disable); EXPORT_SYMBOL_GPL(device_wakeup_disable);
...@@ -502,7 +501,11 @@ EXPORT_SYMBOL_GPL(device_set_wakeup_capable); ...@@ -502,7 +501,11 @@ EXPORT_SYMBOL_GPL(device_set_wakeup_capable);
*/ */
int device_set_wakeup_enable(struct device *dev, bool enable) int device_set_wakeup_enable(struct device *dev, bool enable)
{ {
return enable ? device_wakeup_enable(dev) : device_wakeup_disable(dev); if (enable)
return device_wakeup_enable(dev);
device_wakeup_disable(dev);
return 0;
} }
EXPORT_SYMBOL_GPL(device_set_wakeup_enable); EXPORT_SYMBOL_GPL(device_set_wakeup_enable);
......
...@@ -59,15 +59,14 @@ static int kirkwood_cpuidle_probe(struct platform_device *pdev) ...@@ -59,15 +59,14 @@ static int kirkwood_cpuidle_probe(struct platform_device *pdev)
return cpuidle_register(&kirkwood_idle_driver, NULL); return cpuidle_register(&kirkwood_idle_driver, NULL);
} }
static int kirkwood_cpuidle_remove(struct platform_device *pdev) static void kirkwood_cpuidle_remove(struct platform_device *pdev)
{ {
cpuidle_unregister(&kirkwood_idle_driver); cpuidle_unregister(&kirkwood_idle_driver);
return 0;
} }
static struct platform_driver kirkwood_cpuidle_driver = { static struct platform_driver kirkwood_cpuidle_driver = {
.probe = kirkwood_cpuidle_probe, .probe = kirkwood_cpuidle_probe,
.remove = kirkwood_cpuidle_remove, .remove_new = kirkwood_cpuidle_remove,
.driver = { .driver = {
.name = "kirkwood_cpuidle", .name = "kirkwood_cpuidle",
}, },
......
...@@ -44,6 +44,7 @@ static DEFINE_PER_CPU(struct ladder_device, ladder_devices); ...@@ -44,6 +44,7 @@ static DEFINE_PER_CPU(struct ladder_device, ladder_devices);
/** /**
* ladder_do_selection - prepares private data for a state change * ladder_do_selection - prepares private data for a state change
* @dev: the CPU
* @ldev: the ladder device * @ldev: the ladder device
* @old_idx: the current state index * @old_idx: the current state index
* @new_idx: the new target state index * @new_idx: the new target state index
......
...@@ -63,7 +63,7 @@ static int sdhci_pci_init_wakeup(struct sdhci_pci_chip *chip) ...@@ -63,7 +63,7 @@ static int sdhci_pci_init_wakeup(struct sdhci_pci_chip *chip)
if ((pm_flags & MMC_PM_KEEP_POWER) && (pm_flags & MMC_PM_WAKE_SDIO_IRQ)) if ((pm_flags & MMC_PM_KEEP_POWER) && (pm_flags & MMC_PM_WAKE_SDIO_IRQ))
return device_wakeup_enable(&chip->pdev->dev); return device_wakeup_enable(&chip->pdev->dev);
else if (!cap_cd_wake) else if (!cap_cd_wake)
return device_wakeup_disable(&chip->pdev->dev); device_wakeup_disable(&chip->pdev->dev);
return 0; return 0;
} }
......
...@@ -43,13 +43,11 @@ static u64 set_pd_power_limit(struct dtpm *dtpm, u64 power_limit) ...@@ -43,13 +43,11 @@ static u64 set_pd_power_limit(struct dtpm *dtpm, u64 power_limit)
struct dtpm_cpu *dtpm_cpu = to_dtpm_cpu(dtpm); struct dtpm_cpu *dtpm_cpu = to_dtpm_cpu(dtpm);
struct em_perf_domain *pd = em_cpu_get(dtpm_cpu->cpu); struct em_perf_domain *pd = em_cpu_get(dtpm_cpu->cpu);
struct em_perf_state *table; struct em_perf_state *table;
struct cpumask cpus;
unsigned long freq; unsigned long freq;
u64 power; u64 power;
int i, nr_cpus; int i, nr_cpus;
cpumask_and(&cpus, cpu_online_mask, to_cpumask(pd->cpus)); nr_cpus = cpumask_weight_and(cpu_online_mask, to_cpumask(pd->cpus));
nr_cpus = cpumask_weight(&cpus);
rcu_read_lock(); rcu_read_lock();
table = em_perf_state_from_pd(pd); table = em_perf_state_from_pd(pd);
...@@ -123,11 +121,9 @@ static int update_pd_power_uw(struct dtpm *dtpm) ...@@ -123,11 +121,9 @@ static int update_pd_power_uw(struct dtpm *dtpm)
struct dtpm_cpu *dtpm_cpu = to_dtpm_cpu(dtpm); struct dtpm_cpu *dtpm_cpu = to_dtpm_cpu(dtpm);
struct em_perf_domain *em = em_cpu_get(dtpm_cpu->cpu); struct em_perf_domain *em = em_cpu_get(dtpm_cpu->cpu);
struct em_perf_state *table; struct em_perf_state *table;
struct cpumask cpus;
int nr_cpus; int nr_cpus;
cpumask_and(&cpus, cpu_online_mask, to_cpumask(em->cpus)); nr_cpus = cpumask_weight_and(cpu_online_mask, to_cpumask(em->cpus));
nr_cpus = cpumask_weight(&cpus);
rcu_read_lock(); rcu_read_lock();
table = em_perf_state_from_pd(em); table = em_perf_state_from_pd(em);
......
This diff is collapsed.
...@@ -302,6 +302,8 @@ static int intel_rapl_tpmi_probe(struct auxiliary_device *auxdev, ...@@ -302,6 +302,8 @@ static int intel_rapl_tpmi_probe(struct auxiliary_device *auxdev,
goto err; goto err;
} }
rapl_package_add_pmu(trp->rp);
auxiliary_set_drvdata(auxdev, trp); auxiliary_set_drvdata(auxdev, trp);
return 0; return 0;
...@@ -314,6 +316,7 @@ static void intel_rapl_tpmi_remove(struct auxiliary_device *auxdev) ...@@ -314,6 +316,7 @@ static void intel_rapl_tpmi_remove(struct auxiliary_device *auxdev)
{ {
struct tpmi_rapl_package *trp = auxiliary_get_drvdata(auxdev); struct tpmi_rapl_package *trp = auxiliary_get_drvdata(auxdev);
rapl_package_remove_pmu(trp->rp);
rapl_remove_package(trp->rp); rapl_remove_package(trp->rp);
trp_release(trp); trp_release(trp);
} }
......
...@@ -158,6 +158,26 @@ struct rapl_if_priv { ...@@ -158,6 +158,26 @@ struct rapl_if_priv {
void *rpi; void *rpi;
}; };
#ifdef CONFIG_PERF_EVENTS
/**
* struct rapl_package_pmu_data: Per package data for PMU support
* @scale: Scale of 2^-32 Joules for each energy counter increase.
* @lock: Lock to protect n_active and active_list.
* @n_active: Number of active events.
* @active_list: List of active events.
* @timer_interval: Maximum timer expiration time before counter overflow.
* @hrtimer: Periodically update the counter to prevent overflow.
*/
struct rapl_package_pmu_data {
u64 scale[RAPL_DOMAIN_MAX];
raw_spinlock_t lock;
int n_active;
struct list_head active_list;
ktime_t timer_interval;
struct hrtimer hrtimer;
};
#endif
/* maximum rapl package domain name: package-%d-die-%d */ /* maximum rapl package domain name: package-%d-die-%d */
#define PACKAGE_DOMAIN_NAME_LENGTH 30 #define PACKAGE_DOMAIN_NAME_LENGTH 30
...@@ -176,6 +196,10 @@ struct rapl_package { ...@@ -176,6 +196,10 @@ struct rapl_package {
struct cpumask cpumask; struct cpumask cpumask;
char name[PACKAGE_DOMAIN_NAME_LENGTH]; char name[PACKAGE_DOMAIN_NAME_LENGTH];
struct rapl_if_priv *priv; struct rapl_if_priv *priv;
#ifdef CONFIG_PERF_EVENTS
bool has_pmu;
struct rapl_package_pmu_data pmu_data;
#endif
}; };
struct rapl_package *rapl_find_package_domain_cpuslocked(int id, struct rapl_if_priv *priv, struct rapl_package *rapl_find_package_domain_cpuslocked(int id, struct rapl_if_priv *priv,
...@@ -188,4 +212,12 @@ struct rapl_package *rapl_find_package_domain(int id, struct rapl_if_priv *priv, ...@@ -188,4 +212,12 @@ struct rapl_package *rapl_find_package_domain(int id, struct rapl_if_priv *priv,
struct rapl_package *rapl_add_package(int id, struct rapl_if_priv *priv, bool id_is_cpu); struct rapl_package *rapl_add_package(int id, struct rapl_if_priv *priv, bool id_is_cpu);
void rapl_remove_package(struct rapl_package *rp); void rapl_remove_package(struct rapl_package *rp);
#ifdef CONFIG_PERF_EVENTS
int rapl_package_add_pmu(struct rapl_package *rp);
void rapl_package_remove_pmu(struct rapl_package *rp);
#else
static inline int rapl_package_add_pmu(struct rapl_package *rp) { return 0; }
static inline void rapl_package_remove_pmu(struct rapl_package *rp) { }
#endif
#endif /* __INTEL_RAPL_H__ */ #endif /* __INTEL_RAPL_H__ */
...@@ -107,7 +107,7 @@ extern void wakeup_sources_read_unlock(int idx); ...@@ -107,7 +107,7 @@ extern void wakeup_sources_read_unlock(int idx);
extern struct wakeup_source *wakeup_sources_walk_start(void); extern struct wakeup_source *wakeup_sources_walk_start(void);
extern struct wakeup_source *wakeup_sources_walk_next(struct wakeup_source *ws); extern struct wakeup_source *wakeup_sources_walk_next(struct wakeup_source *ws);
extern int device_wakeup_enable(struct device *dev); extern int device_wakeup_enable(struct device *dev);
extern int device_wakeup_disable(struct device *dev); extern void device_wakeup_disable(struct device *dev);
extern void device_set_wakeup_capable(struct device *dev, bool capable); extern void device_set_wakeup_capable(struct device *dev, bool capable);
extern int device_set_wakeup_enable(struct device *dev, bool enable); extern int device_set_wakeup_enable(struct device *dev, bool enable);
extern void __pm_stay_awake(struct wakeup_source *ws); extern void __pm_stay_awake(struct wakeup_source *ws);
...@@ -154,10 +154,9 @@ static inline int device_wakeup_enable(struct device *dev) ...@@ -154,10 +154,9 @@ static inline int device_wakeup_enable(struct device *dev)
return 0; return 0;
} }
static inline int device_wakeup_disable(struct device *dev) static inline void device_wakeup_disable(struct device *dev)
{ {
dev->power.should_wakeup = false; dev->power.should_wakeup = false;
return 0;
} }
static inline int device_set_wakeup_enable(struct device *dev, bool enable) static inline int device_set_wakeup_enable(struct device *dev, bool enable)
...@@ -235,11 +234,10 @@ static inline int device_init_wakeup(struct device *dev, bool enable) ...@@ -235,11 +234,10 @@ static inline int device_init_wakeup(struct device *dev, bool enable)
if (enable) { if (enable) {
device_set_wakeup_capable(dev, true); device_set_wakeup_capable(dev, true);
return device_wakeup_enable(dev); return device_wakeup_enable(dev);
} else { }
device_wakeup_disable(dev); device_wakeup_disable(dev);
device_set_wakeup_capable(dev, false); device_set_wakeup_capable(dev, false);
return 0; return 0;
}
} }
#endif /* _LINUX_PM_WAKEUP_H */ #endif /* _LINUX_PM_WAKEUP_H */
...@@ -1361,7 +1361,7 @@ static int __init resume_setup(char *str) ...@@ -1361,7 +1361,7 @@ static int __init resume_setup(char *str)
if (noresume) if (noresume)
return 1; return 1;
strncpy(resume_file, str, 255); strscpy(resume_file, str);
return 1; return 1;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment