diff options
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | Transceiver52M/device/lms/LMSDevice.cpp | 42 | ||||
-rwxr-xr-x | tests/Transceiver52M/ConvolveTest | bin | 0 -> 68904 bytes | |||
-rw-r--r-- | tests/Transceiver52M/LMSDeviceTest.cpp | 45 | ||||
-rw-r--r-- | tests/Transceiver52M/Makefile.am | 9 | ||||
-rw-r--r-- | tests/testsuite.at | 6 |
6 files changed, 101 insertions, 2 deletions
@@ -18,6 +18,7 @@ tests/CommonLibs/URLEncodeTest tests/CommonLibs/VectorTest tests/CommonLibs/PRBSTest tests/Transceiver52M/convolve_test +tests/Transceiver52M/LMSDeviceTest # automake/autoconf *.in diff --git a/Transceiver52M/device/lms/LMSDevice.cpp b/Transceiver52M/device/lms/LMSDevice.cpp index 5e21894..15e1041 100644 --- a/Transceiver52M/device/lms/LMSDevice.cpp +++ b/Transceiver52M/device/lms/LMSDevice.cpp @@ -22,6 +22,7 @@ #include "Threads.h" #include "LMSDevice.h" +#include <boost/algorithm/string.hpp> #include <lime/LimeSuite.h> #include <osmocom/core/utils.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 item 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; + + boost::split(filters, args, boost::is_any_of(",")); + + /* 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: " << info_list[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; diff --git a/tests/Transceiver52M/ConvolveTest b/tests/Transceiver52M/ConvolveTest Binary files differnew file mode 100755 index 0000000..b9af2f5 --- /dev/null +++ b/tests/Transceiver52M/ConvolveTest diff --git a/tests/Transceiver52M/LMSDeviceTest.cpp b/tests/Transceiver52M/LMSDeviceTest.cpp new file mode 100644 index 0000000..bca12df --- /dev/null +++ b/tests/Transceiver52M/LMSDeviceTest.cpp @@ -0,0 +1,45 @@ +#include <stdio.h> +#include <string> +#include <string.h> +#include <stdlib.h> +#include <assert.h> + +#include <lime/LimeSuite.h> + +extern "C" +{ + size_t osmo_strlcpy(char *dst, const char *src, size_t siz); +} + +int info_list_find(lms_info_str_t* info_list, unsigned int count, const std::string &args); + +using namespace std; + +int main(void) +{ + unsigned int count; + lms_info_str_t* info_list; + std::string args; + + /* two fake entries for info_list */ + count = 2; + info_list = new lms_info_str_t[count]; + osmo_strlcpy(info_list[0], "LimeSDR Mini, addr=24607:1337, serial=FAKESERIAL0001", sizeof(lms_info_str_t)); + osmo_strlcpy(info_list[1], "LimeSDR Mini, addr=24607:1338, serial=FAKESERIAL0002", sizeof(lms_info_str_t)); + + /* find second entry by args filter */ + args = "serial=FAKESERIAL0002,LimeSDR Mini"; + assert(info_list_find(info_list, count, args) == 1); + + /* empty args -> first entry */ + args = ""; + assert(info_list_find(info_list, count, args) == 0); + + /* not matching args -> -1 */ + args = "serial=NOTMATCHING"; + assert(info_list_find(info_list, count, args) == -1); + + /* clean up */ + delete [] info_list; + return 0; +} diff --git a/tests/Transceiver52M/Makefile.am b/tests/Transceiver52M/Makefile.am index 06db5b0..ebd84f6 100644 --- a/tests/Transceiver52M/Makefile.am +++ b/tests/Transceiver52M/Makefile.am @@ -16,3 +16,12 @@ endif if HAVE_SSE4_1 convolve_test_CFLAGS += $(SIMD_FLAGS) endif + +if DEVICE_LMS +noinst_PROGRAMS += LMSDeviceTest +LMSDeviceTest_SOURCES = LMSDeviceTest.cpp +LMSDeviceTest_LDFLAGS = $(LIBOSMOCORE_LIBS) $(LMS_LIBS) +LMSDeviceTest_LDADD = \ + $(top_builddir)/Transceiver52M/device/lms/.libs/LMSDevice.o \ + $(COMMON_LA) +endif diff --git a/tests/testsuite.at b/tests/testsuite.at index f84225e..602f163 100644 --- a/tests/testsuite.at +++ b/tests/testsuite.at @@ -51,3 +51,9 @@ AT_SKIP_IF(true) cat $abs_srcdir/Transceiver52M/convolve_test.ok > expout AT_CHECK([$abs_top_builddir/tests/Transceiver52M/convolve_test], [], [expout], []) AT_CLEANUP + +AT_SETUP([LMSDeviceTest]) +AT_KEYWORDS([LMSDeviceTest]) +AT_SKIP_IF([! test -e $abs_top_builddir/tests/Transceiver52M/LMSDeviceTest]) +AT_CHECK([$abs_top_builddir/tests/Transceiver52M/LMSDeviceTest], [], [], []) +AT_CLEANUP |