From 22fedfc3a656eca181f8bba6ffcec680e6c300e4 Mon Sep 17 00:00:00 2001 From: Michael Dickens Date: Wed, 1 Jul 2015 10:30:49 -0400 Subject: docs: tweak OSX build from source advice to have more obvious NOTEs, per uhd issue #37 --- host/docs/build.dox | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/host/docs/build.dox b/host/docs/build.dox index 95514da23..1097ab5ab 100644 --- a/host/docs/build.dox +++ b/host/docs/build.dox @@ -246,21 +246,24 @@ Once the Command Line Tools are installed, UHD and other projects can be install There are a number of background libraries and applications that must be installed from source or binary in order to compile or execute UHD; for a full list, see \ref build_dependencies. These can be obtained by using MacPorts, Fink, HomeBrew, and/or from source / scratch. MacPorts tends to be more up-to-date with respect to new releases, which can be both a blessing and a curse since sometimes new released are untested and result in build or runtime errors. MacPorts, HomeBrew, and Fink offer thousands of ready-to-install libraries and applications, and hence they are highly recommended to use instead of installing from source / scratch. -\b Note: We highly recommended that you install all dependencies via the same package manager! When issues arise, they are much easier to track down, and your updating to newer versions is also much easier. - Many UHD developers first install UHD using MacPorts in order to get all of the necessary background dependencies installed, then remove just UHD via + sudo port install uhd sudo port uninstall uhd +\b NOTE: We highly recommended that all dependencies be installed via the same package manager! When issues arise, they are much easier to track down, and updating to newer versions of UHD as well as dependencies is much easier. + +\b NOTE: Other package managers (e.g., Fink, HomeBrew) will require diffrent commands than the above to install all dependencies and then remove the UHD install. Please consult the specific package manager in use for how to do these commands properly; they will not be covered here. + #### Compiling UHD from Source Installing UHD from source follows the standard cmake method as found in many places, with a few arguments to make sure cmake always finds the correct version of Python, and uses the desired compiler. First, download the source code either via a release or via GIT. -For example, on OSX 10.8 or 10.9 using Xcode 5's Apple GCC, MacPorts installed into /opt/local (the default), and for Python 2.7 (as installed by MacPorts), issue the following commands from within the UHD source directory: +For example, on OSX 10.8+ and using Xcode's legacy Apple GCC (via llvm), MacPorts installed into /opt/local (the default), and for Python 2.7 as installed by MacPorts, issue the following commands from within the UHD source directory: $ mkdir build $ cd build - $ CC=/usr/bin/llvm-gcc CXX=/usr/bin/llvm-g++ cmake -DPYTHON_EXECUTABLE=/opt/local/bin/python2.7 -DPYTHON_INCLUDE_DIR=/opt/local/Library/Frameworks/Python.framework/Versions/2.7/Headers -DPYTHON_LIBRARY=/opt/local/Library/Frameworks/Python.framework/Versions/2.7/Python ../host + $ CC=/usr/bin/llvm-gcc CXX=/usr/bin/llvm-g++ cmake -DCMAKE_INSTALL_PREFIX=/opt/local -DPYTHON_EXECUTABLE=/opt/local/bin/python2.7 -DPYTHON_INCLUDE_DIR=/opt/local/Library/Frameworks/Python.framework/Versions/2.7/Headers -DPYTHON_LIBRARY=/opt/local/Library/Frameworks/Python.framework/Versions/2.7/Python ../host $ make If make succeeds, then you can test the build for errors via @@ -271,7 +274,11 @@ To install the build, issue $ sudo make install -Selecting another compiler is as simple as changing the CC and CXX pre-arguments to the cmake command. Note that all of the PYTHON defines must point to the same install of Python, otherwise runtime errors are likely to occur. +Selecting another compiler is as simple as changing the CC and CXX pre-arguments to the cmake command. Similarly, one can change the install prefix by changing the setting of the variable CMAKE_INSTALL_PREFIX. + +\b NOTE: All of the PYTHON defines must point to the same install of Python, otherwise runtime errors are likely to occur. + +\b NOTE: When using some other package manager (e.g., Fink, HomeBrew), the actual variable settings (-D...=...) will be different than those above. Please consult the specific package manager in use for how to do these settings properly; they will not be covered here. \section post_install_tasks Post-Install Tasks @@ -279,6 +286,8 @@ Selecting another compiler is as simple as changing the CC and CXX pre-arguments `uhd_images_downloader` on the command line, or one of these executables (the actual path may differ based on your installation): + Linux: /usr/local/lib/uhd/utils/uhd_images_downloader.py + Windows: C:\\Program Files\\share\\uhd\\utils\\uhd_images_downloader.py + + Mac OS X: In MacPorts, when UHD is installed the images are automatically downloaded and installed into their proper location. For any other package manager or install method, you should execute the uhd_images_downloader.py script to get the images installed appropriately. + - For USB-Based devices, make sure to read \ref transport_usb for platform-specific post-installation tasks. \section build_apps Building applications that require UHD using CMake -- cgit v1.2.3 From 69bcfba936e49c2825a6d9be677c3150a5c6b70c Mon Sep 17 00:00:00 2001 From: Ian Buckley Date: Tue, 26 May 2015 15:35:04 -0700 Subject: B200: New AD9361 I/O timing programming to work with new b200_io.v logic design. --- host/lib/usrp/b200/b200_impl.cpp | 2 +- host/lib/usrp/common/ad9361_driver/ad9361_device.cpp | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/host/lib/usrp/b200/b200_impl.cpp b/host/lib/usrp/b200/b200_impl.cpp index 55ae29575..0409adf30 100644 --- a/host/lib/usrp/b200/b200_impl.cpp +++ b/host/lib/usrp/b200/b200_impl.cpp @@ -63,7 +63,7 @@ public: digital_interface_delays_t get_digital_interface_timing() { digital_interface_delays_t delays; delays.rx_clk_delay = 0; - delays.rx_data_delay = 0x6; + delays.rx_data_delay = 0xF; delays.tx_clk_delay = 0; delays.tx_data_delay = 0xF; return delays; diff --git a/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp b/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp index e63460730..db5de52d0 100644 --- a/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp +++ b/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp @@ -1455,13 +1455,13 @@ void ad9361_device_t::initialize() * Force TX on one port, RX on the other. */ switch (_client_params->get_digital_interface_mode()) { case AD9361_DDR_FDD_LVCMOS: { - _io_iface->poke8(0x010, 0xc8); + _io_iface->poke8(0x010, 0xc8); // Swap I&Q on Tx, Swap I&Q on Rx, Toggle frame sync mode _io_iface->poke8(0x011, 0x00); _io_iface->poke8(0x012, 0x02); } break; case AD9361_DDR_FDD_LVDS: { - _io_iface->poke8(0x010, 0xcc); + _io_iface->poke8(0x010, 0xcc); // Swap I&Q on Tx, Swap I&Q on Rx, Toggle frame sync mode, 2R2T timing. _io_iface->poke8(0x011, 0x00); _io_iface->poke8(0x012, 0x10); -- cgit v1.2.3