soc: mediatek: PMIC wrap: Fix clock rate handling
replace chipselect extension values based on SPI clock with hardcoded SoC specific values. The PMIC wrapper has the ability of extending the chipselects by configurable amounts of time. We configured the values based on the rate of SPI clock, but this is wrong. The delays should be configured based on the internal PMIC clock that latches the values from the SPI bus to the internal PMIC registers. By default this clock is 24MHz. Other clock frequencies are for debugging only and can be removed from the driver. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> Signed-off-by: Matthias Brugger <matthias.bgg@gmail.com>
This commit is contained in:
parent
b787f68c36
commit
d71c11f3bd
@ -563,45 +563,17 @@ static int pwrap_init_sidly(struct pmic_wrapper *wrp)
|
|||||||
|
|
||||||
static int pwrap_init_reg_clock(struct pmic_wrapper *wrp)
|
static int pwrap_init_reg_clock(struct pmic_wrapper *wrp)
|
||||||
{
|
{
|
||||||
unsigned long rate_spi;
|
if (pwrap_is_mt8135(wrp)) {
|
||||||
int ck_mhz;
|
pwrap_writel(wrp, 0x4, PWRAP_CSHEXT);
|
||||||
|
|
||||||
rate_spi = clk_get_rate(wrp->clk_spi);
|
|
||||||
|
|
||||||
if (rate_spi > 26000000)
|
|
||||||
ck_mhz = 26;
|
|
||||||
else if (rate_spi > 18000000)
|
|
||||||
ck_mhz = 18;
|
|
||||||
else
|
|
||||||
ck_mhz = 0;
|
|
||||||
|
|
||||||
switch (ck_mhz) {
|
|
||||||
case 18:
|
|
||||||
if (pwrap_is_mt8135(wrp))
|
|
||||||
pwrap_writel(wrp, 0xc, PWRAP_CSHEXT);
|
|
||||||
pwrap_writel(wrp, 0x4, PWRAP_CSHEXT_WRITE);
|
|
||||||
pwrap_writel(wrp, 0xc, PWRAP_CSHEXT_READ);
|
|
||||||
pwrap_writel(wrp, 0x0, PWRAP_CSLEXT_START);
|
|
||||||
pwrap_writel(wrp, 0x0, PWRAP_CSLEXT_END);
|
|
||||||
break;
|
|
||||||
case 26:
|
|
||||||
if (pwrap_is_mt8135(wrp))
|
|
||||||
pwrap_writel(wrp, 0x4, PWRAP_CSHEXT);
|
|
||||||
pwrap_writel(wrp, 0x0, PWRAP_CSHEXT_WRITE);
|
pwrap_writel(wrp, 0x0, PWRAP_CSHEXT_WRITE);
|
||||||
pwrap_writel(wrp, 0x4, PWRAP_CSHEXT_READ);
|
pwrap_writel(wrp, 0x4, PWRAP_CSHEXT_READ);
|
||||||
pwrap_writel(wrp, 0x0, PWRAP_CSLEXT_START);
|
pwrap_writel(wrp, 0x0, PWRAP_CSLEXT_START);
|
||||||
pwrap_writel(wrp, 0x0, PWRAP_CSLEXT_END);
|
pwrap_writel(wrp, 0x0, PWRAP_CSLEXT_END);
|
||||||
break;
|
} else {
|
||||||
case 0:
|
pwrap_writel(wrp, 0x0, PWRAP_CSHEXT_WRITE);
|
||||||
if (pwrap_is_mt8135(wrp))
|
pwrap_writel(wrp, 0x4, PWRAP_CSHEXT_READ);
|
||||||
pwrap_writel(wrp, 0xf, PWRAP_CSHEXT);
|
pwrap_writel(wrp, 0x2, PWRAP_CSLEXT_START);
|
||||||
pwrap_writel(wrp, 0xf, PWRAP_CSHEXT_WRITE);
|
pwrap_writel(wrp, 0x2, PWRAP_CSLEXT_END);
|
||||||
pwrap_writel(wrp, 0xf, PWRAP_CSHEXT_READ);
|
|
||||||
pwrap_writel(wrp, 0xf, PWRAP_CSLEXT_START);
|
|
||||||
pwrap_writel(wrp, 0xf, PWRAP_CSLEXT_END);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user