soc/cores/clock/ECP5PLL: add CLKI_DIV support.

This commit is contained in:
Florent Kermarrec 2020-04-03 11:14:57 +02:00
parent 27f00851d0
commit 6043108376

View file

@ -598,6 +598,7 @@ class iCE40PLL(Module):
class ECP5PLL(Module): class ECP5PLL(Module):
nclkouts_max = 3 nclkouts_max = 3
clki_div_range = (1, 128+1)
clkfb_div_range = (1, 128+1) clkfb_div_range = (1, 128+1)
clko_div_range = (1, 128+1) clko_div_range = (1, 128+1)
clki_freq_range = ( 8e6, 400e6) clki_freq_range = ( 8e6, 400e6)
@ -641,31 +642,32 @@ class ECP5PLL(Module):
def compute_config(self): def compute_config(self):
config = {} config = {}
config["clki_div"] = 1 for clki_div in range(*self.clki_div_range):
for clkfb_div in range(*self.clkfb_div_range): config["clki_div"] = clki_div
all_valid = True for clkfb_div in range(*self.clkfb_div_range):
vco_freq = self.clkin_freq*clkfb_div*1 # clkos3_div=1 all_valid = True
(vco_freq_min, vco_freq_max) = self.vco_freq_range vco_freq = self.clkin_freq/clki_div*clkfb_div*1 # clkos3_div=1
if vco_freq >= vco_freq_min and vco_freq <= vco_freq_max: (vco_freq_min, vco_freq_max) = self.vco_freq_range
for n, (clk, f, p, m) in sorted(self.clkouts.items()): if vco_freq >= vco_freq_min and vco_freq <= vco_freq_max:
valid = False for n, (clk, f, p, m) in sorted(self.clkouts.items()):
for d in range(*self.clko_div_range): valid = False
clk_freq = vco_freq/d for d in range(*self.clko_div_range):
if abs(clk_freq - f) <= f*m: clk_freq = vco_freq/d
config["clko{}_freq".format(n)] = clk_freq if abs(clk_freq - f) <= f*m:
config["clko{}_div".format(n)] = d config["clko{}_freq".format(n)] = clk_freq
config["clko{}_phase".format(n)] = p config["clko{}_div".format(n)] = d
valid = True config["clko{}_phase".format(n)] = p
break valid = True
if not valid: break
all_valid = False if not valid:
else: all_valid = False
all_valid = False else:
if all_valid: all_valid = False
config["vco"] = vco_freq if all_valid:
config["clkfb_div"] = clkfb_div config["vco"] = vco_freq
compute_config_log(self.logger, config) config["clkfb_div"] = clkfb_div
return config compute_config_log(self.logger, config)
return config
raise ValueError("No PLL config found") raise ValueError("No PLL config found")
def do_finalize(self): def do_finalize(self):
@ -684,7 +686,7 @@ class ECP5PLL(Module):
p_CLKOS3_ENABLE = "ENABLED", p_CLKOS3_ENABLE = "ENABLED",
p_CLKOS3_DIV = 1, p_CLKOS3_DIV = 1,
p_CLKFB_DIV = config["clkfb_div"], p_CLKFB_DIV = config["clkfb_div"],
p_CLKI_DIV = 1, p_CLKI_DIV = config["clki_div"],
) )
for n, (clk, f, p, m) in sorted(self.clkouts.items()): for n, (clk, f, p, m) in sorted(self.clkouts.items()):
n_to_l = {0: "P", 1: "S", 2: "S2"} n_to_l = {0: "P", 1: "S", 2: "S2"}