Skip to content
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

Successfull arm64 build #1425

Closed
1 task done
SilPan opened this issue Apr 18, 2024 · 8 comments
Closed
1 task done

Successfull arm64 build #1425

SilPan opened this issue Apr 18, 2024 · 8 comments
Labels
enhancement New feature or request

Comments

@SilPan
Copy link

SilPan commented Apr 18, 2024

I would like to report that I was able to successfully create an arm64 build.

There were several issues in the past regarding this, apparently it is difficult.

I was unsuccessful with RaspberryPiOS and Debian due to old packages, but Ubuntu22.04 arm worked.

The packages mentioned in CONTRIBUTION.md were sufficient.

I used source version v3.6.0, to play around with a tiny media computer on a RaspberryPi and the new remote control feature :D

For it to actually run on RaspberryPiOS I had to patch out discord, otherwise it would not run.

Find ubuntu arm cloud images here.

@KRTirtho What were the issues you had with CircleCI & ARM? I would like to help automate this.

  • I'm ready to work on this issue!
@SilPan SilPan added the enhancement New feature or request label Apr 18, 2024
@SilPan
Copy link
Author

SilPan commented Apr 18, 2024

So what I described up there I did with qemu-system-aarch64, but now I was able to get CircleCI build the arm version :D

https://app.circleci.com/pipelines/circleci/FGdqDakLr1hfC2iZkHo2qj/UbbkGQEN4gGm2oyFVgV4aK/8/workflows/29acfa34-3d0d-4eba-9e99-8218567ccd40/jobs/5/steps

Have a look at my circleci config, it just hang because of ubuntu's weird necessary user interaction during apt upgrade and I needed to create some empty ENV vars.

I patched out the Github stuff from the CircleCI config so I can play around, therefore it is unfit for a PR, but maybe we can get automated arm64 builds running together.

@KRTirtho
Copy link
Owner

That's a great success. My CircleCI free tier got full thus the builds were not working anymore. I was already using for a lot other projects before so that's why.

Btw, GIthub Actions recently added Apple m1 (aarch64) runner support. So, theoretically we can build linux arm binaries through docker in a macos runner. It'll be better as everything will be done in a single place.

@SilPan
Copy link
Author

SilPan commented Apr 19, 2024

Ahja!

It's impossible to find Apple M1 runners if you only search for aarch64 :(

It's kind of a hack, and a shame that github does not provide aarch64 runners just like that, but I'll look into it.

@KRTirtho
Copy link
Owner

I was finally able successfully build for aarch64 through Github CI. Well not through M1 because Apple Sillicon doesn't support nested virtualization (Docker in Docker). So used Docker buildx with qemu arm64 emulation to build the flutter app on a traditoinal ubuntu 22.04 runner.

@KRTirtho
Copy link
Owner

New updated ARM-64 binaries are available on the nightly

RPM is not available though as the packager flutter_distributor doesn't support arm64 for RPM yet (I think I've to create another PR)

@SilPan
Copy link
Author

SilPan commented Apr 20, 2024

Wow. That's great!

Aarch64 emulation on amd64 with qemu is a bit slow, that's what I did in my manual builds.
What I tried to do now was: on a MacOS github runner create a docker image that builds on top of ubunru22.04 then install all the dependencies and flutter. Then use this docker image to build spotube in again on a MacOS runner. I split it so that the dependency installation and so on does not have to happen every time spotube is built.

But I got stuck at running docker on mac from the commandline... I never used Mac before 😓
Here is my experiment.

If I get it working eventually we may be able to speed up the build significantly.
But let's see what my motivation is since it is already working XD

Great Job!

@SilPan
Copy link
Author

SilPan commented Apr 20, 2024

Docker in Docker is not nested virtualization, because Docker itself is not virtualization. Just containerization. That works solely with namespaces and separation.
With Docker one uses the host OS's kernel and not bring a new one, like with a virtualized OS.
That's why it is so damn fast.

But i see how Docker in Docker could bring trouble.
I honestly never tried this before.

@SilPan
Copy link
Author

SilPan commented Oct 2, 2024

Closing this since there are aarch64 .deb packages in the release <3

@SilPan SilPan closed this as completed Oct 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants