Does anyone have any real world (such as iperf) performance numbers of routing traffic WAN to LAN over an rk3566/rk3568 based device?
I'm extremely familiar with this chip (just check kernel.org's commit history if you don't believe me), however I'm worried if the quad core A55 can keep up with 2.5GB NICs, specifically the realtek 8125b. My specific concern is at the maximum throughput of the NIC the CPU will get overwhelmed with IRQs and not be able to keep up with line speed.
While I bet the rk3588 can, it's probably several months to a year behind the rk3568 in terms of mainline, and thus mainline acceptance into OpenWRT.
I searched a bit and checked out some YouTube video reviews, with the FriendlyWRT the NanoPi R5S doesn't seem to be able to deliver 2.5G NAT throughput, in fact the RK3568 looks like sitting in between RK3288 and RK3399. That's why I skipped R5S and bought R6S (RK3588) for it.
That's kind of what I'm afraid of. I have a Celeron N3160 and it hits CPU capacity (due to interrupts according to top) with some Realtek gigabit NICs, can only imagine what a marginally slower CPU would do with NICs twice as fast. Not that they make i225/i226 on this CPU, but I would bet it could handle it because that doesn't flood the CPU with IRQs.
I'm taking a slightly further back seat on the rk3588 mainlining efforts relative to the rk3568 stuff, but to my knowledge I think we're mostly there already (at least as long as you don't want video, which is pointless on a router).
Because of Realtek NICs? My Jetway NF9HG-2930 uses Celeron N2930 which is even older than yours but I am no trouble in getting 1G routing, but my board has 4x Intel i211 instead of Realtek. What I learned from this is, RTL8125B also has RSS which should improve performance, unlike the cheap Realtek 1G NIC.
You just get one of Pine64's boards and stick whatever NIC you want that's compatible into it?
The RockPro64 is probably a better choice and according to Pine64's Wiki you should be able to push 5Gbit or close to it using a Intel X550-T2 Dual Port or similar. https://wiki.pine64.org/wiki/ROCKPro64_Hardware_Accessory_Compatibility#PCIe_devices
Looking at my own RockPro64 setups using Intel Gbit NICs (FreeBSD however) I'd say that it should in theory be doable in the same ballpark as listed using netperf.
RockPro64 could work. Also looking at R6S (for the RK3588), and some x86 based stuff. I'm almost certain that the R6S will work for my needs, I just have to be willing to put the legwork into it. For reference, I have been a key contributor in the mainlining efforts of the RK3566, so I'm super-familiar with the Rockchip stuff (proof/shameless plug: Commits · torvalds/linux (github.com) ). On the other hand x86 is pretty much perpetually in a "plug it in and forget it" state, so that's pretty compelling too.
I'd be very careful about "bleeding edge" hardware on ARM, it takes several months mature and RK3588 definitely falls under that category but I guess you know that by know. I'd also be a concerned about the NanoPI overall as uboot etc never seems to land. From what I know there are several parts missing in the latest kernel (upstream) for RK3588 to be somewhat ready. You also have the issue that there's very few options around and FriendlyELEC usually ends up on the shortlist. I think your best bet would be a Quartz64Pro in terms of hardware as you can pop in a nother NIC but I don't think they have any left in stock. Personally I'm excitied to see when SoC support lands in FreeBSD but that's another story...