-
Notifications
You must be signed in to change notification settings - Fork 5.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for 32-bit ARM processors #2295
Comments
arm64 was introduced in #1846, which was really done by someone wanting to contribute it, an arm32 build likely would need to be done the same way. |
@jkdmyrs me also faced the same issue. |
I would like to get builds for arm32+arm64 into the wild, but we had quite a few issues with testing last time. |
Without this it means Deno won't run on Raspberry Pi Zero, Zero W, 1, or 2... Source: https://en.wikipedia.org/w/index.php?title=Raspberry_Pi§ion=12#Specifications Update: Ubuntu now has an official ARM64 version with Unity. Raspbian also has a beta version out of a long overdue x64 faster version. |
We certainly would love to produce arm builds. In order for this to happen the test suite needs to run in CI - presumably in travis under qemu. We had some tentative support for arm64 a while ago, but it was removed [for various reasons]. Have a look for a good starting point. |
@afinch7 Where did you get to with an arm build? |
rusty_v8 (deno's major dependency) now has aarch64 builds in CI: denoland/rusty_v8@ffdf69b |
Deno for ARM 32bit (usually Raspberries) are really appreciated. Maybe it can even be bundled standardly with Debian/Raspbian instead of Node.js. Because Node.js doesn't has official 32bit ARM support. Debian ports it themselves, which is sadly still 2 version behind the official 64bit counterpart and also can cause problems for NPM (well according to their warnings). |
You can install nvm and have any version of node working , I'm using it and had absolutely no problem |
Sitting from Termux, architecture "armv71". What are safe build instructions for 32-bit ARM to try out right now? |
@vintprox There are none... 32bit ARM is on it's way out quickly... Pi 3 and 4 both support ARM64, Ubuntu Unity was ported to ARM64, Raspbian is fairly stable... Ubuntu Core and Server are rock solid on ARM64 for Raspberry Pi. Treat those devices as vintage/arduino style hardware... The last holdout for me is the RPi Zero... which should get an update soon |
If I interpreted it correctly, that's sad. Wanted to try out Deno on Android badly, but it turns out I'm sticking with JS for real fast prototyping until I get PC. 🤷♂️ |
I got a Surface Pro X and for some reason the first thing I wanted to do with it was learn Deno. I'm so disappointed. |
@vintprox @716green ... The Samsung Galaxy S4 was the first to make the jump to a 64bit ARM processor. That came out, spring 2013. Google Play effectively ended support for ARM v7a processors in 2019. You may need to flash a post Lolipop version of Android to make it run in 64 bit though... released in 2014. The Surface Pro X is an amazing computer with one of the fastest ARM64 capable processors out there... it can run deno without issue. User agent sniffers might be giving you bad packages... you want the x86 or ARM64 versions of apps NOT the "x64" or "x86_64" or "amd64" versions, which all refer to the same non-ARM, Intel x686 derived, instruction set which is incompatible with the emulator Microsoft uses. Intel x64 emulation for ARM64 will be supported "in the first half of 2021" after Microsoft finishes adding support to their emulation engine. |
Where can I get a package that's compatible with the SQ1 ARM64 processor in my Surface Pro X? The recommended install is through Chocolatey from what I've read. |
I'd like to start using Deno instead of Node.js for servers on my Raspberry Pi 2B, and the fact that arm32 is still missing continues to be a roadblock. I can't upgrade at the moment, and the Raspberry Pi 2 is still in production so I see no reason for this to not be supported. |
Now that we have Experimental support for Mac Arm64 and arm64 on linux works fairly well. The last thing is arm32 within the triple target for me. The only reason I actually want this is because of the Raspberry Pi Zero (WH) that still has the older 32bit core. I'm going to start poking around Raspberry Pi to see if what they did to get v8 on the 32 bit builds of Raspberry Pi OS. @spl237 (Simon Long) is really the person that I would love to talk to, he's the Senior Principal Software Engineer over at the Raspberry Pi Foundation and somehow he builds V8 on the Raspberry Pi OS for 32 bit CPUs. So there is clearly something to learn there that can be used here. |
Nothing to do with me, I'm afraid - our 32-bit builds are a third-party project called Raspbian, and we don't make them ourselves. See https://www.raspbian.org for details - asking a question on the forums there is probably a good start. |
@spl237 Thanks for pointing me in the correct direction! |
Hello tryed to install on rasp WO with exec format error pi@raspberrypiW0:~ $ curl -fsSL https://deno.land/x/install/install.sh | sh |
There is a reason the issue is open, because there isn't support yet. |
What is the window of time in which this may be supported using the standard install method? |
I don't think they will ever support arm32. While there are plenty of edge devices out there that are using arm32, there are far more that are going to be arm64 with a lot more power. I have a Raspberry Pi Zero that I would love to run Deno, but I don't think that will ever be in the cards given the how hard it is to get a version of V8 running on that platform. |
I did get it to work on Raspberry 4 (Raspberry Pi OS Lite 32bit) but it did took some work like: // kernel to 64bit // resize swap sudo dphys-swapfile setup sudo apt-get install -y raspbian-nspawn-64 ds64-shell sudo apt-get install curl unzip curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh sudo apt-get install gcc g++ sudo mount -o remount,size=9G /tmp/ cargo install deno |
Just an idea, could cross-compilation be handled by Zig? Similar to what's described here: https://dev.to/kristoff/zig-makes-go-cross-compilation-just-work-29ho
|
I tried building from source using this guide: https://deno.land/[email protected]/contributing/building_from_source I use Raspberry Pi 4, 8gb, but after several minutes of building it's stuck into:
P.S. I'm actually wondered why this error occurs. The manual says that to build deno I have to pass special env variable: |
While this issue covers Eventually mine and the previous comment can be hidden, as long as they don't add anything new to the original issue. Footnotes¹ Hard Float images are the naming that Canonical use on https://cdimage.ubuntu.com/releases/21.10/release/ |
For the record: upstream V8 is straightforward to compile on arm32 (I've successfully done it myself, on a Raspi) or cross-compile for arm32 (that's e.g. how Chrome for Android gets built). This issue is all about adding such support to Deno's / rusty_v8's build and bindings system. From a related complaint I saw elsewhere recently, my understanding is that supporting 32-bit builds at all (regardless of x86 or arm) might be quite a bit of work. |
If you could provide a guide for building it for 64bit on Raspberry Pi OS (64bit) that would be extremely helpful given that the Raspberry Pi foundation has now officially released the 64bit version of their OS. Ideally including all packages required to be installed via apt. |
These are my notes from last year, using Ubuntu 2020.10: https://docs.google.com/document/d/1u-HAFfjWIH3WY3xajuGxGii-lWi1rpf16hVmB-mRdTA/edit?usp=sharing, including all packages I installed. I'd expect Raspberry Pi OS to be very similar, but I don't have time to verify that currently. For cross-compiling from Linux x64, I think that installing the right sysroot and putting See also: https://v8.dev/docs/build-gn (general instructions) and https://v8.dev/docs/compile-arm64. |
For those who are curious, the reason cross compile doesn't work is because snapshotting doesn't work cross platform. |
@lino-levan so how does node.js do it then? |
I wonder if cross compiling using zig would fix this |
bump, exec format error on raspberry 32bit, snap available, but only 64bit it seems. |
Would be nice if the install script would abort instead of just installing X86 binaries :-( ie. install.sh currently contains: if [ "$OS" = "Windows_NT" ]; then
target="x86_64-pc-windows-msvc"
else
case $(uname -sm) in
"Darwin x86_64") target="x86_64-apple-darwin" ;;
"Darwin arm64") target="aarch64-apple-darwin" ;;
"Linux aarch64") target="aarch64-unknown-linux-gnu" ;;
*) target="x86_64-unknown-linux-gnu" ;;
esac
fi
|
Deno does not support any other 32 bit platforms (like x86), so we are not going to work on this. The era of 32 bit processors is over. |
We're talking about ARM, not x86.
Raspberry Pis beg to differ. |
Yeah, that's fair. In the 5 years that this has gone on, the need for this has been less and less. Especially with the Zero W 2, and the Pi 5 both having easy to use 64-bit implementations of their OS. |
Thats a legitimate position to hold, I'm not asking for 32 bit binaries. From a defensive coding perspective I would say that the default My 2cts. |
When attempting to install deno on my Raspberry Pi, I get the following:
$ curl -fsSL https://deno.land/x/install/install.sh | sh -s v0.4.0
Unsuported architecture armv7l. Only x64 binaries are available.
Is support for 32-bit ARM processors something we can eventually expect?
The text was updated successfully, but these errors were encountered: