diff options
| author | 2021-12-10 16:18:14 -0800 | |
|---|---|---|
| committer | 2022-01-21 04:27:41 -0800 | |
| commit | a295ebd5fc13f51f86329f5ed9e9dfcdf573b335 (patch) | |
| tree | 047757ebbce5b2c349fb01aa0f18cb6bc17fb2f2 | |
| parent | d73fb507c87e4a79d1a64104967526022471a180 (diff) | |
Small fixes to PowerProfile and ModemPowerProfile
Bug: 207697945
Test: atest PowerProfileTest
Change-Id: I48ee45efbbe8e2ac8e0d808dee50d2b216c41a01
4 files changed, 264 insertions, 70 deletions
diff --git a/core/java/com/android/internal/os/PowerProfile.java b/core/java/com/android/internal/os/PowerProfile.java index 7f8acccd72bb..54e65e079b83 100644 --- a/core/java/com/android/internal/os/PowerProfile.java +++ b/core/java/com/android/internal/os/PowerProfile.java @@ -274,16 +274,15 @@ public class PowerProfile { * [31:0] - per Subsystem fields, see {@link ModemPowerProfile}. * */ - private static final int SUBSYSTEM_SHIFT = 32; - private static final long SUBSYSTEM_MASK = 0xF << SUBSYSTEM_SHIFT; + private static final long SUBSYSTEM_MASK = 0xF_0000_0000L; /** * Power constant not associated with a subsystem. */ - public static final long SUBSYSTEM_NONE = 0 << SUBSYSTEM_SHIFT; + public static final long SUBSYSTEM_NONE = 0x0_0000_0000L; /** * Modem power constant. */ - public static final long SUBSYSTEM_MODEM = 1 << SUBSYSTEM_SHIFT; + public static final long SUBSYSTEM_MODEM = 0x1_0000_0000L; @LongDef(prefix = { "SUBSYSTEM_" }, value = { SUBSYSTEM_NONE, @@ -292,7 +291,7 @@ public class PowerProfile { @Retention(RetentionPolicy.SOURCE) public @interface Subsystem {} - private static final long SUBSYSTEM_FIELDS_MASK = 0xFFFFFFFF; + private static final long SUBSYSTEM_FIELDS_MASK = 0xFFFF_FFFF; /** * A map from Power Use Item to its power consumption. @@ -582,7 +581,7 @@ public class PowerProfile { handleDeprecatedModemConstant(ModemPowerProfile.MODEM_DRAIN_TYPE_SLEEP, POWER_MODEM_CONTROLLER_SLEEP, 0); handleDeprecatedModemConstant(ModemPowerProfile.MODEM_DRAIN_TYPE_IDLE, - POWER_MODEM_CONTROLLER_SLEEP, 0); + POWER_MODEM_CONTROLLER_IDLE, 0); handleDeprecatedModemConstant( ModemPowerProfile.MODEM_RAT_TYPE_DEFAULT | ModemPowerProfile.MODEM_DRAIN_TYPE_RX, POWER_MODEM_CONTROLLER_RX, 0); diff --git a/core/java/com/android/internal/power/ModemPowerProfile.java b/core/java/com/android/internal/power/ModemPowerProfile.java index 456ff4ba8a26..afea69a9c3f2 100644 --- a/core/java/com/android/internal/power/ModemPowerProfile.java +++ b/core/java/com/android/internal/power/ModemPowerProfile.java @@ -22,9 +22,9 @@ import android.telephony.ModemActivityInfo; import android.telephony.ServiceState; import android.telephony.TelephonyManager; import android.util.Slog; +import android.util.SparseArray; import android.util.SparseDoubleArray; -import com.android.internal.telephony.util.ArrayUtils; import com.android.internal.util.XmlUtils; import org.xmlpull.v1.XmlPullParser; @@ -64,34 +64,27 @@ public class ModemPowerProfile { */ private final SparseDoubleArray mPowerConstants = new SparseDoubleArray(); - private static final int MODEM_DRAIN_TYPE_SHIFT = 28; - private static final int MODEM_DRAIN_TYPE_MASK = 0xF << MODEM_DRAIN_TYPE_SHIFT; - - private static final int MODEM_TX_LEVEL_SHIFT = 24; - private static final int MODEM_TX_LEVEL_MASK = 0xF << MODEM_TX_LEVEL_SHIFT; - - private static final int MODEM_RAT_TYPE_SHIFT = 20; - private static final int MODEM_RAT_TYPE_MASK = 0xF << MODEM_RAT_TYPE_SHIFT; - - private static final int MODEM_NR_FREQUENCY_RANGE_SHIFT = 16; - private static final int MODEM_NR_FREQUENCY_RANGE_MASK = 0xF << MODEM_NR_FREQUENCY_RANGE_SHIFT; + private static final int MODEM_DRAIN_TYPE_MASK = 0xF000_0000; + private static final int MODEM_TX_LEVEL_MASK = 0x0F00_0000; + private static final int MODEM_RAT_TYPE_MASK = 0x00F0_0000; + private static final int MODEM_NR_FREQUENCY_RANGE_MASK = 0x000F_0000; /** * Corresponds to the overall modem battery drain while asleep. */ - public static final int MODEM_DRAIN_TYPE_SLEEP = 0 << MODEM_DRAIN_TYPE_SHIFT; + public static final int MODEM_DRAIN_TYPE_SLEEP = 0x0000_0000; /** * Corresponds to the overall modem battery drain while idle. */ - public static final int MODEM_DRAIN_TYPE_IDLE = 1 << MODEM_DRAIN_TYPE_SHIFT; + public static final int MODEM_DRAIN_TYPE_IDLE = 0x1000_0000; /** * Corresponds to the modem battery drain while receiving data. A specific Rx battery drain * power constant can be selected using a bitwise OR (|) with {@link ModemRatType} and * {@link ModemNrFrequencyRange} (when applicable). */ - public static final int MODEM_DRAIN_TYPE_RX = 2 << MODEM_DRAIN_TYPE_SHIFT; + public static final int MODEM_DRAIN_TYPE_RX = 0x2000_0000; /** * Corresponds to the modem battery drain while receiving data. @@ -99,7 +92,7 @@ public class ModemPowerProfile { * Specific Tx battery drain power constanta can be selected using a bitwise OR (|) with * {@link ModemRatType} and {@link ModemNrFrequencyRange} (when applicable). */ - public static final int MODEM_DRAIN_TYPE_TX = 3 << MODEM_DRAIN_TYPE_SHIFT; + public static final int MODEM_DRAIN_TYPE_TX = 0x3000_0000; @IntDef(prefix = {"MODEM_DRAIN_TYPE_"}, value = { MODEM_DRAIN_TYPE_SLEEP, @@ -111,33 +104,44 @@ public class ModemPowerProfile { public @interface ModemDrainType { } - private static final String[] MODEM_DRAIN_TYPE_NAMES = - new String[]{"SLEEP", "IDLE", "RX", "TX"}; + + private static final SparseArray<String> MODEM_DRAIN_TYPE_NAMES = new SparseArray<>(4); + static { + MODEM_DRAIN_TYPE_NAMES.put(MODEM_DRAIN_TYPE_SLEEP, "SLEEP"); + MODEM_DRAIN_TYPE_NAMES.put(MODEM_DRAIN_TYPE_IDLE, "IDLE"); + MODEM_DRAIN_TYPE_NAMES.put(MODEM_DRAIN_TYPE_RX, "RX"); + MODEM_DRAIN_TYPE_NAMES.put(MODEM_DRAIN_TYPE_TX, "TX"); + } /** * Corresponds to {@link ModemActivityInfo#TX_POWER_LEVEL_0}. */ - public static final int MODEM_TX_LEVEL_0 = 0 << MODEM_TX_LEVEL_SHIFT; + + public static final int MODEM_TX_LEVEL_0 = 0x0000_0000; /** * Corresponds to {@link ModemActivityInfo#TX_POWER_LEVEL_1}. */ - public static final int MODEM_TX_LEVEL_1 = 1 << MODEM_TX_LEVEL_SHIFT; + + public static final int MODEM_TX_LEVEL_1 = 0x0100_0000; /** * Corresponds to {@link ModemActivityInfo#TX_POWER_LEVEL_2}. */ - public static final int MODEM_TX_LEVEL_2 = 2 << MODEM_TX_LEVEL_SHIFT; + + public static final int MODEM_TX_LEVEL_2 = 0x0200_0000; /** * Corresponds to {@link ModemActivityInfo#TX_POWER_LEVEL_3}. */ - public static final int MODEM_TX_LEVEL_3 = 3 << MODEM_TX_LEVEL_SHIFT; + + public static final int MODEM_TX_LEVEL_3 = 0x0300_0000; /** * Corresponds to {@link ModemActivityInfo#TX_POWER_LEVEL_4}. */ - public static final int MODEM_TX_LEVEL_4 = 4 << MODEM_TX_LEVEL_SHIFT; + + public static final int MODEM_TX_LEVEL_4 = 0x0400_0000; private static final int MODEM_TX_LEVEL_COUNT = 5; @@ -152,21 +156,37 @@ public class ModemPowerProfile { public @interface ModemTxLevel { } + private static final SparseArray<String> MODEM_TX_LEVEL_NAMES = new SparseArray<>(5); + static { + MODEM_DRAIN_TYPE_NAMES.put(MODEM_TX_LEVEL_0, "0"); + MODEM_DRAIN_TYPE_NAMES.put(MODEM_TX_LEVEL_1, "1"); + MODEM_DRAIN_TYPE_NAMES.put(MODEM_TX_LEVEL_2, "2"); + MODEM_DRAIN_TYPE_NAMES.put(MODEM_TX_LEVEL_3, "3"); + MODEM_DRAIN_TYPE_NAMES.put(MODEM_TX_LEVEL_4, "4"); + } + + private static final int[] MODEM_TX_LEVEL_MAP = new int[]{ + MODEM_TX_LEVEL_0, + MODEM_TX_LEVEL_1, + MODEM_TX_LEVEL_2, + MODEM_TX_LEVEL_3, + MODEM_TX_LEVEL_4}; + /** * Fallback for any active modem usage that does not match specified Radio Access Technology * (RAT) power constants. */ - public static final int MODEM_RAT_TYPE_DEFAULT = 0 << MODEM_RAT_TYPE_SHIFT; + public static final int MODEM_RAT_TYPE_DEFAULT = 0x0000_0000; /** * Corresponds to active modem usage on 4G {@link TelephonyManager#NETWORK_TYPE_LTE} RAT. */ - public static final int MODEM_RAT_TYPE_LTE = 1 << MODEM_RAT_TYPE_SHIFT; + public static final int MODEM_RAT_TYPE_LTE = 0x0010_0000; /** * Corresponds to active modem usage on 5G {@link TelephonyManager#NETWORK_TYPE_NR} RAT. */ - public static final int MODEM_RAT_TYPE_NR = 2 << MODEM_RAT_TYPE_SHIFT; + public static final int MODEM_RAT_TYPE_NR = 0x0020_0000; @IntDef(prefix = {"MODEM_RAT_TYPE_"}, value = { MODEM_RAT_TYPE_DEFAULT, @@ -177,33 +197,38 @@ public class ModemPowerProfile { public @interface ModemRatType { } - private static final String[] MODEM_RAT_TYPE_NAMES = new String[]{"DEFAULT", "LTE", "NR"}; + private static final SparseArray<String> MODEM_RAT_TYPE_NAMES = new SparseArray<>(3); + static { + MODEM_RAT_TYPE_NAMES.put(MODEM_RAT_TYPE_DEFAULT, "DEFAULT"); + MODEM_RAT_TYPE_NAMES.put(MODEM_RAT_TYPE_LTE, "LTE"); + MODEM_RAT_TYPE_NAMES.put(MODEM_RAT_TYPE_NR, "NR"); + } /** * Fallback for any active 5G modem usage that does not match specified NR frequency power * constants. */ - public static final int MODEM_NR_FREQUENCY_RANGE_DEFAULT = 0 << MODEM_NR_FREQUENCY_RANGE_SHIFT; + public static final int MODEM_NR_FREQUENCY_RANGE_DEFAULT = 0x0000_0000; /** * Corresponds to active NR modem usage on {@link ServiceState#FREQUENCY_RANGE_LOW}. */ - public static final int MODEM_NR_FREQUENCY_RANGE_LOW = 1 << MODEM_NR_FREQUENCY_RANGE_SHIFT; + public static final int MODEM_NR_FREQUENCY_RANGE_LOW = 0x0001_0000; /** * Corresponds to active NR modem usage on {@link ServiceState#FREQUENCY_RANGE_MID}. */ - public static final int MODEM_NR_FREQUENCY_RANGE_MID = 2 << MODEM_NR_FREQUENCY_RANGE_SHIFT; + public static final int MODEM_NR_FREQUENCY_RANGE_MID = 0x0002_0000; /** * Corresponds to active NR modem usage on {@link ServiceState#FREQUENCY_RANGE_HIGH}. */ - public static final int MODEM_NR_FREQUENCY_RANGE_HIGH = 3 << MODEM_NR_FREQUENCY_RANGE_SHIFT; + public static final int MODEM_NR_FREQUENCY_RANGE_HIGH = 0x0003_0000; /** * Corresponds to active NR modem usage on {@link ServiceState#FREQUENCY_RANGE_MMWAVE}. */ - public static final int MODEM_NR_FREQUENCY_RANGE_MMWAVE = 4 << MODEM_NR_FREQUENCY_RANGE_SHIFT; + public static final int MODEM_NR_FREQUENCY_RANGE_MMWAVE = 0x0004_0000; @IntDef(prefix = {"MODEM_NR_FREQUENCY_RANGE_"}, value = { MODEM_RAT_TYPE_DEFAULT, @@ -215,9 +240,14 @@ public class ModemPowerProfile { @Retention(RetentionPolicy.SOURCE) public @interface ModemNrFrequencyRange { } - - private static final String[] MODEM_NR_FREQUENCY_RANGE_NAMES = - new String[]{"DEFAULT", "LOW", "MID", "HIGH", "MMWAVE"}; + private static final SparseArray<String> MODEM_NR_FREQUENCY_RANGE_NAMES = new SparseArray<>(5); + static { + MODEM_NR_FREQUENCY_RANGE_NAMES.put(MODEM_NR_FREQUENCY_RANGE_DEFAULT, "DEFAULT"); + MODEM_NR_FREQUENCY_RANGE_NAMES.put(MODEM_NR_FREQUENCY_RANGE_LOW, "LOW"); + MODEM_NR_FREQUENCY_RANGE_NAMES.put(MODEM_NR_FREQUENCY_RANGE_MID, "MID"); + MODEM_NR_FREQUENCY_RANGE_NAMES.put(MODEM_NR_FREQUENCY_RANGE_HIGH, "HIGH"); + MODEM_NR_FREQUENCY_RANGE_NAMES.put(MODEM_NR_FREQUENCY_RANGE_MMWAVE, "MMWAVE"); + } public ModemPowerProfile() { } @@ -261,11 +291,10 @@ public class ModemPowerProfile { final int ratType; final int nrfType; try { - ratType = getTypeFromAttribute(parser, ATTR_RAT, MODEM_RAT_TYPE_SHIFT, - MODEM_RAT_TYPE_NAMES); + ratType = getTypeFromAttribute(parser, ATTR_RAT, MODEM_RAT_TYPE_NAMES); if (ratType == MODEM_RAT_TYPE_NR) { nrfType = getTypeFromAttribute(parser, ATTR_NR_FREQUENCY, - MODEM_NR_FREQUENCY_RANGE_SHIFT, MODEM_NR_FREQUENCY_RANGE_NAMES); + MODEM_NR_FREQUENCY_RANGE_NAMES); } else { nrfType = 0; } @@ -299,10 +328,7 @@ public class ModemPowerProfile { MODEM_TX_LEVEL_COUNT - 1)); continue; } - final int modemTxLevel = level << MODEM_TX_LEVEL_SHIFT; - Slog.d("MWACHENS", - "parsing tx at level:" + level + ", aka 0x" + Integer.toHexString( - modemTxLevel)); + final int modemTxLevel = MODEM_TX_LEVEL_MAP[level]; final int txKey = MODEM_DRAIN_TYPE_TX | modemTxLevel | ratType | nrfType; setPowerConstant(txKey, txDrain); break; @@ -312,20 +338,31 @@ public class ModemPowerProfile { } } - private static int getTypeFromAttribute(XmlResourceParser parser, String attr, int shift, - String[] names) { + private static int getTypeFromAttribute(XmlResourceParser parser, String attr, + SparseArray<String> names) { final String value = XmlUtils.readStringAttribute(parser, attr); - final int index = ArrayUtils.indexOf(names, value); if (value == null) { // Attribute was not specified, just use the default. return 0; } + int index = -1; + final int size = names.size(); + // Manual linear search for string. (SparseArray uses == not equals.) + for (int i = 0; i < size; i++) { + if (value.equals(names.valueAt(i))) { + index = i; + } + } if (index < 0) { + final String[] stringNames = new String[size]; + for (int i = 0; i < size; i++) { + stringNames[i] = names.valueAt(i); + } throw new IllegalArgumentException( "Unexpected " + attr + " value : " + value + ". Acceptable values are " - + Arrays.toString(names)); + + Arrays.toString(stringNames)); } - return index << shift; + return names.keyAt(index); } /** @@ -384,39 +421,35 @@ public class ModemPowerProfile { private static String keyToString(int key) { StringBuilder sb = new StringBuilder(); final int drainType = key & MODEM_DRAIN_TYPE_MASK; - appendFieldToString(sb, "drain", MODEM_DRAIN_TYPE_NAMES, - drainType >> MODEM_DRAIN_TYPE_SHIFT); + appendFieldToString(sb, "drain", MODEM_DRAIN_TYPE_NAMES, drainType); sb.append(","); if (drainType == MODEM_DRAIN_TYPE_TX) { - final int txLevel = (key & MODEM_TX_LEVEL_MASK) >> MODEM_TX_LEVEL_SHIFT; - sb.append("level:"); - sb.append(txLevel); - sb.append(","); + final int txLevel = key & MODEM_TX_LEVEL_MASK; + appendFieldToString(sb, "level", MODEM_TX_LEVEL_NAMES, txLevel); } final int ratType = key & MODEM_RAT_TYPE_MASK; - appendFieldToString(sb, "RAT", MODEM_RAT_TYPE_NAMES, ratType >> MODEM_RAT_TYPE_SHIFT); + appendFieldToString(sb, "RAT", MODEM_RAT_TYPE_NAMES, ratType); if (ratType == MODEM_RAT_TYPE_NR) { sb.append(","); final int nrFreq = key & MODEM_NR_FREQUENCY_RANGE_MASK; - appendFieldToString(sb, "nrFreq", MODEM_NR_FREQUENCY_RANGE_NAMES, - nrFreq >> MODEM_NR_FREQUENCY_RANGE_SHIFT); + appendFieldToString(sb, "nrFreq", MODEM_NR_FREQUENCY_RANGE_NAMES, nrFreq); } return sb.toString(); } - - private static void appendFieldToString(StringBuilder sb, String fieldName, String[] names, - int index) { + private static void appendFieldToString(StringBuilder sb, String fieldName, + SparseArray<String> names, int key) { sb.append(fieldName); sb.append(":"); - if (index < 0 || index >= names.length) { - sb.append("UNKNOWN("); - sb.append(index); + final String name = names.get(key, null); + if (name == null) { + sb.append("UNKNOWN(0x"); + sb.append(Integer.toHexString(key)); sb.append(")"); } else { - sb.append(names[index]); + sb.append(name); } } diff --git a/core/tests/coretests/res/xml/power_profile_test.xml b/core/tests/coretests/res/xml/power_profile_test.xml new file mode 100644 index 000000000000..22571142a350 --- /dev/null +++ b/core/tests/coretests/res/xml/power_profile_test.xml @@ -0,0 +1,123 @@ +<?xml version="1.0" encoding="utf-8"?> +<!-- + ~ Copyright (C) 2022 The Android Open Source Project + ~ + ~ Licensed under the Apache License, Version 2.0 (the "License"); + ~ you may not use this file except in compliance with the License. + ~ You may obtain a copy of the License at + ~ + ~ http://www.apache.org/licenses/LICENSE-2.0 + ~ + ~ Unless required by applicable law or agreed to in writing, software + ~ distributed under the License is distributed on an "AS IS" BASIS, + ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + ~ See the License for the specific language governing permissions and + ~ limitations under the License. + --> + +<device name="Android"> + <!-- This is the battery capacity in mAh --> + <item name="battery.capacity">3000</item> + + <!-- Number of cores each CPU cluster contains --> + <array name="cpu.clusters.cores"> + <value>4</value> <!-- Cluster 0 has 4 cores (cpu0, cpu1, cpu2, cpu3) --> + <value>4</value> <!-- Cluster 1 has 4 cores (cpu4, cpu5, cpu5, cpu7) --> + </array> + + <!-- Power consumption when CPU is suspended --> + <item name="cpu.suspend">5</item> + <!-- Additional power consumption when CPU is in a kernel idle loop --> + <item name="cpu.idle">1.11</item> + <!-- Additional power consumption by CPU excluding cluster and core when running --> + <item name="cpu.active">2.55</item> + + <!-- Additional power consumption by CPU cluster0 itself when running excluding cores in it --> + <item name="cpu.cluster_power.cluster0">2.11</item> + <!-- Additional power consumption by CPU cluster1 itself when running excluding cores in it --> + <item name="cpu.cluster_power.cluster1">2.22</item> + + <!-- Different CPU speeds as reported in + /sys/devices/system/cpu/cpu0/cpufreq/stats/scaling_available_frequencies --> + <array name="cpu.core_speeds.cluster0"> + <value>300000</value> <!-- 300 MHz CPU speed --> + <value>1000000</value> <!-- 1000 MHz CPU speed --> + <value>2000000</value> <!-- 2000 MHz CPU speed --> + </array> + <!-- Different CPU speeds as reported in + /sys/devices/system/cpu/cpu4/cpufreq/stats/scaling_available_frequencies --> + <array name="cpu.core_speeds.cluster1"> + <value>300000</value> <!-- 300 MHz CPU speed --> + <value>1000000</value> <!-- 1000 MHz CPU speed --> + <value>2500000</value> <!-- 2500 MHz CPU speed --> + <value>3000000</value> <!-- 3000 MHz CPU speed --> + </array> + + <!-- Additional power used by a CPU from cluster 0 when running at different + speeds. Currently this measurement also includes cluster cost. --> + <array name="cpu.core_power.cluster0"> + <value>10</value> <!-- 300 MHz CPU speed --> + <value>20</value> <!-- 1000 MHz CPU speed --> + <value>30</value> <!-- 1900 MHz CPU speed --> + </array> + <!-- Additional power used by a CPU from cluster 1 when running at different + speeds. Currently this measurement also includes cluster cost. --> + <array name="cpu.core_power.cluster1"> + <value>25</value> <!-- 300 MHz CPU speed --> + <value>35</value> <!-- 1000 MHz CPU speed --> + <value>50</value> <!-- 2500 MHz CPU speed --> + <value>60</value> <!-- 3000 MHz CPU speed --> + </array> + + <!-- Power used by display unit in ambient display mode, including back lighting--> + <item name="ambient.on">0.5</item> + <!-- Additional power used when screen is turned on at minimum brightness --> + <item name="screen.on">100</item> + <!-- Additional power used when screen is at maximum brightness, compared to + screen at minimum brightness --> + <item name="screen.full">800</item> + + <!-- Average power used by the camera flash module when on --> + <item name="camera.flashlight">500</item> + <!-- Average power use by the camera subsystem for a typical camera + application. Intended as a rough estimate for an application running a + preview and capturing approximately 10 full-resolution pictures per + minute. --> + <item name="camera.avg">600</item> + + <!-- Additional power used by the audio hardware, probably due to DSP --> + <item name="audio">100.0</item> + + <!-- Additional power used by the video hardware, probably due to DSP --> + <item name="video">150.0</item> <!-- ~50mA --> + + <!-- Additional power used when GPS is acquiring a signal --> + <item name="gps.on">10</item> + + <!-- Additional power used when cellular radio is transmitting/receiving --> + <item name="radio.active">60</item> + <!-- Additional power used when cellular radio is paging the tower --> + <item name="radio.scanning">3</item> + <!-- Additional power used when the cellular radio is on. Multi-value entry, + one per signal strength (no signal, weak, moderate, strong) --> + <array name="radio.on"> <!-- Strength 0 to BINS-1 --> + <value>6</value> <!-- none --> + <value>5</value> <!-- poor --> + <value>4</value> <!-- moderate --> + <value>3</value> <!-- good --> + <value>3</value> <!-- great --> + </array> + + <!-- Cellular modem related values. These constants are deprecated, but still supported and + need to be tested --> + <item name="modem.controller.sleep">123</item> + <item name="modem.controller.idle">456</item> + <item name="modem.controller.rx">789</item> + <array name="modem.controller.tx"> <!-- Strength 0 to 4 --> + <value>10</value> + <value>20</value> + <value>30</value> + <value>40</value> + <value>50</value> + </array> +</device>
\ No newline at end of file diff --git a/core/tests/coretests/src/com/android/internal/os/PowerProfileTest.java b/core/tests/coretests/src/com/android/internal/os/PowerProfileTest.java index 1efd78bc13fc..bc3b4229f5e5 100644 --- a/core/tests/coretests/src/com/android/internal/os/PowerProfileTest.java +++ b/core/tests/coretests/src/com/android/internal/os/PowerProfileTest.java @@ -57,11 +57,13 @@ public class PowerProfileTest extends TestCase { @Before public void setUp() { mContext = InstrumentationRegistry.getContext(); - mProfile = new PowerProfile(mContext, true); + mProfile = new PowerProfile(mContext); } @Test public void testPowerProfile() { + mProfile.forceInitForTesting(mContext, R.xml.power_profile_test); + assertEquals(2, mProfile.getNumCpuClusters()); assertEquals(4, mProfile.getNumCoresInCpuCluster(0)); assertEquals(4, mProfile.getNumCoresInCpuCluster(1)); @@ -83,6 +85,43 @@ public class PowerProfileTest extends TestCase { mProfile.getAveragePowerForOrdinal(POWER_GROUP_DISPLAY_SCREEN_FULL, 0)); assertEquals(100.0, mProfile.getAveragePower(PowerProfile.POWER_AUDIO)); assertEquals(150.0, mProfile.getAveragePower(PowerProfile.POWER_VIDEO)); + + assertEquals(123.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_SLEEP)); + assertEquals(456.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_IDLE)); + assertEquals(789.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_RX)); + assertEquals(10.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_TX, 0)); + assertEquals(20.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_TX, 1)); + assertEquals(30.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_TX, 2)); + assertEquals(40.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_TX, 3)); + assertEquals(50.0, mProfile.getAveragePower(PowerProfile.POWER_MODEM_CONTROLLER_TX, 4)); + + // Deprecated Modem constants should work with current format. + assertEquals(123.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_DRAIN_TYPE_SLEEP)); + assertEquals(456.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_DRAIN_TYPE_IDLE)); + assertEquals(789.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_DRAIN_TYPE_RX)); + assertEquals(10.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_RAT_TYPE_DEFAULT + | ModemPowerProfile.MODEM_DRAIN_TYPE_TX + | ModemPowerProfile.MODEM_TX_LEVEL_0)); + assertEquals(20.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_RAT_TYPE_DEFAULT + | ModemPowerProfile.MODEM_DRAIN_TYPE_TX + | ModemPowerProfile.MODEM_TX_LEVEL_1)); + assertEquals(30.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_RAT_TYPE_DEFAULT + | ModemPowerProfile.MODEM_DRAIN_TYPE_TX + | ModemPowerProfile.MODEM_TX_LEVEL_2)); + assertEquals(40.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_RAT_TYPE_DEFAULT + | ModemPowerProfile.MODEM_DRAIN_TYPE_TX + | ModemPowerProfile.MODEM_TX_LEVEL_3)); + assertEquals(50.0, mProfile.getAverageBatteryDrainMa( + PowerProfile.SUBSYSTEM_MODEM | ModemPowerProfile.MODEM_RAT_TYPE_DEFAULT + | ModemPowerProfile.MODEM_DRAIN_TYPE_TX + | ModemPowerProfile.MODEM_TX_LEVEL_4)); } @Test |