diff options
author | Oliver Smith <osmith@sysmocom.de> | 2018-12-10 17:10:36 +0100 |
---|---|---|
committer | Oliver Smith <osmith@sysmocom.de> | 2018-12-13 11:07:02 +0100 |
commit | 871713bf6acc823115f59427855e96549a5be2ac (patch) | |
tree | 8725985d07b57c285a56a2e898154fd6c7d1498d /Transceiver52M/device | |
parent | 8d9a05ce5bebb2df636e235e7d568569426e872d (diff) |
LMSDevice: make use of dev-args in osmo-trx.cfg
Allow selecting a specific LimeSDR device by setting dev-args in the
config file. Split up the given dev-args address by comma and select
the device where all substrings can be found.
I could not test this with real hardware, but I have added a test case
to make sure this works as expected.
Related: OS#3654
Change-Id: Ib9aaa066a01bf9de3f78234d7ada884d6f28c852
Diffstat (limited to 'Transceiver52M/device')
-rw-r--r-- | Transceiver52M/device/lms/LMSDevice.cpp | 42 |
1 files changed, 40 insertions, 2 deletions
diff --git a/Transceiver52M/device/lms/LMSDevice.cpp b/Transceiver52M/device/lms/LMSDevice.cpp index 5e21894..270bd4a 100644 --- a/Transceiver52M/device/lms/LMSDevice.cpp +++ b/Transceiver52M/device/lms/LMSDevice.cpp @@ -21,6 +21,7 @@ #include "Logger.h" #include "Threads.h" #include "LMSDevice.h" +#include "Utils.h" #include <lime/LimeSuite.h> @@ -95,6 +96,35 @@ static void print_range(const char* name, lms_range_t *range) << " Step=" << range->step; } +/*! Find the device string that matches all filters from \a args. + * \param[in] info_list device addresses found by LMS_GetDeviceList() + * \param[in] count length of info_list + * \param[in] args dev-args value from osmo-trx.cfg, containing comma separated key=value pairs + * \return index of first matching device or -1 (no match) */ +int info_list_find(lms_info_str_t* info_list, unsigned int count, const std::string &args) +{ + unsigned int i, j; + vector<string> filters; + + filters = comma_delimited_to_vector(args.c_str()); + + /* iterate over device addresses */ + for (i=0; i < count; i++) { + /* check if all filters match */ + bool match = true; + for (j=0; j < filters.size(); j++) { + if (!strstr(info_list[i], filters[j].c_str())) { + match = false; + break; + } + } + + if (match) + return i; + } + return -1; +} + int LMSDevice::open(const std::string &args, int ref, bool swap_channels) { //lms_info_str_t dev_str; @@ -103,7 +133,7 @@ int LMSDevice::open(const std::string &args, int ref, bool swap_channels) float_type sr_host, sr_rf, lpfbw_rx, lpfbw_tx; uint16_t dac_val; unsigned int i, n; - int rc; + int rc, dev_id; LOGC(DDEV, INFO) << "Opening LMS device.."; @@ -123,7 +153,15 @@ int LMSDevice::open(const std::string &args, int ref, bool swap_channels) for (i = 0; i < n; i++) LOGC(DDEV, INFO) << "Device [" << i << "]: " << info_list[i]; - rc = LMS_Open(&m_lms_dev, info_list[0], NULL); + dev_id = info_list_find(info_list, n, args); + if (dev_id == -1) { + LOGC(DDEV, ERROR) << "No LMS device found with address '" << args << "'"; + delete[] info_list; + return -1; + } + + LOGC(DDEV, INFO) << "Using device[" << dev_id << "]"; + rc = LMS_Open(&m_lms_dev, info_list[dev_id], NULL); if (rc != 0) { LOGC(DDEV, ERROR) << "LMS_GetDeviceList() failed)"; delete [] info_list; |