Hi, Pavel!
Did you make to get the i2s working without skipped/zero samples?
Hi, Pavel!
Did you make to get the i2s working without skipped/zero samples?
The HW seems to work OK, with radxa kernel - see RockPi S + CS42448 I2S/I2C DAC setup . But the mainline is broken somehow and I could not get any pointers where to start. I could not find any difference in the I2S driver. IMO itās some low-level setting/timing issue, perhaps for the clocks, DMA, ā¦
Yes, I also tried this kernel and found no sound issues, but found a very slow Ethernet, so playback from NAS of bitrates greater than 96k in mpd is choppy (message from mpd.log: alsa_output: Decoder is too slow; playing silence to avoid xrun). With mainline kernel network works fine, but audio is buggy.
iperf on Radxa kernel - 10 MBit, mainline - 95 MBit/
Thatās interesting. My radxa kernel 6.1.43 does 94Mbps with iperf on local network.
What kernel sources (branch) did you use?
https://github.com/radxa/kernel/tree/linux-6.1-stan-rkr4.1 , commit 8c5a7e2ee229007f8f430df4c463cd755c017e9f , but then I applied quite a few patches to make it work for Pi S and the USB audio gadget, maybe some of them are already in the newer commits. E.g. Rock Pi S + radxa kernel linux-6.1-stan-rkr1 - inactive USB host? - see the last post, it was never fixed by Radxa.
It would definitely be good to have a properly working relatively recent Pi-S kernel
I also used this repository, but the HEAD branch, and I found in kernel.log a message that ethernet can only run on 10Mb.
Have you tried linux kernel version 5? I built an armbian image with mainline kernel 5.19 and quickly tested it. And I did not find the choppy sound like in mainline kernel version 6.
BTW, I found similar problem with NanoPi Neo3 (rk3328) and kernel version 6.
IIRC I tested only newer kernels, not 5. Older kernels are unusable for developing and submitting patches to mainline (I am interested in the USB audio gadget, specifically).
That 10Mb message could perhaps be troubleshooted, to find out what is causing it.
I found Radxa kernel configurations lacking important options (like that USB support, also missing support for overlays etc.).
Pavel, can you check your test case with kernel 6.12 where file drivers/dma/pl330.c is replaced with this one? I tried playback and havenāt noticed any issues yet, but your case to be creating a higher load and Iām very interested in your results.
PS. I used Armbian build with BRANCH=current
Please can you specify how you built your kernel version? If possibly some github repo with config file used for the build, and optionally the patches you applied. There are many various kernel versions available online. The goal would be having a working repo (ideally tied to mainline https://github.com/torvalds/linux/tree/master, or some other up-to-date reference related to mainline). Thanks a lot.
There are quite a few recent commits in https://github.com/torvalds/linux/commits/5bc55a333a2f7316b58edc7573e8e893f7acb532/drivers/dma/pl330.c , some of them seem to be already present in that bulk commit https://github.com/kvn61/rk3308/commit/ae6a75f8a551229ee2af7d6b5a7de1db112b24f1 .
Hello!
I was investigating the problem separately for my own concerns, and then I discovered this thread.
I can confirm that there is an issue in the mainline kernel pl330.c driver code, and applying a patch to that driver fixes the problem in the most common scenario. Yet I have discovered that, under heavy memory load, the issues still appears.
Since I am a maintainer at Armbian, I supplied a pull request to the project with some more details and a way to consistently reproduce the issue:
I used the current version of the armbian build tool. It can build u-boot, kernel packages or full image with the 6.12 kernel with armbian and custom users patches.
The Armbian build tool uses the mainline repository with some patches from the armbian team.
At the first step, I create a custom patch by command
./compile.sh kernel-patch BOARD=rockpi-s BRANCH=current
and simply replacing original pl330.c file to new file after prompt from build tool.
At the second step I copy created patch to specified folder and build the kernel (kernel only or full image) with my patch.
PS this file pl330.c is taken from the radxa repository with one small change at lines 3454-3457
Hello!
Your patch is similar radxa linux-6.1-stan-rkr4.1. You say rockchip 4.4 has no problem. But rockchip has some additional code in pl330.
And, rk3308 Support 16-bit data width memory access. May be memory benchmark simultaneously with other task is too hard test for our purposes
IIUC you took armbian 6.12 kernel (which has mainline pl330.c, no patches to this file in the build-tool repository) and used the radxa pl330.c version (your patch just disables the error msg, IIUC).
I have not tested yet, but your results suggest it fixes the problem, just like the linux-6.1-stan-rkr4.1 kernel was running OK with me up to 384kHz/32bit sample (I did get dropped-packets with I2S at 768kHz samplerate but thatās way above the HW specs and I2S data loopback is already randomly delayed by one bit).
Hi, thanks for the work. IIUC armbian uses mainline 6.12 pl330.c https://github.com/torvalds/linux/commits/master/drivers/dma/pl330.c which does not contain that crucial rockchip commit https://github.com/radxa/kernel/commit/ec0b65dbc59793426b6dc7af06ab6675f4a24940 yet.
But the two files https://github.com/radxa/kernel/commits/linux-6.1-stan-rkr4.1/drivers/dma/pl330.c and https://github.com/torvalds/linux/commits/master/drivers/dma/pl330.c differ in a number of commits, some only in mainline, some only in radxa/rockchip. I wonder why the rockchip people did not submit to the mainline insteadā¦ This way itās almost impossible to use the mainline and test/develop new features not tied specifically to rockchip (patches based on other files in 6.1 kernel are unlikely to fit 6.12 mainline).
Yes, bencharmking with radxa official debian image, which has rockchip 4.4 kernel, does not produce any issue, so the problem lies somewhere in the mainline kernel code and not in the hardware.
Thanks for pointing the radxa branch with an updated pl330.c driver; I tried to compile the 6.12 mainline kernel with pl330.c in the radxa 6.1 kernel repository and, after some trivial adjustments, the issue still persists. I will do some more investigationsā¦
How do you actually do the benchmarking?
IIUC @Nik_Kov tested armbian 6.12 with the pl330.c from that 6.1 repo and it reportedly worked OK, to some extent (which may be the ultimate performance ceiling). At least there is a list of patches applied to mainline by the armbian kernel available.
You can see the commands I used to test and replicate the issue in the Armbian pull request description above.
In particular I first used ogg123
and mbw
together, and this caused the issue to appear clearly on mainline kernel with vanilla driver.
After applying a patch that was submitted by Rockchip to kernel mailing lists (but never accepted), these two commands works ok, but if I add another process iperf3
to stress more the memory subsystem, the issue reappears.
After applying applying the radxa pl330.c driver on top of mainline kernel, still produces the issue when all the three processes run together.
What I noticed later, though, is that iperf3
causes the kernel IRQ handler tasklet to fully hog one cpu core. This is unexpected and absolutely not acceptable; it is possible that I hit another issue with the ethernet that is disturbing audio playing, because if I rule out iperf3
and stress test only with ogg123
and mbw
, I canāt notice any issues.