Linux kernel:
- added support for I2C GPIO expanders (PCA953X, MCP23S08)
- added GPIO based drivers for SPI, I2C and 1-wire
- enabled reset controller support
- patched Cadence I2C controller driver to add proper HW reset
- changed kernel patching procedure, the kernel is now forked, and patches are commited to the fork Git repo
- updated kernel to 2016.2
Application changes:
- partial cleanup of copied JS/CSS code and images
System Changes:
- recoded Bazaar related Makefiles, instead of cross compilation, a native compiler root system is used, running inside an ARM QEMU virtualized environment, this avoids library version issues, but emulation is slow
- top Makefiles are now split into a system Makefile.x86, which requires x86 to run tools like Vivado and a user space Makefile used to compile applications (Bazaar, web apps, SCPI, API, ...)
- updated Nginx from version 1.5.3 to the latest 1.10.0
- removed NGINX patches
- updated Lua Nginx from version v0.8.7 to the latest v0.10.2
- updated Websocket++ from version 0.5.0 to a slightly newer 0.7.0, and provided a patch for an issue triggered by kernel update to 4.4
- removed Buildroot, lately it was only used to provide libraries at compile time, now Debian libraries are used directly
- removing SDK, since it was not maintained, now it is possible to compile all user space code directly on Red Pitaya
- removed some deprecated/duplicated source code
- Vivado/U-Boot/Linux were updated to xilins-v2016.2
- the Linaro compiler is no longer needed, ARMHF compiler is now part of Vivado SDK
OS changes:
- the OS was switched from Debian Jessie to Ubintu 16.04, the main reason for the switch is access to Launchpad PPA
- OS image building scripts are now a bit cleaner with separation into generic Ubuntu settings, network and Red Pitaya specific settings
Network:
- the network setup was entirely recoded using systemd specific tools
- zeroconf support was added
- the network setup is now properly documented in NETWORK.md
FPGA2:
fpga2
project was added, which is used byapi2
and the LA application- the project is rewritten in SystemVerilog mostly to make the code shorter
- instead of storing samples in a short buffer, Xilinx DMA is used to copy data into the main memory
- more thought is (should be) given to modules with Linux kernel drivers available
API2:
- UIO is used to divide the memory space into separate segments each controlled by a separate driver
- device tree overlays are used to handle loading various FPGA images, this is not yet ready for public use
Application changes:
- Makefile changes so applications can be compiled directly on Red Pitaya
- removing 'libjpeg' sources from spectrum analyzer applications and instead using the 'libjpeg-turbo' Debian system library
Network manager /SCPI/Wyliodrin managers
New applications:
- LCR meter application - accurately measures capacitors, inductors and resistors using the test frequencies of 100Hz, 1 kHz, 10kHz and 100kHz.
Application improvements: -SCPI server:
- can now be started directly from WEB browser via Remote control app
- Oscilloscope:
- navigation was improved (time offset can now be set by mouse dragging, t/div can be changed by scrolling)
- user is now able to retrieve signal acquired into ADC buffer even if acquisition is stopped
- stability of data transfer was improved together with network performance indication
- gain setting is now remembered when quitting app
- trigger status is now properly updated at high frequencies
- we fixed few normal trigger issues
- Spectrum analyzer:
- acquire algorithm fix that fixes spectrum issues
General system improvements:
- discovery service & market access problems are now solved
- user is now able to upgrade Red Pitaya OS directly from the WEB browser rewriting complete SD card image is now only necesary in case of Debian/Ubuntu changes (usually systemd and network related)
- Red Pitaya desktop was improved so it is more simple to use and also provides better support for tablets and smartphones
- browser detection was added that suggest users to install or upgrade to recommended version
- online/offline detection was added so that user knows if Red Pitaya can access the internet / if it is possible use some features that requires internet connection
- switching between contributed and official applications doesn’t causes problems anymore
- system crashes reports with debug information can now be sent to Red Pitaya team on user request
- Feedback app - enables user to send feedback our support with attached information about Red Pitaya OS, computer OS & browser
- Analytics is sent to Red Pitaya team on user request in order to track system events that can help improve user experience
Other:
- access to wiki page was added, but the main news is that we also updated wiki documentation
Changes:
- libstdc++.so was removed from /opt/redpitaya/lib, this was made possible by fixing C++ application Makefile-s, some were using g++ while also linking stdc++, which caused conflicts, linking stdc++ was removed
- small updates to free applications
Known issues (at least major ones) are same as in 0.94 RC23.
Changes:
- migration to Vivado 2015.4 and related U-Boot, Linux kernel and devicetree versions
- changes to ARM clocking so the CPU runs at 666MHz instead of 500MHz (Ulrich Habel)
- SPI userspace access seems to be fixed,
/dev/spidev1.0
is present, but kernel log still does not mention SPI or QSPI drivers
- possible timing issues
- poorly written test benches
- generator burst mode is buggy
- there is no simple method to remove 3 second boot wait
- Warnings are reported for Lantiq Ethernet PHY devicetree
- wireless is broken on Buildroot, and will probably only be futher maintained on Debian/Ubuntu
- SCPI server is poorly tested and the documentation is old
System changes:
- fixed slow analog output API
- fixed generator code in many old applications, so they can use the latest FPGA bitstream (0.94), this should reduce issues with applications, which do not load their own bitstream (Test, SCPI)
Application changes:
- system monitor was added under (Settings -> SYS INFO) in order to monitor network performances, refresh rate and RP CPU, RAM status
- refresh rate is auto-adjusted to network performance and user is also informed if network performance is too low and can affect user experience
- transferred data is now compressed
Known issues (at least major ones) are same as in 0.94 RC12.
- generator burst mode is buggy
- SPI interface is not working (seems to be a kernel configuration issue)
Changes:
- fixed copy-paste error in GPIO API (https://github.com/jjmz)
- added fallback to static IP if DHCP fails (Pavel Demin)
- a fix for IMM trigger for generator
- removing some backup files
- added support for LCR meter addon board to lcr executable
- come calibration related changes to scopegenpro UI
Known issues (at least major ones) are same as in 0.94 RC12.
- generator burst mode is buggy
- SPI interface is not working (seems to be a kernel configuration issue)
Changes:
- fixed licensing related regression
Known issues (at least major ones) are same as in 0.94 RC12.
- generator burst mode is buggy
- SPI interface is not working (seems to be a kernel configuration issue)
Changes:
- fix for WiFi driver switching (Pavel Demin)
- fixed command prompt issues (Pavel Demin)
- some SCPI fixes (arbitrary generator sequence support, ...)
- some cleanup of SCPI and API examples
- some building documentation updates
Known issues (at least major ones) are same as in 0.94 RC12.
- generator burst mode is buggy
- SPI interface is not working (seems to be a kernel configuration issue)
Changes:
- fixed missing configuration file for WiFi access point mode (Pavel Demin)
- cleanup of analog output PWM and digital IO API code, it is now reduced to a single layer
- API header file was moved from other API sources, to avoid header file name conflicts
Known issues (at least major ones) are same as in 0.94 RC12.
- SPI interface is not working (seems to be a kernel configuration issue)
Changes:
- move to a newer version of SCPI parser (between v2.1 and Git master) some patches were ported some removed
- fixed a SCPI acquisition issue, where buffer was overwritten by incoming data (involuntary continuous acquisition mode)
- removed continuous calibration related I2C EEPROM reads while running scopegenpro, this improved stability
- removed rebug option from application builds, thus improving performance
- updated build process (Makefile) mostly for the public release
- some cleanup of Examples
Known issues (at least major ones) are same as in 0.94 RC12.
- SPI interface is not working (seems to be a kernel configuration issue)
Changes:
- on extension board analog input divider was removed, so in libwyliodrin analog input range was changed from 10V to 7V
Known issues (at least major ones) are same as in 0.94 RC12.
Changes:
- removed superfluous debug messages in Nginx debug log
- updated visual programing WEB URL
Known issues (at least major ones) are same as in 0.94 RC12.
Changes:
- spectrum analyzer was very slow on slow SD cards, a tmpfs /tmp/ram was created for waterfall JPEG images
- removed XADC code from monitor, added Examples/xadc/xadc.sh covering the same functionality (currently missing proper voltage scaling)
Known issues (at least major ones) are same as in 0.94 RC12.
RC12 is the first public release in the series.
- reorganized
fpga
directory structure - removed Vivado project, instead added non project mode TCL scripts
- added Vivado TCL scripts for creating a project (used for migrating to newer tool versions)
- updated Vivado to newest version 2015.2
- fixed an ASG issue which could result in a slightly wrong frequency and slightly distorted signals
- restructured
rtl/red_pitaya_analog.v
to move IO and PLL related code (device specific code) to the top module - connected XADC to AXI using the Xilinx provided Wizard, which allows us to use the IIO Linux driver with it
- LED[0] is now a normal software controllable output
- test benches were updated, so they compile now, and some were also run and used, there were no significant changes to functionality
- updated to Xilinx version 2015.1
- changed patch structure, to take advantage of device tree language features
- added nodes for XADC
- added nodes for
LED8
andLED9
- updated to Xilinx version 2015.2
- patched so it executes additional code (from script files) after I2C EEPROM configuration is executed and before running the Linux kernel (porting done by Pavel Demin)
- scripts were added to run either Buildroot from initramfs or Debian from EXT4
- updated to Xilinx version 2015.1 (porting done by Pavel Demin)
- updated Wireless driver, copied from Raspberry PI
- in addition to Buildroot, Debian Jessie OS is now supported (porting done by Pavel Demin)
- discovery was rewritten from lengthy C code into a short BASH script
- for bare metal applications the toolchain from Vivado 2015.2 SDK is used
- for Linux user space Linaro 2014.11 is used
- ARMHF ABI is used for better compatibility with modern Linux distributions, breaking compatibility with older ARMEL applications
- existing free applications were recompiled for ARMHF, and are still also compatible with ARMEL for older ecosystems
- new Oscilloscope+Generator and Spectrum analyzer were added
- fixed support for applications loading their own FPGA bitstream images
- Wyliodrin was ported to Debian on Red Pitaya
- the prefered API for XADC is now the Linux IIO driver
- the prefered API for LED[9:8] is now the Linux LED driver
- removed some dependencies to
libredpitaya
, will probably be deprecated, since most functionality is present inlibrp
- possible timing issues
- poorly written test benches
- there is no simple method to remove 3 second boot wait
- Linux kernel could not be updated to the latest Xilinx version 2015.2.01, due to changes to the Ethernet and USB subsystems, which caused issues
- wireless is broken on Buildroot, and will probably only be futher maintained on Debian/Ubuntu
- The scrip for detecting the WiFi driver and reconfiguring the AP config file is not able to write the file, so only one chip is supported without manually modifying
hostapd.conf
- SCPI server is poorly tested and the documentation is old
- added burst mode to ASG (arbitrary signal generator)
- added DMA for writing oscilloscope streams directly into the main memory (512MB)
- removed all (most) references to the unsupported tool Ahead (ISE), from now on only Vivado should be used
- partial RTL whitespace cleanup
- CDC (clock domain crossing) moved from
bus_clk_bridge.v
into PS (processing system) - registered read data bus for all slaves on the custom system bus
- removed unconnected SPI interface from PS
- removed bench support from Vivado project
- removed unconnected SPI interface
- added a dummy SPI device to the device tree, so
/dev/spidev1.0
is now available - added interface usage examples to
Examples/Communication/C/
- the test bench is broken, mostly because the removal of CDC from modules
- the plan is to use SystemVerilog in the test environment, this is not supported by the Vivado simulator
Release 0.92 is a bug-fix release, not introducing any new features. The bug-fixes resolve mainly the following issues:
- Several AUTO button related issues.
- Several zoom related issues.
- Several Measure panel improvements (refresh rate, readability, accuracy, relevance).
- Manual range controls.
- Artifacts in signal traces at long time ranges (> 1 s).
- Long delays at incremental acquisitions and long time ranges (> 1 s).
- Trigger level visibility in plot area based on trigger mode & source.
- Trigger level dependency on gain settings.
- Arbitrary waveform generator file upload & immediate new waveform activation.
- Signal generation on EXT trigger.
- Acquire uses correct FPGA filter coefficients.
- Problems with double GET/POST requests sent from browser for single click.
- Several general SW stability issues, crashing applications at certain conditions.
- U-Boot reports correct amount of memory.
- Ecosystem fixes:
- Linux OS built completely from sources, including the ramdisk.
- Using buildroot for the ramdisk, making it possible to add (almost) any SW.
- Using nginx dependency libraries from buildroot.
- Versions embedded to all major Red Pitaya binaries & scripts for traceability.
- WiFi (wlan0) and wired (eth0) routing conflict when WiFi is used.
- Cosmetics: improved logging, unique app icons...
- Cleanup of obsolete code.
Initial release.