From b03564a7d59d3bf15b9b8f9f2ae8bb6d8d35d955 Mon Sep 17 00:00:00 2001 From: "Matthias P. Braendli" Date: Sat, 22 Mar 2014 22:34:04 +0100 Subject: To USRP refclk lock loss check only if refclk is not 'internal' --- src/OutputUHD.cpp | 12 +++++++++--- src/OutputUHD.h | 4 ++++ 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/src/OutputUHD.cpp b/src/OutputUHD.cpp index c9e630b..bd4231e 100644 --- a/src/OutputUHD.cpp +++ b/src/OutputUHD.cpp @@ -206,6 +206,13 @@ OutputUHD::OutputUHD( uwd.logger = &myLogger; uwd.refclk_lock_loss_behaviour = myConf.refclk_lock_loss_behaviour; + if (myConf.refclk_src == "internal") { + uwd.check_refclk_loss = false; + } + else { + uwd.check_refclk_loss = true; + } + shared_ptr b(new barrier(2)); mySyncBarrier = b; @@ -320,7 +327,6 @@ void UHDWorker::process() size_t bufsize = myTxStream->get_max_num_samps(); #endif - bool check_refclk_loss = false; const complexf* in; uhd::tx_metadata_t md; @@ -359,7 +365,7 @@ void UHDWorker::process() #if ENABLE_UHD // Check for ref_lock - if (check_refclk_loss) + if (uwd->check_refclk_loss) { try { // TODO: Is this check specific to the B100 and USRP2 ? @@ -373,7 +379,7 @@ void UHDWorker::process() } } catch (uhd::lookup_error &e) { - check_refclk_loss = false; + uwd->check_refclk_loss = false; uwd->logger->log(warn, "OutputUHD: This USRP does not have mboard sensor for ext clock loss." " Check disabled."); diff --git a/src/OutputUHD.h b/src/OutputUHD.h index 86ecaae..530a30a 100644 --- a/src/OutputUHD.h +++ b/src/OutputUHD.h @@ -105,6 +105,9 @@ struct UHDWorkerData { struct UHDWorkerFrameData frame1; size_t bufsize; // in bytes + // If we want to verify loss of refclk + bool check_refclk_loss; + // muting set by remote control bool muting; @@ -219,3 +222,4 @@ class OutputUHD: public ModOutput, public RemoteControllable { #endif // OUTPUT_UHD_H + -- cgit v1.2.3