 27c9d80f51
			
		
	
	27c9d80f51
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			109 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From fd59b838dd90452f61a17dc9e5ff175205003068 Mon Sep 17 00:00:00 2001
 | |
| From: Christian Marangi <ansuelsmth@gmail.com>
 | |
| Date: Thu, 15 Sep 2022 18:49:43 +0200
 | |
| Subject: [PATCH] OPP: Provide old opp to config_clks on _set_opp
 | |
| 
 | |
| With the target opp, also pass the old opp to config_clks function.
 | |
| This can be useful when a driver needs to take decision on what fequency
 | |
| to set based on what is the current frequency without using a
 | |
| clk_get_freq call.
 | |
| Update the only user of custom config_clks (tegra30 devfreq driver) to
 | |
| this new implementation.
 | |
| 
 | |
| Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
 | |
| ---
 | |
|  drivers/devfreq/tegra30-devfreq.c |  5 +++--
 | |
|  drivers/opp/core.c                | 11 ++++++-----
 | |
|  include/linux/pm_opp.h            | 11 ++++++-----
 | |
|  3 files changed, 15 insertions(+), 12 deletions(-)
 | |
| 
 | |
| --- a/drivers/devfreq/tegra30-devfreq.c
 | |
| +++ b/drivers/devfreq/tegra30-devfreq.c
 | |
| @@ -823,8 +823,9 @@ static int devm_tegra_devfreq_init_hw(st
 | |
|  
 | |
|  static int tegra_devfreq_config_clks_nop(struct device *dev,
 | |
|  					 struct opp_table *opp_table,
 | |
| -					 struct dev_pm_opp *opp, void *data,
 | |
| -					 bool scaling_down)
 | |
| +					 struct dev_pm_opp *old_opp,
 | |
| +					 struct dev_pm_opp *opp,
 | |
| +					 void *data, bool scaling_down)
 | |
|  {
 | |
|  	/* We want to skip clk configuration via dev_pm_opp_set_opp() */
 | |
|  	return 0;
 | |
| --- a/drivers/opp/core.c
 | |
| +++ b/drivers/opp/core.c
 | |
| @@ -902,7 +902,8 @@ static int _set_opp_voltage(struct devic
 | |
|  
 | |
|  static int
 | |
|  _opp_config_clk_single(struct device *dev, struct opp_table *opp_table,
 | |
| -		       struct dev_pm_opp *opp, void *data, bool scaling_down)
 | |
| +		       struct dev_pm_opp *old_opp, struct dev_pm_opp *opp,
 | |
| +		       void *data, bool scaling_down)
 | |
|  {
 | |
|  	unsigned long *target = data;
 | |
|  	unsigned long freq;
 | |
| @@ -934,8 +935,8 @@ _opp_config_clk_single(struct device *de
 | |
|   * the order in which they are present in the array while scaling up.
 | |
|   */
 | |
|  int dev_pm_opp_config_clks_simple(struct device *dev,
 | |
| -		struct opp_table *opp_table, struct dev_pm_opp *opp, void *data,
 | |
| -		bool scaling_down)
 | |
| +		struct opp_table *opp_table, struct dev_pm_opp *old_opp,
 | |
| +		struct dev_pm_opp *opp, void *data, bool scaling_down)
 | |
|  {
 | |
|  	int ret, i;
 | |
|  
 | |
| @@ -1217,7 +1218,7 @@ static int _set_opp(struct device *dev,
 | |
|  	}
 | |
|  
 | |
|  	if (opp_table->config_clks) {
 | |
| -		ret = opp_table->config_clks(dev, opp_table, opp, clk_data, scaling_down);
 | |
| +		ret = opp_table->config_clks(dev, opp_table, old_opp, opp, clk_data, scaling_down);
 | |
|  		if (ret)
 | |
|  			return ret;
 | |
|  	}
 | |
| @@ -1292,7 +1293,7 @@ int dev_pm_opp_set_rate(struct device *d
 | |
|  		 * equivalent to a clk_set_rate()
 | |
|  		 */
 | |
|  		if (!_get_opp_count(opp_table)) {
 | |
| -			ret = opp_table->config_clks(dev, opp_table, NULL,
 | |
| +			ret = opp_table->config_clks(dev, opp_table, NULL, NULL,
 | |
|  						     &target_freq, false);
 | |
|  			goto put_opp_table;
 | |
|  		}
 | |
| --- a/include/linux/pm_opp.h
 | |
| +++ b/include/linux/pm_opp.h
 | |
| @@ -61,7 +61,8 @@ typedef int (*config_regulators_t)(struc
 | |
|  			struct dev_pm_opp *old_opp, struct dev_pm_opp *new_opp,
 | |
|  			struct regulator **regulators, unsigned int count);
 | |
|  
 | |
| -typedef int (*config_clks_t)(struct device *dev, struct opp_table *opp_table,
 | |
| +typedef int (*config_clks_t)(struct device *dev,
 | |
| +			struct opp_table *opp_table, struct dev_pm_opp *old_opp,
 | |
|  			struct dev_pm_opp *opp, void *data, bool scaling_down);
 | |
|  
 | |
|  /**
 | |
| @@ -172,8 +173,8 @@ int dev_pm_opp_set_config(struct device
 | |
|  int devm_pm_opp_set_config(struct device *dev, struct dev_pm_opp_config *config);
 | |
|  void dev_pm_opp_clear_config(int token);
 | |
|  int dev_pm_opp_config_clks_simple(struct device *dev,
 | |
| -		struct opp_table *opp_table, struct dev_pm_opp *opp, void *data,
 | |
| -		bool scaling_down);
 | |
| +		struct opp_table *opp_table, struct dev_pm_opp *old_opp,
 | |
| +		struct dev_pm_opp *opp, void *data, bool scaling_down);
 | |
|  
 | |
|  struct dev_pm_opp *dev_pm_opp_xlate_required_opp(struct opp_table *src_table, struct opp_table *dst_table, struct dev_pm_opp *src_opp);
 | |
|  int dev_pm_opp_xlate_performance_state(struct opp_table *src_table, struct opp_table *dst_table, unsigned int pstate);
 | |
| @@ -377,8 +378,8 @@ static inline int devm_pm_opp_set_config
 | |
|  static inline void dev_pm_opp_clear_config(int token) {}
 | |
|  
 | |
|  static inline int dev_pm_opp_config_clks_simple(struct device *dev,
 | |
| -		struct opp_table *opp_table, struct dev_pm_opp *opp, void *data,
 | |
| -		bool scaling_down)
 | |
| +		struct opp_table *opp_table, struct dev_pm_opp *old_opp,
 | |
| +		struct dev_pm_opp *opp, void *data, bool scaling_down)
 | |
|  {
 | |
|  	return -EOPNOTSUPP;
 | |
|  }
 |