From 698f040f0b62baa59ce45da890a16e9155890c70 Mon Sep 17 00:00:00 2001 From: Philip Balister Date: Thu, 28 Apr 2016 13:53:55 -0400 Subject: docs: Update E310 documentation. Provide some more background on when you need to cross compile UHD and install it on the E310. Clarify image build process. Signed-off-by: Philip Balister --- host/docs/usrp_e3x0.dox | 36 ++++++++++++++++++++++++++++++------ 1 file changed, 30 insertions(+), 6 deletions(-) diff --git a/host/docs/usrp_e3x0.dox b/host/docs/usrp_e3x0.dox index 64e784399..1a94e6c7e 100644 --- a/host/docs/usrp_e3x0.dox +++ b/host/docs/usrp_e3x0.dox @@ -102,7 +102,7 @@ If you are not sure which image is installed on your device, upgrading to the la To install the toolchain you downloaded type: - $ ./oecore-${TCLIBC}-${SDK_ARCH}-${IMAGE_BASENAME}-${TUNE_PKGARCH}.sh + $ ./oecore-x86_64-armv7ahf-vfp-neon-toolchain-nodistro.0.sh This will prompt you for an installation path. Please ensure you have sufficient disk space, as each of the SDKs may require several gigabytes of disk space (depends on the image flavor selected). @@ -127,17 +127,24 @@ which should return 'arm-oe-linux-gnueabi'. \subsubsection e3x0_sdk_usage_uhd Building UHD +The E310 comes with UHD already installed on the SD card. You will only need +to build UHD and install it if there is a critical bug fix in a later UHD or you +have custom UHD modifications. + -# Obtain the UHD source code via git or tarball -# Setup your environment as described in \ref e3x0_sdk_usage -# Type the following in the build directory (assuming a build in host/build): - $ cmake -DCMAKE_TOOLCHAIN_FILE=/host/cmake/Toolchains/oe-sdk_cross.cmake -DCMAKE_INSTALL_PREFIX=/usr -DENABLE_E300=ON .. + $ cmake -DCMAKE_TOOLCHAIN_FILE=../host/cmake/Toolchains/oe-sdk_cross.cmake -DCMAKE_INSTALL_PREFIX=/usr -DENABLE_E300=ON .. $ make For instructions on building UHD on a PC to interact with your E-Series device, follow these instructions: \ref e3x0_uhd_build \subsubsection e3x0_sdk_usage_gnuradio Building GNU Radio +GNU Radio is already installed on the SD card. You only need to build GNU Radio +for the E3XX if you are doing custom GNU Radio development work. + -# Obtain the gnuradio source code via git. -# Setup the environment as described in \ref e3x0_sdk_usage -# Use the following commands to create a build directory, configure and compile gnuradio. You only need create the build directory once. @@ -158,9 +165,12 @@ The file system images are built using OpenEmbedded Core. The `repo` tool is used to manage the versions of the various layers that supply recipes for building the image. For more documentation see http://www.yoctoproject.org. These notes will show you how to rebuild the files used to create the SD -card included with the E310. These instructions assume you ahve a working +card included with the E310. These instructions assume you have a working knowledge of Linux. +Once you have rebuilt the factory image, you can create your own custom recipes +to build file system images for specific application. + -# Install `repo`. \code{.sh} $ curl http://commondatastorage.googleapis.com/git-repo-downloads/repo > repo @@ -172,7 +182,7 @@ knowledge of Linux. \code{.sh} $ mkdir e300-oe-build $ cd e300-oe-build - $ repo init -u git://github.com/EttusResearch/e300-manifest.git -b Release-3 + $ repo init -u git://github.com/EttusResearch/e300-manifest.git -b Release-4 \endcode -# Initialize the environment. This will take a little while. @@ -187,12 +197,13 @@ path names make sense for your machine. it will download all the required sources. (These are saved locally for future builds) \code{.sh} - $ export MACHINE="ettus-e300" + $ export MACHINE="ettus-e3xx-sg1" $ bitbake gnuradio-dev-image \endcode When this completes, the files needed to create the SD card are in -`tmp-glibc/deploy/images/ettus-e300` +`tmp-glibc/deploy/images/ettus-e300`. Building the file that is written +directly to the SD card is covered later in this document. -# Build the toolchain. \code{.sh} @@ -202,6 +213,19 @@ The sdk is in `tmp-glibc/deploy/sdk` Note that you can set the `MACHINE` variable in `local.conf so that you no longer need to set it from the command line. +-# Building the complete set of E3XX image files and sdk. + +There is a script in the meta-ettus BSP layer that builds SD card images for +all E3XX series devices and the sdk. + +From the build directory run: +\code{.sh} + $ sh ../meta-ettus/scripts/build-all.sh +\endcode + +When the script finishes, the SD ard image files are in ./images and the sdk +is in tmp-glibc/deploy/sdk/ . + -# Using the environment When you log back in, you will need to setup the OpenEmbedded environment again by: -- cgit v1.2.3 From 9e8bb7e7d6a8191ff582c40665d1d85ff55328e6 Mon Sep 17 00:00:00 2001 From: Andrew Lynch Date: Wed, 4 May 2016 15:43:38 -0700 Subject: b200: Changed tree sptr in lambda to wptr --- host/lib/usrp/b200/b200_impl.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/host/lib/usrp/b200/b200_impl.cpp b/host/lib/usrp/b200/b200_impl.cpp index 327d7760d..3c9fe2e27 100644 --- a/host/lib/usrp/b200/b200_impl.cpp +++ b/host/lib/usrp/b200/b200_impl.cpp @@ -33,6 +33,7 @@ #include #include #include +#include #include #include #include @@ -731,9 +732,12 @@ b200_impl::~b200_impl(void) * setup radio control objects **********************************************************************/ -void lambda_set_bool_prop(property_tree::sptr tree, fs_path path, bool value, double) +void lambda_set_bool_prop(boost::weak_ptr tree_wptr, fs_path path, bool value, double) { - tree->access(path).set(value); + property_tree::sptr tree = tree_wptr.lock(); + if (tree) { + tree->access(path).set(value); + } } void b200_impl::setup_radio(const size_t dspno) -- cgit v1.2.3 From 60ed2ef4212a74911c490f2bb6b91d791844fcfc Mon Sep 17 00:00:00 2001 From: Andrew Lynch Date: Thu, 5 May 2016 09:30:44 -0500 Subject: b200: Changed implicit conversion to explicit conversion for wptr --- host/lib/usrp/b200/b200_impl.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/host/lib/usrp/b200/b200_impl.cpp b/host/lib/usrp/b200/b200_impl.cpp index 3c9fe2e27..734367af1 100644 --- a/host/lib/usrp/b200/b200_impl.cpp +++ b/host/lib/usrp/b200/b200_impl.cpp @@ -800,7 +800,7 @@ void b200_impl::setup_radio(const size_t dspno) _tree->create(rx_dsp_path / "rate" / "set").set(false); _tree->access(rx_dsp_path / "rate" / "value") .coerce(boost::bind(&b200_impl::coerce_rx_samp_rate, this, perif.ddc, dspno, _1)) - .subscribe(boost::bind(&lambda_set_bool_prop, _tree, rx_dsp_path / "rate" / "set", true, _1)) + .subscribe(boost::bind(&lambda_set_bool_prop, boost::weak_ptr(_tree), rx_dsp_path / "rate" / "set", true, _1)) .subscribe(boost::bind(&b200_impl::update_rx_samp_rate, this, dspno, _1)) ; _tree->create(rx_dsp_path / "stream_cmd") @@ -817,7 +817,7 @@ void b200_impl::setup_radio(const size_t dspno) _tree->create(tx_dsp_path / "rate" / "set").set(false); _tree->access(tx_dsp_path / "rate" / "value") .coerce(boost::bind(&b200_impl::coerce_tx_samp_rate, this, perif.duc, dspno, _1)) - .subscribe(boost::bind(&lambda_set_bool_prop, _tree, tx_dsp_path / "rate" / "set", true, _1)) + .subscribe(boost::bind(&lambda_set_bool_prop, boost::weak_ptr(_tree), tx_dsp_path / "rate" / "set", true, _1)) .subscribe(boost::bind(&b200_impl::update_tx_samp_rate, this, dspno, _1)) ; -- cgit v1.2.3 From 2b5a88bb2031367123f728827660d267c87f220a Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Thu, 5 May 2016 13:02:52 -0700 Subject: Final changes for 3.9.4 release: - Updated UHD images packages (zip file name change) - Updated Debian changelog --- host/CMakeLists.txt | 4 ++-- host/cmake/debian/changelog | 15 +++++++++++++++ 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/host/CMakeLists.txt b/host/CMakeLists.txt index 258c288be..29e89b8b7 100644 --- a/host/CMakeLists.txt +++ b/host/CMakeLists.txt @@ -274,8 +274,8 @@ UHD_INSTALL(FILES #{{{IMG_SECTION # This section is written automatically by /images/create_imgs_package.py # Any manual changes in here will be overwritten. -SET(UHD_IMAGES_MD5SUM "7c7356d1ca2979c7c9aeeead5eeac39e") -SET(UHD_IMAGES_DOWNLOAD_SRC "uhd-images_003.009.004-rc1.zip") +SET(UHD_IMAGES_MD5SUM "c33b36a74d82198c8cfede64d8775c46") +SET(UHD_IMAGES_DOWNLOAD_SRC "uhd-images_003.009.004-release.zip") #}}} ######################################################################## diff --git a/host/cmake/debian/changelog b/host/cmake/debian/changelog index 75aeeab81..f83d834a2 100644 --- a/host/cmake/debian/changelog +++ b/host/cmake/debian/changelog @@ -1,3 +1,18 @@ +uhd (3.9.4-0ubuntu1) trusty; urgency=low + + - GPIO control: Fix address mismatch for RX and full duplex. + This fixes full-duplex mode for most devices. + - B200: Fixed auto rate selection (can now select 61.44 Msps) + - UBX: Fix member declaration order which could cause + segfaults for debug builds + - Manual/Docs: Numerous fixes, use dot for graphs in manual + - Utils: multiple fixes for query_gpsdo_sensors, fixed floating point + comparison + - Windows: Include registry file in installation + - Converters: Improve NEON converters + + -- Ettus Research Thu, 05 May 2016 12:56:28 -0800 + uhd (3.9.3-0ubuntu1) trusty; urgency=low * UBX: Fixed a phase synchronization issue on the sub-1GHz band -- cgit v1.2.3 From 8426569f5c6ee954c5f0345351bd8239725a8fee Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Thu, 5 May 2016 16:32:37 -0700 Subject: doxygen/cmake: Allow Doxygen to use shorter filenames This fixes cases where automatic builds fail on operating systems with character limits in paths, such as Windows. --- host/docs/CMakeLists.txt | 6 ++++++ host/docs/Doxyfile.in | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/host/docs/CMakeLists.txt b/host/docs/CMakeLists.txt index 96f388b2e..7cb047264 100644 --- a/host/docs/CMakeLists.txt +++ b/host/docs/CMakeLists.txt @@ -67,6 +67,7 @@ MESSAGE(STATUS "") LIBUHD_REGISTER_COMPONENT("API/Doxygen" ENABLE_DOXYGEN ON "DOXYGEN_FOUND" OFF OFF) OPTION(ENABLE_DOXYGEN_FULL "Use Doxygen to document the entire source tree (not just API)" OFF) OPTION(ENABLE_DOXYGEN_DOT "Let Doxygen use dot (requires graphviz)" OFF) +OPTION(ENABLE_DOXYGEN_SHORTNAMES "Let Doxygen use shorter filenames (helps on Windows)" OFF) IF(LIBUHDDEV_PKG) SET(PKG_DOC_DIR share/doc/libuhd-dev) @@ -100,6 +101,11 @@ IF(ENABLE_MANUAL_OR_DOXYGEN) ELSE(ENABLE_DOXYGEN_DOT) SET(DOXYGEN_HAVE_DOT "NO") ENDIF(ENABLE_DOXYGEN_DOT) + IF(ENABLE_DOXYGEN_SHORTNAMES) + SET(DOXYGEN_SHORT_NAMES "YES") + ELSE(ENABLE_DOXYGEN_SHORTNAMES) + SET(DOXYGEN_SHORT_NAMES "NO") + ENDIF(ENABLE_DOXYGEN_SHORTNAMES) CONFIGURE_FILE( ${CMAKE_CURRENT_SOURCE_DIR}/Doxyfile.in diff --git a/host/docs/Doxyfile.in b/host/docs/Doxyfile.in index 8aa6299ae..d230352d4 100644 --- a/host/docs/Doxyfile.in +++ b/host/docs/Doxyfile.in @@ -147,7 +147,7 @@ STRIP_FROM_INC_PATH = @CMAKE_SOURCE_DIR@/include # (but less readable) file names. This can be useful if your file system # doesn't support long names like on DOS, Mac, or CD-ROM. -SHORT_NAMES = NO +SHORT_NAMES = @DOXYGEN_SHORT_NAMES@ # If the JAVADOC_AUTOBRIEF tag is set to YES then Doxygen # will interpret the first line (until the first dot) of a JavaDoc-style -- cgit v1.2.3