Releases: EttusResearch/uhd
UHD v4.1.0.5 Release
Apart from some minor enhancements and bugfixes, this release adds support for the NI Ettus USRP X410 with module revision E and motherboard revision G, which uses a different CPLD on the motherboard than previous revisions. Please note that the X410 filesystem image that ships with versions of UHD prior to v4.1.0.5 will not support newer revisions of the USRP X410; thus, we strongly recommend that all USRP X410 users upgrade their devices with the filesystem that ships with v4.1.0.5. Please refer to the instructions under 'Updating Filesystems' in the USRP X4xx section of the UHD manual at https://files.ettus.com/manual/page_usrp_x4xx.html for information on how to perform the update.
004.001.000.005
- ad9361
- Add comment re overclocking
- Modify set-tx-gain procedure to update gain in one go
- b200
- Re-sync times
- Move the B200 radio control core into usrp/b200/
- cal
- Use safe version of set_thread_priority()
- ci
- Device wait to redlock scope for Vivado close
- Add Fedora 34 and remove Fedora 32
- Refactor installers and add Windows support
- Add custom boost version support
- Remove documentation-only changes from pipeline runs
- enable batch CI
- Split CI and PR pipelines for mono pipeline
- Enable custom CXX flags, enable -Werror
- Let make keep building upon failure
- Add clang as a compiler to all Fedora and Ubuntu containers
- cmake
- use LooseVersion to ensure correct version comparisons
- Fix rfnoc-example (CMake paths)
- Fix issues with static builds and CMRC
- Replace CMAKE_{SOURCE,BINARY}DIR with UHD*_DIR
- tests: Add build-python path to PYTHONPATH
- Add check for libatomic linking requirement
- remove duplicate entry in LIBUHD_PYTHON_GEN_SOURCE
- Fix VS names and use relative for images
- dbsrx
- Fix issue with loop variable
- debs
- Update upload_debs script
- devtest
- Clarify data type in multi_usrp_test::send_waveform()
- Add receive stability test to B2xx devtest
- Add receive stability test
- dissectors
- Fix whitespace formatting in CMake files
- Fix inclusion of glib.h and Python version
- docs
- Several minor manual improvements
- Collect all RFNoC block controllers in a module in the manual
- Align dependencies and bump deb package versions
- Clarify set/get_gpio_attr() and GPIO banks
- Fix GPIO documentation example
- x410: Fix info on loading SD card images with bmaptool
- Improve docs for rx_streamer::recv() on overruns
- sync: Update page on synchronization
- Fix typo in ZBX Block Diagram
- x4xx: Document configuring eth0 static IP
- Remove bmaptool instructions for writing filesystems
- examples
- Use cmul for gain block in-tree IP example
- Test all variants in gain testbench
- Make IQ order clear in gain RFNoC block
- Improve txrx_loopback_to_file (late recv, Boost, timing)
- Show how to use in-tree Verilog header
- Add x400/x410 target to RFNoC example
- gpio: Separate bank and port arguments
- usrp_power_meter: fix channel indexing when reading USRP power
- fpga
- Revert "Add ability to get time from Radio block"
- Add ability to get time from Radio block
- rfnoc: Add RFNoC CHDR resize module
- rfnoc: Add CHDR management util functions
- lib: Clean up axi_mux
- rfnoc: Add labels to axi_switch generate blocks
- rfnoc: Add labels to chdr_mgmt_pkt_handler
- rfnoc: Add documentation to chdr_xb_routing_table
- Shorten line length for Launchpad linter
- x300: Update synchronizer constraint
- n3xx: Update synchronizer constraint
- lib: Update example constraint in synchronizer
- Update help message for setupenv.sh
- Remove stale references to UHD_FPGA_DIR
- tools: Add UHD_FPGA_DIR definition to synthesis
- Set default part for sim in setupenv.sh
- Fix Xilinx bitfile parser for Python 3
- rfnoc: Fix EOB loss in DUC
- sim: Add PkgComplex, PkgMath, and PkgRandom
- lib: Clean up and document lib files
- x400: Remove stale information in register map
- ci: Add testbench pipeline
- host
- Revert "Add ability to get time from Radio block"
- Add ability to get time from Radio block
- python: Return mb_controller with reference_internal
- x4xx: Implement GPIO API
- Add GPIO functions to MPM RPC shim
- gpio: Create gpio_atr_offsets to store GPIO registers
- images
- Update image packager script for Python 3
- lib
- Remove all remaining usage of boost::numeric::bounds<>
- transport: Mark typecast as intended
- transport: Initialize _hshake_args_server
- rfnoc: Make implicit typecasts explicit
- rfnoc: Change enum node_type to enum class
- Add various missing includes
- libusb
- Remove unused context variable
- mpm
- x4xx: update mboard_max_rev
- x4xx: Allow GPIO0 and GPIO1 as port names
- x4xx: add DIO GPIO API configuration methods
- mpm: x4xx: Add checks before accessing self.dio_control
- Fix handling of rfic_digital_loopback argument
- rfdc: Tear down RFDC on teardown
- add X410 support for 250e6 master clock rate
- Expose motherboard regs for debugging
- mpmd
- Increase UHD-side MTU cap for 10 GbE and 1 GbE
- multi_usrp_rfnoc
- Revert "Reduce latency of get_time_now()"
- Reduce latency of get_time_now()
- n320
- Reduce PLL lock time
- n3x0/e3x0
- Remove reference to "master FP-GPIO radio"
- n3xx
- Add support for rev 10
- Fix White Rabbit
- python
- multi_usrp: Add set_rx_spp()
- multi_usrp: Fix issues in send_waveform()
- multi_usrp: Fix issues with recv_num_samps()
- Fix dropped-sample calculation in benchmark_rate.py
- multi_usrp: Fix overloaded function definition
- Add new method bindings to noc_block_base
- rfnoc: Change reference type for noc_block_base export
- responder
- Fix printw function arguments
- rfnoc
- radio: Fix async message handling channel checks
- mgmt_portal: Fix order of validity checks
- blocks: Minor cleanup (whitespace, typos)
- mgmt_portal: Remove two unused variables
- Add vivado-path to rfnoc_image_builder
- ddc: Improve unit tests and documentation
- duc: Fix frequency range for DUC block
- duc: Remove stale references to CORDIC
- siggen: Fix direction of rotation
- rh
- Fix auto DC-offset correction and auto-IQ balance APIs
- tests
- Remove skip_dram from streaming performance test script
- Fix rfnoc_graph mock nodes stop-stream command
- Use reference type to prevent copy
- Fix check in link_test
- Fix potential resource leak
- tools
- Fix rfnoc dissector build
- uhd
- add support for max10 variants
- update manifest for x410 cpld
- Update manifest
- update num_recv_frames calculation for ctrl links
- Remove spurious template from property dtor
- Fix spelling errors
- mpm: Expose filesystem version information on MPM tree
- Remove Boost version checks for Boost 1.61
- Fix usage of std::abs with template parameters
- utils
- Get signal above noise floor when finding optimal gain
- x300
- Fix error message for wrong reference frequency
- Remove unused variables in x300_eth_mgr.cpp
- Fix MAX_RATE_1GIGE value
- Fix sfpp_io_core tuser width
- Initialize struct variable before using it
- x410
- correct 100GbE link speed
UHD 4.1.0.4 Release
This release corrects an oversight in the 4.1.0.3 release by updating the version string reported by UHD.
004.001.000.004
- uhd
- Update version in UHDVersion.cmake
UHD 4.1.0.3 Release
This release addresses one issue in UHD regarding RX and TX antenna configuration on the ZBX daughterboard.
004.001.000.003
- uhd
- zbx: Prevent TX antenna config from disrupting RX
UHD 4.1.0.2 Release
This release fixes some minor issues in UHD:
- Some streaming issues with the B2xx, notably good data packets being dropped in the event of an overrun and USB overflow issues when using the
sc12
data type, have been resolved. - The semantics of calling
recv()
on a streamer with 0 fornsamps_per_buff
was inadvertently changed in a previous commit. The original correct semantics (return immediately without regard for the timeout and availability of samples) have been restored. - Certain link establishment timeout cases could result in an exception being thrown while another exception is in flight, thus triggering process termination. The codepath triggering the errant second exception has been corrected to avoid this situation.
004.001.000.002
- b200
- Fix overflow handling
- fpga
- Re-order error and data packets
- Fix sc16 to sc12 converter
- host
- Add static_assert to prevent meta_range_t(0,0)
- mpm
- x4xx: update mboard_max_rev
- mpmd
- Add discoverable feature for trig i/o mode
- sim
- Update chdr_16sc_to_sc12 testbench
- tests
- Add recv(0) case to rx_streamer_test
- uhd
- transport: Avoid exceptions in disconnect_receiver()
- streamer: Restore original recv(0) semantics
- x4xx_bist
- use get_mpm_client in gpio bist
UHD 4.1.0.1 Release
The UHD 4.1.0.1 release addresses a few bugs that slipped their way into UHD v4.1.0.0:
- The revision compatibility check for ZBX hardware (the X410 daughterboard) was broken, causing MPM to fail to start with ZBX revisions B or C.
- A missing include caused compilation failures on certain compilers when testing is enabled.
- UHD 4.1 would fail to build with using Boost 1.76.0.
004.001.000.001
- cmake
- remove redundant include
- correctly set and unset any CMAKE_REQUIRED variables
- fix finding PkgConfig to work robustly (without CMake warnings)
- core
- remove boost::math in favor of std cmath
- docs
- x4xx: Update information on CPLD updating
- usrp_x4xx: improve filesystem update instructions
- mpm
- zbx: Fix revision compat check
- Update usrp_update_fs to support X410
- max10_cpld_flash_ctrl: improve programming log
- Skip DTS compatibility check if DTS is not being updated
UHD 4.1.0.0 Release
We are proud to announce the release of UHD 4.1! The marquee feature of UHD 4.1 is support for the new NI Ettus USRP X410, a new generation of radio providing the highest performance of any USRP to date. Along with X410 support, UHD 4.1 also brings usability and stability enhancements to UHD and to the entire stable of NI Ettus USRP devices.
Read more about the X410 on the Ettus Research website.
004.001.000.000
- adf535x
- Change freq_resolution to mod2
- b200
- handle overruns during continuous streaming
- cal
- ensure proper range handling
- Remove silent capture of TypeError
- Add X410 internal antenna names to invalid antenna list
- add more error number for ADC overload
- make 'calibrate all channels' default for --channels argument
- Add support for X410
- Add min_freq and max_freq attributes to USRPCalibratorBase
- Fix minor issues in the calibration utilities
- sync log output between file system and resource data
- chdr
- Fix u64_to_host vs. u64_from_host usage
- ci
- Add trace builds to pipeline
- Add deb build support for ubuntu 1804/2004
- Update docker images for Ubuntu with pbuilder
- Support for x3xx devtest on rhombus
- Install vc_buildtools instead of vc_community
- Build uhd with Pipelines
- Linux and Windows uhd build docker images
- Hardware pytests / devtests in AzDO for n310
- Add stub for python hardware tests
- cmake
- Add RegMaps build component to MPM
- fix cut-and-paste typo to fix SIM APPLE build
- convert
- Remove unused variables
- dboard
- magnesium: Update Rx IF Frequency Value
- dboard_iface
- Fix sleep()
- Modify sleep() function
- debian
- Update supported Ubuntu releases
- Update Python3 dependencies
- debug_dboard
- Fix compiler warning
- deps
- rpclib: Fix issue on socket closing
- devtest
- benchmark_rate: Add support for rx and tx only tests
- Make Python tests their own type of devtest
- Lower rate for rx_all_chans_fast test
- Allow extra device arguments when running devtests
- Optionally generate XML report when running devtests
- docs
- usrp_x4xx: add network leds behavior to docs
- devices: remove child page relation to individual dboards
- zbx: link docs to rf specifications
- zbx: address review observations in docs
- usrp_x4xx: address review observations in docs
- Fix typos
- Fix python3-ruamel.yaml name on RPM based OS
- zbx: update cpld source code location
- usrp_x4xx: apply minor corrections in docs
- zbx: improve cpld update docs
- usrp_x4xx: improve mb cpld update docs
- Fix missing section header in power level controls page
- Fix typo in mender section
- Add N320 frontend correction section
- Use Mathjax for equation rendering
- Remove reference to Python six
- mpm: correct ? notation to display help
- Update Python3 dependencies
- Fix sensor names for N3xx boards
- duc
- Fix incorrect DDS_GAIN
- examples
- Fix underrun/seq error reporting in benchmark_rate.py
- Add min dynamic range limit to ascii art DFT example
- Add IP to OOT RFNoC gain example
- Remove unused arguments for rfnoc_radio_loopback
- Fix PPS option in rfnoc_radio_loopback
- Fix --random option in benchmark_rate
- Fix icores example to match current RFNoC specs
- experts
- Change coercion policy for regular prop nodes
- fpga
- x400: Fix x4xx_qsfp_wrapper testbench
- sim: Check for empty packet in clear_unused_bytes
- Update testbenches to work in ModelSim
- x400: Add makefiles for RF testbenches
- tools: Detect assertions in ModelSim simulation
- tools: Put SIM_SRCS at end of compile order
- tools: Support new FPGA types in viv_simulator.mak
- tools: Fix python2 reference in viv_ip_builder.mak
- tools: Add modelsim.excludes
- tools: Add modelsim.ini to ModelSim calls
- tools: Add features to run_testbenches.py
- tools: Add ip target to simulation makefiles
- tools: Add X410 support for image packaging
- ci: Add build definitions for FPGA CI
- x400: zbx: Add support for ZBX CPLD
- x400: cpld: Add support for X410 motherboard CPLD
- x400: Add support for X410 motherboard FPGA
- sim: Add slave_idle() to PkgAxiStreamBfm.sv
- lib: Update register comments in eth_regs.vh
- Update rfnoc_image_core for all targets
- Update recommended HDL header guideline
- tools: Fix part selection in setupenv
- Change RFNoC YAML version numbers to strings
- lib: Add modports to SV AXI-Stream blocks
- lib: Add time_increment port to timekeeper
- lib: Pipeline ctrlport_timer
- lib: Add clock domain comments to interfaces
- lib: Add 2 to 1 gearbox module
- lib: Add PHASE parameter to sim_clk_gen
- lib: Add AXI4 (full) interface
- lib: add pause support to ethernet xport
- lib: Add eth_ipv4_internal
- lib: Add zynquplus family to axi_bitq
- tools: Add ability to run commands before route
- tools: Add ability to patch IP during generation
- tools: Add support for RFSoC
- lib: Minor cleanup of axi_lite.vh
- rfnoc: Add ability to disable output flow control
- lib: Add rx_front_end_gen3 testbench
- lib: Update round_sd to eliminate X from simulation
- lib: Fix simulation of axi_fir_filter
- docs: Improve documentation of rx_frontend_gen3
- lib: Fix DDS_SIN_COS_LUT outputs in makefile
- dsp: Fix formatting of rx_dcoffset and add docs
- Remove Python2 support from build system
- e320: Improve timing on LVDS interface
- lib: add glitch free mux module
- e31x: Add OOT sources to Makefile.e31x.inc
- lib: Fix axis_strm_monitor parameters
- lib: Fix small packets stuck in 10 GbE TX
- lib: Fix 10 GbE cut-through mode
- lib: add generic to disable bitq engine tri-stating
- graph
- Restore default resolver callback at node removal
- Serialize all graph-related functions
- Re-fetch dst_node descriptor after src_node potential removal
- host
- utils: Print block ID for RFNoC dboards
- Update code base using clang-tidy
- Update code base using clang-tidy
- ic_reg_map
- Allow registers to be arrays
- Remove SPCC core reg map
- Add SPCC reg map
- Add common regmap template for Python
- images
- Update manifest
- Add X410 series FPGA images
- Update manifest
- Update B2xx firmware
- installers
- Refactor deb script and build
- Resolve ubuntu linter issue
- lib
- deps: Upgrade vendor version of Pybind11 to 2.6.1
- Fix misssing include in e3xx_radio_control_impl
- rpc: Add virtual dtor to RPC iface base class
- Remove move-on-return for chdr_packet_writer
- Fix unresolved cleanup conflict (sorry!)
- deps: Ignore more warnings in our versions of rpclib, pybind11
- Use const-ref in for loops instead of const-copy
- Add some virtual dtors
- Fix warnings related to unnecessary lambda captures
- lmx2592: Comment out some unused constants
- Remove unused constants
- Fix missing includes in rpc.hpp
- Disable non pcie types in find with resource
- graph_utils: Error on single SEP edge
- graph_utils: Fix formatting and compiler warnings
- lmx2572
- Fix compiler warning
- mg
- Fix slot_idx reference
- Remove unused private attribute from ad9371_iface
- mpm
- Move cal freeze defaults to x4xx
- Restore rfdc nco frequency after setting sync source
- tests: Add lib/ to library load path
- install cpld update scripts in runtime dir
- x4xx_bist: run spi_flash tests on both DBs
- max10_cpld_flash_ctrl: only reprogram cpld if necessary
- Add chip driver for LMK05318 PLL
- gpsd_iface: Make GPGGA generation more robust
- sys_utils: add libgpiod-based Gpio helper
- Remove helper classes from RPC API
- systemd: Add UseDomains=true to eth0.network
- Fix MD5 hashing of opkg status
- check-filesystem: liberalize version check
- Add unit tests for EEPROM readers
- Add symbol name based EEPROM read, cleanup EEPROM handling
- Add tlv_eeprom
- gpsd_iface: Refactor class
- Remove unnecessary imports
- Add FPGA type to the info returned during discovery
- Remove unused argument info
- lmk04832: Clean up driver
- PeriphManagerBase: Add _add_public_methods()
- Fix minor log formatting issue
- db_flash: Check mount status before mounting
- sysutils: mount: Check both mount point and data path
- mount: Demote already-mounted warning
- periph_mgr: Demote "no SPI nodes" warning
- mg: periphs: Read lowband lo lock status from cpld
- Remove references to rfnoc_num_blocks
- Remove logging for mmap_regs_iface
- periph manager: Fix get_mb_eeprom() return value formatting
- rpc: don't expose reset_mgr call via RPC
- Add i2c_dev lookup using sys_name
- rpc: Use contextmanager for claim timeouts
- add helper for symbol lookup
- Implement 32 bit register interface with SPI
- Add DboardIface for MB DB driver control
- Add an LMK03328 base chip driver
- Add an LMK04832 base chip driver
- prevent dead lock in timer kill during unclaim
- Add support to safely reset peripheral manager from uhd
- Create Mock classes for unit testing
- Deduplicate dboard eeprom handling
- Added DBFlash class
- Added Mount class
- systemd: create udev rules files for each MPM_DEVICE
- filesystem_status: tolerate absence of mender
- Implement get_sync_source and get_sync_sources.
- rpc server: Fix unclaim sequence
- rpc server: Remove Python2 compat code
- rpc_server: fix get_log_buf for MPM Shell
- Fix issue with check-filesystem test execution
- Add dependency on pyusrp_periphs to MPM
- Cleanup rpc_server.py
- Use filesystem_status from sys_utils
- Added check-filesystem utility
- Add 'XQ' image as valid when using sfp0 as time_source
- mpmd
- Support four links
- Sk...
UHD 4.1.0.0 Release Candidate 1
004.001.000.000
- adf535x
- Change freq_resolution to mod2
- b200
- handle overruns during continuous streaming
- cal
- ensure proper range handling
- Remove silent capture of TypeError
- Add X410 internal antenna names to invalid antenna list
- add more error number for ADC overload
- make 'calibrate all channels' default for --channels argument
- Add support for X410
- Add min_freq and max_freq attributes to USRPCalibratorBase
- Fix minor issues in the calibration utilities
- sync log output between file system and resource data
- chdr
- Fix u64_to_host vs. u64_from_host usage
- ci
- Add trace builds to pipeline
- Add deb build support for ubuntu 1804/2004
- Update docker images for Ubuntu with pbuilder
- Support for x3xx devtest on rhombus
- Install vc_buildtools instead of vc_community
- Build uhd with Pipelines
- Linux and Windows uhd build docker images
- Hardware pytests / devtests in AzDO for n310
- Add stub for python hardware tests
- cmake
- Add RegMaps build component to MPM
- fix cut-and-paste typo to fix SIM APPLE build
- convert
- Remove unused variables
- dboard
- magnesium: Update Rx IF Frequency Value
- dboard_iface
- Fix sleep()
- Modify sleep() function
- debian
- Update supported Ubuntu releases
- Update Python3 dependencies
- debug_dboard
- Fix compiler warning
- deps
- rpclib: Fix issue on socket closing
- devtest
- benchmark_rate: Add support for rx and tx only tests
- Make Python tests their own type of devtest
- Lower rate for rx_all_chans_fast test
- Allow extra device arguments when running devtests
- Optionally generate XML report when running devtests
- docs
- usrp_x4xx: add network leds behavior to docs
- devices: remove child page relation to individual dboards
- zbx: link docs to rf specifications
- zbx: address review observations in docs
- usrp_x4xx: address review observations in docs
- Fix typos
- Fix python3-ruamel.yaml name on RPM based OS
- zbx: update cpld source code location
- usrp_x4xx: apply minor corrections in docs
- zbx: improve cpld update docs
- usrp_x4xx: improve mb cpld update docs
- Fix missing section header in power level controls page
- Fix typo in mender section
- Add N320 frontend correction section
- Use Mathjax for equation rendering
- Remove reference to Python six
- mpm: correct ? notation to display help
- Update Python3 dependencies
- Fix sensor names for N3xx boards
- duc
- Fix incorrect DDS_GAIN
- examples
- Fix underrun/seq error reporting in benchmark_rate.py
- Add min dynamic range limit to ascii art DFT example
- Add IP to OOT RFNoC gain example
- Remove unused arguments for rfnoc_radio_loopback
- Fix PPS option in rfnoc_radio_loopback
- Fix --random option in benchmark_rate
- experts
- Change coercion policy for regular prop nodes
- fpga
- x400: Fix x4xx_qsfp_wrapper testbench
- sim: Check for empty packet in clear_unused_bytes
- Update testbenches to work in ModelSim
- x400: Add makefiles for RF testbenches
- tools: Detect assertions in ModelSim simulation
- tools: Put SIM_SRCS at end of compile order
- tools: Support new FPGA types in viv_simulator.mak
- tools: Fix python2 reference in viv_ip_builder.mak
- tools: Add modelsim.excludes
- tools: Add modelsim.ini to ModelSim calls
- tools: Add features to run_testbenches.py
- tools: Add ip target to simulation makefiles
- tools: Add X410 support for image packaging
- ci: Add build definitions for FPGA CI
- x400: zbx: Add support for ZBX CPLD
- x400: cpld: Add support for X410 motherboard CPLD
- x400: Add support for X410 motherboard FPGA
- sim: Add slave_idle() to PkgAxiStreamBfm.sv
- lib: Update register comments in eth_regs.vh
- Update rfnoc_image_core for all targets
- Update recommended HDL header guideline
- tools: Fix part selection in setupenv
- Change RFNoC YAML version numbers to strings
- lib: Add modports to SV AXI-Stream blocks
- lib: Add time_increment port to timekeeper
- lib: Pipeline ctrlport_timer
- lib: Add clock domain comments to interfaces
- lib: Add 2 to 1 gearbox module
- lib: Add PHASE parameter to sim_clk_gen
- lib: Add AXI4 (full) interface
- lib: add pause support to ethernet xport
- lib: Add eth_ipv4_internal
- lib: Add zynquplus family to axi_bitq
- tools: Add ability to run commands before route
- tools: Add ability to patch IP during generation
- tools: Add support for RFSoC
- lib: Minor cleanup of axi_lite.vh
- rfnoc: Add ability to disable output flow control
- lib: Add rx_front_end_gen3 testbench
- lib: Update round_sd to eliminate X from simulation
- lib: Fix simulation of axi_fir_filter
- docs: Improve documentation of rx_frontend_gen3
- lib: Fix DDS_SIN_COS_LUT outputs in makefile
- dsp: Fix formatting of rx_dcoffset and add docs
- Remove Python2 support from build system
- e320: Improve timing on LVDS interface
- lib: add glitch free mux module
- e31x: Add OOT sources to Makefile.e31x.inc
- lib: Fix axis_strm_monitor parameters
- lib: Fix small packets stuck in 10 GbE TX
- lib: Fix 10 GbE cut-through mode
- lib: add generic to disable bitq engine tri-stating
- graph
- Restore default resolver callback at node removal
- Serialize all graph-related functions
- Re-fetch dst_node descriptor after src_node potential removal
- host
- utils: Print block ID for RFNoC dboards
- Update code base using clang-tidy
- Update code base using clang-tidy
- ic_reg_map
- Allow registers to be arrays
- Remove SPCC core reg map
- Add SPCC reg map
- Add common regmap template for Python
- images
- Update manifest
- Add X410 series FPGA images
- Update manifest
- Update B2xx firmware
- installers
- Refactor deb script and build
- Resolve ubuntu linter issue
- lib
- deps: Upgrade vendor version of Pybind11 to 2.6.1
- Fix misssing include in e3xx_radio_control_impl
- rpc: Add virtual dtor to RPC iface base class
- Remove move-on-return for chdr_packet_writer
- Fix unresolved cleanup conflict (sorry!)
- deps: Ignore more warnings in our versions of rpclib, pybind11
- Use const-ref in for loops instead of const-copy
- Add some virtual dtors
- Fix warnings related to unnecessary lambda captures
- lmx2592: Comment out some unused constants
- Remove unused constants
- Fix missing includes in rpc.hpp
- Disable non pcie types in find with resource
- graph_utils: Error on single SEP edge
- graph_utils: Fix formatting and compiler warnings
- lmx2572
- Fix compiler warning
- mg
- Fix slot_idx reference
- Remove unused private attribute from ad9371_iface
- mpm
- Move cal freeze defaults to x4xx
- Restore rfdc nco frequency after setting sync source
- tests: Add lib/ to library load path
- install cpld update scripts in runtime dir
- x4xx_bist: run spi_flash tests on both DBs
- max10_cpld_flash_ctrl: only reprogram cpld if necessary
- Add chip driver for LMK05318 PLL
- gpsd_iface: Make GPGGA generation more robust
- sys_utils: add libgpiod-based Gpio helper
- Remove helper classes from RPC API
- systemd: Add UseDomains=true to eth0.network
- Fix MD5 hashing of opkg status
- check-filesystem: liberalize version check
- Add unit tests for EEPROM readers
- Add symbol name based EEPROM read, cleanup EEPROM handling
- Add tlv_eeprom
- gpsd_iface: Refactor class
- Remove unnecessary imports
- Add FPGA type to the info returned during discovery
- Remove unused argument info
- lmk04832: Clean up driver
- PeriphManagerBase: Add _add_public_methods()
- Fix minor log formatting issue
- db_flash: Check mount status before mounting
- sysutils: mount: Check both mount point and data path
- mount: Demote already-mounted warning
- periph_mgr: Demote "no SPI nodes" warning
- mg: periphs: Read lowband lo lock status from cpld
- Remove references to rfnoc_num_blocks
- Remove logging for mmap_regs_iface
- periph manager: Fix get_mb_eeprom() return value formatting
- rpc: don't expose reset_mgr call via RPC
- Add i2c_dev lookup using sys_name
- rpc: Use contextmanager for claim timeouts
- add helper for symbol lookup
- Implement 32 bit register interface with SPI
- Add DboardIface for MB DB driver control
- Add an LMK03328 base chip driver
- Add an LMK04832 base chip driver
- prevent dead lock in timer kill during unclaim
- Add support to safely reset peripheral manager from uhd
- Create Mock classes for unit testing
- Deduplicate dboard eeprom handling
- Added DBFlash class
- Added Mount class
- systemd: create udev rules files for each MPM_DEVICE
- filesystem_status: tolerate absence of mender
- Implement get_sync_source and get_sync_sources.
- rpc server: Fix unclaim sequence
- rpc server: Remove Python2 compat code
- rpc_server: fix get_log_buf for MPM Shell
- Fix issue with check-filesystem test execution
- Add dependency on pyusrp_periphs to MPM
- Cleanup rpc_server.py
- Use filesystem_status from sys_utils
- Added check-filesystem utility
- Add 'XQ' image as valid when using sfp0 as time_source
- mpmd
- Support four links
- Skip find if "resource" key is specified
- Add support to delay and trigger fpga/dts load after update
- Export RPC token and mb_args to the property tree
- Reduce max frame size for 10 GbE
- msgpack/predef
- Add riscV support
- multi_usrp
- Factor out make_overall_tune_range() and fix limits
- Fix typos in streamer destruction callback
- Fix streamer destruction callback
- Add get_mb_controller() API call
- Relax LO set API strictness
- multi_usrp_rfnoc
- Fix get_device()->get_tree()
- Serialize make_rf...
UHD 4.0.0.0 Release
UHD 4.0 was a massive development undertaking, more than just a new version it's a leap forward in performance, usability, and stability you can learn more and see some demos at : https://www.ettus.com/announcing-uhd4/
004.000.000.000
- b200:
- Add unload-bootloader option to b2xx_fx3_utils
- Update FX3 SDK for bootloader and firmware
- Fix address for serial number in firmware
- Enable power calibration API
- Add a prop tree node usb_version
- cal:
- Add utility to update all .fbs files, or check the generated ones
- Add pwr_cal container
- cmake:
- Use relative path to Python lib location for Windows installer
- Add ability to pass CXXFLAGS to CMake environment
- docs:
- Add new CHDR format to transports
- Update register maps
- Update FPGA manual
- Update mender commands for Zeus filesystems
- Add section about network mode on E3xx devices
- Add DPDK link detection section
- Add Windows-specific UHD Python module notes
- Add note about compiling on Ubuntu 20.04
- Update PCIe xport instructions for NI Repos
- n3xx: Include WX in table of N320 images
- Add stream and transport args documentation
- Update Basic/LF dboard references to use new operating mode
- e3xx/n3xx: Add sections on FP-GPIOs and how to drive them
- n3xx: Document eeprom flags
- Add note about DPDK needing to be built as shared libraries
- Change DPDK version to 18.11 and make args use underscores
- Clarifying which devices support DPDK
- dpdk:
- Improve link status detection
- Increase default num recv frames
- Add new DPDK stack to integrate with I/O services
- e31x:
- Add retry to loopback_self_test
- Change RFNoC Ctrl clock to 40 MHz
- Fix timeout for timekeeper registers
- Fix filter bank and antenna switching for channel 0
- Swap out liberio for internal Ethernet
- e320:
- Fix timeout for timekeeper registers
- Swap out liberio for internal Ethernet
- examples:
- Fix install paths in OOT RFNoC block example
- Add usrp_power_meter example
- Update test_messages example
- Update gpio example
- Add options to benchmark_rate
- Add example out-of-tree module for RFNoC modules
- Remove thread priority elevation
- fpga:
- Added AA image mappings to N320 image package
- Add Replay Block to RFNoC Core Image
- Update DRAM IO signatures
- sim: chdr_stream_endpoint_tb improvements
- sim: Fix stream command and status models
- Update AXI interconnect address range for n3xx and e320
- rfnoc: Update CHDR stream INIT command
- Update coding guidelines
- Replaced RFNoC architecture with new 4.0 version
- Added modelsim make simulation target
- Upgrade to Vivade 2019.1
- Removed unused coregen files and modules
- Removed fpga submodule and merged into uhd repo
- lib: Change max FFT size to 1024
- lib: add Intel MAX10 architecture for 2clk FIFO
- rfnoc: Port RFNoC Keep One in N block to new RFNoC architecture
- rfnoc: Port RFNoC Replay block to new RFNoC architecture
- rfnoc: Port Signal Generator RFNoC block to new RFNoC architecture
- Add Switchboard RFNoC block
- Remove liberio
- rfnoc: Port RFNoC Moving Average block to new RFNoC architecture
- rfnoc: Port Log-Power block to new RFNoC architecture
- rfnoc: Port RFNoC Window block to new RFNoC architecture
- lib: Add synthesizable AXI4-Stream SV components
- lib: Add interface and model for AXI4-Lite
- rfnoc: Add support for 512-bit CHDR widths
- rfnoc: Port RFNoC Add/Sub block to new RFNoC architecture
- rfnoc: Port Vector IIR RFNoC block to new RFNoC architecture
- lib: Add AXI-Stream splitter (axis_split)
- lib:
- Remove recursive locks in apply_corrections
- Add power cal manager
- deps: Add FlatBuffers 1.11.0 header files
- Add DPDK service queue
- mpm:
- e31x: Accept FF terminated strings in eeprom (legacy support)
- Return 10 Gbs link speed on failure
- Exclude internal NIC for network hosts
- Add ability to run scripts to MPM shell
- n3xx: Remove eth1, eth2 from interface list
- Default virtual NIC CHDR IP selection
- Enable internal NIC on the N3xx
- Clean up code, improve Pylint score
- Move common mboard regs code to common location
- mpmd:
- Remove liberio
- multi_usrp:
- Fix connect/disconnect of RFNoC chains
- Various multi_usrp_rfnoc fixes
- n310:
- Add Replay Block to default FGPA images
- Fix GPIO registers
- n320:
- Add Replay Block to default FGPA images
- Double radio ingress buffer size
- Enable inverse sinc filter for DAC37J82
- n3xx:
- Fix timeout for timekeeper registers
- Swap out liberio for internal Ethernet
- python:
- Add peek/poke bindings to noc_block_base
- Add Keep One in N block controller bindings
- Add replay RFNoC block controller bindings
- Add siggen RFNoC block controller bindings
- Add Switchboard block python bindings
- Add moving average RFNoC block controller bindings
- Add bindings for C++ CHDR Parser
- Add window RFNoC block controller bindings
- Add FFT RFNoC block controller bindings
- Add null RFNoC block controller bindings
- Add vector IIR RFNoC block controller bindings
- Add radio RFNoC block controller bindings
- Add FIR filter RFNoC block controller bindings
- Add Fosphor RFNoC block controller bindings
- Add DUC RFNoC block controller bindings
- Add DDC RFNoC block controller bindings
- Added new RFNoC image builder module under the uhd module
- Remove Python2-specific code
- Included complex.h to allow pybind to convert that data type
- rfnoc:
- replay: Update packet size on mtu update
- Set null source/sink block initial state
- Add support for 32-bit memory address widths to Replay block
- Enable SEPs with connect_through_blocks
- Exit disconnect() early if nodes not in node map
- Add multichannel register interface
- Added support for destruction of streamers
- Add Keep One in N block support
- Port siggen RFNoC block controller support to new RFNoC architecture
- Add Switchboard block support
- Port Moving Average block controller to new RFNoC architecture
- Port Log Power RFNoC block support to new RFNoC architecture
- Port window RFNoC block controller to new RFNoC architecture
- Port Add/Sub RFNoC block support to new RFNoC architecture
- Add USE_MAP prop/action forwarding policy
- Port Split Stream RFNoC block to new RFNoC architecture
- Port Vector IIR RFNoC block support to new RFNoC architecture
- Port RFNoC fosphor block to new RFNoC architecture
- Port FIR filter RFNoC block controller to new RFNoC architecture
- Add multichannel register interface
- Add RFNoC Python API
- Unify endianness of transports
- Add DMA FIFO block controller
- examples: Port examples to new RFNoC
- Implement flushing on overrun
- client_zero can track num SEPs and num ctrl EPs separately
- Add basic round-robin allocation for links
- Add ability to select transport for streamers to user APIs
- Use link_stream_manager's mgmt_portal for all mgmt packets
- graph: Optimize property propagation algorithm
- Port DUC block controller to new RFNoC architecture
- Add MTU tracking
- Implement overrun handling using action API
- Port null block controller to new RFNoC architecture
- Add mb_controller API
- Port radio block controller to new RFNoC architecture
- Port default block controller to new RFNoC architecture
- Port DDC block controller to new RFNoC architecture
- Add rfnoc_graph class
- Add action API
- Refactored CHDR packet interfaces
- Add noc_block_base class
- tests:
- Fix build issue with Boost 1.67
- Add unit tests for new RFNoC block controllers
- Fix multi_usrp_test
- Add unit tests for pwr_cal_mgr
- Migrated rfnoc block tests to dedicated subdirectory
- Add more tests for max rate streaming
- Add tests to exercise max streaming rates and report results
- tools:
- Update dissectors for Wireshark major version 3, new CHDR
- Update FPGA functional verification tests for X3x0 mcr's & dpdk
- transport:
- Implement eov indications for Rx and Tx streams
- Implement an I/O service that uses an offload thread
- Implement a single-threaded I/O service
- twinrx:
- Bypass adf535x feedback divider
- Update synthesizer register values for improved rf performance
- Fix increased noise floor
- Remove decimation from frontend
- uhd:
- Disable optimizations for Mac for build speed
- remove liberio
- improved handling of empty serial number hints
- Add discoverable_features API
- Add reference power level API to multi_usrp and radio_control
- Add fuzzy serial number checking
- paths: Harmonize around XDG Base Directory specification
- cal: Use usrp::cal::database instead of CSV files
- cal: Add iq_cal calibration data container class
- cal: Add calibration container class
- cal: Add database class
- Introduce I/O service manager
- Replace usage of boost smart pointers with C++11 counterparts
- add udp boost asio implementation of transport interface
- Add thread affinity utility functions
- types: Extend stream_cmd_t::num_samps to 64 bits
- utils:
- Expose CHDR Parsing API
- Expose CHDR Types in Public API
- Support expressions for num_ports in block defs
- Let uhd_images_downloader also use HTTPS proxies
- Fix FPGA search in rfnoc_image_builder from fpga-src to fpga
- Add convert_cal_data utility
- image_builder: Support parameterized number of ports on blocks
- x300:
- Add Replay Block to default FGPA images
- Update frame sizes for 10GbE
- Fix for incorrect PCIe buffer size values
- Change default dboard clock rate from 50 to 100 MHz
- Update maximum bitstream size
- Enable power reference API
- Expand DRAM address space to 1G
- Add ...
UHD 4.0.0.0 Release Candidate 1
004.000.000.000
- b200:
- Enable power calibration API
- Add a prop tree node usb_version
- cal:
- Add utility to update all .fbs files, or check the generated ones
- Add pwr_cal container
- cmake:
- Add ability to pass CXXFLAGS to CMake environment
- docs:
- Update PCIe xport instructions for NI Repos
- n3xx: Include WX in table of N320 images
- Add stream and transport args documentation
- Update Basic/LF dboard references to use new operating mode
- e3xx/n3xx: Add sections on FP-GPIOs and how to drive them
- n3xx: Document eeprom flags
- Add note about DPDK needing to be built as shared libraries
- Change DPDK version to 18.11 and make args use underscores
- Clarifying which devices support DPDK
- dpdk:
- Add new DPDK stack to integrate with I/O services
- e31x:
- Change RFNoC Ctrl clock to 40 MHz
- Fix timeout for timekeeper registers
- Fix filter bank and antenna switching for channel 0
- Swap out liberio for internal Ethernet
- e320:
- Fix timeout for timekeeper registers
- Swap out liberio for internal Ethernet
- examples:
- Add usrp_power_meter example
- Update test_messages example
- Update gpio example
- Add options to benchmark_rate
- Add example out-of-tree module for RFNoC modules
- Remove thread priority elevation
- fpga:
- Replaced RFNoC architecture with new 4.0 version
- Added modelsim make simulation target
- Upgrade to Vivade 2019.1
- Removed unused coregen files and modules
- Removed fpga submodule and merged into uhd repo
- lib: Change max FFT size to 1024
- lib: add Intel MAX10 architecture for 2clk FIFO
- rfnoc: Port RFNoC Keep One in N block to new RFNoC architecture
- rfnoc: Port RFNoC Replay block to new RFNoC architecture
- rfnoc: Port Signal Generator RFNoC block to new RFNoC architecture
- Add Switchboard RFNoC block
- Remove liberio
- rfnoc: Port RFNoC Moving Average block to new RFNoC architecture
- rfnoc: Port Log-Power block to new RFNoC architecture
- rfnoc: Port RFNoC Window block to new RFNoC architecture
- lib: Add synthesizable AXI4-Stream SV components
- lib: Add interface and model for AXI4-Lite
- rfnoc: Add support for 512-bit CHDR widths
- rfnoc: Port RFNoC Add/Sub block to new RFNoC architecture
- rfnoc: Port Vector IIR RFNoC block to new RFNoC architecture
- lib: Add AXI-Stream splitter (axis_split)
- lib:
- Add power cal manager
- deps: Add FlatBuffers 1.11.0 header files
- Add DPDK service queue
- mpm:
- Exclude internal NIC for network hosts
- Add ability to run scripts to MPM shell
- n3xx: Remove eth1, eth2 from interface list
- Default virtual NIC CHDR IP selection
- Enable internal NIC on the N3xx
- Clean up code, improve Pylint score
- Move common mboard regs code to common location
- mpmd:
- Remove liberio
- multi_usrp:
- Fix connect/disconnect of RFNoC chains
- Various multi_usrp_rfnoc fixes
- n310:
- Fix GPIO registers
- n320:
- Double radio ingress buffer size
- Enable inverse sinc filter for DAC37J82
- n3xx:
- Fix timeout for timekeeper registers
- Swap out liberio for internal Ethernet
- python:
- Add Keep One in N block controller bindings
- Add replay RFNoC block controller bindings
- Add siggen RFNoC block controller bindings
- Add Switchboard block python bindings
- Add moving average RFNoC block controller bindings
- Add bindings for C++ CHDR Parser
- Add window RFNoC block controller bindings
- Add FFT RFNoC block controller bindings
- Add null RFNoC block controller bindings
- Add vector IIR RFNoC block controller bindings
- Add radio RFNoC block controller bindings
- Add FIR filter RFNoC block controller bindings
- Add Fosphor RFNoC block controller bindings
- Add DUC RFNoC block controller bindings
- Add DDC RFNoC block controller bindings
- Added new RFNoC image builder module under the uhd module
- Remove Python2-specific code
- Included complex.h to allow pybind to convert that data type
- rfnoc:
- Add multichannel register interface
- Added support for destruction of streamers
- Add Keep One in N block support
- Port siggen RFNoC block controller support to new RFNoC architecture
- Add Switchboard block support
- Port Moving Average block controller to new RFNoC architecture
- Port Log Power RFNoC block support to new RFNoC architecture
- Port window RFNoC block controller to new RFNoC architecture
- Port Add/Sub RFNoC block support to new RFNoC architecture
- Add USE_MAP prop/action forwarding policy
- Port Split Stream RFNoC block to new RFNoC architecture
- Port Vector IIR RFNoC block support to new RFNoC architecture
- Port RFNoC fosphor block to new RFNoC architecture
- Port FIR filter RFNoC block controller to new RFNoC architecture
- Add multichannel register interface
- Add RFNoC Python API
- Unify endianness of transports
- Add DMA FIFO block controller
- examples: Port examples to new RFNoC
- Implement flushing on overrun
- client_zero can track num SEPs and num ctrl EPs separately
- Add basic round-robin allocation for links
- Add ability to select transport for streamers to user APIs
- Use link_stream_manager's mgmt_portal for all mgmt packets
- graph: Optimize property propagation algorithm
- Port DUC block controller to new RFNoC architecture
- Add MTU tracking
- Implement overrun handling using action API
- Port null block controller to new RFNoC architecture
- Add mb_controller API
- Port radio block controller to new RFNoC architecture
- Port default block controller to new RFNoC architecture
- Port DDC block controller to new RFNoC architecture
- Add rfnoc_graph class
- Add action API
- Refactored CHDR packet interfaces
- Add noc_block_base class
- tests:
- Add unit tests for new RFNoC block controllers
- Fix multi_usrp_test
- Add unit tests for pwr_cal_mgr
- Migrated rfnoc block tests to dedicated subdirectory
- Add more tests for max rate streaming
- Add tests to exercise max streaming rates and report results
- tools:
- Update dissectors for Wireshark major version 3, new CHDR
- Update FPGA functional verification tests for X3x0 mcr's & dpdk
- transport:
- Implement eov indications for Rx and Tx streams
- Implement an I/O service that uses an offload thread
- Implement a single-threaded I/O service
- twinrx:
- Update synthesizer register values for improved rf performance
- Fix increased noise floor
- Remove decimation from frontend
- uhd:
- Disable optimizations for Mac for build speed
- remove liberio
- improved handling of empty serial number hints
- Add discoverable_features API
- Add reference power level API to multi_usrp and radio_control
- Add fuzzy serial number checking
- paths: Harmonize around XDG Base Directory specification
- cal: Use usrp::cal::database instead of CSV files
- cal: Add iq_cal calibration data container class
- cal: Add calibration container class
- cal: Add database class
- Introduce I/O service manager
- Replace usage of boost smart pointers with C++11 counterparts
- add udp boost asio implementation of transport interface
- Add thread affinity utility functions
- types: Extend stream_cmd_t::num_samps to 64 bits
- utils:
- Expose CHDR Parsing API
- Expose CHDR Types in Public API
- Support expressions for num_ports in block defs
- Let uhd_images_downloader also use HTTPS proxies
- Fix FPGA search in rfnoc_image_builder from fpga-src to fpga
- Add convert_cal_data utility
- image_builder: Support parameterized number of ports on blocks
- x300:
- Update frame sizes for 10GbE
- Fix for incorrect PCIe buffer size values
- Change default dboard clock rate from 50 to 100 MHz
- Update maximum bitstream size
- Enable power reference API
- Expand DRAM address space to 1G
- Add front-panel GPIO source control
UHD 3.15.0.0
003.015.000.000
- N320: Fix MCR initialization, fix checks for LO distribution board,
reset RX IQ balance on init, replace DRAM FIFO with replay block,
improve constraints, fix I/Q imbalance compensation, add FPGPIO control - N310: increase default dc offset averaging window, make tunes
asynchronous, add capability to control RF filter bypass and freq.band
limits, fix setting user DB EEPROM, correctly report N321 vs N320,
improve DDR3 BIST, update max revision to 7, fix DMA arbitration to
use contiguous packets, replace DRAM FIFO with replay block, fix SFP
link up status, add workaround for clocking interference with external
reference clocks, disable gpsdo clock/time source options when
enable_gps=0 - X300: Fix max bitfile size, fix GPIO ATR property access type, heavily
refactor, introduce conn_mgr, add DPDK support, add
capability to flash NI-2974 FPGA, fix clocking code, enable 11.52 MHz
and 23.04 MHz system ref rates, improve usage of constrained device
args, enable ADC gain through RFNoC API, add mode to set master clock
rate to arbitrary values between 184.32 and 200 MHz, throttle
muxed_zero_copy_if - E320: Fix time source clobbering ref source, add support for RevE, fix
reporting of FPGA version hash, fix SFP link up status, fix missing
ce_clk driver - E310: Convert to MPM architecture, fix uhd_image_loader usage, fix DMA
arbitration to use contiguous packets, reduced DMA chans to 4 (using
data stream muxing), fix DRAM_TEST target build - E3xx: Correct frontend name in devtest
- B200: Add command to query bootloader status, fix sc12 streaming, fix
FIFO sizes on GPIFII interface - UBX: add temperature compensation mode
- SBX: Only update ATRs when lock state changes
- TwinRX: add LO charge pump properties, increase default charge pump
value on LO1, add low spur tuning mode, fix duplicate write to N value
in DDC - RFNoC/device3: Read command FIFO size from device instead of
hardcoding values, fix multidevice graph connections, ENABLE_RFNOC now
defaults to ON, search all nodes for tick rate, add update_graph()
call which lets blocks do a graph-wide update of properties, fix
missing port arg in SR_WRITE Noc-Script call, constrain
send/recv_frame_size baed on MTU, fix flushing on init/deinit, disable
FC ACKs for lossless links - RFNOC/FPGA: Fix rb_stb in split stream block, fix off-by-one error in
the window block, fix phase reset and -accumulator for DDC and DUC
blocks, fix flushing on split-stream block, fix DC offset issue with
DDS by using proper rounding, fix DUC/DDC sample rate switching by
latching N on M in axi_rate_change, various fixes to
uhd_image_builder, fix MTU settings in blocks, align byte count to
8-byte word - RFNOC: Allow UHD_RFNOC_DIR to contain multiple paths
- Python API: Replace Boost.Python with PyBind11, fix benchmark_rate
statistics, fix phase alignment test script - Python API: Added include of complex.h to allow pybind to convert
complex data types - Python API: Make multi_usrp::get_*_usrp_info() return a Python dict
- Python API: Fix array processing in send_waveforms()
- UHD: Allow ignoring fallthrough warnings, reduce Boost footprint,
remove gpsd dependency, improve streaming, reduced the number of
compiler warnings, introduce pop() to the prop tree, add typecast
operator from uhd::dict<> to std::map<>, properly cache config file
data - MPM/mpmd: Introduce compatible rev numbers to support future hardware,
fix some resource leaks in mpmd, fix spurious reclaims causing
unnecessary warnings, fix resource leaks in liberio xport, allow to
mux data streams over liberio transports (e.g. to require fewer DMA
channels on E310), wait for DPDK links to come up before proceeding,
relax failure handling when updating components (fixes spurious errors
when updating FPGA images over SFP), fix issue where RPC
initialization would hang on failure - MPM: Re-enable RPC server timeouts after components have been updated
- MPMD: Remove arbitraty frame size defaults for UDP transports
- MPMD: Fix incorrect link rate warnings
- FPGA: Use new device-tree overlay syntax, upgraded to Vivado 2018.3,
broke various paths with critical timing, allow SystemVerilog source
files, improve viv_modify_bd and viv_modify_tcl_bd, fix resets on 2clk
FIFOs - USB: Allow cancelled USB requests to occur
- USB: Fix global session race condition
- Logging: Always honour log level, don't log colours for non-ttys, fix
includes, demote various log messages, fix logging colours, fix
deadlock on Windows machines - Examples: Fix benchmark_rate INIT_DELAY, fix memory leak in
tx_samples_c - Examples: Remove thread priority elevation
- Examples: Add options to benchmark_rate for start delays and priority
- Tests: Make the Python interpreter for devtests a parameter, add unit
tests to MPM - Utilities: Fix converter benchmark for Py3k and scaling issue
- Tools: Fix kitchen_sink
- Tools: Fix Wireshark dissectors to work with WS1, 2, and 3
- Tools: Various fixes to FPGA functional verification tests
- Docs: Various fixes, fix Doxygen warnings, fix links to KB, update
DPDK information about building libraries, add DPDK subsection about
thread priorities, update testing procedures - C API: Add uhd_get_abi_string, uhd_get_version_string
- CMake: Make manpage compression optional, allow setting of PKG_DOC_DIR
from the CMake commandline, add replay example, fix missing 'project',
replace ENABLE_PYTHON3 with a simpler Python detection, clean up
superfluous modules, improve log statements, bump dependency min
versions, add MPM unit testing, fix missing BIGOBJ for MSVC, add our
own UHDBoost.cmake to better find Boost across versions and systems,
constrain DPDK check to exact version - Formatting: Apply clang-format to all files, break after template<>