Post Reply

[KERNEL][AOSP4.4/TW4.1/TW4.3] dkp - d2att - 9/30/14

9th April 2013, 01:35 AM   |  #1  
decimalman's Avatar
OP Senior Member
Thanks Meter: 2,916
 
1,063 posts
Join Date:Joined: Nov 2012
Donate to Me
More
Welcome to decimalman's kernel playground!

As the name suggests, dkp is a hodgepodge of features and tweaks that I wanted to play with. It should get excellent battery life without feeling sluggish. It doesn't come with its own tuner app, so pick your favorite. I go out of my way to support Trickster MOD, but most other apps work well.

Features:
  • Overclocking up to 2.1 GHz, but you'll need to increase your voltages to get there (if you can get there at all)
  • Underclocking down to 54 MHz, with stability improvements
  • Undervolting compatible with most apps
  • Fast charge without unplugging first
  • Glorious animations for the notification and softkey LEDs
  • Well-integrated erandom means you don't need CrossBreeder or Seeder (recent AOSP builds use ISAAC instead)
  • freelunch governor provides a good compromise between battery life and performance
  • Automatic mpdecision and auto-hotplug are only enabled when needed
  • Adjustable minimum voltage for stability on finicky processors
  • exFAT support for 64GB SD cards
  • Optimized UKSM to free up some extra memory
  • Code optimizations for size and speed
  • Compiler optimizations (-O3, LTO, and more) because faster is better

Donors: Thanks, everyone! Your generosity is much appreciated.
drpenguino, 0xScott, vmancini3 (twice! ), Ch4m3l30n, rompnit, Mystique, ryandubbz, techdog

Remember:
  • Nandroid!
  • last_kmsg and/or logcat or it didn't happen.
  • Other kernels have their own threads or forums. Discuss them there.
  • Image dumps (settings, battery life, whatever) belong inside [HIDE][/HIDE] (that's HIDE, if you're on the mobile app) tags.
  • Be silly. We're here to have fun.

Installation:
  1. Reboot to recovery. I recommend that one recovery...you know, the one that flashes zips? I forget what it's called.
  2. Flash dkp. Optionally, rename and flash dkp-vmin-XXX.zip (see below).
  3. Reboot.

Undervolting:
Undervolting on dkp is more complex than other kernels. Some processors get unstable at lower voltages, so (like the stock kernel) dkp keeps the processor voltage above 1150 mV by default. I refer to this limit as the minimum voltage. In order to undervolt, you'll need to lower the minimum voltage: if you use Trickster MOD, just disable "Override Minimum Voltage" in the "Specific" page, otherwise rename dkp-vmin-XXX.zip to e.g. dkp-vmin-600.zip (which would apply a 600 mV minimum voltage) and flash it. If this causes instability (crashes, audio/video glitches, etc.), try using dkp-vmin-XXX.zip to apply a higher minimum voltage (somewhere between 950 and 1050 mV seems to work well for most people).

Downloads:
Downloads: thanks to xstefen for providing hosting!

dkp-vmin-XXX.zip

Downloads (MediaFire mirror)

dkp-vmin-XXX.zip (MediaFire mirror)

Really old downloads

Source: I'm always happy to see my code used, so cherry-pick away. I'll even put together feature patches if you ask nicely.
Last edited by decimalman; Yesterday at 02:41 AM.
The Following 65 Users Say Thank You to decimalman For This Useful Post: [ View ]
9th April 2013, 01:36 AM   |  #2  
decimalman's Avatar
OP Senior Member
Thanks Meter: 2,916
 
1,063 posts
Join Date:Joined: Nov 2012
Donate to Me
More
Bugs:
Let me know.

Stable changelog:
3/3/13: Initial release for d2spr. Didn't get around to making threads for other carriers.
4/8/13 (3.0):
  • FauxSound support
  • Strip more useless stuff
  • A few bonus optimizations
4/8/13 (3.4):
  • Port everything except erandom from 3.0
  • Enhance cpufreq for easier configuration
4/24/13 (3.4):
  • Bugfixes: better support for tuner apps, fixed potential SOD bugs, automatic mpdecision fixups, etc.
  • Lots of CM/CAF/Linux updates
  • Working AssWax governor
  • Trinity colors support
  • sio, zen I/O schedulers
  • erandom is back!
  • Built with a super-fancy Linaro GCC 4.8.1-dev compiler toolchain for maximum -O3 goodness
  • Probably lots more, but there's hundreds of commits to sort through...
5/29/13 (3.4):
  • Bugfixes: better overclocking support, better hwrng support, etc.
  • Updates: new CM updates, Linux 3.4.47, updated FauxSound driver, added invisiblek's new panel colors interface
  • Automatic auto-hotplug
  • New optimizations, including link-time optimization and an updated GNU+Linaro GCC 4.8.1-dev toolchain
6/14/13 (3.4):
  • Bugfixes: fix several critical bugs in the 5/29 release.
9/7/13 (3.4):
  • Fixes for OC, UV, auto-hotplug.
  • A few new optimizations.
  • Synced up with CM.
9/20/13 (TW):
  • Ported everything from AOSP to TW.
9/20/13 (4.3):
  • Merged 4.3 from CM into the existing 4.2 code.

Current experimental branches:
  • Nothing interesting at the moment.
Last edited by decimalman; 21st September 2013 at 01:29 AM.
The Following 11 Users Say Thank You to decimalman For This Useful Post: [ View ]
9th April 2013, 01:36 AM   |  #3  
decimalman's Avatar
OP Senior Member
Thanks Meter: 2,916
 
1,063 posts
Join Date:Joined: Nov 2012
Donate to Me
More
Goodies:
dkp doesn't come with its own splash screen. However, the dkp installer (i.e. the install zip) is smarter than you think, and can apply a custom splash screen for you. Here's how:
  1. Create a folder on your internal storage named "dkp"
  2. Copy a PNG image into the directory, and rename it "splash.png". Alternatively, copy an RLE image (i.e. from a flashable custom splash screen zip) and rename it "splash.rle". Ideally, the image should be roughly 1280x720 to begin with, since it won't be resized.
  3. The image will be used as your splash screen whenever you flash dkp. Reflash to apply initially.

mikedavis120 has put together a how-to video that covers tweaking dkp for optimal battery life. If you're new to dkp, take a look! He also put together a zipped collection of apps that will come in handy while tuning dkp. It also includes a flashable zip, "dkp-debug_v1.zip". After flashing it, running
Code:
su
dkp
from a terminal emulator will collect lots of useful debug information that will make it much easier for me to track down the issue you're having. mikedavis120 recommends installing SuperSU (included in the zip) instead of what's included in you ROM.



sysfs:
 

It's possible to adjust all the settings available in dkp without using apps. Because they show up as files, settings can be adjusted with file managers, terminal emulators, adb and initscripts. Here's the most interesting files inside sysfs:
  • /sys/devices/platform/mipi_samsung_oled.513/lcd/panel/panel_colors: display tint (0 = very red, 2 = default, 4 = trinity colors)
  • /sys/devices/system/cpu/cpu<N>/cpufreq/UV_mV_table: voltage table
  • /sys/devices/system/cpu/cpu<N>/cpufreq/scaling_...: scaling_governor is the governor, scaling_min_freq and scaling_max_freq are the minimum and maximum frequencies, scaling_available_governors and scaling_available_frequencies show the available governors and frequencies
  • /sys/kernel/dkp/force_fast_charge: fast charge
  • /sys/kernel/dkp/link_core_settings: when linked (the default), frequency settings and some governors are automatically copied to the other core
  • /sys/kernel/dkp/vmin: minimum processor voltage in mV
  • /sys/kernel/mm/uksm/run: activate UKSM


auto-hotplug tuners:
 

These show up in the governor settings for any governor that doesn't do its own hotplugging. They only take effect when using auto-hotplug, so you'll probably need to disable mpdecision in Trickster.
  • hotplug_intpulse: when set to 1, automatically turns core 2 on whenever the screen/buttons/whatever is pressed. Default is 0.
  • hotplug_sampling_periods: number of samples to use for average number of running tasks. Default is 15.
  • hotplug_sampling_rate: number of 'jiffies' (currently 1 jiffy = 10 ms) between each sample of running tasks. Default is 20 (0.2 sec).
  • hotplug_enable_one_threshold: the average number of running tasks required to turn core 2 on, multiplied by 100. Default is 125 (1.25 tasks on average).
  • hotplug_disable_one_threshold: the average number of running tasks required to keep core 2 on, multiplied by 100. Default is 250 (2.5 tasks on average).


freelunch/nanolunch tuners:
 

freelunch and nanolunch aren't materially based on other governors, so their configuration is quite different than other governors. There's lots of tuners, since I haven't really decided on an ideal tuning. I encourage experimentation! I'll explain a bit of how these governors work before actually listing the tuners.

Generally speaking, there are two modes: in "normal" mode, sampling is done occasionally and frequency is generally increased slowly; in "interactive" mode, sampling is done much more quickly, and frequency increases much more quickly. "Interactive" mode ends after several samples of very low usage. The idea of a "hispeed" frequency is used in lots of governors, and it refers to the frequency that the CPU will jump to when more CPU usage is needed; generally, it's a generous estimate of how much CPU will be needed. Here, the hispeed frequency is adjusted on-the-fly, increasing when more CPU is needed and gradually decreasing when the CPU is idle. In "interactive" mode, the hispeed frequency is kept fairly high so that everything will feel snappy.

Hotplugging is taken care of in the least complicated (and in my opinion, most reasonable) way possible: if core 1 is using lots of CPU, and there are several tasks running (in other words, if it's likely that core 2 will have something to do), core 2 is turned on; if either core isn't doing much except using power, core 2 is turned off.
  • sampling_rate: the usual
  • hotplug_up_cycles: number of consecutive heavily-loaded samples before core 2 is turned on
  • hotplug_down_cycles: number of consecutive lightly-loaded samples before core 2 is turned off
  • hotplug_up_load: number of running tasks required to bring core 2 online
  • hotplug_up_usage: number of used CPU cycles (in thousands per second) required to bring core 2 online
  • hotplug_down_usage: number of used CPU cycles (in thousands per second) required on both cores to keep core 2 online
  • overestimate_khz: number of CPU cycles to overshoot usage by in "normal" mode
  • hispeed_thresh: if CPU usage is within this many cycles (in thousands per second) of the maximum frequency, frequency will be increased to the hispeed frequency. Generally, hispeed is pretty low in "normal" mode, and fairly high in "interactive" mode.
  • hispeed_decrease: when the CPU is sitting idle, the hispeed frequency is decreased by this amount each sample (this isn't ideal, but it works)
  • interaction_hispeed: the initial hispeed frequency when switching to "interactive" mode
  • interaction_return_cycles: number of consecutive lightly-loaded samples before returning to "normal" mode
  • interaction_return_usage: number of used CPU cycles (in thousands per second) required to stay in "interactive" mode
  • interaction_panic (nanolunch only): when set to 1, allows aggressively jumping past the current hispeed frequency under some circumstances
  • interaction_sampling_rate/overestimate_khz: equivalent to the "normal" versions of the tuners, these take effect in "interactive" mode
Last edited by decimalman; 25th September 2014 at 05:46 AM.
The Following 7 Users Say Thank You to decimalman For This Useful Post: [ View ]
9th April 2013, 01:48 AM   |  #4  
pingfl00d's Avatar
Senior Member
Thanks Meter: 18
 
190 posts
Join Date:Joined: Nov 2011
Just loaded it on pa 3.15

Sent from my SAMSUNG-SGH-I747 using xda premium
9th April 2013, 03:27 AM   |  #5  
Senior Member
Thanks Meter: 247
 
1,061 posts
Join Date:Joined: Sep 2012
It doesn't say that it has morfic colors, but looks like it does. Gonna give it a whirl

Sent from my SGH-I747 using xda app-developers app
9th April 2013, 03:35 AM   |  #6  
decimalman's Avatar
OP Senior Member
Thanks Meter: 2,916
 
1,063 posts
Join Date:Joined: Nov 2012
Donate to Me
More
Quote:
Originally Posted by rmead01

It doesn't say that it has morfic colors, but looks like it does. Gonna give it a whirl

Sent from my SGH-I747 using xda app-developers app

It doesn't, but I'll merge it and put out a test build.
The Following User Says Thank You to decimalman For This Useful Post: [ View ]
9th April 2013, 03:41 AM   |  #7  
Senior Member
Thanks Meter: 247
 
1,061 posts
Join Date:Joined: Sep 2012
Quote:
Originally Posted by decimalman

It doesn't, but I'll merge it and put out a test build.

Is it possible they are left over from a previous kernel? Because I can def tell the difference usually and seems like it does.

Either way, advise when its updated. This governor seems solid so far.

Sent from my SGH-I747 using xda app-developers app
9th April 2013, 04:34 AM   |  #8  
decimalman's Avatar
OP Senior Member
Thanks Meter: 2,916
 
1,063 posts
Join Date:Joined: Nov 2012
Donate to Me
More
Quote:
Originally Posted by rmead01

Is it possible they are left over from a previous kernel? Because I can def tell the difference usually and seems like it does.

Either way, advise when its updated. This governor seems solid so far.

Sent from my SGH-I747 using xda app-developers app

dkp is based off clean CM source, so it shouldn't have been merged already.

I've got test builds compiling now, and the 3.4 builds will be up shortly. Flashing the trinity-colors test build and this zip will enable trinity colors. You can toggle it with
Code:
su
echo X >/sys/class/mdnie/mdnie/trinity_colors
where X is 0 to disable or 1 to enable.

Edit: and sorry for taking so long to respond.
Edit 2: 3.4 builds are up. http://d-h.st/7Ae
Last edited by decimalman; 9th April 2013 at 04:42 AM.
The Following 2 Users Say Thank You to decimalman For This Useful Post: [ View ]
9th April 2013, 08:45 AM   |  #9  
jayRokk's Avatar
Senior Member
Flag Rack City
Thanks Meter: 2,047
 
2,941 posts
Join Date:Joined: Jan 2012
More
Thnx for this kernel
9th April 2013, 12:50 PM   |  #10  
Senior Member
Thanks Meter: 247
 
1,061 posts
Join Date:Joined: Sep 2012
Quote:
Originally Posted by decimalman

dkp is based off clean CM source, so it shouldn't have been merged already.

I've got test builds compiling now, and the 3.4 builds will be up shortly. Flashing the trinity-colors test build and this zip will enable trinity colors. You can toggle it with

Code:
su
echo X >/sys/class/mdnie/mdnie/trinity_colors
where X is 0 to disable or 1 to enable.

Edit: and sorry for taking so long to respond.
Edit 2: 3.4 builds are up. http://d-h.st/7Ae

Maybe I was just seeing things, had just watched jurassic park in 3d.

New "test" build flashed as well as the file to enable it. Thanks for the addition. It's very hard to go back to normal once you've been smurfed depending on your display.


Only issue i'm having ATM is the ability to change the voltage table. My phone doesn't handle undervolting as well and i run a minimum of 950 baseline, if not 975. One of my normal apps wasn't able to set the voltage at all. I'm trying to use performance control which I don't like. It crashes trying to set the voltage on boot but at least I can go in and manually set the values on boot and they stick.

One last question, since this is your kernel, what scheduler do you recommend pairs well to freelunch? What would you use for performance and what would you use for batt?
Last edited by rmead01; 9th April 2013 at 12:54 PM.

Post Reply Subscribe to Thread

Tags
aosp, battery, kernel
Previous Thread Next Thread
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes