Commit b16fb669 authored by Jernej Skrabec's avatar Jernej Skrabec Committed by Maxime Ripard

clk: sunxi-ng: r40: Add max. rate constraint to video PLLs

Video PLLs on R40 can be set to higher rate that it is actually
supported by HW.

Limit maximum rate to 1008 MHz. This is the maximum allowed rate by BSP
clock driver. Interestengly, user manual specifies maximum frequency to
be 600 MHz. Historically, this data was wrong in some user manuals for
other SoCs, so more faith is put in BSP clock driver.
Signed-off-by: default avatarJernej Skrabec <jernej.skrabec@siol.net>
Signed-off-by: default avatarMaxime Ripard <maxime.ripard@bootlin.com>
parent 02d79016
...@@ -65,19 +65,19 @@ static SUNXI_CCU_NM_WITH_GATE_LOCK(pll_audio_base_clk, "pll-audio-base", ...@@ -65,19 +65,19 @@ static SUNXI_CCU_NM_WITH_GATE_LOCK(pll_audio_base_clk, "pll-audio-base",
BIT(28), /* lock */ BIT(28), /* lock */
CLK_SET_RATE_UNGATE); CLK_SET_RATE_UNGATE);
/* TODO: The result of N/M is required to be in [8, 25] range. */ static SUNXI_CCU_NM_WITH_FRAC_GATE_LOCK_MIN_MAX(pll_video0_clk, "pll-video0",
static SUNXI_CCU_NM_WITH_FRAC_GATE_LOCK_MIN(pll_video0_clk, "pll-video0", "osc24M", 0x0010,
"osc24M", 0x0010, 192000000, /* Minimum rate */
192000000, /* Minimum rate */ 1008000000, /* Maximum rate */
8, 7, /* N */ 8, 7, /* N */
0, 4, /* M */ 0, 4, /* M */
BIT(24), /* frac enable */ BIT(24), /* frac enable */
BIT(25), /* frac select */ BIT(25), /* frac select */
270000000, /* frac rate 0 */ 270000000, /* frac rate 0 */
297000000, /* frac rate 1 */ 297000000, /* frac rate 1 */
BIT(31), /* gate */ BIT(31), /* gate */
BIT(28), /* lock */ BIT(28), /* lock */
CLK_SET_RATE_UNGATE); CLK_SET_RATE_UNGATE);
/* TODO: The result of N/M is required to be in [8, 25] range. */ /* TODO: The result of N/M is required to be in [8, 25] range. */
static SUNXI_CCU_NM_WITH_FRAC_GATE_LOCK(pll_ve_clk, "pll-ve", static SUNXI_CCU_NM_WITH_FRAC_GATE_LOCK(pll_ve_clk, "pll-ve",
...@@ -152,19 +152,19 @@ static struct ccu_nk pll_periph1_clk = { ...@@ -152,19 +152,19 @@ static struct ccu_nk pll_periph1_clk = {
}, },
}; };
/* TODO: The result of N/M is required to be in [8, 25] range. */ static SUNXI_CCU_NM_WITH_FRAC_GATE_LOCK_MIN_MAX(pll_video1_clk, "pll-video1",
static SUNXI_CCU_NM_WITH_FRAC_GATE_LOCK_MIN(pll_video1_clk, "pll-video1", "osc24M", 0x030,
"osc24M", 0x030, 192000000, /* Minimum rate */
192000000, /* Minimum rate */ 1008000000, /* Maximum rate */
8, 7, /* N */ 8, 7, /* N */
0, 4, /* M */ 0, 4, /* M */
BIT(24), /* frac enable */ BIT(24), /* frac enable */
BIT(25), /* frac select */ BIT(25), /* frac select */
270000000, /* frac rate 0 */ 270000000, /* frac rate 0 */
297000000, /* frac rate 1 */ 297000000, /* frac rate 1 */
BIT(31), /* gate */ BIT(31), /* gate */
BIT(28), /* lock */ BIT(28), /* lock */
CLK_SET_RATE_UNGATE); CLK_SET_RATE_UNGATE);
static struct ccu_nkm pll_sata_clk = { static struct ccu_nkm pll_sata_clk = {
.enable = BIT(31), .enable = BIT(31),
......
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