From mboxrd@z Thu Jan 1 00:00:00 1970 From: Michael Tremer To: development@lists.ipfire.org Subject: Re: Porting IPFire 2 to RISC-V Date: Tue, 15 Feb 2022 12:15:02 +0000 Message-ID: In-Reply-To: <3DB72557-3F8B-4097-8A49-87EFA7C82C37@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============5585262658884973862==" List-Id: --===============5585262658884973862== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Hello everybody, Since I have recently been submitting a toolchain update to the lists, I woul= d like to update everyone on my efforts to port this all to RISC-V: A new feature that we now have is to cross-compile toolchains everywhere with= minimal requirements of the host system. We would need QEMU to emulate the t= arget architecture and a working toolchain in the host architecture. The IPFi= re build system will take care of the rest. That enables everyone to build IP= Fire for any architecture with the slight caveat that compiling in an emulato= r is substantially slower. Since I don=E2=80=99t own any RISC-V hardware at all, this was the only way t= o go and I was happy that I no longer need to run an entire VM which is emula= ted. So, I built the toolchain and uploaded it to our toolchain server for everyon= e to download. I did this on my x86_64 Debian machine. After that, I ran a build of the entire distribution which needed a couple of= changes to go through: * I added a kernel configuration (because we need *some* kernel) * I added the Rust compiler for riscv64gc * And there were some smaller bits (mainly updating autotools with our UPDATE= _AUTOTOOLS macro) I will push my patchset in the next couple of days for everyone to review and= to merge into our main Git repository. So far it does not affect anything fo= r the other architectures, so it won=E2=80=99t destroy anything. However, it = is not very useful because of lack of hardware. Regarding that and my other points from my previous email, I would say that t= hings have not improved here at all. As far as I am aware, most developer boa= rds are entirely unavailable now because of the whole supply crisis. So I will do what I said earlier: Recompile IPFire on a regular basis and mak= e sure that it builds fine on RISC-V and wait for some hardware. Thanks for your time :) -Michael > On 8 Mar 2021, at 17:27, Michael Tremer wrote: >=20 > Hello, >=20 > Apologies that this email comes a bit late and my changes have caused some = confusion on the list, but better late than never. >=20 > I have spent some time to port IPFire 2 to RISC-V. This is nothing that had= a very high priority, but I wanted to get my hands on it to see whether it w= as =E2=80=9Cjust another architecture=E2=80=9D that could bring us 1% of user= s, or if it was different from ARM which we already support as an alternative= architecture to x86. >=20 > To keep it short, RISC-V seems to be very different. In a good way. But it = is too soon. >=20 > The bootstrap for ARM took many months whereas this port compiled almost on= the first go. There were some issues with autotools, but no bigger linker is= sues in the toolchain, assembly errors or simply where a build process broken= because it didn=E2=80=99t recognise the architecture. The only exception was= that PCRE/PCRE2 do not have support for RISC-V for their JIT, yet. >=20 > Therefore I decided to merge the branch with all required changes into the = main repository because there are no changes that will break anything else. T= his was a very nice experience. As a package maintainer, you probably just sw= itch on RISC-V and you are done. >=20 > There are, however, a couple of downsides. The biggest one is that I didn= =E2=80=99t have hardware and that there isn=E2=80=99t much available at this = point in time. The development boards are too expensive and I didn=E2=80=99t = even consider to buy one because even if I could compile IPFire for RISC-V in= reasonable time, literally nobody will be able to use it. >=20 > With ARM, we were quite early and we can only conclude that that wasn=E2=80= =99t a good thing. We ran into loads of problems with the architecture and we= still have *very* limited choice of hardware available. At least RISC-V does= not seem to cause these issues on the software development side, which might= make support for it a lot less painful for us. Yay. >=20 > I have used QEMU to emulate the whole architecture and it can be built on a= ny machine that has qemu-system-riscv64 installed. Please do not forget to do= wnload the toolchain first. Although QEMU is fast, compiling it took about th= ree days on a 12-core Xeon processor that was a little bit dated actually. >=20 > One of the biggest pain points is Rust which isn=E2=80=99t available at all= for RISC-V and therefore I could not build suricata. Due to the lack of real= -world application for this and our limited usage of Rust this won=E2=80=99t = be a problem for now, but probably further down the line. >=20 > So, what we are going to do with it? >=20 > I will probably compile it every once in a while just to check if it is sti= ll compiling. There is no point in uploading it to a server yet because nobod= y will be able to use it. >=20 > I unfortunately have no connection to the (RISC-V) hardware industry. If so= meone does have such connection, please let me know. It would be great to hav= e some development hardware to use and make IPFire boot on it. We would also = require some strong build power to not delay development because of adding an= other architecture. >=20 > Those are my thoughts on this :) >=20 > -Michael --===============5585262658884973862==--