I used to hate android emulators, since the ones I’d tested on Windows were ad-ridden, slow bloatware.

The other day I needed to run an android app on Fedora 40.

I tried Waydroid and it worked very well. The app ran supersmooth as if it was running natively.

Also the cli syntax was very sane an user friendly.

waydroid app install|run|list …

So if you need an Android app on linux the experience might be better than what you think it would be.

  • GolfNovemberUniform@lemmy.ml
    link
    fedilink
    arrow-up
    57
    arrow-down
    3
    ·
    6 months ago

    I think a part of your positive experience is also thanks to Linux. Android emulation works better on it because the difference between Linux and Android is not that big and definitely not as big as between Windows and Android. Though Waydroid rocks anyways

    • d_k_bo@feddit.de
      link
      fedilink
      arrow-up
      30
      ·
      6 months ago

      The documentation says:

      Waydroid uses Linux namespaces (user, pid, uts, net, mount, ipc) to run a full Android system in a container and provide Android applications on any GNU/Linux-based platform.

      To my understanding this isn’t even emulation but regular container technology.

      • alteredEnvoy
        link
        fedilink
        arrow-up
        10
        ·
        6 months ago

        Wouldn’t some Android Apps require specific builds for x86 architectures? Does Android take care of that?

          • Quack Doc@lemmy.world
            link
            fedilink
            arrow-up
            5
            ·
            6 months ago

            libhoudini is optimized for Intel, NDK for AMD, but some apps may be incompatible with one or the other.

        • Zangoose@lemmy.one
          link
          fedilink
          arrow-up
          11
          ·
          6 months ago

          A lot of android apps are built using Java/Kotlin, so you don’t actually need to care about architecture since the JVM supports both x86_64 and arm64.

          There are exceptions to this though, since some apps need to run native code. Those apps would need some sort of emulation/translation layer for the arm instructions.

        • Quack Doc@lemmy.world
          link
          fedilink
          arrow-up
          5
          ·
          6 months ago

          most android apps are architecure agnostic “java, kotlin etc” and even apps that are often ship “Universal binaries” which include x86, or split builds for arm and x86

    • Björn Tantau@swg-empire.de
      link
      fedilink
      arrow-up
      30
      arrow-down
      3
      ·
      6 months ago

      It took a long long time until Android emulators on Linux worked even close to what has been available on Windows.

        • Quack Doc@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          edit-2
          6 months ago

          google play games is still really good, it’s more or less just android inside of crosvm, usually android emulators are based on virtualbox, some are based on qemu

      • Quack Doc@lemmy.world
        link
        fedilink
        arrow-up
        6
        ·
        6 months ago

        this is not really quite true, we have always been able to run androidx86/BlissOS in qemu which works about “as well” but with less integration, IE no “native like” windows

    • Captain Beyond@linkage.ds8.zone
      link
      fedilink
      arrow-up
      6
      arrow-down
      2
      ·
      edit-2
      6 months ago

      Android emulation works better on it because the difference between Linux and Android is not that big

      To be clear, the difference between Linux and Android is about the same as the difference between Linux and Fedora, in that they are both Linuxes. That’s why this works, and why the reverse (running GNU/Linux apps and even entire systems on Android) is possible as well.

      • GolfNovemberUniform@lemmy.ml
        link
        fedilink
        arrow-up
        7
        arrow-down
        1
        ·
        edit-2
        6 months ago

        I meant a desktop Linux distro, not the kernel itself. And Android has a ton of bloatware on top of it so it’s not really the same thing. Android has like a double decker kernel

        • Quack Doc@lemmy.world
          link
          fedilink
          arrow-up
          4
          arrow-down
          1
          ·
          6 months ago

          AOSP doesn’t have that much bloat, it’s far lighter then your typical linux distro, It’s vendors that bloat it up, Custom roms are extremely light, This is BlissOS running on 2Gb of ram https://files.catbox.moe/4n17z3.mp4.

          It’s far more responsive then many linux distros would be since android and it’s applications are optimized around low ram and low system resource in general

          • GolfNovemberUniform@lemmy.ml
            link
            fedilink
            arrow-up
            2
            arrow-down
            3
            ·
            edit-2
            6 months ago

            Android can run on 2Gb but the experience won’t be great. Linux with something like JWM or Xfce runs way better. Android 12 and higher are especially heavy. You can notice it by comparing on relatively low end devices (with like a Unisoc T606 or something). Android 14 runs better but it has ads-related stuff in it. And Android kernel itself has a lot of unnecessary stuff. They say it’s better for performance but bruh how can a more bloated thing be better? Real tests speak for themselves. Don’t trust theory and Google’s changelogs.

            • bitfucker@programming.dev
              link
              fedilink
              arrow-up
              2
              ·
              6 months ago

              This is for the general case, size doesn’t always translate to performance. I haven’t read the AOSP source so I wouldn’t know for sure, but the general case for any algorithm is that. Sometimes having more code can result in faster performance due to how the algorithm works.

              • Quack Doc@lemmy.world
                link
                fedilink
                arrow-up
                2
                ·
                6 months ago

                its easy to test BlissOS is open source and can be installed on any relatively modern PC or in a VM, coms with foss and gapps variants, install foss

                • bitfucker@programming.dev
                  link
                  fedilink
                  arrow-up
                  1
                  ·
                  6 months ago

                  I am merely rebutting your point about how more stuff can make things perform faster. Multi-tasking comes to mind. In a simple program, a task may be run in a procedural manner without interruption. Say for example, network access. The network stack must wait for the reply to arrive, but since the program is simple, it really is waiting for it doing nothing, wasting time that can be used to perform other computations. So the code will get bigger, but the performance is increased by reducing time wasted waiting for resources. By size alone, it is more bloated, but it is increasing performance. And as I said, I haven’t looked at AOSP source code so my comment is not directed towards that point as I have no knowledge about low level android stuff.

            • Quack Doc@lemmy.world
              link
              fedilink
              arrow-up
              2
              arrow-down
              1
              ·
              6 months ago

              this really isn’t true at all. android works great on 2Gb of ram, you don’t really hit issues until you load gapps. If you don’t it works great. I actually run BlissOS on my old Asus t100ta and Im not the only one.

              When you do nothing something like xfce works great, but when you actually start doing things like browsing the web, watching youtube etc then it starts to really become a slog. Meanwhile something like BlissOS is actually usable even when watching 1440p content (gpu not strong enough to test UHD)

              • GolfNovemberUniform@lemmy.ml
                link
                fedilink
                arrow-up
                1
                ·
                6 months ago

                I didn’t mean that Android is bad. What I meant originally is that Android is getting less efficient and slower for no reason over time.

                • Quack Doc@lemmy.world
                  link
                  fedilink
                  arrow-up
                  1
                  ·
                  6 months ago

                  This is for sure the case for vendor solutions, but AOSP itself is still quite the lean OS. Android also has GO variants which perform even better at low resources, (Bliss also has builds of these if one is curious). They are extremely responsive. I don’t think Bliss as A14 go builds, but we do have A13 go builds, and they are extremely responsive on very low end hardware, the bar is actually support for SSE.

                  Bliss currently has a hard requirement on SSE 4.2 or greater due to a load of changes (occasionally some work is made on lowering this but it’s slow and a lack of real motivation), but pretty much everything I have tested that is supported works fairly well, from my old i3 desktops, my atoms and celerons etc.

  • CCF_100@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    46
    ·
    6 months ago

    The app ran super smooth as if it was running natively

    That’s because it is native! Waydroid runs an android container on top of your existing kernel. You will notice that you can even see the Android processes while running Waydroid in a top utility.

    • kevincox@lemmy.ml
      link
      fedilink
      arrow-up
      11
      ·
      6 months ago

      Although the Android kernel is slightly customized isn’t it? I thought it exposed a few extra syscalls. How do these work on Waydroid?

  • TFO Winder@lemmy.ml
    link
    fedilink
    arrow-up
    18
    ·
    6 months ago

    I just tried it 3 days ago on Fedora 40, Did not run for me.

    Followed their wiki

    How did you setup?

    • mFat@lemdro.idOP
      link
      fedilink
      English
      arrow-up
      8
      ·
      6 months ago

      I don’t remember tbh. I installed it a couple of years ago but used it for the first only recently.

    • Plaksys@mander.xyz
      link
      fedilink
      arrow-up
      5
      ·
      6 months ago

      At what point did it not work for you? I just got it running on Fedora 40 following their wiki.

      • TFO Winder@lemmy.ml
        link
        fedilink
        arrow-up
        4
        ·
        6 months ago
        Failed to get service waydroidplatform
        

        on doing waydroid app install myapk.apk

        ERROR: WayDroid container service is already running
        

        IT says already running on doing sudo waydroid container start

        • Plaksys@mander.xyz
          link
          fedilink
          arrow-up
          5
          ·
          edit-2
          6 months ago

          I got it into android “desktopt” previously, but now after rebooting and trying to install an apk it seems to no longer be opening at all. Sorry :/

          Edit: I just uninstalled and reinstalled via the software Center and now it works and I could install F-Droid.

            • Quack Doc@lemmy.world
              link
              fedilink
              arrow-up
              1
              ·
              6 months ago

              ah my bad, I misread, I thought you had tried sudo waydroid app install.

              Failed to get service waydroidplatform usually happens when something fails when communciating to the container, this usually means the container is partially loaded so you will need to stop it and start again, you may even need to do a full reboot

    • caseyweederman@lemmy.ca
      link
      fedilink
      arrow-up
      3
      ·
      6 months ago

      You need a custom kernel, or a kernel module plus DKMS and kernel headers for your current kernel.
      You also need the package that handles whatever filesystem they use for their containers.
      Then, you need to be running it on Wayland or else it doesn’t work.
      The part that I’m stuck on is running games, which gives an error about not being able to find libmain.so, which might be an architecture mismatch problem. Maybe I can virtualize that part? But at that point I might as well just buy a phone.

    • Quack Doc@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      6 months ago

      can you report your issues to the waydroid github or check on the fedora forums? the matrix and telegram chats are always open to help too if you have a bit of patience.

  • Quack Doc@lemmy.world
    link
    fedilink
    arrow-up
    16
    ·
    6 months ago

    I tried Waydroid and it worked very well. The app ran supersmooth as if it was running natively.

    thats because it was running natively

  • Eyck_of_denesle@lemmy.zip
    link
    fedilink
    arrow-up
    4
    ·
    6 months ago

    Used it but couldn’t play any media on it, which was going to be my use case. Nvidia!!!. But the devs and the community are quite patient and helpful in their telegram channel.

  • HakFoo@lemmy.sdf.org
    link
    fedilink
    arrow-up
    7
    arrow-down
    9
    ·
    6 months ago

    I had a similar positive experience with Gamescope, which tamed a game that freaked out every time I moved the moude onto the other monitor.

    Maybe Wayland’s healthy place is as a secondary window system you launch inside your normal X11 session.

    • Quack Doc@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      6 months ago

      for many people YES! Both wayland and x11 can work very nicely when nested. For many people wayland will be remain unusable for a very long time, and for many other they are finding that now x11 is unusable for them.

      It’s not a great situation, but with xwayland and running wayland compositors nested (really wish we had an “way11” too, but per app cage works for me) many people’s usecase will remain to be covered