Skip to content
Snippets Groups Projects
  1. Nov 13, 2020
    • Ryan Mitchell's avatar
      Revert "libandroidfw hardening for IncFs" · 55ef6167
      Ryan Mitchell authored
      Revert "Move map_ptr to incfs namspace"
      
      Revert submission 12787270
      
      Reason for revert: b/173250495
      Reverted Changes:
      I5cd1bc8a2:libandroidfw hardening for IncFs
      Ice5dbcfb2:Move map_ptr to incfs namspace
      I29ccdc8ed:Do not cache bag parent stack until requested
      I1e9e9acaa:Cache resolved theme values
      
      Change-Id: Ib90ef68339710086df41e9abe0833a542d03a74f
      55ef6167
    • Ryan Mitchell's avatar
      Revert "Cache resolved theme values" · 6ca48473
      Ryan Mitchell authored
      Revert "Move map_ptr to incfs namspace"
      
      Revert submission 12787270
      
      Reason for revert: b/173250495
      Reverted Changes:
      I5cd1bc8a2:libandroidfw hardening for IncFs
      Ice5dbcfb2:Move map_ptr to incfs namspace
      I29ccdc8ed:Do not cache bag parent stack until requested
      I1e9e9acaa:Cache resolved theme values
      
      Change-Id: Ibec051c79dfd28783a57b9ae82ebd8cdbed82fce
      6ca48473
    • Ryan Mitchell's avatar
      Revert "Do not cache bag parent stack until requested" · 06a7331b
      Ryan Mitchell authored
      Revert "Move map_ptr to incfs namspace"
      
      Revert submission 12787270
      
      Reason for revert: b/173250495
      Reverted Changes:
      I5cd1bc8a2:libandroidfw hardening for IncFs
      Ice5dbcfb2:Move map_ptr to incfs namspace
      I29ccdc8ed:Do not cache bag parent stack until requested
      I1e9e9acaa:Cache resolved theme values
      
      Change-Id: Ib06f254ca4ac6fdec1f9cf75e6fdab35c7d4fb32
      06a7331b
  2. Nov 12, 2020
    • Ryan Mitchell's avatar
      Do not cache bag parent stack until requested · 5602dc93
      Ryan Mitchell authored
      Bag parent stacks are used when inspecting/debugging layouts. Since
      they are not needed at runtime when running applications normally,
      do not cache bag the parent stack when calling AssetManager::GetBag.
      
      Bug: none
      Test: libandroidfw_tests
      Change-Id: I29ccdc8ed30d4f2d11ee51ef58f6e459ca6c1f6a
      5602dc93
    • Ryan Mitchell's avatar
      Cache resolved theme values · 87e89546
      Ryan Mitchell authored
      When calling Resources#obtainStyledAttributes, if a value for an
      attribute is supplied from the theme, and the value in the theme
      is a reference to a resource, the reference will be resolved using
      AssetManager2::ResolveReference each time the value from the theme
      is selected. This causes Resources#obtainStyledAttributes to do
      repeated work every time the same attribute is supplied from the
      theme in multiple invocations.
      
      Caching the result of ResolveReference reduces the cost of this
      repeated work and reduces the amount of time needed to inflate views.
      
      Before:
      com.android.resources.perf (3 Tests)
      [1/3] com.android.resources.perf.PerfTest#youtube: PASSED (11.748s)
          youtube_ns_median: 95490747
          youtube_ns_standardDeviation: 7282249
          youtube_ns_mean: 98442515
      [2/3] com.android.resources.perf.PerfTest#maps: PASSED (10.862s)
          maps_ns_standardDeviation: 4484213
          maps_ns_mean: 87912988
          maps_ns_median: 86325549
      [3/3] com.android.resources.perf.PerfTest#gmail: PASSED (24.034s)
          gmail_ns_median: 282175838
          gmail_ns_standardDeviation: 6560876
          gmail_ns_mean: 282869146
      
      After:
      com.android.resources.perf (3 Tests)
      [1/3] com.android.resources.perf.PerfTest#youtube: PASSED (11.245s)
          youtube_ns_median: 92292347
          youtube_ns_standardDeviation: 5899906
          youtube_ns_mean: 93045239
      [2/3] com.android.resources.perf.PerfTest#maps: PASSED (10.583s)
          maps_ns_standardDeviation: 7567929
          maps_ns_mean: 81895979
          maps_ns_median: 78647883
      [3/3] com.android.resources.perf.PerfTest#gmail: PASSED (21.439s)
          gmail_ns_median: 229185043
          gmail_ns_standardDeviation: 8770133
          gmail_ns_mean: 232561234
      
      These tests were done on a Pixel 3 and with cpu settings configured by
      libs/hwui/tests/scripts/prep_generic.sh:
      
       Locked CPUs 4,5,6,7 to 1459200 / 2803200 KHz
       Disabled CPUs 0,1,2,3
      
      Bug: 170232288
      Test: atest ResourcesPerfWorkloads
      Change-Id: I1e9e9acaa40fa60475a0e55230e11243f5b69b39
      87e89546
    • Ryan Mitchell's avatar
      libandroidfw hardening for IncFs · c75c2e09
      Ryan Mitchell authored
      Migrate libandroifw to using incfs::util::map_ptr to prevent processes
      from crashing when parsing the resources.arsc, parsing compiled xml,
      files, and retrieving resource values.
      
      This change propagates incremental failures to the JNI level where they
      are raised as ResourcesNotFoundException.
      
      Performance of ResourcesPerfWorkloads without change (time in
      nanoseconds):
      [1/3] com.android.resources.perf.PerfTest#youtube: PASSED (11.883s)
          youtube_ns_median: 93812805
          youtube_ns_standardDeviation: 4387062
          youtube_ns_mean: 94455597
      [2/3] com.android.resources.perf.PerfTest#maps: PASSED (11.265s)
          maps_ns_standardDeviation: 2997543
          maps_ns_mean: 83480371
          maps_ns_median: 82210941
      [3/3] com.android.resources.perf.PerfTest#gmail: PASSED (24.963s)
          gmail_ns_median: 266141091
          gmail_ns_standardDeviation: 3492043
          gmail_ns_mean: 267472765
      
      With change and verification forcibly enabled for all apks
      (including the framework-res.apk):
      [1/3] com.android.resources.perf.PerfTest#youtube: PASSED (11.646s)
          youtube_ns_median: 101999396
          youtube_ns_standardDeviation: 4625782
          youtube_ns_mean: 102631770
      [2/3] com.android.resources.perf.PerfTest#maps: PASSED (11.286s)
          maps_ns_standardDeviation: 2692088
          maps_ns_mean: 91326538
          maps_ns_median: 90519884
      [3/3] com.android.resources.perf.PerfTest#gmail: PASSED (24.694s)
          gmail_ns_median: 290284442
          gmail_ns_standardDeviation: 5764632
          gmail_ns_mean: 291660464
      
      With change and verification disabled:
      [1/3] com.android.resources.perf.PerfTest#youtube: PASSED (11.748s)
          youtube_ns_median: 95490747
          youtube_ns_standardDeviation: 7282249
          youtube_ns_mean: 98442515
      [2/3] com.android.resources.perf.PerfTest#maps: PASSED (10.862s)
          maps_ns_standardDeviation: 4484213
          maps_ns_mean: 87912988
          maps_ns_median: 86325549
      [3/3] com.android.resources.perf.PerfTest#gmail: PASSED (24.034s)
          gmail_ns_median: 282175838
          gmail_ns_standardDeviation: 6560876
          gmail_ns_mean: 282869146
      
      These tests were done on a Pixel 3 and with cpu settings configured by
      libs/hwui/tests/scripts/prep_generic.sh:
      
       Locked CPUs 4,5,6,7 to 1459200 / 2803200 KHz
       Disabled CPUs 0,1,2,3
      
      Bug: 160635104
      Bug: 169423204
      Test: boot device && atest ResourcesPerfWorkloads
      
      Change-Id: I5cd1bc8a2257bffaba6ca4a1c96f4e6640106866
      c75c2e09
  3. Oct 20, 2020
Loading