diff options
author | Harald Welte <laforge@gnumonks.org> | 2018-04-28 21:38:58 +0200 |
---|---|---|
committer | Pau Espin Pedrol <pespin@sysmocom.de> | 2018-05-25 17:14:43 +0200 |
commit | 7ca30375c96c04a0764d969a4ed355eff24720b7 (patch) | |
tree | 418e5e3959f248b98ae5ad2f9415679d8ec43b96 | |
parent | ce092147ac0af9c2fbcec860bcf1c2cd9fa4de06 (diff) |
LMSDevice: Call LMS_Init() before setting sample rate
LMS_Init() will override basically all device settings with their
default value, including the sample rate. We hence have to make sure
to call it before any other API function that changes the device config
such as sample rate, frequency, filter bandwidth, ...
Change-Id: I4cdbae8406b5e1e93da491e90f8bad41d4be748b
-rw-r--r-- | Transceiver52M/device/lms/LMSDevice.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/Transceiver52M/device/lms/LMSDevice.cpp b/Transceiver52M/device/lms/LMSDevice.cpp index 603b23d..0442e27 100644 --- a/Transceiver52M/device/lms/LMSDevice.cpp +++ b/Transceiver52M/device/lms/LMSDevice.cpp @@ -112,6 +112,12 @@ int LMSDevice::open(const std::string &args, int ref, bool swap_channels) delete [] info_list; + LOG(INFO) << "Init LMS device"; + if (LMS_Init(m_lms_dev) != 0) { + LOG(ERROR) << "LMS_Init() failed"; + return -1; + } + LOG(DEBUG) << "Setting sample rate to " << GSMRATE*sps << " " << sps; if (LMS_SetSampleRate(m_lms_dev, GSMRATE*sps, 32) < 0) goto out_close; @@ -139,10 +145,6 @@ int LMSDevice::open(const std::string &args, int ref, bool swap_channels) goto out_close; } - LOG(INFO) << "Init LMS device"; - if (LMS_Init(m_lms_dev) < 0) - goto out_close; - /* Perform Rx and Tx calibration */ for (i=0; i<chans; i++) { LOG(INFO) << "Calibrating chan " << i; |