2019-06-04 16:11:33 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2014-05-20 15:01:53 +08:00
|
|
|
/*
|
|
|
|
* rl6231.h - RL6231 class device shared support
|
|
|
|
*
|
|
|
|
* Copyright 2014 Realtek Semiconductor Corp.
|
|
|
|
*
|
|
|
|
* Author: Oder Chiou <oder_chiou@realtek.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __RL6231_H__
|
|
|
|
#define __RL6231_H__
|
|
|
|
|
2014-05-20 15:01:54 +08:00
|
|
|
#define RL6231_PLL_INP_MAX 40000000
|
|
|
|
#define RL6231_PLL_INP_MIN 256000
|
|
|
|
#define RL6231_PLL_N_MAX 0x1ff
|
|
|
|
#define RL6231_PLL_K_MAX 0x1f
|
|
|
|
#define RL6231_PLL_M_MAX 0xf
|
|
|
|
|
|
|
|
struct rl6231_pll_code {
|
|
|
|
bool m_bp; /* Indicates bypass m code or not. */
|
|
|
|
int m_code;
|
|
|
|
int n_code;
|
|
|
|
int k_code;
|
|
|
|
};
|
|
|
|
|
2014-05-20 15:01:53 +08:00
|
|
|
int rl6231_calc_dmic_clk(int rate);
|
2014-05-20 15:01:54 +08:00
|
|
|
int rl6231_pll_calc(const unsigned int freq_in,
|
|
|
|
const unsigned int freq_out, struct rl6231_pll_code *pll_code);
|
2014-05-20 15:01:55 +08:00
|
|
|
int rl6231_get_clk_info(int sclk, int rate);
|
2015-08-05 10:03:18 +08:00
|
|
|
int rl6231_get_pre_div(struct regmap *map, unsigned int reg, int sft);
|
2014-05-20 15:01:53 +08:00
|
|
|
|
|
|
|
#endif /* __RL6231_H__ */
|