From fd125a506ffbb196c5ec7fe1269c1cd4d40c8aa2 Mon Sep 17 00:00:00 2001 From: linuswck Date: Fri, 10 Jan 2025 12:40:05 +0800 Subject: [PATCH] gateware: sys freq 100MHz -> 125MHz --- .../linien-gateware/fast_servo_platform.py | 2 +- fast-servo/linien-gateware/fast_servo_soc.py | 14 ++++++------- fast-servo/pyfastservo/si5340.py | 20 +++++++++---------- 3 files changed, 18 insertions(+), 18 deletions(-) diff --git a/fast-servo/linien-gateware/fast_servo_platform.py b/fast-servo/linien-gateware/fast_servo_platform.py index 0ffbe04..45ddd91 100644 --- a/fast-servo/linien-gateware/fast_servo_platform.py +++ b/fast-servo/linien-gateware/fast_servo_platform.py @@ -318,7 +318,7 @@ ps7_config_board_preset = { class Platform(XilinxPlatform): default_clk_name = "adc_dco_clk_p" - default_clk_period = 5.0 + default_clk_period = 4.0 def __init__(self): XilinxPlatform.__init__(self, "xc7z015-clg485-1", _io, _connector_gpio + _connector_eem, toolchain="vivado") diff --git a/fast-servo/linien-gateware/fast_servo_soc.py b/fast-servo/linien-gateware/fast_servo_soc.py index 8af27bd..29b1725 100644 --- a/fast-servo/linien-gateware/fast_servo_soc.py +++ b/fast-servo/linien-gateware/fast_servo_soc.py @@ -31,7 +31,7 @@ from fast_servo.gateware.cores.spi_phy import SpiInterface, SpiPhy class CRG(Module): - def __init__(self, platform, dco_freq=200e6): + def __init__(self, platform, dco_freq=250e6): self.ps_rst = Signal() self.locked = Signal() @@ -69,7 +69,7 @@ class CRG(Module): p_BANDWIDTH="OPTIMIZED", p_DIVCLK_DIVIDE=1, p_CLKFBOUT_PHASE=0.0, - p_CLKFBOUT_MULT_F=4, # VCO @ 800 MHz + p_CLKFBOUT_MULT_F=4, # VCO @ 1000 MHz p_CLKIN1_PERIOD=(1e9 / dco_freq), p_REF_JITTER1=0.06, # From LTC2195 Datasheet p_STARTUP_WAIT="FALSE", @@ -83,23 +83,23 @@ class CRG(Module): p_CLKOUT0_DIVIDE_F=8, p_CLKOUT0_PHASE=45.0, p_CLKOUT0_DUTY_CYCLE=0.5, - o_CLKOUT0=clk_sys_45_degree, # 800MHz / 8 -> 100MHz + o_CLKOUT0=clk_sys_45_degree, # 1000MHz / 8 -> 125MHz o_LOCKED=self.locked, p_CLKOUT1_DIVIDE=8, p_CLKOUT1_PHASE=0.0, p_CLKOUT1_DUTY_CYCLE=0.5, - o_CLKOUT1=clk_sys, # 800MHz / 8 -> 100MHz + o_CLKOUT1=clk_sys, # 1000MHz / 8 -> 120MHz p_CLKOUT2_DIVIDE=4, p_CLKOUT2_PHASE=0.0, p_CLKOUT2_DUTY_CYCLE=0.5, - o_CLKOUT2=clk_sys_double, # 800MHz / 4 -> 200MHz + o_CLKOUT2=clk_sys_double, # 1000MHz / 4 -> 250MHz - p_CLKOUT3_DIVIDE=4, + p_CLKOUT3_DIVIDE=5, p_CLKOUT3_PHASE=0.0, p_CLKOUT3_DUTY_CYCLE=0.5, - o_CLKOUT3=clk_idelay, # 800MHz / 4 -> 200MHz + o_CLKOUT3=clk_idelay, # 1000MHz / 5 -> 200MHz i_PSCLK=ClockSignal(), i_PSEN=self.ddr_clk_phase_shift_en, diff --git a/fast-servo/pyfastservo/si5340.py b/fast-servo/pyfastservo/si5340.py index 2cc5b74..7001106 100644 --- a/fast-servo/pyfastservo/si5340.py +++ b/fast-servo/pyfastservo/si5340.py @@ -143,8 +143,8 @@ def configure_si5340(): (0x0235, 0x00), # M_NUM (0x0236, 0x00), (0x0237, 0x00), - (0x0238, 0x80), - (0x0239, 0x89), + (0x0238, 0xA0), + (0x0239, 0x8C), (0x023A, 0x00), (0x023B, 0x00), # M_DEN (0x023C, 0x00), @@ -156,13 +156,13 @@ def configure_si5340(): (0x0303, 0x00), (0x0304, 0x00), (0x0305, 0x00), - (0x0306, 0x21), + (0x0306, 0x1B), (0x0307, 0x00), (0x0308, 0x00), # N0_DEN (0x0309, 0x00), (0x030A, 0x00), (0x030B, 0x80), - (0x030C, 0x01), # N0_UPDATE + (0x030C, 0x01), # N0_UPDATE # N1 Configuration (1:1 ratio) (0x030D, 0x00), # N1_NUM @@ -170,11 +170,11 @@ def configure_si5340(): (0x030F, 0x00), (0x0310, 0x00), (0x0311, 0x00), - (0x0312, 0x01), + (0x0312, 0x00), (0x0313, 0x00), # N1_DEN (0x0314, 0x00), (0x0315, 0x00), - (0x0316, 0x01), + (0x0316, 0x00), (0x0317, 0x01), # N1_UPDATE # N2 Configuration (1:1 ratio) @@ -183,11 +183,11 @@ def configure_si5340(): (0x031A, 0x00), (0x031B, 0x00), (0x031C, 0x00), - (0x031D, 0x01), + (0x031D, 0x00), (0x031E, 0x00), # N2_DEN (0x031F, 0x00), (0x0320, 0x00), - (0x0321, 0x01), + (0x0321, 0x00), (0x0322, 0x01), # N2_UPDATE # N3 Configuration (1:1 ratio) @@ -196,11 +196,11 @@ def configure_si5340(): (0x0325, 0x00), (0x0326, 0x00), (0x0327, 0x00), - (0x0328, 0x01), + (0x0328, 0x00), (0x0329, 0x00), # N3_DEN (0x032A, 0x00), (0x032B, 0x00), - (0x032C, 0x01), + (0x032C, 0x00), (0x032D, 0x01), # N3_UPDATE # Output configuration