Loading core/java/android/os/BatteryUsageStats.java +13 −4 Original line number Diff line number Diff line Loading @@ -127,6 +127,7 @@ public final class BatteryUsageStats implements Parcelable { private final AggregateBatteryConsumer[] mAggregateBatteryConsumers; private final Parcel mHistoryBuffer; private final List<BatteryStats.HistoryTag> mHistoryTagPool; private final BatteryStatsHistory mBatteryStatsHistory; private BatteryUsageStats(@NonNull Builder builder) { mStatsStartTimestampMs = builder.mStatsStartTimestampMs; Loading @@ -138,6 +139,7 @@ public final class BatteryUsageStats implements Parcelable { mDischargedPowerUpperBound = builder.mDischargedPowerUpperBoundMah; mHistoryBuffer = builder.mHistoryBuffer; mHistoryTagPool = builder.mHistoryTagPool; mBatteryStatsHistory = builder.mBatteryStatsHistory; mBatteryTimeRemainingMs = builder.mBatteryTimeRemainingMs; mChargeTimeRemainingMs = builder.mChargeTimeRemainingMs; mCustomPowerComponentNames = builder.mCustomPowerComponentNames; Loading Loading @@ -289,8 +291,8 @@ public final class BatteryUsageStats implements Parcelable { throw new IllegalStateException( "Battery history was not requested in the BatteryUsageStatsQuery"); } return new BatteryStatsHistoryIterator(new BatteryStatsHistory(mHistoryBuffer), mHistoryTagPool); return new BatteryStatsHistoryIterator(mBatteryStatsHistory, mHistoryTagPool); } @Override Loading Loading @@ -356,7 +358,10 @@ public final class BatteryUsageStats implements Parcelable { tag.poolIdx = source.readInt(); mHistoryTagPool.add(tag); } mBatteryStatsHistory = new BatteryStatsHistory(mHistoryBuffer); mBatteryStatsHistory.readFromBatteryUsageStatsParcel(source); } else { mBatteryStatsHistory = null; mHistoryBuffer = null; mHistoryTagPool = null; } Loading Loading @@ -404,6 +409,7 @@ public final class BatteryUsageStats implements Parcelable { dest.writeInt(tag.uid); dest.writeInt(tag.poolIdx); } mBatteryStatsHistory.writeToBatteryUsageStatsParcel(dest); } else { dest.writeBoolean(false); } Loading Loading @@ -757,6 +763,7 @@ public final class BatteryUsageStats implements Parcelable { new SparseArray<>(); private Parcel mHistoryBuffer; private List<BatteryStats.HistoryTag> mHistoryTagPool; private BatteryStatsHistory mBatteryStatsHistory; public Builder(@NonNull String[] customPowerComponentNames) { this(customPowerComponentNames, false); Loading Loading @@ -865,10 +872,12 @@ public final class BatteryUsageStats implements Parcelable { * Sets the parceled recent history. */ @NonNull public Builder setBatteryHistory(Parcel historyBuffer, List<BatteryStats.HistoryTag> historyTagPool) { public Builder setBatteryHistory(@NonNull Parcel historyBuffer, @NonNull List<BatteryStats.HistoryTag> historyTagPool, @NonNull BatteryStatsHistory batteryStatsHistory) { mHistoryBuffer = historyBuffer; mHistoryTagPool = historyTagPool; mBatteryStatsHistory = batteryStatsHistory; return this; } Loading core/java/com/android/internal/os/BatteryStatsHistory.java +41 −8 Original line number Diff line number Diff line Loading @@ -160,6 +160,11 @@ public class BatteryStatsHistory { mHistoryDir = null; mHistoryBuffer = historyBuffer; } public File getHistoryDirectory() { return mHistoryDir; } /** * Set the active file that mHistoryBuffer is backed up into. * Loading Loading @@ -374,13 +379,25 @@ public class BatteryStatsHistory { return true; } /** * Read all history files and serialize into a big Parcel. * Checkin file calls this method. * @param out the output parcel */ public void writeToParcel(Parcel out) { writeToParcel(out, false /* useBlobs */); } /** * Read all history files and serialize into a big Parcel. This is to send history files to * Settings app since Settings app can not access /data/system directory. * Checkin file also call this method. * @param out the output parcel */ public void writeToParcel(Parcel out) { public void writeToBatteryUsageStatsParcel(Parcel out) { writeToParcel(out, true /* useBlobs */); } private void writeToParcel(Parcel out, boolean useBlobs) { final long start = SystemClock.uptimeMillis(); out.writeInt(mFileNumbers.size() - 1); for(int i = 0; i < mFileNumbers.size() - 1; i++) { Loading @@ -391,26 +408,42 @@ public class BatteryStatsHistory { } catch(Exception e) { Slog.e(TAG, "Error reading file "+ file.getBaseFile().getPath(), e); } if (useBlobs) { out.writeBlob(raw); } else { // Avoiding blobs in the check-in file for compatibility out.writeByteArray(raw); } } if (DEBUG) { Slog.d(TAG, "writeToParcel duration ms:" + (SystemClock.uptimeMillis() - start)); } } /** * This is for Settings app, when Settings app receives big history parcel, it call * this method to parse it into list of parcels. * Checkin file also call this method. * This is for the check-in file, which has all history files embedded. * @param in the input parcel. */ public void readFromParcel(Parcel in) { readFromParcel(in, false /* useBlobs */); } /** * This is for Settings app, when Settings app receives big history parcel, it calls * this method to parse it into list of parcels. * @param in the input parcel. */ public void readFromBatteryUsageStatsParcel(Parcel in) { readFromParcel(in, true /* useBlobs */); } private void readFromParcel(Parcel in, boolean useBlobs) { final long start = SystemClock.uptimeMillis(); mHistoryParcels = new ArrayList<>(); final int count = in.readInt(); for(int i = 0; i < count; i++) { byte[] temp = in.createByteArray(); if (temp.length == 0) { byte[] temp = useBlobs ? in.readBlob() : in.createByteArray(); if (temp == null || temp.length == 0) { continue; } Parcel p = Parcel.obtain(); Loading core/java/com/android/internal/os/BatteryStatsImpl.java +11 −2 Original line number Diff line number Diff line Loading @@ -1200,12 +1200,21 @@ public class BatteryStatsImpl extends BatteryStats { } public BatteryStatsImpl(Clocks clocks) { this(clocks, (File) null); } public BatteryStatsImpl(Clocks clocks, File historyDirectory) { init(clocks); mStartClockTimeMs = clocks.currentTimeMillis(); mStatsFile = null; mCheckinFile = null; mDailyFile = null; if (historyDirectory == null) { mStatsFile = null; mBatteryStatsHistory = new BatteryStatsHistory(mHistoryBuffer); } else { mStatsFile = new AtomicFile(new File(historyDirectory, "batterystats.bin")); mBatteryStatsHistory = new BatteryStatsHistory(this, historyDirectory, mHistoryBuffer); } mHandler = null; mPlatformIdleStateCallback = null; mMeasuredEnergyRetriever = null; Loading core/java/com/android/internal/os/BatteryUsageStatsProvider.java +7 −1 Original line number Diff line number Diff line Loading @@ -29,6 +29,7 @@ import android.util.SparseArray; import com.android.internal.annotations.VisibleForTesting; import java.io.File; import java.util.ArrayList; import java.util.Arrays; import java.util.List; Loading Loading @@ -203,7 +204,12 @@ public class BatteryUsageStatsProvider { tags.add(tag); } batteryUsageStatsBuilder.setBatteryHistory(historyBuffer, tags); final File systemDir = batteryStatsImpl.mBatteryStatsHistory.getHistoryDirectory().getParentFile(); final BatteryStatsHistory batteryStatsHistory = new BatteryStatsHistory(batteryStatsImpl, systemDir, historyBuffer); batteryUsageStatsBuilder.setBatteryHistory(historyBuffer, tags, batteryStatsHistory); } return batteryUsageStatsBuilder.build(); Loading core/tests/coretests/src/com/android/internal/os/BatteryUsageStatsProviderTest.java +6 −1 Original line number Diff line number Diff line Loading @@ -39,6 +39,8 @@ import androidx.test.InstrumentationRegistry; import androidx.test.filters.SmallTest; import androidx.test.runner.AndroidJUnit4; import libcore.testing.io.TestIoUtils; import org.junit.Rule; import org.junit.Test; import org.junit.runner.RunWith; Loading @@ -52,8 +54,11 @@ public class BatteryUsageStatsProviderTest { private static final int APP_UID = Process.FIRST_APPLICATION_UID + 42; private static final long MINUTE_IN_MS = 60 * 1000; private final File mHistoryDir = TestIoUtils.createTemporaryDirectory(getClass().getSimpleName()); @Rule public final BatteryUsageStatsRule mStatsRule = new BatteryUsageStatsRule(12345) public final BatteryUsageStatsRule mStatsRule = new BatteryUsageStatsRule(12345, mHistoryDir) .setAveragePower(PowerProfile.POWER_FLASHLIGHT, 360.0); @Test Loading Loading
core/java/android/os/BatteryUsageStats.java +13 −4 Original line number Diff line number Diff line Loading @@ -127,6 +127,7 @@ public final class BatteryUsageStats implements Parcelable { private final AggregateBatteryConsumer[] mAggregateBatteryConsumers; private final Parcel mHistoryBuffer; private final List<BatteryStats.HistoryTag> mHistoryTagPool; private final BatteryStatsHistory mBatteryStatsHistory; private BatteryUsageStats(@NonNull Builder builder) { mStatsStartTimestampMs = builder.mStatsStartTimestampMs; Loading @@ -138,6 +139,7 @@ public final class BatteryUsageStats implements Parcelable { mDischargedPowerUpperBound = builder.mDischargedPowerUpperBoundMah; mHistoryBuffer = builder.mHistoryBuffer; mHistoryTagPool = builder.mHistoryTagPool; mBatteryStatsHistory = builder.mBatteryStatsHistory; mBatteryTimeRemainingMs = builder.mBatteryTimeRemainingMs; mChargeTimeRemainingMs = builder.mChargeTimeRemainingMs; mCustomPowerComponentNames = builder.mCustomPowerComponentNames; Loading Loading @@ -289,8 +291,8 @@ public final class BatteryUsageStats implements Parcelable { throw new IllegalStateException( "Battery history was not requested in the BatteryUsageStatsQuery"); } return new BatteryStatsHistoryIterator(new BatteryStatsHistory(mHistoryBuffer), mHistoryTagPool); return new BatteryStatsHistoryIterator(mBatteryStatsHistory, mHistoryTagPool); } @Override Loading Loading @@ -356,7 +358,10 @@ public final class BatteryUsageStats implements Parcelable { tag.poolIdx = source.readInt(); mHistoryTagPool.add(tag); } mBatteryStatsHistory = new BatteryStatsHistory(mHistoryBuffer); mBatteryStatsHistory.readFromBatteryUsageStatsParcel(source); } else { mBatteryStatsHistory = null; mHistoryBuffer = null; mHistoryTagPool = null; } Loading Loading @@ -404,6 +409,7 @@ public final class BatteryUsageStats implements Parcelable { dest.writeInt(tag.uid); dest.writeInt(tag.poolIdx); } mBatteryStatsHistory.writeToBatteryUsageStatsParcel(dest); } else { dest.writeBoolean(false); } Loading Loading @@ -757,6 +763,7 @@ public final class BatteryUsageStats implements Parcelable { new SparseArray<>(); private Parcel mHistoryBuffer; private List<BatteryStats.HistoryTag> mHistoryTagPool; private BatteryStatsHistory mBatteryStatsHistory; public Builder(@NonNull String[] customPowerComponentNames) { this(customPowerComponentNames, false); Loading Loading @@ -865,10 +872,12 @@ public final class BatteryUsageStats implements Parcelable { * Sets the parceled recent history. */ @NonNull public Builder setBatteryHistory(Parcel historyBuffer, List<BatteryStats.HistoryTag> historyTagPool) { public Builder setBatteryHistory(@NonNull Parcel historyBuffer, @NonNull List<BatteryStats.HistoryTag> historyTagPool, @NonNull BatteryStatsHistory batteryStatsHistory) { mHistoryBuffer = historyBuffer; mHistoryTagPool = historyTagPool; mBatteryStatsHistory = batteryStatsHistory; return this; } Loading
core/java/com/android/internal/os/BatteryStatsHistory.java +41 −8 Original line number Diff line number Diff line Loading @@ -160,6 +160,11 @@ public class BatteryStatsHistory { mHistoryDir = null; mHistoryBuffer = historyBuffer; } public File getHistoryDirectory() { return mHistoryDir; } /** * Set the active file that mHistoryBuffer is backed up into. * Loading Loading @@ -374,13 +379,25 @@ public class BatteryStatsHistory { return true; } /** * Read all history files and serialize into a big Parcel. * Checkin file calls this method. * @param out the output parcel */ public void writeToParcel(Parcel out) { writeToParcel(out, false /* useBlobs */); } /** * Read all history files and serialize into a big Parcel. This is to send history files to * Settings app since Settings app can not access /data/system directory. * Checkin file also call this method. * @param out the output parcel */ public void writeToParcel(Parcel out) { public void writeToBatteryUsageStatsParcel(Parcel out) { writeToParcel(out, true /* useBlobs */); } private void writeToParcel(Parcel out, boolean useBlobs) { final long start = SystemClock.uptimeMillis(); out.writeInt(mFileNumbers.size() - 1); for(int i = 0; i < mFileNumbers.size() - 1; i++) { Loading @@ -391,26 +408,42 @@ public class BatteryStatsHistory { } catch(Exception e) { Slog.e(TAG, "Error reading file "+ file.getBaseFile().getPath(), e); } if (useBlobs) { out.writeBlob(raw); } else { // Avoiding blobs in the check-in file for compatibility out.writeByteArray(raw); } } if (DEBUG) { Slog.d(TAG, "writeToParcel duration ms:" + (SystemClock.uptimeMillis() - start)); } } /** * This is for Settings app, when Settings app receives big history parcel, it call * this method to parse it into list of parcels. * Checkin file also call this method. * This is for the check-in file, which has all history files embedded. * @param in the input parcel. */ public void readFromParcel(Parcel in) { readFromParcel(in, false /* useBlobs */); } /** * This is for Settings app, when Settings app receives big history parcel, it calls * this method to parse it into list of parcels. * @param in the input parcel. */ public void readFromBatteryUsageStatsParcel(Parcel in) { readFromParcel(in, true /* useBlobs */); } private void readFromParcel(Parcel in, boolean useBlobs) { final long start = SystemClock.uptimeMillis(); mHistoryParcels = new ArrayList<>(); final int count = in.readInt(); for(int i = 0; i < count; i++) { byte[] temp = in.createByteArray(); if (temp.length == 0) { byte[] temp = useBlobs ? in.readBlob() : in.createByteArray(); if (temp == null || temp.length == 0) { continue; } Parcel p = Parcel.obtain(); Loading
core/java/com/android/internal/os/BatteryStatsImpl.java +11 −2 Original line number Diff line number Diff line Loading @@ -1200,12 +1200,21 @@ public class BatteryStatsImpl extends BatteryStats { } public BatteryStatsImpl(Clocks clocks) { this(clocks, (File) null); } public BatteryStatsImpl(Clocks clocks, File historyDirectory) { init(clocks); mStartClockTimeMs = clocks.currentTimeMillis(); mStatsFile = null; mCheckinFile = null; mDailyFile = null; if (historyDirectory == null) { mStatsFile = null; mBatteryStatsHistory = new BatteryStatsHistory(mHistoryBuffer); } else { mStatsFile = new AtomicFile(new File(historyDirectory, "batterystats.bin")); mBatteryStatsHistory = new BatteryStatsHistory(this, historyDirectory, mHistoryBuffer); } mHandler = null; mPlatformIdleStateCallback = null; mMeasuredEnergyRetriever = null; Loading
core/java/com/android/internal/os/BatteryUsageStatsProvider.java +7 −1 Original line number Diff line number Diff line Loading @@ -29,6 +29,7 @@ import android.util.SparseArray; import com.android.internal.annotations.VisibleForTesting; import java.io.File; import java.util.ArrayList; import java.util.Arrays; import java.util.List; Loading Loading @@ -203,7 +204,12 @@ public class BatteryUsageStatsProvider { tags.add(tag); } batteryUsageStatsBuilder.setBatteryHistory(historyBuffer, tags); final File systemDir = batteryStatsImpl.mBatteryStatsHistory.getHistoryDirectory().getParentFile(); final BatteryStatsHistory batteryStatsHistory = new BatteryStatsHistory(batteryStatsImpl, systemDir, historyBuffer); batteryUsageStatsBuilder.setBatteryHistory(historyBuffer, tags, batteryStatsHistory); } return batteryUsageStatsBuilder.build(); Loading
core/tests/coretests/src/com/android/internal/os/BatteryUsageStatsProviderTest.java +6 −1 Original line number Diff line number Diff line Loading @@ -39,6 +39,8 @@ import androidx.test.InstrumentationRegistry; import androidx.test.filters.SmallTest; import androidx.test.runner.AndroidJUnit4; import libcore.testing.io.TestIoUtils; import org.junit.Rule; import org.junit.Test; import org.junit.runner.RunWith; Loading @@ -52,8 +54,11 @@ public class BatteryUsageStatsProviderTest { private static final int APP_UID = Process.FIRST_APPLICATION_UID + 42; private static final long MINUTE_IN_MS = 60 * 1000; private final File mHistoryDir = TestIoUtils.createTemporaryDirectory(getClass().getSimpleName()); @Rule public final BatteryUsageStatsRule mStatsRule = new BatteryUsageStatsRule(12345) public final BatteryUsageStatsRule mStatsRule = new BatteryUsageStatsRule(12345, mHistoryDir) .setAveragePower(PowerProfile.POWER_FLASHLIGHT, 360.0); @Test Loading