Progress Report 2014/05/23
Different Applications Run different applications on ODROID board and observe the loading and power reading. Type 1 big.LITTLE core board Applications including Video Game Mobile benchmarks
Video - .rmvb
Video - .mkv
Observations The CPU loadings vary from one media player to the other on playing the same video. A media player results in different CPU loading while playing videos with different format.
Game - Angry Bird
Observation There are many “peaks of loading”. Probably caused by user behaviors.
Benchmark - Antutu
Benchmark - Quadrant
Benchmark - Vellamo
Short Summary It is difficult to predict or estimate the behavior of each task in the system during runtime.
Scheduler in Hypervisor Instead of focusing on scheduling tasks to (virtual) cores in one OS, we can consider scheduling virtual cores to physical cores from the hypervisor perspective.
Problem Given a set of VMs, each VM has several virtual cores with different frequencies. How to schedule these virtual cores to a set of big and little physical cores, such that each virtual core is can have sufficient computing cycles in a fixed time interval.
Core Model Need to build the Loading-to-Power model of big and little core. Decide which is better, “separate” or “consolidate” Run bzip2 and busyAdding using one big or little core, and measure the power consumption. Use cpulimit to cap the loading of task.
Result – bzip2
Result - busyAdding
Short Summary The power consumption is almost linear to the loading. Even the loading is the same, the power consumption is slightly higher while executing bzip2 than busyAdding. Probably the power consumed by cache or other components on core.
Current Idea “Big vCPUs to big ARM cores, little vCPUs to little ARM cores”. If big ARM cores can not provide enough CPU resource, then consider schedule big vCPUs on both big and little ARM cores. Note that we can “slice” a core.