[KERNEL][3.18.140+][EOL for now] SwanKernel for the LG V20

Search This thread

AShiningRay

Senior Member
Sep 1, 2021
145
65
Xiaomi Redmi Note 4
LG V20
I tried 3 different toolchain, no modifications yet.

View attachment 5810269
Try getting my build.sh script from Swan's repo and using it to build gamma. Not sure how i build it a while ago, but i'm pretty sure i also used it to some capacity... you'll need to make some adjustments to the script though, such as toolchain locations and defconfig names.
 
  • Like
Reactions: yesimxev

yesimxev

Senior Member
May 8, 2017
438
163
Try getting my build.sh script from Swan's repo and using it to build gamma. Not sure how i build it a while ago, but i'm pretty sure i also used it to some capacity... you'll need to make some adjustments to the script though, such as toolchain locations and defconfig names.
I did it, and didn't work, same error. Seems like this branch is messed up then. I'll try to patch

1674424366100.png
 

yesimxev

Senior Member
May 8, 2017
438
163
Last edited:

AShiningRay

Senior Member
Sep 1, 2021
145
65
Xiaomi Redmi Note 4
LG V20
Huh, never faced something like that when building a kernel. Is it really using the downloaded ARM toolchains? Should be building if it is.
Yup the following ones:
https://developer.arm.com/-/media/F...-arm-10.3-2021.07-x86_64-arm-none-eabi.tar.xz
https://developer.arm.com/-/media/F...m-10.3-2021.07-x86_64-aarch64-none-elf.tar.xz

Building on Kali, same issue as with the other toolchains, wondering if there's anything of build-essential that can fail?
Not really, at least arch's build-essential causes no issues with kernel, recovery or rom builds over here.

I don't have experience with kali, so i can't say whether it has any difference from arch in regards to tools and kernel... those error messages tell that some critical functions are missing (and it doesn't seem to be missing in gamma's oreo-stable branch, or else it wouldn't build for anyone).
 

yesimxev

Senior Member
May 8, 2017
438
163
Not really, at least arch's build-essential causes no issues with kernel, recovery or rom builds over here.

I don't have experience with kali, so i can't say whether it has any difference from arch in regards to tools and kernel... those error messages tell that some critical functions are missing (and it doesn't seem to be missing in gamma's oreo-stable branch, or else it wouldn't build for anyone).
I'll try on another distro
 

yesimxev

Senior Member
May 8, 2017
438
163
Ah
Not really, at least arch's build-essential causes no issues with kernel, recovery or rom builds over here.

I don't have experience with kali, so i can't say whether it has any difference from arch in regards to tools and kernel... those error messages tell that some critical functions are missing (and it doesn't seem to be missing in gamma's oreo-stable branch, or else it wouldn't build for anyone).
Ah truly annoying. It's probably related to newer gcc on host, or similar. I guess this was automatic back then. After some time, I figured out from the Makefile, that you need to add this make arg to your make command, or script: CONFIG_CC_OPTIMIZE_FOR_SIZE=y.
So it will trigger the build flags around line 625 in Makefile:
Code:
ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
KBUILD_CFLAGS   += -Os $(call cc-disable-warning,maybe-uninitialized,)
else
KBUILD_CFLAGS   += -O2
endif
 

AShiningRay

Senior Member
Sep 1, 2021
145
65
Xiaomi Redmi Note 4
LG V20
Ah

Ah truly annoying. It's probably related to newer gcc on host, or similar. I guess this was automatic back then. After some time, I figured out from the Makefile, that you need to add this make arg to your make command, or script: CONFIG_CC_OPTIMIZE_FOR_SIZE=y.
So it will trigger the build flags around line 625 in Makefile:
Code:
ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
KBUILD_CFLAGS   += -Os $(call cc-disable-warning,maybe-uninitialized,)
else
KBUILD_CFLAGS   += -O2
endif
Oh right, i completely forgot that one of Gamma's features is that it tries to build with -O3 by default, which demands some specific adjustments and toolchains, as arm's GCC and Google's Clang tools are meant to build the kernel with -Os. Been a while since i've built it so i might have used mk2000's custom built toolchains.

But back to the main conversation: Did it finally build with OPTIMIZE_FOR_SIZE?
 

yesimxev

Senior Member
May 8, 2017
438
163
Oh right, i completely forgot that one of Gamma's features is that it tries to build with -O3 by default, which demands some specific adjustments and toolchains, as arm's GCC and Google's Clang tools are meant to build the kernel with -Os. Been a while since i've built it so i might have used mk2000's custom built toolchains.

But back to the main conversation: Did it finally build with OPTIMIZE_FOR_SIZE?
Yeah you must have used those 😅 yes, IR works like a charm, time to add the NetHunter patches. Thank you for your support! 🎉📱📡
 

AShiningRay

Senior Member
Sep 1, 2021
145
65
Xiaomi Redmi Note 4
LG V20
Also, now my camera fails to start, is there any new firmwares in the kernel tree or drivers I should update to LOS18.1 source?
Yes, there's been some rather large camera updates in the kernels and roms since gamma-oreo. Gamma-pie has the most important ones if i'm not mistaken (voltage, gpio and clock adjustments), but i don't remember if IR works well there. Not sure if that will be a bother to you but... could you test those two on gamma-pie? We're in the process of fixing IR on 4.4 and even gamma seems shaky at best with camera and IR.
 

yesimxev

Senior Member
May 8, 2017
438
163
Yes, there's been some rather large camera updates in the kernels and roms since gamma-oreo. Gamma-pie has the most important ones if i'm not mistaken (voltage, gpio and clock adjustments), but i don't remember if IR works well there. Not sure if that will be a bother to you but... could you test those two on gamma-pie? We're in the process of fixing IR on 4.4 and even gamma seems shaky at best with camera and IR.
Pie works like a charm. I couldn't test everything, but the camera and IR are working 🎉
 
  • Like
Reactions: AShiningRay

Top Liked Posts

  • There are no posts matching your filters.
  • 9
    SwanKernelLogo.png


    A custom kernel for (most) V20 variants

    SwanKernel is an android kernel based on the latest Lineage OS 18.1 sources for the LG MSM8996 phones, aiming to bring those features and updates and improve them with some extra tuning, fixing and external features tailored specifically for the LG V20's performance characteristics and feature set, while trying to maximize the battery life and responsiveness of the device at the same time.​

    This kernel is based on Linux 3.18.140, and has become EOL with the last commit, as i don't think there's anything else that can be optimized for the V20 on this source anymore.

    Which phone variants/models does this kernel support?


    The kernel currently supports the following variants:
    • H910/H915
    • H918
    • H990
    • LS997
    • US996
    • VS995
    Support for other special variants like the US996Santa might come at a later date if needed.


    What does this kernel intend to achieve?

    The main goal here is to have a kernel that not only has extra features and improvements, but is also clean and concise, having only features that are truly needed from a kernel that will run alongside a Android 11-based ROM. One example of that is Kcal display control, a feature that is unnecessary here since most, if not all Android 11 ROMs have LiveDisplay for that exact same purpose and without the need to root. This helps the kernel have a smaller file size and lower processing overhead, as well as promote better maintainability.

    This kernel does have a battery life bias, but will still scale up to maximum performance when needed. No Overclocking is done for now.


    Does it have any features over stock?

    Yes, a lot. The kernel is divided into two variants, here are the features both variants have over stock:

    1. AdrenoBoost for improved GPU performance.
    2. GPU and CPU/Cache Undervolt for better power efficiency on load.
    3. CPU governors tuned for better battery life and thermal stability without impacting performance all that much.
    4. Almost no unnecessary debug flags on the kernel for better kernel performance.
    5. Westwood TCP Congestion Algorithm set as default in order to have better network performance and consistency.
    6. AutoSMP CPU Hotplug to shutdown the big cores when their stronger performance isn't needed, slightly improving battery life on light loads and idle.
    7. Disabled CPU Boost when a finger is detected on screen, preventing unnecessary frequency boosts when no meaningful action is done other than tapping on screen and slightly scrolling around. We have Schedutil to keep it smooth anyways.
    8. USB Fast Charge.
    9. Multiple cherry-picks from different msm8996 sources with fixes and improvements to the kernel.
    10. Configurable wakelock blocker (boeffla) for roms that have some "unneeded" wakelocks enabled by default and/or users that know which wakelocks can be blocked for better battery life.
    11. Anxiety IO Scheduler enabled by default, offering a read bias and lower latency in IO operations.
    12. Kernel updated to Linux 3.18.140 with some extra patches from Googlesource.
    13. Wireguard support, improving VPN performance.
    14. Cryptographic functions optimizations, slightly improving the phone's performance when calculating hashes and so on.

    The Extreme variant has some extra features over the Stable one, those being:
    1. Stronger Undervolts (i'm talking about borderline unstable undervolts here, so i really recommend that you flash the Stable one first).
    2. CPU Voltage Control if you need to setup a custom undervolt to keep it more stable and have no need to compile the kernel from source just to change the values... and that's assuming your phone even boots with this variant of the kernel.
    3. Disabled Battery BCL which eliminates the power throttling caused by the battery, just be careful when running demanding tasks while having almost no battery left.


    Are there any bugs?

    Right now, there's the dreaded Infrared Blaster, and it... kinda works? The IR is able to send the very first command i give to my LG TV without any problems after every reboot, but refuses to send anything else after that first command. The IR Blaster's light still works all the time though despite having some big delays between on/off states.


    Download & Installation

    The folders containing each kernel variant can be found here:
    To install the kernel, it's the standard procedure:
    1. Download the kernel you want for your device
    2. Place it into the phone
    3. Boot into recovery, select it and then flash
    4. Wipe Dalvik Cache (optional, you only need to wipe it if you face random Force Closes, but it is a good practice anyway)
    5. Reboot.
    6. Open any app that can check the device info and look for "kernel", where it will show "... 3.18.xxx-Swan" if it installed correctly. I personally use SmartPack for that, but it requires root.
    7. Enjoy the experience!


    Performance and Battery metrics
    And now to the kernel's real world performance. But before delving in, keep in mind that my refurbished H910 is apparently a Snapdragon 821 prototype, that's why you will see higher than normal performance and clock values on cpu matters even with the LITTLE cores underclocked to 1785MHz instead of 2188MHz, the snapdragon 820 ones should not have any underclock applied and will reach the max of 1593MHz on them. I also took the liberty of testing those on the Extreme variant as BCL often interferes with the performance results and the extra undervolt doesn't increase performance in any substantial way, 5-7% at most on Geekbench.

    Battery life:
    Screen SOT test (Youtube looping through a massive playlist of songs with some scrolling to change between them):
    Screenshot_20211025-185046214.jpgScreenshot_20211025-193015235.jpg

    Not very impressive, until you consider the battery currently powering it:
    Screenshot_20211025-185057599.jpg

    CPU/GPU Performance:

    CPU performance according to Geekbench 5.4.1 (there is some minor variance of about 15-21 points in multithread):
    Screenshot_20211025-195919247.jpg

    CPU sustained performance on CPU Throttling Test(running it for 15+ minutes barely changes the curve, as it stabilizes at around 80-82 Celsius, i suppose a Snap 820 will fare better here due to the lower clocks):
    Screenshot_20211025-194844892.jpg

    GPU general performance on GFXBench 5:
    Screenshot_20211025-205142387.jpg

    No copper shim replacement or thermal pad change was made, the phone's internal structure is still the same from when i bought it.

    Storage Performance:

    General IO performance in Androbench 5(Not very accurate, but welp, if anyone has a more in-depth one feel free to share):
    Screenshot_20211025-205621339.jpg

    And there we go, everything i could benchmark so far. This will not be the best kernel on every front so the stock kernel on Lineage 18.1, Lighthouse's kernel or mk2000 might suit you better depending on your needs.

    Changelog

    *********** Swankernel V1.09+ [Maintenance release] ***********
    1. CPU/Cache/GPU Voltages have basically reached the optimum point on both stable and extreme.
    2. Some performance commits were cherry-picked from newer kernels for other devices
    3. Dynamic FSync was disabled since it could cause data loss on some edge cases involving reboots.
    4. Improved some string routines and memory access functions, about 4% or so improvement on geekbench.
    *********** Swankernel V1.09 [Last 3.18 version, i think] ***********
    1. Minor performance and power-saving optimizations throughout the kernel
    2. CPU M4M cache undervolting (not really a big difference, but nice to have anyway).
    3. A few cherry-picked fixes for the 3.18 msm8996 kernel tree.
    4. Crypto function optimizations and HW acceleration for CRC32 Enabled.
    5. Not actually a kernel change but: Can now be flashed on android versions lower than 11.

    *********** Swankernel V1.08 ***********
    1. Small performance optimizations related to the voltage curves, especially in the GPU.
    2. PC USB Charging has been fixed and the phone can now be charged over it again.

    *********** Swankernel V1.06 ***********
    1. Upstreamed kernel to 3.18.140 + some extra patches, with more coming later.​
    2. Added Wireguard support for better VPN performance compared to IPSec.​
    3. Smaller fixes to the kernel zip files, improving compatibility with some models.​
    4. Minor performance optimizations, shouldn't be noticeable to the end user.​
    5. Now stable enough (at least the Stable version is) to be used as a daily driver.​

    *********** Swankernel V1.00 ***********
    Initial release. Has the features from 1 to 12 on both versions, and from 1 to 3 on the Extreme version.​

    Closing notes

    With V1.09, the kernel can now be flashed on basically any android version and should work out-of-the-box, although i didn't test it on stock roms at all and there are no reports of it working there, so it might not work on them.

    From what i could gather during the multiple Pre-Beta tests, the battery life improved considerably over the kernel shipped by default with Lighthouse V20 and even more when compared to Lineage's stock kernel.

    If you have any suggestion or idea that can possibly improve the kernel, do not hesitate to share, i will try to implement it when my time allows it. If there are any problems that only happen on this kernel, submit a log and i'll try to look at it.

    The kernel's source code can be found here.

    And last but not least, a special thanks for those that helped me even if indirectly:

    3
    Alright, with the recently released V1.09 i now deem this kernel EOL, or at least, its 3.18 version since i will now be focusing on porting 4.4 to the LG MSM8996 family of devices alongside @askermk2000, since that tree is still being actively developed by linux-stable and also contains a slew of general improvements to both security and performance over the current 3.18 source that i don't think can be further optimized or fixed. The IR is still in need of fixing, but at this point i think starting fresh from a clean source might prove more beneficial to solve it than looking around the entire kernel source again. But if any issues with that new release crop up, do tell me and i will try to provide support.
    2
    The ir is most likely consumer ir related so, we'll have to tweak it until it starts working
    2
    Hello when I try to flash Swan-H918-Stable.zip on an h918 I get "Unsupported device. Aborting..."
    Huh... that's strange. I must have messed something up during the anykernel zipping procedure on that model. I'm almost pushing an update to the kernel, so i'll be back in a while with a fix for that.

    Edit: Yeah, it was something in the script file, i forgot to change the H910 to H918 on that specific variant flashable. Sorry for that.
    I just pushed the file with the fixed script for all the models i checked. If you could test that, i would appreciate it.
    2
    Wow this Kernel is amazing! Thermals improved massively and the V20 runs much faster and smoother now. I'm able to do things that were impossible before like browse the web while watching Youtube. Duck Duck Go used to stutter when clearing my data, now it does it smoothly.

    Everything is faster while somehow the phone runs much colder. I still need to test my GCam and if I can take a few photos without crashing.

    I'm using the H990DS with Lineage 18.1. During the throttle 1 core stayed at 70C while others were around 60-65C (I'm using a thermal pad).

    wMdy5DJ5brSFPd05n_mBKCwOhYVDJR6Vjzx0jZqG2CjSu49-ox1wbRIeKsg2K6bgNJtjgt6Wr5Vyz8wSr7gAFIMd4jDQeu067ZUeTe5swd1rRFwx0s6es5YfIWKimlNZLKGTHYdigwLbnzYgtBaOhIPXXQz1wrG0BCuzCI4mjY7A-4WaV3ek5ypESqSq_2JuSOVVNcul0m0d9VnlLB2tnlsBxuyhm5ZDiMi6L2BtMxJHtlFiCnCYLESRdCtuC-0zm5IZ6TgljsIbKyRNWpn7H8y_aGrq7AZ2z_G65lsKzAUuMVAFdCcmcOvBJ4QUL8Zzj_c_Vk7Ts1WPptem2Htmmyrp8AZ33cnis4tchiloGvkmbw5BLNY6GOzWuegjkM-hUFtGVwBs2O0lDD9JVQZSrP7xjedS8sAdYiVETEdVzKouF0d8lutIp7epGRFjWGD1jaTtd9-l3P9vVxYo_FJ5KRtJ-tlx-2FNGt1nj8OFQddH6vUBFxza_tZDV5SrJvcUDtcRe52ZWgUF2BQ8u5fZIh7ErO1da0f1kXv0s4-LlAyaZ6YXx0rIJZrEMEwTS7WwCOsnErw2ec_Hz6mxPK4jO4OPPee_m1LS1EQKN5A1-OLaf1JwqUrNMSU98IgAcF-AVSF7kY-Am7z8U_BJWAYxtc8yyFA42GQFRTMhIncu8KaShmOzBX_lazgHyjwJU477CYu_ES9uX6DCEQwT4jcklOcneQ=w497-h937-no

    I bought a V60 as a replacement but now I don't even need it anymore, it's a shame I can't refund it now. Amazing job and thanks for all the devs keeping this phone alive. Might try Lighthouse later but I'm lazy to back up all my data for migration.
    Thanks! Happy to know the kernel is being useful to others as well. And a bit of a spoiler (xxseva already hinted at it in a few places, lol), but there's definitely a lot more coming for the V20, G5 and G6, although i can't share many details about it nor a ETA of when it will arrive. But if/when it arrives, you can expect Android 12 with a kernel that's essentially the best parts of Swan and mk2000 mashed together.