Project

General

Profile

Upstream » History » Version 44

Denis 'GNUtoo' Carikli, 06/17/2018 10:07 AM

1 12 Denis 'GNUtoo' Carikli
h1. Upstream Linux
2 1 Denis 'GNUtoo' Carikli
3 11 Denis 'GNUtoo' Carikli
h2. Benefits of using Upstream Linux
4 2 Denis 'GNUtoo' Carikli
5 11 Denis 'GNUtoo' Carikli
Currently, Replicant uses device specific Hardware Abstraction Layers, because device manufacturers implemented non-standard kernel interfaces. However, Android works with upstream kernels and supports plug-n-play hardware nowadays, so it makes sense to have generic Hardware Abstraction Layers for the standard interfaces of the Linux kernel (ALSA, V4L2, etc).
6 2 Denis 'GNUtoo' Carikli
7
Benefits:
8
* It would allow supporting external WiFi dongles such as the ones supported by the ath9k_htc driver and free firmwares without the need for a specific application or configuration.
9 11 Denis 'GNUtoo' Carikli
* It would make devices last longer by alleviating the device specific maintenance burden: If LineageOS stops supporting a Replicant supported device, Replicant would need to maintain it by its own. This would require a lot of work, unless the device is already supported the upstream Linux kernel and generic hardware abstractions layers. This would enable Replicant to support devices that are not currently supported by LineageOS.
10
* It would enable the support for devices that are or will be added to upstream Linux.
11 2 Denis 'GNUtoo' Carikli
12 22 Denis 'GNUtoo' Carikli
As GNU/Linux expects standard kernel interfaces, this would also enable to run GNU/Linux out of the box on such devices.
13
This has some interesting outcomes:
14
* The device specific work could be shared between GNU/Linux communities and Replicant communities. This could result in less work to do to support individual devices. Since Android libraries depends on Android's libc, non-standard proprietary libraries might be harder to reuse than the free software implementations.
15
* It would enable GNU/Linux distributions to more easily support smartphones and tablets, which would hopefully enable FSDG distributions to be as usable as Replicant. This way, if one day Android devices stop using the Linux kernel or if the code takes directions that is too much problematic, having an Android alternative that is based on GNU/Linux would be easier.
16 23 Denis 'GNUtoo' Carikli
* Older devices with less amount of RAM than Replicant current minimum requirements could be used with GNU/Linux and possibly repurposed for other usages, reducing the amount of electronic devices waste.
17 22 Denis 'GNUtoo' Carikli
18 2 Denis 'GNUtoo' Carikli
h2. Requirements
19
20
* Adding a generic WiFi HAL for external dongles only requires a device that is supported by Replicant, and that can provide enough power for the dongle.
21 11 Denis 'GNUtoo' Carikli
* For the other standard interfaces (like ASLA, etc) a device running a upstream Linux Kenrel with as few patches as possible is required.
22 2 Denis 'GNUtoo' Carikli
23 4 Denis 'GNUtoo' Carikli
h2. Devices
24
25 5 Denis 'GNUtoo' Carikli
It is best to use a device that requires the least amount of work to be functional under Replicant.
26
More precisely we want to minimize:
27 11 Denis 'GNUtoo' Carikli
* The work needed to have the device usable with upstream Linux.
28 5 Denis 'GNUtoo' Carikli
* The work porting or writing Android hardware abstractions layers.
29
30
To achieve that we can choose a device that:
31
* requires no or very minimal work to be fully supported by Linux.
32
* have less hardware features (so we don't need to support them in Linux and in the HALs).
33
* is easy to buy, so the work can be shared among multiple people.
34
35 6 Denis 'GNUtoo' Carikli
It is also a good idea to keep one image per device, as trying to make a single image that
36 11 Denis 'GNUtoo' Carikli
would work on all ARM device supported by upstream Linux is complicated: Even ARM GNU/Linux
37 6 Denis 'GNUtoo' Carikli
distributions still have some issues with that.
38
39 11 Denis 'GNUtoo' Carikli
h3. Smartphones and tablets with a free software bootloader and work in progress upstream Linux support
40 4 Denis 'GNUtoo' Carikli
41 30 Denis 'GNUtoo' Carikli
|_. Formfactor |_. Vendor |_. Product  |_. Linux dts | comments |
42
| Smartphone | LG | Optimus Black | "omap3-sniper.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap3-sniper.dts | no display(no driver), very few peripherals |
43
| Tablet | Amazon | Kindle Fire (first generation) | "omap4-kc1.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap4-kc1.dts | no display(no driver), very few peripherals |
44 31 Denis 'GNUtoo' Carikli
| Smartphone | | GTA04 A3 | "omap3-gta04a3.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap3-gta04a3.dts | |
45
| Smartphone | | GTA04 A4 | "omap3-gta04a4.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap3-gta04a4.dts | |
46
| Smartphone | | GTA04 A5 | "omap3-gta04a5.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap3-gta04a5.dts | |
47
48 4 Denis 'GNUtoo' Carikli
h3. Replicant supported Samsung Exynos devices
49
50 43 Denis 'GNUtoo' Carikli
|_. Formfactor |_. Vendor |_. Product |_. Linux dts | Linux status page | Issues |
51
| Smartphone | Samsung | Galaxy S II (i9100)  | "exynos4210-trats.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/exynos4210-trats.dts  | | Probably has a signed bootloader |
52
| Smartphone | Samsung | Galaxy S III (i9300) | "exynos4412-trats2.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/exynos4412-trats2.dts | | Has a signed bootloader |
53 42 Denis 'GNUtoo' Carikli
| Smartphone | Samsung | Galaxy Note 2 (N7100) | "exynos4412-n710x.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/exynos4412-n710x.dts | | signed bootloader |
54 1 Denis 'GNUtoo' Carikli
55 27 Denis 'GNUtoo' Carikli
h3. Other devices with some upstream support.
56
57 33 Denis 'GNUtoo' Carikli
|_. Formfactor  |_. Vendor |_. Product |_. Linux dts |_. Linux status page |_. Issues |
58 41 Denis 'GNUtoo' Carikli
| Smartphone | Samsung | Galaxy SIII 4G (i9305) | "exynos4412-i9305.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/exynos4412-i9305.dts | | Signed bootloader |
59 30 Denis 'GNUtoo' Carikli
| Smartphone | Nokia | N900 | "omap3-n900.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap3-n900.dts | https://elinux.org/N900 | Has a signed bootloader |
60
| Smartphone | Nokia | N9 | "omap3-n9.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap3-n9.dts | https://elinux.org/N9 | Probably has a signed bootloader |
61
| Smartphone | Nokia | N950 | "omap3-n950.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap3-n950.dts | https://elinux.org/N950 | Probably has a signed bootloader |
62 40 Denis 'GNUtoo' Carikli
| Smartphone | Motorolla | Droid 4 (XT894) | "omap4-droid4-xt894.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/omap4-droid4-xt894.dts | | Probably has a signed bootloader, may have a signed kernel requiring kexec |
63 33 Denis 'GNUtoo' Carikli
| Smartphone | | Nexus 7 (2012) | "qcom-apq8064-asus-nexus7-flo.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-apq8064-asus-nexus7-flo.dts | | Qualcomm SOC (signed bootloader, shared memory) |
64 35 Denis 'GNUtoo' Carikli
| | | | "qcom-apq8064-sony-xperia-yuga.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-apq8064-sony-xperia-yuga.dts |  | Qualcomm SOC (signed bootloader, shared memory) |
65
| | | | "qcom-msm8974-sony-xperia-amami.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-msm8974-sony-xperia-amami.dts | | Qualcomm SOC (signed bootloader, shared memory) |
66
| | | | "qcom-msm8974-sony-xperia-castor.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-msm8974-sony-xperia-castor.dts |  | Qualcomm SOC (signed bootloader, shared memory) |
67
| | | | "qcom-msm8974-sony-xperia-honami.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-msm8974-sony-xperia-honami.dts |  | Qualcomm SOC (signed bootloader, shared memory) |
68 36 Denis 'GNUtoo' Carikli
| Smartphone | | Nexus 5 | "qcom-msm8974-lge-nexus5-hammerhead.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-msm8974-lge-nexus5-hammerhead.dts | | Qualcomm SOC (signed bootloader, shared memory) |
69 37 Denis 'GNUtoo' Carikli
| Smartphone | Samsung | Galaxy S5 | "qcom-msm8974-samsung-klte.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-msm8974-samsung-klte.dts | | Qualcomm SOC (signed bootloader, shared memory) |
70 39 Denis 'GNUtoo' Carikli
| | | Fairphone 2 | "qcom-msm8974-fairphone-fp2.dts":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/qcom-msm8974-fairphone-fp2.dts | | Qualcomm SOC (signed bootloader, shared memory) |
71 27 Denis 'GNUtoo' Carikli
72 1 Denis 'GNUtoo' Carikli
h3. Allwinner devices
73 13 Denis 'GNUtoo' Carikli
74
Devices with Allwinner SOCs are an interesting targets because:
75
* Many of them do not use signed bootloaders.
76
* Many of the SOCs and various devices using them have good Linux and u-boot mainline support
77
78
For instance the Lime 2 from Olimex is pretty well supported and is easy to find.
79
However this device is a single board computer and, as such it doesn't have the have the usual peripherals that are commonly found in tablets and smartphones. This makes a port on this device less relevant and less useful.
80
81
Some research is needed to identify which devices are easiest to work with. Tablets that don't have a modem seem to be better than smartphones, as supporting the modem would require to have it supported in Linux and the userspace libraries. This might even require to write and upstream a Linux driver for the modem.
82
83
A good tablet for this task should have:
84
* A SOC that has good mainline support, see "the Linux mainlining effort page on linux-sunxi":https://linux-sunxi.org/Linux_mainlining_effort for more details.
85
* A Free software bootloader, or the ability to easily add support for the tablet to a free software bootloader.
86
* The ability to power and use an USB WiFi card or chip that is compatible with the ath9k_htc driver.
87
88
It would also be better if the chosen tablet doesn't use an AllWinner SOC with a PowerVR GPU, as MALI GPU have more probability to be usable with free software in the future.
89 1 Denis 'GNUtoo' Carikli
90
h2. See also
91
92
* [[Google Summer of Code 2018]]
93 12 Denis 'GNUtoo' Carikli
94 19 Denis 'GNUtoo' Carikli
h1. Userspace
95
96
h2. Upstream userspace hardware support libraries
97 1 Denis 'GNUtoo' Carikli
98 17 Denis 'GNUtoo' Carikli
|_. Usage |_. Replicant |_. GNU/Linux |_. comments |
99
| Bluetooth stack | BlueDroid | Bluez | |
100 16 Denis 'GNUtoo' Carikli
101 20 Denis 'GNUtoo' Carikli
h2. Upstream non-hardware specific userspace
102 18 Denis 'GNUtoo' Carikli
103
|_. Usage |_. Replicant |_. GNU/Linux |_. comments |
104
| Unix command line tools | ? | Busybox, Coreutils | |
105 44 Denis 'GNUtoo' Carikli
106
h2. Other projects interested in using upstream Linux and/or contributing to it
107
108
* "Postmarketos":https://wiki.postmarketos.org/wiki/The_Mainline_Kernel