diff options
Diffstat (limited to 'mpm/python/usrp_mpm/chips/lmk04828.py')
-rw-r--r-- | mpm/python/usrp_mpm/chips/lmk04828.py | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/mpm/python/usrp_mpm/chips/lmk04828.py b/mpm/python/usrp_mpm/chips/lmk04828.py index 3b9a35bae..a67ca05fd 100644 --- a/mpm/python/usrp_mpm/chips/lmk04828.py +++ b/mpm/python/usrp_mpm/chips/lmk04828.py @@ -28,7 +28,7 @@ class LMK04828(object): def __init__(self, regs_iface, postfix=None): postfix = postfix or "" - self.log = get_logger("LMK04828"+postfix) + self.log = get_logger("LMK04828{}".format(postfix)) self.regs_iface = regs_iface assert hasattr(self.regs_iface, 'peek8') assert hasattr(self.regs_iface, 'poke8') @@ -41,13 +41,13 @@ class LMK04828(object): pokes8((0,1),(0,2)) is the same as calling poke8(0,1), poke8(0,2). """ for addr, val in addr_vals: - self.regs_iface.poke8(addr, val) + self.poke8(addr, val) def get_chip_id(self): """ Read back the chip ID """ - chip_id = self.regs_iface.peek8(0x03) + chip_id = self.peek8(0x03) self.log.trace("Read chip ID: {}".format(chip_id)) return chip_id @@ -61,3 +61,25 @@ class LMK04828(object): return False return True + def check_plls_locked(self): + """ + Checks both PLLs are locked. Will throw an exception otherwise. + Returns True if both PLLs are locked, False otherwise. + """ + self.log.trace("Checking PLL lock bits...") + def check_pll_lock(pll_id, addr): + """ + + pll_id -- A string defining the PLL (e.g. 'PLL1') + addr -- The address to peek to see if it's locked + """ + pll_lock_status = self.regs_iface.peek8(addr) + if (pll_lock_status & 0x7) != 0x02: + self.log.error("LMK {} did not lock. Status: {:x}".format(pll_id, pll_lock_status)) + return False + return True + lock_status = \ + check_pll_lock("PLL1", 0x182) and \ + check_pll_lock("PLL2", 0x183) + return lock_status + |