aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--.gitignore1
-rw-r--r--Transceiver52M/device/lms/LMSDevice.cpp42
-rwxr-xr-xtests/Transceiver52M/ConvolveTestbin0 -> 68904 bytes
-rw-r--r--tests/Transceiver52M/LMSDeviceTest.cpp45
-rw-r--r--tests/Transceiver52M/Makefile.am9
-rw-r--r--tests/testsuite.at6
6 files changed, 101 insertions, 2 deletions
diff --git a/.gitignore b/.gitignore
index ad4c4e3..f163fb6 100644
--- a/.gitignore
+++ b/.gitignore
@@ -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
new file mode 100755
index 0000000..b9af2f5
--- /dev/null
+++ b/tests/Transceiver52M/ConvolveTest
Binary files differ
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