Android phones for example

  • Skull giver
    link
    fedilink
    114 hours ago

    Linux works on desktops because the companies making desktop hardware put somewhere between “some” and “massive” effort into making mainline Linux work. It’s not that difficult for motherboards (most of the work is done for motherboard manufacturers already) but for anything from CPUs to disk drives, manufacturers write Linux code and submit it back upstream. Without companies wanting to make Linux work on PC, it simply wouldn’t. Of course there are plenty of volunteer and hobbyist programmers who also contribute, as well as people paid by the various free software funds, but they generally do smaller stuff rather than complete device support. It also helps that computers have standardised ways of booting and identifying what hardware is present.

    On ARM, companies like Qualcomm take the inverse approach. They take Linux, make some modifications (usually ones that will never be accepted upstream because of code quality or style concerns), build binary drivers for that specific version of Linux, and then hand that entire thing to companies like Google and Samsung. These vendors have no interest in upstreaming code and make a lot of money selling ongoing maintenance for old, customised kernels.

    Booting ARM devices is also a pain. Instead of BIOS/UEFI, every vendor has their own boot method, usually involving a modified version of u-boot that’s customised to do whatever weird shit the vendor needs.

    Even if you get Linux to boot, you’ll probably struggle with basic features like “not burning through the battery in ten minutes” without vendor code or binaries.

    There are projects to bring normal Linux to phones. Ubuntu Touch is actually quite usable, Plasma Mobile works on a few devices, and postmarketOS has a surprising range of working hardware. One big challenge is support for hardware accelerated wifi, and the latter is doing quite well for that.

    Still, despite all the hard work, some stuff like binary drivers just won’t make it into the kernel without major effort for every model of SoC. For Android phones, the custom upstream kernel can form a good basis, but someone needs to go through the code and make it Linux compatible. WiFi and Bluetooth can usually be hacked together but someone needs to do it. Cell modems are even worse, so calling and texting are even less likely to work.

    Basically, there’s no commercial interest, the hardware works very differently, and it’s a lot of work. It can be done if someone is passionate enough about Linux on their device but only for one or a few related models in that case.

  • @BradleyUffner
    link
    English
    7710 hours ago

    I guess I’m going to be that guy today. Android is Linux, and it’s installed on a lot of mobile devices already.

    • @mkwt
      link
      20
      edit-2
      9 hours ago

      Another aspect to this is that Android is Linux, but it is not GNU / Linux. This is true both in the literal sense of not using GNU coreutils or glibc, and also in the broader sense.

      What I mean by the “broader” sense:

      • no X or Wayland
      • GTK or Qt support is something an application has to bring with them.
      • filesystem is substantially reorganized
      • users and system permissions setup substantially differently

      To the application programmer Android / Linux looks like a completely different ball game.

      • @[email protected]
        link
        fedilink
        English
        -56 hours ago

        What prevents Linux from being installed on mobile devices?

        Android is Linux, but it is not GNU / Linux

        You’ll see that’s not the question that was asked. And it’s okay not to give Stallman any more validation for his fame-grab.

    • @[email protected]
      link
      fedilink
      89 hours ago

      And you can (sometimes) install something like PostmarketOS which is closer to the kind of linux people think about when they hear “Linux”

    • @[email protected]
      link
      fedilink
      English
      410 hours ago

      Android is maintaining a fork of Linux kernel that has since diverged.

      Its like saying MAC is UNIX, technically yes but not really

      • @ricdeh
        link
        English
        12
        edit-2
        7 hours ago

        macOS definitely is Unix. In the literal sense that it is actually certified (unlike FreeBSD, for example), and it is very much Unix-y under the hood.

      • @dohpaz42
        link
        English
        209 hours ago

        Its like saying MAC is UNIX, technically yes but not really

        macOS is UNIX-based. Period. In fact, “[s]tarting with Leopard, macOS has been certified as compatible with the Single UNIX Specification version 3 (SUSv3).” Source

      • @stupidcasey
        link
        26 hours ago

        As far as I can tell literally everything (except for windows) is UNIX, it isn’t exactly a high bar to pass, it’s like saying all drinks are water based which is technically true but I’m not going to give a kid a wine box when I run out of juice boxes.

    • @[email protected]
      link
      fedilink
      English
      0
      edit-2
      10 hours ago

      I think that Linux is synonymous with open source and freedom and to some extent privacy.

      android is synonymous with Google

      I’m only guessing, but when people ask about a Linux tablet or phone, they actually want the former, rather than the later, even though android is a Linux derivative, as you rightly said.

        • @[email protected]
          link
          fedilink
          English
          -2
          edit-2
          9 hours ago

          I don’t know if you are deliberately missing the point ?

          You need a lot more than open source android to make a phone work.

          • @dohpaz42
            link
            English
            98 hours ago

            I didn’t miss the point. Maybe you’re conflating a distribution with an operating system. But, since you brought it up:

            1. LineageOS
            2. GrapheneOS
            3. Fire OS
            4. Many more…

            My point is that — at least in my eyes — open source is not synonymous with one single project. Do with that what you will.

              • @dohpaz42
                link
                English
                46 hours ago

                I really shouldn’t feed the trolls, but eh, I’m learning a lot rebuking you, so maybe somebody else can benefit from your ignorance as well:

                GrapheneOS has official production support for the following devices:

                • Pixel 9 Pro Fold (comet)
                • Pixel 9 Pro XL (komodo)
                • Pixel 9 Pro (caiman)
                • Pixel 9 (tokay)
                • Pixel 8a (akita)
                • Pixel 8 Pro (husky)
                • Pixel 8 (shiba)
                • Pixel Fold (felix)
                • Pixel Tablet (tangorpro)
                • Pixel 7a (lynx)
                • Pixel 7 Pro (cheetah)
                • Pixel 7 (panther)
                • Pixel 6a (bluejay)
                • Pixel 6 Pro (raven)
                • Pixel 6 (oriole) Source

                😊

              • @ricdeh
                link
                English
                67 hours ago

                How many support LineageOS? Answer: a lot.

  • Destide
    link
    fedilink
    English
    3112 hours ago

    There’s been multiple attempts Ubuntu and Plasma both have projects, Ultimately a lot of compatibility issues seem to hamper uptake, components like cameras and such can be hit or miss.

    • dual_sport_dork 🐧🗡️
      link
      25 hours ago

      There was also the Nokia N900 which ran Maemo, which was much closer to a traditional Linux distribution to the point that it was fairly trivial to compile desktop Linux programs for it. Which could even be done on the phone itself, if you had a lot of time on your hands.

    • cabbage
      link
      fedilink
      3311 hours ago

      More than anything, the problem is apps. I installed Ubuntu Touch on an old device I had lying around (after replacing the battery to bring it back to life), and I ended up liking it more than my daily driver. It worked, the interface was snappy (no pun intended), and there’s a lot of solid design choices. I found myself trying to navigate with gestures on my android phone after.

      However, I could not talk to my friends, who unfortunately use WhatsApp. I could not install my banking app. There’s a bunch of small thorns in the side that makes changing difficult for most users - kind of like in the early days of desktop Linux.

      As in the early days of desktop Linux, the solution might lie in a compatibility layer (like WINE). Android emulation within at least Ubuntu Touch has gotten quite good, I believe. Unfortunately my device is too old to support it.

      Those interested should also check out Postmarket OS.

      GNOME, a major desktop environment, is also moving towards all apps being designed for all types of devices. But as long as people can’t use their banks, switching is hard.

      • @Kelly
        link
        English
        99 hours ago

        More than anything, the problem is apps.

        True, its a real chicken and egg situation. No one what to use a platform without decent app support but no one wants to develop for a platform without any users.

        • cabbage
          link
          fedilink
          27 hours ago

          Here’s a GNOME blog post from a couple of years ago. But really it’s about GTK4 - apps designed for GNOME are made to be adaptive. So if you’re using a GNOME desktop you can experience it yourself by simply making windows of the core apps smaller, be it GNOME Web, Maps, Weather, Calendar, or a huge range of other apps. Apps like Spot (Spotify client), Tuba (Mastodon), Shortwave (radio), and Podcasts are also perfectly adaptable for mobile devices. Basically apps in the GNOME Circle should work well on mobile, and many of them have screenshots that illustrate how they look in different form factors.

          Also, this.

  • hendrik
    link
    fedilink
    English
    20
    edit-2
    11 hours ago

    The processors and peripherals aren’t as uniform as they are on computers. Each SoC has a different set of components, which need drivers and custom set-up mechanics and they’re often only shared between the chip designer and phone manufacturers. A lot of complicated reverse engineering is needed. And that’s often not worth it as there are many different phones on the market and they’re short-lived devices. So we end up in the current situation where we don’t have the operating system foundation / drivers available to the community to build upon.

    There is Linux on phones. A modified Linux kernel runs on every Android device. Just the userland is an entirely different one. And Linux isn’t there yet with the desktop and apps. A lot of features are missing, power saving, delivering messages while sleeping and doing background tasks while saving power in the pocket… It’s kind of a chicken and egg dilemma. We’d need some popular Linux phone so people are motivated to tackle the remaining software issues for a mobile ecosystem. And we won’t get one unless there is some good software so it can be marketed.

  • @ch00f
    link
    2012 hours ago

    Android OS runs a modified version of the Linux kernel.

  • Ghoelian
    link
    fedilink
    16
    edit-2
    12 hours ago

    Nothing prevents you drom installing a linux os on an android phone, provided someone made a rom for your device. It’s just not very useable due to proprietary drivers. Ubuntu touch exists for example, but on most phones you can’t even use the cellular antenna iirc

  • PonyOfWar
    link
    fedilink
    13
    edit-2
    12 hours ago

    Nothing really. Someone else already wrote that Android is technically Linux. But you can also get “regular” Linux on mobile devices, it’s just a matter of using a distribution with mobile-friendly UI as well as getting driver support for the phone’s hardware. Ubuntu touch exists for example, but only works on a limited number of devices and even on supported devices it’s not really suitable for the average user yet.

  • @[email protected]
    link
    fedilink
    10
    edit-2
    12 hours ago

    Pratically no universal way of making Linux boot with ARM processors.

    Much more closed source drivers (than x86 ecosystem).

    • @[email protected]
      link
      fedilink
      1
      edit-2
      6 hours ago

      This is the key - no universal (i.e. No open standard) BIOS like on PCs.

      We need a BIOS war for ARM, and since Android has it locked down, there’s little competition to push for it, unlike when DOS was trying to become the standard for minicomputers.

  • @[email protected]
    link
    fedilink
    712 hours ago

    In practice? Constantly changing hardware with soc vendors that publish nothing and device manufacturers that (have to) keep pushing out new models on a short cycle. Plus many of them have extra shenanigans to keep the bootloader locked so you can’t install a recovery (presuming you had a working one) so you could replace the os. There are some rare exceptions, but the hardware is rare and tedious and not many people can or will work on installable Linux on them.

    If you just want to run some Linux userland, there’s ways to do that on top of android, though. Want to get to a Linux like system or run a program? Might be as close as installing a terminal or running adb shell.

  • pelya
    link
    312 hours ago

    You can install Linux on rooted phones using Linux Deploy, or you can install Linux-in-an-app such as Userland or Termux if you don’t have root.