this post was submitted on 25 Sep 2024
93 points (100.0% liked)

Linux

48852 readers
1149 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 5 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 24 points 3 months ago (1 children)

If the devs don't have access to the hardware then it's impossible to make drivers for a specific laptop

[–] 0x0 2 points 3 months ago (5 children)

If it's arm-based is the CPU so alien as to not being usable without a very generic kernel?

As for the hardware, is it so unique there are no drivers already?

[–] [email protected] 41 points 3 months ago (1 children)

I can't speak for these specific laptops, but unlike x86, ARM generally doesn't have a way for an OS to discover the available hardware, and most ARM platforms historically didn't do anything to help. There is a standard for UEFI on ARM where the UEFI is supposed to tell the OS about the hardware, but as far as I know this is only a thing on ARM servers and these laptops might not support it.

Without any way of probing for hardware or getting the information from UEFI, Linux has to somehow be compiled with all the info about the hardware built-in. And the build will be model-specific (there's a way to pass a file describing the hardware to Linux from the bootloader which enables a single kernel to be used on multiple models and have just a small part of the bootloader be model-specific, but somebody still needs to make that file and the manufacturers clearly don't intend to do that).

[–] [email protected] 10 points 3 months ago (1 children)

Yep, an OS would need to be monolithic for a given device.

Something the computer world decided was a Bad Thing in about 1978.

[–] [email protected] 1 points 3 months ago

Are we really going back to the dark ages?

[–] [email protected] 8 points 3 months ago

ARM systems don't have the whole ACPI thing to describe what hardware is where. Linux has to bodge together its view of the system with a devicetree instead. If you don't know what device IP blocks are integrated into the SOC (and locked behind an NDA), good luck blindly guessing. You don't even get EFI booting, you get shit like "the rpi gpu runs its own proprietary bootloader lol".

[–] [email protected] 6 points 3 months ago (1 children)

Yes the drivers are all different afaik. You need a device tree, and hardware to debug what you wrote.

Just a kernel doesnt help much.

[–] [email protected] 2 points 3 months ago (1 children)

It would be cool if they provided at least a virtual machine to test on

[–] [email protected] 1 points 3 months ago (1 children)
[–] [email protected] 1 points 3 months ago (1 children)

Because if they can't provide them with real hardware at least a VM would be great

[–] [email protected] 1 points 3 months ago (1 children)

Like a VM emulating their exact hardware? Didnt know that was a thing

[–] [email protected] 2 points 3 months ago

I'm not sure if it's possible

[–] [email protected] 5 points 3 months ago

There's more hardware in a notebook than just the CPU. It's pointless without network and GPU drivers, for example. Also the ARM DeviceTree stuff is BS.

[–] [email protected] 2 points 3 months ago* (last edited 3 months ago)

There's something about the laptops not supporting ACPI so it's not possible to support them without hardcoded "devicetree" support for each laptop in the Linux kernel.