From 02dfb3e5accbeff82e47df5009f32e6764d55762 Mon Sep 17 00:00:00 2001 From: morgan Date: Fri, 16 Feb 2024 16:05:48 +0800 Subject: [PATCH] artiq_ddb_template: backport clk_div config fix add pll_en to json schema and ddb_template set CLK IN divided by 1 as default when bypassing AD9910 PLL raise ValueError when bypassing AD9912 PLL --- artiq/coredevice/coredevice_generic.schema.json | 12 ++++++++++++ artiq/frontend/artiq_ddb_template.py | 15 +++++++++++---- 2 files changed, 23 insertions(+), 4 deletions(-) diff --git a/artiq/coredevice/coredevice_generic.schema.json b/artiq/coredevice/coredevice_generic.schema.json index f69211262..21adbfa1a 100644 --- a/artiq/coredevice/coredevice_generic.schema.json +++ b/artiq/coredevice/coredevice_generic.schema.json @@ -302,6 +302,12 @@ "pll_n": { "type": "integer" }, + "pll_en": { + "type": "integer", + "minimum": 0, + "maximum": 1, + "default": 1 + }, "pll_vco": { "type": "integer" }, @@ -405,6 +411,12 @@ "type": "integer", "default": 32 }, + "pll_en": { + "type": "integer", + "minimum": 0, + "maximum": 1, + "default": 1 + }, "pll_vco": { "type": "integer" } diff --git a/artiq/frontend/artiq_ddb_template.py b/artiq/frontend/artiq_ddb_template.py index 87e20cc91..11b763261 100755 --- a/artiq/frontend/artiq_ddb_template.py +++ b/artiq/frontend/artiq_ddb_template.py @@ -173,6 +173,11 @@ class PeripheralManager: urukul_name = self.get_name("urukul") synchronization = peripheral["synchronization"] channel = count(0) + pll_en = peripheral["pll_en"] + dds = peripheral["dds"] + if dds == "ad9912" and not pll_en: + raise ValueError("PLL bypass is not supported on AD9912") + self.gen(""" device_db["eeprom_{name}"] = {{ "type": "local", @@ -231,14 +236,15 @@ class PeripheralManager: "sync_device": {sync_device}, "io_update_device": "ttl_{name}_io_update", "refclk": {refclk}, - "clk_sel": {clk_sel} + "clk_sel": {clk_sel}, + "clk_div" : {clk_div} }} }}""", name=urukul_name, sync_device="\"ttl_{name}_sync\"".format(name=urukul_name) if synchronization else "None", refclk=peripheral.get("refclk", self.master_description["rtio_frequency"]), - clk_sel=peripheral["clk_sel"]) - dds = peripheral["dds"] + clk_sel=peripheral["clk_sel"], + clk_div= 0 if pll_en else 1) pll_vco = peripheral.get("pll_vco") for i in range(4): if dds == "ad9910": @@ -248,6 +254,7 @@ class PeripheralManager: "module": "artiq.coredevice.ad9910", "class": "AD9910", "arguments": {{ + "pll_en": {pll_en}, "pll_n": {pll_n}, "chip_select": {chip_select}, "cpld_device": "{name}_cpld"{sw}{pll_vco}{sync_delay_seed}{io_update_delay} @@ -258,7 +265,7 @@ class PeripheralManager: uchn=i, sw=",\n \"sw_device\": \"ttl_{name}_sw{uchn}\"".format(name=urukul_name, uchn=i) if len(peripheral["ports"]) > 1 else "", pll_vco=",\n \"pll_vco\": {}".format(pll_vco) if pll_vco is not None else "", - pll_n=peripheral.get("pll_n", 32), + pll_n=peripheral.get("pll_n", 32), pll_en=pll_en, sync_delay_seed=",\n \"sync_delay_seed\": \"eeprom_{}:{}\"".format(urukul_name, 64 + 4*i) if synchronization else "", io_update_delay=",\n \"io_update_delay\": \"eeprom_{}:{}\"".format(urukul_name, 64 + 4*i) if synchronization else "") elif dds == "ad9912":