Android phones for example
I guess I’m going to be that guy today. Android is Linux, and it’s installed on a lot of mobile devices already.
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.
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.
And you can (sometimes) install something like PostmarketOS which is closer to the kind of linux people think about when they hear “Linux”
PostmarketOS isn’t “closer”… It fully is GNU/Linux.
You are correct. His statement wasn’t about technology, it was about expectations.
Android is maintaining a fork of Linux kernel that has since diverged.
Its like saying MAC is UNIX, technically yes but not really
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
Exactly Android also is “Linux based” period.
That’s my point.
Mac isn’t UNIX based, it is UNIX and comes with many of the UNIX tools a user would expect. Completely different situation.
so macOS is sus
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.
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.
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.
FYI, Android is open source.
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.
I didn’t miss the point. Maybe you’re conflating a distribution with an operating system. But, since you brought it up:
My point is that — at least in my eyes — open source is not synonymous with one single project. Do with that what you will.
Edge cases
How many phones support grapheme ?
How many support LineageOS? Answer: a lot.
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
😊
deleted by creator
😂
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.
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.
Do you have a link for what gnome is doing?
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.
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.
I’ve seen marathons with less running-on than that sentence-esque collection of letters.
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.
Android OS runs a modified version of the Linux kernel.
And with Termux, you can run Linux on Android on Linux.
Shhhh…
we don’t speak of that.
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.
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
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.
Pratically no universal way of making Linux boot with ARM processors.
Much more closed source drivers (than x86 ecosystem).
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.
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.
Locked bootloaders can prevent that. Or proprietary hardware drivers can make it unworkable.
Android is Linux
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.
Because all the linux distros for mobile are steaming piles of horse shit.