GNU Radio is trivially easy to install on Ubuntu, which includes the UHD driver.
apt install gnuradio
DO NOT use GNU Radio from a virtual machine in general with an SDR, as typically many packets will be lost and the data will not be useful.
The typical best choice is to use a
GNU Radio live USB image.
Frequent GNU Radio users often dual boot into Ubuntu for working with SDR.
The HP-Setup program sets up HP printers on Linux and is easy to install and use.
Install HP setup program:
apt install hplip
Get the IP address of your networked HP printer from its front panel or the network address e.g. myprinter.local
The CLI method is very quick and reliable.
BIOS update via FreeDOS works across many PCs, including Dell and Gigabyte.
The key is that the OEM provides BIOS as a DOS executable.
Setup DOS-bootable USB drive: download the DOS-flashable BIOS firmware from the OEM e.g. support.dell.com
Determine USB drive device (e.g. /dev/mmcblk0) by issuing this command before and after USB drive insertion:
lsblk
Format (permanently erase) this USB drive with
umount /dev/mmcblk0
mkdosfs -F 32 /dev/mmcblk0
Download
the FreeDOS “USB Full Image” and extract the FD*.img file.
Write this image to the USB stick:
dd if=FD*.img of=/dev/mmcblk0 bs=4M
the image write will take a minute or two, depending on the write speed of the USB stick.
To be sure it’s done, wait for this command to exit in a second Terminal window:
sync
Update BIOS: extract/copy ALL the BIOS self-extracted files to the root of the FreeDOS flash drive from Linux.
Insert the USB flash drive into the PC to be flashed
Upon powerup, choose to boot from the USB drive.
This might require pressing F12 key.
In the BIOS boot device menu, look under Legacy boot. If Legacy boot is not enabled, it may need to be enabled to see the FreeDOS USB drive.
Do NOT install FreeDOS, just boot to DOS when prompted by FreeDOS.
In FreeDOS prompt, type the name of the .exe or .bat file for the firmware update as per OEM instructions.
The flashing process may take several minutes.
If the PC says
operating system not found
on this DOS USB drive, try it in another PC.
If it still doesn’t work, try another model of USB flash drive.
Some flash drives just are not amenable to being booted from.
If a new computer motherboard seems to be dead out of the box, be sure the power supply is working and connected correctly.
It may have a CPU that’s too new for the motherboard BIOS.
Specific example:
This happened for Gigabyte GA-Q87M-D2H with version F6 BIOS.
Version F7 BIOS was necessary for Haswell Refresh CPUs.
I had to put an “old” CPU in the motherboard to flash the motherboard BIOS!
The Gfortran flag -std=legacy disables warning for very out of date non-standard Fortran syntax that should not be used anymore.
However, where you are using a legacy package where the code isn’t being changed, using -std=legacy can be necessary, particularly for Gfortran ≥ 8.
Some of the syntax enabled by -std=legacy includes pre-Fortran 77 arbitrary length arrays,
where A(1) was declared instead of A(*) in Fortran 77 or A(:) in modern Fortran.
Bash scripts by default ignore aliases, unless the command
shopt -s expand_aliases
has been used before the aliased command.
This is typically a good thing, as if one has set in ~/.bash_aliases something like
aliasmv="mv -v"
any script using mv could produce extremely lengthy and verbose output when installing a program for example.
However, sometimes a user has multiple versions of a program installed in directories in $PATH and for whatever reason cannot use update-alternatives to make the desired one the default.
Use
update-alternatives
instead whenever possible as this method described here is not as robust.
Because we are not sourceing the Bash script, the alias scope is only within the Bash script itself.
That is, once the script is done, the alias disappears.
If a script needs CMake 3.x and update-alternatives is not available, do within the Bash script:
Again, we stress this is not general or robust, so only do this as a last resort.
sudo is not required for
update-alternatives.
Put the softlinks under $HOME/.local/bin and put that on your $PATH as a much better choice.
RFSpace SpectraVue is a nice SDR GUI that work both online (with a radio) and offline (from a saved file).
SpectraVue is a Windows program that also works on Linux via WINE.
For USB based SDRs, since WINE doesn’t currently have USB support, we use the Linux program siqs-ftdi to connects to the SDR-IQ over USB, and provide the packets on a local network socket.
For Debian and Ubuntu, siqs-ftdi is provided with the CuteSDR program, another useful SDR interface.
It is necessary to use siqs-ftdi on the Linux Terminal to make the USB → network connection, since WINE currently does not support USB in general.
This method has worked for several years across various versions of WINE, SpectraVue and Linux.
SpectraVue on Linux is run via WINE.
Configure WINE with MFC42 and VCRun2010:
For USB-connected RFSpace SDR-IQ, use siqs-ftdi to make the USB connection.
For Ubuntu, siqs-ftdi is available in the cutesdr package for
Ubuntu:
apt install cutesdr
If siqs_ftdi is not included with your CuteSDR Ubuntu package, it’s possible to manually extract siqs-ftdi from the
cutesdr*.deb for your platform using dpkg-deb:
USB SDR and SpectraVue on Linux is one of the best ways to use the RFSpace SDR-IQ or other USB-connected SDR on Linux.
Open a Terminal and type
siqs-ftdi
Open a second Terminal window and type:
SpectraVue
Errors like:
err:module:import_dll Library mfc100.dll (which is needed by L"C:\SpectraVue\IOModule.dll") not found
err:module:import_dll Library IOModule.dll (which is needed by L"C:\SpectraVue\SpectraVue.exe") not found
err:module:import_dll Library mfc100.dll (which is needed by L"C:\SpectraVue\SpectraVue.exe") not found
are fixed by
winetricks vcrun2010
The error
err:module:import_dll Library MFC42.DLL (which is needed by L"c:\\SpectraVue\\SDR14X.dll") not found
htop is great for viewing processes on Unix-like systems.
It has the unfortunate behavior of overwriting changes to a manually written ~/.htoprc.
It seems the best way to disable threads is to remember the following:
capital H: toggle user thread display
capital K: toggle kernel thread display
This helps declutter the process tracking display.
There can exist incompatible terminal types between the local and remote computers on an SSH connection.
The issue arises when trying to scroll in a text editor on the remote computer such as nano, emacs or vim among others.
The text display would become all scrambled.
On the local SSH client PC, make the entries to the problem remote connection(s) as follows in the ~/.ssh/config file on your local PC.
opens a pseudo-terminal on the remote server, like the ssh -t option. If you have trouble, try RequestTTY force
RemoteCommand
this should normally have a && bash at the end of the command, assuming you want an interactive SSH session. Otherwise the remote server runs the command and immediately disconnects.