Category: LinHT

  • LinHT rev B – first boot

    Sharing great news from Andreas OE3ANC. Good work, team!

  • LinHT Rev B update

    We finally have the first fully assembled LinHT Rev B PCB.

    The board powers up correctly, the ATTiny power-management firmware is working, and the PMU logic now controls the startup/shutdown sequence as intended.

    USB-C charging is also working as expected, and the whole device can be powered on with the rotary ON/OFF switch.

    We also confirmed debug UART from the SoM is available on the Kenwood connector and works with common Baofeng-style USB serial adapters.

    There is still a lot of work ahead: update the Linux device tree for the new Rev B pinout, validate all new peripherals, and fully test GNSS, the RF power amplifier stage, and the rest of the hardware.

    Stay tuned.

  • LinHT boards have arrived!

    Today, we have received a set of three Rev B boards. They will be tested in the coming days. Stay tuned!

    What’s new in Rev B:
    – redesigned power supply
    – internal RF power amplifier (~5W at 435MHz, CW)
    – improved RF receiver path (added variable attenuation)
    – GNSS receiver
    – battery charging through USB-C
    – cleaner layout and grounding

    Photo courtesy of Vlastimil, OK5VAS.

  • LinHT – Yocto image update

    News from Andreas OE3ANC:

    I just uploaded a new image for Rev A

    • Latest versions of LinHT repos
    • Removed gr-bokeh (this removes nodejs dependencies which makes build faster)
    • Updated raylib (new lic hash)
    • Changed default sample rate to 125k
    • Creating /var/lib/linht folder for gui_test sqlite

    The new image can be downloaded here: https://m17project.org/linht/experimental/

    Flashing instructions: https://wiki.m17foundation.org/index.php?title=LinHT

    This is how the display looks like now:

    Rev B is still in the works. Stay tuned for more updates.

  • LinHT + CC1200 HAT combo

    More photos (and maybe even videos) soon!

    By the way – we have some news from Vlastimil, OK5VAS.

  • LinHT – its internal structure and a quick explanation on how it all works

    While many people already know what LinHT is, not many are aware how it works. Yes, it’s an SDR radio – but what’s inside?

    The core of the device is a System on Module running carefully crafted Yocto Linux image. It offers all the Linux things, including a file system, GPIO/ADC ports, beloved ALSA, and many other higher-level goodies, such as Python3 and gcc with make/cmake. The SoM uses the NXP i.MX9352: dual-core ARM Cortex-A55, clocked at 1.7GHz. There is also a quite powerful Neural Processing Unit available, but we are going to pretend it;s not there for now πŸ™‚

    The system can run GNU Radio. Along with ssh/scp, it creates a powerful tool for amateur radio enthusiasts and RF engineers. This is definitely the best part, as the combination basically gives you a pocket computer with a full-blown SDR. It is no longer a black-box FM-only radio. This is actually a true, user-defined SDR. And it comes with a battery! Obsolescence is not an issue anymore. If a new protocol shows up in 5 years, it will most likely be possible to implement it on the LinHT. As GNU Radio blocks. It is that simple.

    Let’s take a look at the internal structure of the device.

    The GNU Radio flowgraph (as defined by a .grc file) can not do much on its own. The flowgraph has to be translated into Python code first. This is what the GR built-in grcc compiler does. So: after the flowgraph is prepared, it can be turned into an executable Python file (.py). The python code can be spawned by the Interface Daemon.

    What the hell is that daemon for? Well – as a user, you need a way to tell the radio what to do. It is also good to know what the radio is actually doing, and if it’s aligned with the user’s intentions πŸ™‚ You can not just turn the radio on (by turning the volume knob) and expect the OS to know what you want. This is what the daemon handles – your intent (by reading the keypad, PTT, etc.). It also uses the display to tell you want the radio is up to. But its function is not limited to that – it also controls the SX1255 RF front end chip and selects which flowgraph to run. It pre-configures the front end based on whatever settings are in the YML configuration file.

    The daemon also communicates with the flowgraph and ALSA. The flowgraph is a mere state machine – it needs to know what to do and when (state transitions). Which mode are we using? Are we transmitting? Are we receiving? Has an M17 packet with a text message arrived? Or are we going to reply to it? The daemon tells the flowgraph what and when to do it. The flowgraph can not just simply stay free-running all the time.

    Linux makes things easy here – the daemon works as a system service.

    Now the ZeroMQ Proxy. Since ALSA can be a pain in the rear to configure and work with, we decided to put a very simple additional layer between the SX1255 (again – disguised as ALSA sound device) and the GNU Radio flowgraph. There is a simple C code doing the proxy work: bi-directional ALSA-ZMQ bridge for baseband samples. Now, instead of using Audio Source/Sink blocks to access baseband (that did not work) we can now do the same task with ZMQ PUB/SUB Sink/Sources, connected to a pair of IPC sockets using very little CPU resources. Clever, right?

    The flowgraph can notify the daemon that it received something – this can be anything – in our case it’s an M17 packet reception. The flowgraph uses ZeroMQ with an IPC socket (again) to announce RF events. This path is used for non-audio streams (data). Audio streams are routed directly to ALSA through an Audio Sink.

    Microphone signal is handled by ALSA as well. It is sampled by the flowgraph directly.

    PTT signal handler is simple as well – we use the daemon here again. In an infinite loop, we read the keypad state (and the PTT). PTT press and release events trigger a ZeroMQ message transmission from the daemon to the flowgraph. The state machine in the flowgraph (M17 Coder/Decoder blocks have appropriate handlers built-in) reacts to the message and either starts reception or transmission. SX1255 (and the rest of the RF front end) is configured in the same way – by the daemon, upon user input.

    I hope this article is understandable and clarifies how LinHT works under the hood. It is not very detailed, as I did not want it to be too long. I just wanted to cover the core idea.

    Have fun experimenting!

  • LinHT M17 reception stability tests

    Today, I decided to stress-test my LinHT Rev A prototype. The aim was to assess the battery life in the following conditions: minimal transmission time – mostly reception. I used a CC1200 hotspot connected to M17-KCW A as a solid M17 RF source (with stable traffic). The handheld’s backlight (including keypad) was kept on for the whole test duration. Stock Retevis C62 2S Li-ion battery was used, fully charged on the previous day (in the evening). A modified charger was used – I replaced the 0.47ohm resistor with a 0.33ohm one* (a stack of three 1ohm resistors) for increased charge current. Silicon thermal pads were used to allow the SoC to dissipate heat through the aluminum part of the chassis (see this entry for details).

    I started the test by switching the volume knob at 9:17 LT. The starting battery voltage was 8.05V.

    At 19:17 LT (t+10h), the battery was at 6.7V.

    htop – CPU utilization and process list

    # uptime
    19:18:14 up 10:02, 2 users, load average: 0.49, 0.50, 0.47
    # ./LinHT-utils/scripts/temp.sh
    40.85

    CPU slightly below 41 deg. C after 10 hours of continuous DSP work? I think this is a very good result. This would definitely not be possible without some DSP tweaks we introduced in the M17 GNU Radio flowgraph. I had to quickly reset the flowgraph in the first 30 minutes due to an unexpected segfault πŸ™‚ The cause is yet to be found.

    Last but not least – big shout out to the rest of our team – Andreas OE3ANC and Vlastimil OK5VAS, and every financial contributor out there. Let’s keep this up πŸ™‚

    *the values are taken off the top of my head – I believe they are correct. The idea is to slightly reduce the resistance to increase the current.

  • LinHT update

    We have decided to assemble a set of Rev B prototypes in Czech Republic due to long lead times at PCBWay.

    All of the electronic components are already there. A small batch of 10 PCBs has been ordered today. Stay tuned for more news.

    Big shout out to Vlastimil OK5VAS for a substantial support in making some real progress here.

  • Running OpenWebRX on LinHT?

    Hell yeah! Vlastimil, OK5VAS, managed to prepare an example LinHT SoapySDR driver for the SX1255. This allows OpenWebRX to be ran on the device, fetching IQ baseband samples directly from the ZMQ proxy (described a few posts back).

    OpenWebRX decodes M17, along with other digi modes.

    Astonishing work! This is the innovation amateur radio world needs. Can your radio do this? πŸ˜‰