Project

General

Profile

PortingToAndroid11 » History » Version 19

Denis 'GNUtoo' Carikli, 05/03/2021 01:27 PM
update build launch

1 1 Joonas Kylmälä
h1. Porting Replicant to Android 11
2
3
{{>toc}}
4
5
Active development has moved towards AOSP 11.
6
7 11 dl lud
The basic features working on Replicant 9 and 10 have been confirmed to work on Replicant 11, but not everything has been tested yet on either version. The source code and build instruction for both these previous versions have been kept to do regression tracking:
8
* [[DeprecatedPortingToAndroid9|Porting Replicant to Android 9]]
9
* [[DeprecatedPortingToAndroid10|Porting Replicant to Android 10]]
10 1 Joonas Kylmälä
11 12 Denis 'GNUtoo' Carikli
h2. Precautions
12
13
See [[RunningReplicant11]] before installing Replicant 11 on your device to not break it.
14
15 1 Joonas Kylmälä
h2. Building Replicant 11
16
17
h3. Source code
18
19
<pre>
20
$ repo init -u https://git.replicant.us/replicant-next/manifest.git -b replicant-11-dev
21
$ repo sync
22
</pre>
23
24
Alternatively a shallow copy of the source tree can be fetched in order to save on disk space:
25
26
<pre>
27
$ repo init -u https://git.replicant.us/replicant-next/manifest.git -b replicant-11-dev --depth=1
28
$ repo sync -c
29
</pre>
30
31
To unshallow a specific module:
32
33
<pre>
34
$ cd path/to/module
35
$ git fetch --unshallow <remote>
36
</pre>
37
38
h3. Build dependencies
39
40
h4. For Trisquel 8
41
42
<pre>
43 16 Denis 'GNUtoo' Carikli
sudo apt-get install bc bison build-essential bsdmainutils ccache curl flex g++-multilib gcc-multilib gettext git gnupg gperf imagemagick lib32ncurses5-dev lib32readline-dev lib32z1-dev liblz4-tool libncurses5-dev libsdl1.2-dev libssl-dev libwxgtk3.0-dev libxml2 libxml2-utils lzop python-mako python3-mako pngcrush rsync schedtool squashfs-tools xsltproc zip zlib1g-dev
44 1 Joonas Kylmälä
sudo apt-get install gcc-5-arm-linux-gnueabi
45
</pre>
46
47 14 Denis 'GNUtoo' Carikli
You will also need to install repo as described in the bug #2199.
48
49 15 Denis 'GNUtoo' Carikli
h4. For Trisquel 9
50 14 Denis 'GNUtoo' Carikli
51 15 Denis 'GNUtoo' Carikli
This section is a work in progress.
52
53
<pre>
54 17 Denis 'GNUtoo' Carikli
sudo apt-get install bc bison build-essential bsdmainutils ccache curl flex g++-multilib gcc-multilib gettext git gnupg gperf imagemagick lib32ncurses5-dev lib32readline-dev lib32z1-dev liblz4-tool libncurses5-dev libsdl1.2-dev libssl-dev libwxgtk3.0-dev libxml2 libxml2-utils lzop python-mako python3-mako pngcrush rsync schedtool squashfs-tools xsltproc zip zlib1g-dev
55 15 Denis 'GNUtoo' Carikli
sudo apt-get install gcc-5-arm-linux-gnueabi
56
</pre>
57
58
You will also need to install repo as described in the bug #2199.
59 14 Denis 'GNUtoo' Carikli
60 1 Joonas Kylmälä
h3. Fixing the build environment
61
62
h4. Allow system binaries for building
63
64
By default, the Android 11 build system can only use the prebuilt binaries it ships.
65
66
While having binary toolchains is better for reproducible builds, and that the binaries are free software, this creates a number of issues:
67
* We need to be able to rebuild the binaries, and so far no one did it yet.
68
* Binaries are way harder to trust than source code and not everyone trust Google.
69
70
As GNU/Linux distribution's tools can be rebuilt and are easier to trust, we are using that for now.
71
72
h4. Java heap space
73
74
The Java heap size is automatically set according to the available system memory. On machines with 8 GB or less RAM, it is set to a value which is too low, and will result in the following error during the build:
75
76
<pre>
77
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
78
</pre>
79
80
The heap size can be "increased with an envirnoment variable":https://stackoverflow.com/a/60474592/1313087:
81
82
<pre>
83
$ export _JAVA_OPTIONS="-Xmx3g"
84
</pre>
85
86
h4. Reduce parallel jobs to avoid killed processes
87
88
Increasing the Java heap space is not enough to get a successful build on machines with 8 GB or less RAM. It is also necessary to reduce the number of parallel jobs, to avoid processes from being killed due to lack of memory. This typically happens during the build of @frameworks/base@ components.
89
90
For greater speed, you may let your build run with the defaults, wait for it to fail due to killed processes, and then relunch the build with:
91
92
<pre>
93
$ make -j1
94
</pre>
95
96
By default, "Ninja":https://ninja-build.org/manual.html, the underlaying build system for Android, used when you run @make bacon@, computes the number of parallel jobs according to the number of CPUs on your machine (typically #CPUs + 2 parallel jobs).
97
98
h3. Launching the build
99
100 18 Denis 'GNUtoo' Carikli
You can either launch builds with our wrapper script like that:
101 1 Joonas Kylmälä
<pre>
102 18 Denis 'GNUtoo' Carikli
$ ./vendor/replicant/build.sh i9305
103
</pre>
104
105 19 Denis 'GNUtoo' Carikli
It will try to use all the the CPU cores you have available by using one job per processor + one extra job.
106
107
You can also manually launch the build with the usual AOSP commands (so you could adjust the number of jobs with -j for instance):
108 18 Denis 'GNUtoo' Carikli
<pre>
109 1 Joonas Kylmälä
$ source build/envsetup.sh
110 18 Denis 'GNUtoo' Carikli
$ lunch lineage_i9305-userdebug
111 1 Joonas Kylmälä
$ make -j2
112 18 Denis 'GNUtoo' Carikli
</pre>
113 1 Joonas Kylmälä
114
h3. Install the images
115
116
h4. From scratch
117 13 Denis 'GNUtoo' Carikli
118
119 1 Joonas Kylmälä
Due to the bug #2235 we can't use the same commands than before with Replicant 9 and 10:
120
<pre>
121
$ cd out/target/product/i9305
122
$ sudo heimdall flash --BOOT boot.img --USERDATA userdata.img --SYSTEM system.img 
123 13 Denis 'GNUtoo' Carikli
</pre>
124
125
Instead we have to install it in a different way:
126
* First we need to flash the images with @heimdall flash --BOOT boot.img  --RECOVERY recovery.img --SYSTEM system.img@
127
* Then we need to reboot to recovery during the boot by pressing the volume up, menu and power buttons
128
* Then we need to select @Wipe data/factory reset@ and then @Factory data reset@
129
* And finally we can boot to Replicant 11 by selecting @Reboot the system now@
130
131
132
133 1 Joonas Kylmälä
134
135
h4. Update previous installation
136
137
<pre>
138
adb remount
139
adb sync
140
</pre>
141
142
h3. Get adb
143
144
As the device IDs are the ones given by the Linux kernel, they are not in the adb udev rules, so for now it requires to run adb as root:
145
<pre>
146
$ sudo adb shell
147
* daemon not running; starting now at tcp:5037
148
* daemon started successfully
149
i9305:/ #                                 
150
$ sudo adb kill-server
151
$ adb shell
152
* daemon not running; starting now at tcp:5037
153
* daemon started successfully
154
error: no devices/emulators found
155
</pre>
156
So make sure to kill the adb-server and run it as root:
157
<pre>
158
$ adb kill-server
159
$ sudo adb shell
160
* daemon not running; starting now at tcp:5037
161
* daemon started successfully
162
i9305:/ # 
163
</pre>
164
165
h3. Boot progress
166
167
You can also follow the boot progress with adb:
168
<pre>
169
adb logcat
170
adb logcat -b main
171
</pre>
172
173
Note that the device can go into suspend at any time, so adb might be interrupted. That looks like that:
174
First you get a shell
175
<pre>
176
$ sudo adb shell
177
i9305:/ #
178
</pre>
179
180
Then the connection is interrupted:
181
<pre>
182
$ adb shell
183
i9305:/ # [randomdev@fullyfreelaptop ]$                                                                                                     
184
</pre>
185
186
The effect with adb logcat is similar.
187
188
h3. Getting the latest changes
189
190
* The repositories are being constantly modified with @git push --force@ as we are trying things out, and don't want to make the commits history look too dirty, so be sure to backup your local changes.
191
* Sometimes the manifest repository is also modified with @git push --force@. In that case the following commands will loose all the work you did locally but will make the repository consistent with upstream repositories again:
192
<pre>
193
$ rm -rf .repo/manifests .repo/manifests.git .repo/manifest.xml
194
$ repo init -u https://git.replicant.us/replicant-next/manifest.git -b replicant-11-dev
195
$ repo sync --force-sync
196
</pre>
197
* The following command might also be necessary to make the state consistent with upstream repositories again, when the manifest history wasn't rewritten, but it will also loose all the work you did locally: 
198
<pre>
199
$ repo sync --force-sync
200
</pre>
201 3 Denis 'GNUtoo' Carikli
202
h3. Known working distributions
203
204
|_. Distribution |_. Works |_. Comments |
205
| Trisquel 8 | Yes | Tested with an lxc chroot:
206 4 Denis 'GNUtoo' Carikli
                     * Builds images fine       |
207 3 Denis 'GNUtoo' Carikli
| Debian 10 | Yes | |
208 1 Joonas Kylmälä
209
h3. Build VM
210
211
If you use Parabola, you may be interested in running Trisquel 8 in LXC.
212
213
To do that first debootstrap a Trisquel 8 rootfs. 
214
215
Parabola's debootstrap does support Trisquel 8 and its manual has an example on how to do that:
216
<pre>
217
$ man debootstrap
218
[...]
219
# debootstrap flidas flidas-root http://archive.trisquel.info/trisquel
220
</pre>
221
222
Then you can use virt-manager to setup the LXC instance.
223
224
The advantages of this solution are that:
225
* The LXC guest and host shares their resources (CPU, RAM) with almost no penalty
226
* Trisquel 8 is not a rolling release distribution
227
228
The disadvantage of this solution are that:
229
* you need to configure the Trisquel 8 LXC instance (vimrc, sshd_config, etc)
230
* It's more complicated to setup
231
* The Android build system outputs a warning message about not being able to use namespaces which may become mandatory in newer Android versions
232 5 Denis 'GNUtoo' Carikli
233
h3. Known issues
234 9 Denis 'GNUtoo' Carikli
235 1 Joonas Kylmälä
h4. Trisquel 8
236 9 Denis 'GNUtoo' Carikli
237
With Trisquel 8 we have several issues.
238
239
First we can't update the repo, else we have:
240
<pre>
241
$ repo --force-sync
242
repo: error: Python 3 version is too old; Please use Python 3.6 or newer.
243
</pre>
244
245
The repo from the package may not work if you have python2 in /usr/bin/python.
246
247
To workaround both issues you could do that:
248
<pre>
249
$ sudo apt install repo
250
$ sudo install -m 755 /usr/bin/repo /usr/local/bin/
251
$ sudo sed 's&^#!/usr/bin/python$&#!/usr/bin/python3&' /usr/local/bin/repo -i
252
</pre>
253 10 Denis 'GNUtoo' Carikli
254 1 Joonas Kylmälä
h4. Using latest repo (from .repo/repo/repo) ?
255 10 Denis 'GNUtoo' Carikli
256
If you use your distribution's repo, you might have an old version of repo.
257
258 1 Joonas Kylmälä
When that happens, repo notify you about it:
259 10 Denis 'GNUtoo' Carikli
<pre>
260
... A new version of repo (2.8) is available.
261
... New version is available at: /home/replicant/replicant-11/.repo/repo/repo
262
... The launcher is run from: /usr/local/bin/repo
263
!!! The launcher is not writable.  Please talk to your sysadmin or distro
264
!!! to get an update installed.
265
</pre>
266
267
So in case you have a recent enough python3, you can upgrade.
268
269
Trisquel 8 doesn't have a recent enough python3 to do that.
270
271
h4. latest repo not working due to python2 in /usr/bin/python
272
273
If you have the latest repo and python2 is in /usr/bin/python, you might end with an issue like that:
274 5 Denis 'GNUtoo' Carikli
<pre>
275
$ repo init [...]
276
Traceback (most recent call last):
277
  File "[...]/replicant-11/.repo/repo/main.py", line 56, in <module>
278
    from subcmds.version import Version
279
  File "[...]/replicant-11/.repo/repo/subcmds/__init__.py", line 38, in <module>
280
    ['%s' % name])
281
  File "[...]/replicant-11/.repo/repo/subcmds/upload.py", line 27, in <module>
282
    from hooks import RepoHook
283
  File "[...]/replicant-11/.repo/repo/hooks.py", line 472
284
    file=sys.stderr)
285
        ^
286
SyntaxError: invalid syntax
287
</pre>
288
289
This is because /usr/bin/python is python2 instead of python3.
290 7 Denis 'GNUtoo' Carikli
291 5 Denis 'GNUtoo' Carikli
In that case you can use @python3 $(which repo)@ instead of @repo@) like that:
292
293
<pre>
294
$ python3 $(which repo) init [...]
295
</pre>
296
297
Or you can install repo in /usr/local/bin and modify the @#!/usr/bin/env python@ inside it with the following commands:
298 8 Denis 'GNUtoo' Carikli
<pre>
299 1 Joonas Kylmälä
$ sudo install -m 755 .repo/repo/repo -t /usr/local/bin
300
$ sudo sed 's&^#!/usr/bin/env python$&#!/usr/bin/env python3&' /usr/local/bin/repo -i
301 10 Denis 'GNUtoo' Carikli
</pre>
302
303 5 Denis 'GNUtoo' Carikli
Note that the sed command doesn't work for older versions of repo. See the section above about making it work on trisquel8 for one that works on older versions of repo.
304 1 Joonas Kylmälä
305
h2. Cleanups to be done
306
307
* Make adb work as user by using the right USB IDs, and make userspace do the USB setup.
308
* -Make the kernel not use hardcoded CMDLINE_FORCE- Not possible unless the bootloader is changed or Linux is very heavily patched.
309
* Make the kernel not use hardcoded partitions if possible (though we use system as root)
310
* Make a clean Gatekeeper HAL module implementation instead of using the same hack than goldfish
311
* Look at "init.rc":https://android.googlesource.com/platform/system/core/+/master/init/README.md documentation to see if init.rc can be overriden clearly with the override statement to see if it's possible to keep the serial console patch for -eng
312
313
h2. Upstreaming status
314
315
* The stock bootloader is incompatible with Linux, see [[BootloadersIncompatibleWithLinux#Devices-with-the-Exynos-4412]] for more information. So we maintain patches to enable the Galaxy SIII, and Galaxy Note II to boot with the stock bootloader. In the long run we need to look into using u-boot in the kernel partition as using u-boot instead of the stock bootloader currently require nonfree and non-redistributable software (BL1).
316
* For the patches that are not merged yet, see the "issues of the redmine upstreaming sub-project":https://redmine.replicant.us/projects/upstreaming/issues
317
318
h2. Graphics status
319
320
Progress of the graphics related tasks is tracked at [[GraphicsReplicant10]].
321
322
h2. Modem status
323
324
*libsamsung-ipc:* 
325
* Fully tested under GNU/Linux only
326
* Can initialize completely the modem and receive messages (see the #1954 bug report for the logs)
327
* Needs more cleanup but there is now a better abstraction
328
329
*libsamsung-ril:* 
330
* Ported to Replicant 9 using a wrapper for the API >=12 in libsamsung-ril source code that needs to be removed
331
* Tested under Replicant 9 without up to date libsamsung-ipc (no modem init)
332
* Tested and validated under Replicant 6 (doesn't break telephony)
333
334
h3. Modem status TODO
335
336
* Implement the missing part to shut down the modem, close the interfaces and such, in order to need to reboot after each test.
337
* Continue to clean up the libsamsung-ipc and libsamsung-ril patches, test the patches in Replicant 6 when applicable, and merge them in the upstream repositories.
338
* Convert the firmware loading driver to the upstream API and then adapt libsamsung-ipc for that. This should also benefit other devices like the Galaxy SIII 4G, and the Galaxy Note II 4G which probably don't need much more to get their modem supported by upstream Linux.
339
* Cleanup and convert the rest of the drivers to look like the ones for the Nokia N900 and adapt the userspace in libsamsung-ipc, and merge libsamsung-ipc support for that once the kernel API is stable.
340
* Test the code under Replicant 10 when the graphics status will enable to have decent enough speed to do some testing through human interaction.
341
342
h2. TODO
343
344
First month of full time equivalent work:
345
346
|_. Time estimation  |_.Task |_. Comments |
347
| DONE | -boot a device under AOSP9- | Only boots with graphics, not much more |
348
| -7h- DONE | -build it under a "FSDG compliant distribution":https://www.gnu.org/distros/free-distros.html like Trisquel8- | -WIP for AOSP, It's difficult to do precise time estimations as it could work out of the box or require one full time month of work depending on how much issues are encountered- 
349
Builds under Trisquel8|
350
| -21h- DONE | * -port the changes from AOSP9 to LineageOS 16-
351
* -cleanup the code-
352
* -build the kernel from the Android build system-
353
* -make sure it builds with an FSDG compliant distribution-
354
* -document the build procedure- |
355
Status:
356
* Boots with adb.
357
* Has ultra slow graphics |
358
| 14h | find, remove and document proprietary software in LineageOS 16 | |
359
| 21h | find, remove and document privacy issues in LineageOS 16 | |
360
| 7h | -Add support for the touch keys driver in the  galaxy-s3 dts- | "applied":https://lists.infradead.org/pipermail/linux-arm-kernel/2019-November/694100.html |
361
| 7h | -upstream the AAT1290 flash led Linux dts for the galaxy-s3 boards- | "Now in 5.3":https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?h=v5.3&id=4e4dfcb2a425cccc6dd1fb7d46e060cd57999afc |
362
| 7h | rebrand LineageOS as Replicant | |
363
| 70h | -port and- cleanup the the Galaxy SIII (i9300) "modem":https://github.com/fourkbomb/linux/tree/modem Linux driver from 4.16 to 5.0| See the [[PortingToAndroid9/#Modem-status|modem status]] for more details |
364
|_\3. Total: 147h (~1 month) |
365
366
Second month of full time equivalent work:
367
| * port  libsamsung-ril and libsamsung-ipc to Android 9
368
* Make the modem driver and libsamsung-ipc work together | 157h | See the [[PortingToAndroid9/#Modem-status|modem status]] for more details |
369
|_. Total |_. 157h | ~1 month |
370
371
Third month of full time equivalent work:
372
|_. Task |_. Time estimation |_. Comments |
373
| -port the sensors libraries and other device specific libraries-
374
Look which sensor libraries can be used | 70h | Already done by the unofficial LineageOS port of the Galaxy SIII (i9300), needs testing |
375
| add support for Audio with the upstream kernel driver | 70h | Might be way faster, depending on what Android 9 uses
376
                                                               See also "this bugreport":https://github.com/CustomROMs/android_local_manifests_i9300/issues/1 |
377
| -add partial (no modem) support for the Galaxy SIII 4G (i9305) and- factorize the code with i9300 | 14h | * The source code on which the work was based changed from AOSP to an unofficial LineageOS port to a port of i9305 support for AOSP by Joonas to the official LineageOS so it's now supported by default
378
* The work to factorize the code between the i9300 and i9305 still need to be done |
379
 |
380
|_. Total |_. 154h | ~1 month |
381
382
|_. Task |_. Time estimation |_. Comments |
383
| create a recovery | 21h | |
384
| add internal WiFi support and validate the functionality | 6h | |
385
| add external WiFi dongles support | 20h | External dongles support might be tricky |
386
| -create new- update the install and upgrade instructions | -35h- | -Our current install instructions don't scale as we have one copy for each device.-
387
-We also created generic instructions but they tend to be harder to follow[1] than the device specific ones.-
388
-This will be made in a modular format (for instance in LaTeX) that enables to generate per device install instructions without requiring to have multiples copy of the same text.-
389
-The instructions will need to be able to be modified and compiled on an FSDG compliant distribution.-
390
Mostly done: 
391
* The installation instructions are now generic enough. 
392
* Some long standing TODO were also done along the way like adding backup instructions for the EFS.
393
* The current instructions are still for Replicant 6.0 and will need to be updated for Replicant 9.0 |
394
395
|_. Task |_. Time estimation |_. Comments |
396
| Estimate the amount of work to Reduce the attack surface | ? | |
397
| Estimate the amount of work to add in-system upgrades | ? | |
398
399
fn1. The generic instructions were tested at Install parties in Paris 
400
401
h3. Devices support:
402
403
h4. Easy, because it's similar enough to the Galaxy SIII (I9300)
404
405
|_\3. Galaxy Note II (N7100) |
406
|_. Task |_. Time estimation |_. Comments |
407
| port the EA8061 LCD Linux driver | 35h | |
408
| port the S6EVR02 LCD Linux driver | 35h | |
409
| port the MAX77693 flash led Linux driver | 7h | |
410
| android: add support for the Note II (N7100) and factorize the code with Galaxy SIII (i9300) and Galaxy SIII 4G (i9305) | 14h | Should be similar to the Galaxy SIII |
411
| port the sensors libraries and other device specific libraries | 70h | It's difficult to evaluate how much time it could take |
412
| add support for Audio with the upstream kernel driver | 14h | Should be similar to the Galaxy SIII |
413
414
|_\3. Galaxy Note 8.0 (N5100) and 8.0 WiFi (N5110) |
415
|_. Task |_. Time estimation |_. Comments |
416
| Evaluate the time required to do the port | 14h | TODO |
417
418
h4. Needs more work and unknown upstream Linux status
419
420
|_. Device |_. Time estimation |_. Comments |
421
| Galaxy S II (i9100) | | Linux: devboard dts upstream? unknown status |
422
| Galaxy Note (N7000) | | unknown Linux upstream status |
423
| Galaxy Nexus (I9250) | |/2. OMAP4, no dts upstream |
424
| Galaxy Tab 2 7.0 (P3100), 7.0 WiFi (P3110), 10.1 (P5100), 10.1 WiFi (P5110) | |
425
| GTA04 >= A4 | | TODO: a RIL needs to be written, userspace GPS support is missing, audio scenarios, etc |
426
427
h2. Documentation
428
429
h3. Replicant 6.0 changes
430
431
See [[Replican6Changes]].
432
433
h3. Other rebases
434
435
See the [[Samsung-ipc]] page.
436
437
h2. Other attempts
438
439
* It might be interesting to contact the people doing ports once we have something working well enough.
440
* It is also interesting to look at other attempts to understand if a given device is powerful enough to run Android 9 and what configuration was used to achieve it.
441
442
|_. Device(s) |_. Repository |_. status |_. Comments |
443
| i9300 | "CustomROMs":https://github.com/CustomROMs/android_local_manifests_i9300 | * "February 8 2020 Pie release":https://forum.xda-developers.com/galaxy-s3/development/rom-lineageos-16-0-t3875899 | |
444
| i9300 | "Team InFusion":https://github.com/team-infusion-developers/android_local_manifests_i9300 | * "August 20 2019 Pie release":https://forum.xda-developers.com/galaxy-s3/development/rom-optimized-lineageos-16-0-team-t3940142 | Issues: * Uses a Samsung kernel
445
* Uses too many nonfree libraries
446
=> Probably nothing we could reuse from its code |
447
| n7100 | "ComicoTeam":https://github.com/ComicoTeam/android_device_samsung_n7100 | * "January 4 2020 Pie release":https://forum.xda-developers.com/galaxy-note-2/development/rom-lineageos-16-0-20190112-comico-t3889281 | |
448
| i9100 | "rINanDO":https://github.com/rINanDO/android_device_samsung_galaxys2-common | * "March 20 2020 Pie release":https://forum.xda-developers.com/galaxy-s2/development-derivatives/pie-i9100-t3850588 
449
* "July 19 2020 Android 10 release":https://forum.xda-developers.com/galaxy-s2/development-derivatives/rom-lineageos-17-0-t4022733 | |
450
451
h3. Links for other attempts
452
453
* https://www.xda-developers.com/android-pie-android-9-port-custom-roms/
454
455
h3. CustomROMs i9300 components
456
457
|_. Repository |_. Tree path |_. Dependencies |_. Function |_. Comments |
458
|/8. https://github.com/CustomROMs/android_hardware_samsung
459
lineage-16.0 branch | hardware/samsung/macloader | | Loads the MAC Address of the WiFi network interface | Might be useful |
460
| hardware/samsung/wifiloader | | Loads the wifi kernel module (like modprobe) and setup firmware filesystems permissions | May be useful |
461
| hardware/samsung/audio | | seems to contains ril related stuff as well | Look if the ril stuff is required, go for standard audio |
462
| hardware/samsung/lineagehw/hidl/livedisplay | | livedisplay is a feature similar to what redshift does on GNU/Linux | Not sure if it works with mainline |
463
| hardware/samsung/exynos/multimedia/utils/ | seem meant for audio/video decoding offload | assembly obtimized color conversion and resize code | check assembly code license, not sure if useful |
464
| all other directories in hardware/samsung/exynos/ | nonfree firmwares, nonfree software?, smdk kernel? | audio/video decoding offload | Avoid using that |
465
| hardware/samsung/exynos3 |/2. nonfree firmwares?, nonfree software?, smdk kernel? |/2. some light libraries, display stuff (gralloc, etc), 2D acceleration (FIMG), camera (FIMC), 3D acceleration, etc |/2. Avoid using that for now |
466
| hardware/samsung/exynos4 |
467
468
h2. Known error messages that are safe to ignore
469
470
* TestHarnessModeService: Failed to start Test Harness Mode; no implementation of PersistentDataBlockManagerInternal was bound
471
* JniUtils: Could not load native library jni_latinimegoogle
472
473
h2. Links 
474
475
* "Android build requirements - hardware and software":https://source.android.com/setup/build/requirements
476
* "Why LineageOS Developers are building Android Go-optimized custom ROMs":https://www.xda-developers.com/android-go-old-android-8-1-oreo/
477
* "Android Go recommended default values for propreties for optimization":https://android.googlesource.com/platform/build/+/master/target/product/go_defaults_common.mk
478
* "Team InFusion i9300 optimized system.prop":https://github.com/team-infusion-developers/android_device_samsung_i9300/blob/lineage-16.0/system.prop#L23
479
* "Hack to fix high CPU usage caused by logd":https://github.com/team-infusion-developers/android_device_samsung_smdk4412-common/commit/c66015514fc9779edfed2665f67e841f3620c71e
480
* "Use low-end video codecs":https://github.com/team-infusion-developers/android_device_samsung_smdk4412-common/commit/adc919f04b981a4fe005fab2cf443596a22992b2
481
* "Optimize ActivityManager cached apps":https://github.com/team-infusion-developers/android_device_samsung_smdk4412-common/commit/24bc62970d35eb5a7a257463e7dbfe873ceb5779
482
* "Use 1Gb Dalvik config":https://github.com/team-infusion-developers/android_device_samsung_smdk4412-common/commit/8a7cebc5af772a2949420ac4a383f5f75236c65c