trace_processor: ParsePowerRails: skip huge power rail indices

This is in response to the oss-fuzz issue where it constructs a message with
uint32_t index of max size , and then overflowing the resize's `idx+1`
parameter to 0.

We could instead avoid overflow in the calculation - but that still means that
parsing power rails could allocate 1<<32 elements, which feels wrong.

Bug: https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=14018
Change-Id: I27cdc7184ef646081083788e690ac13e6696a7f3
1 file changed
tree: c317bf996a04881e6068c72c07baf14e88530940
  1. build_overrides/
  2. buildtools/
  3. debian/
  4. docs/
  5. gn/
  6. include/
  7. infra/
  8. protos/
  9. src/
  10. test/
  11. tools/
  12. ui/
  13. .clang-format
  14. .gitignore
  15. .gn
  16. .travis.yml
  17. Android.bp
  18. Android.bp.extras
  19. BUILD
  20. BUILD.extras
  21. BUILD.gn
  22. codereview.settings
  23. heapprofd.rc
  24. MODULE_LICENSE_APACHE2
  25. NOTICE
  26. OWNERS
  27. perfetto.rc
  28. PRESUBMIT.py
  29. README.chromium
  30. README.md
  31. TEST_MAPPING
README.md

Perfetto - Performance instrumentation and tracing

Perfetto is an open-source project for performance instrumentation and tracing of Linux/Android/Chrome platforms and user-space apps.

See www.perfetto.dev for docs.

Bugs

  • For bugs affecting Android or the tracing internals use the internal bug tracker (go/perfetto-bugs).
  • For bugs affecting Chrome use http://crbug.com, Component:Speed>Tracing label:Perfetto.