mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-15 12:07:12 +07:00
1b2d4ad585
The patch corrects the case when the rate table is being scanned for a given frequency, and the search frequency is beyond the maximum frequency indexed in the table. By default, the system should be set at max frequency present in the rate table. This patch correctly returns the corresponding index value. Signed-off-by: Deepak Sikri <deepak.sikri@st.com> Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org> Signed-off-by: Mike Turquette <mturquette@linaro.org>
40 lines
883 B
C
40 lines
883 B
C
/*
|
|
* Copyright (C) 2012 ST Microelectronics
|
|
* Viresh Kumar <viresh.linux@gmail.com>
|
|
*
|
|
* This file is licensed under the terms of the GNU General Public
|
|
* License version 2. This program is licensed "as is" without any
|
|
* warranty of any kind, whether express or implied.
|
|
*
|
|
* SPEAr clk - Common routines
|
|
*/
|
|
|
|
#include <linux/clk-provider.h>
|
|
#include <linux/types.h>
|
|
#include "clk.h"
|
|
|
|
long clk_round_rate_index(struct clk_hw *hw, unsigned long drate,
|
|
unsigned long parent_rate, clk_calc_rate calc_rate, u8 rtbl_cnt,
|
|
int *index)
|
|
{
|
|
unsigned long prev_rate, rate = 0;
|
|
|
|
for (*index = 0; *index < rtbl_cnt; (*index)++) {
|
|
prev_rate = rate;
|
|
rate = calc_rate(hw, parent_rate, *index);
|
|
if (drate < rate) {
|
|
/* previous clock was best */
|
|
if (*index) {
|
|
rate = prev_rate;
|
|
(*index)--;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
if ((*index) == rtbl_cnt)
|
|
(*index)--;
|
|
|
|
return rate;
|
|
}
|