I am running vanilla Arch Linux with the stock mainline kernel on my RockPro64 (If you are interested in how to install, just check the other threads).
However, for a while now the ethernet on the RockPro was as good as dead, with network speeds reaching about 50-80Kbit/s!!!
As I am using my RockPro as a home cloud server, you can imagine how frustrating this is for me. This is so slow that even system upgrades fail due to timeouts on downloading the upgrade packages. So I used the free time now to dig into this issue, especially as I have not read anything of this behaviour from the other mainline users in this forum.
The first big difference between me and the other mainline users seem to be that while I am using the mainline Kernel from Arch, others on the Ayufan Images use the kernel compiled from Ayufan's mainline repo, where he also implements some patches specific to the Rockchip devices.
After a while I found a mail from him on the Linux Kernel Mailing Lists,
describing my problem as a bug in some rockchip boards where TX checksumming fails for ethernet packets larger than 1498 Bytes due to incorrect buffer utilization. This would also explain why I am still having a connection to my RockPro through SSH and why the DNS server on the RockPro still serves my home network, but updates fail: An ethernet packet can be as big as 65536 Bytes(!), so while SSH and DNS usually stay below a packet size of 1498B due to the small amounts of data they need to transmit, any file download will be split in packets as big as possible, breaking the checksums.
I could nicely verify this behavoiur with Iperf3 on my board: Iperf3 sends 128KB packets as default, reaching the expected 0-50Kbit/s ethernet speed, but when told to send packets of size 1490B only, ethernet throughput suddenly jumps up to gigabit speeds.
So, how to solve this?
It seems that the discussion turns around if this is just a board related issue or something in the SoC, as the problem seems to be in the utilization of the TX FIFO buffers by Linux. As it looks like they are experimenting with the burst lengths and a workaround of using software checksumming instead of offloading the checksumming.
So, I just took the Arch Linux PKGBUILD for the linux-aarch64 stock kernel and tweaked the device tree for the RockPro64 to include the lines
Code:
snps,no-pbl-x8;
snps,txpbl = <0x20>;
in the gmac node. Of course you could also just go to /boot/dts/rockchip, decompile the device tree with dtc, change the lines at the appropriate position and recompile with dtc to save the fuss of having to unnecessarily recompile the whole kernel.
According to the mailing list, just setting
Code:
snps,txpbl = <0x4>;
also work fine.
Changes discussed in the mailing list thread can be found in the commits designated for Linux 5.7, so lets hope this fix does not have to be applied manually for every kernel upgrade in the future.
So, hopefully this thread will become obsolete in a couple of months
ZOOM would be a Great app to have on PBP, given the unfortunate Shelters in Place, but so far my attempts to start Zoom from urls in MeetUp.com draw a blank, and attempts to install a Zoom from Synaptics have found no Zoom. Is there a Zoom app for PBP please, or must I continue to use cell Zoom when away from desk?
PBP is now my favorite laptop, very easily carried, but it needs a Zoom.
I am loving Manjaro 20.04 on Pinebook Pro, really working well for me. I have had very few issues and most have been solved easily.
One issue that I have not figured out and have not been able to find in the forum with a search: I miss the CPU speed indicator/selector widget that was in the Debian install.
I completed the definition of an ISO keyboard with accented characters for Romance languages.
I have not prepared a script or an installation package.
OPTIMIZED LAYOUT, FILE CHANGED
If there is interest, installation can be made easier.
In the meantime, mark here how you can remap the keyboard.
This is the file named "iso" which should be placed in the directory (for Debian-like distributions)
"/usr/share/X11/xkb/symbols"
These are the lines to add to the "gb" file of this directory:
Code:
partial alphanumeric_keys
xkb_symbols "iso" {
include "iso"
};
these lines must be inserted between two descriptions of variants
example:
...
include "level3(ralt_switch)"
};
<-- enter HERE -------------------------------------------------------------------
// Describe the differences between the US Colemak layout
// and a UK variant. By Andy Buckley (andy@insectnation.org)
partial alphanumeric_keys
xkb_symbols "colemak" {
include "us(colemak)"
...
edit the file "/usr/share/X11/xkb/rules/base.lst"
adding the line:
Code:
iso gb: ISO (with latin letters)
(near line 721)
for example
...
mac_intl gb: English (UK, intl., Macintosh)
<-- enter HERE -------------------------------------------------------------------
colemak gb: English (UK, Colemak)
...
edit the file "/usr/share/X11/xkb/rules/base.xml"
adding the lines:
Code:
<variant>
<configItem>
<name>iso</name>
<description>ISO (with latin letters)</description>
</configItem>
</variant>
(near line 5618)
for example
...
<variant>
<configItem>
<name>mac_intl</name>
<description>English (UK, intl., Macintosh)</description>
</configItem>
</variant>
<-- enter HERE -------------------------------------------------------------------
<variant>
<configItem>
<name>colemak</name>
<description>English (UK, Colemak)</description>
</configItem>
</variant>
...
copy the two files "base.lst" and "base.xml" replacing respectively "evdev.lst" and "evdev.xml"
For safety, better rename the initial files so you can easily restore them.
To make the changes effective, use mate control center / keybord / add keybord ("mate-keyboard-properties") and select UK (GB) language and "ISO (with latin letters)" variant.