[PartitionAlloc] Use a larger empty slot span ring buffer on Linux.

Document and change the empty SlotSpan ring buffer limits.

When running Speedometer 2.0 on Linux (release build, no DCHECK()s),
~90-100k system calls are made from PartitionAlloc. A common way for the
allocator to make a system call is when decommitting an empty SlotSpan,
then when a recommit is required.

While this is not necessarily a large performance issue on Linux,
reducing the number of system calls is always a good idea, as most of
them are made with the root lock held, and can incur high tail
latency. Furthermore, while Linux is performing very well with these
calls (from local testing, <1us per call), this is not necessarily the
case of all operating systems.

A way to reduce the number of syscalls is to increase the size of the
ring buffer. This may increase peak committed memory, which we
monitor. Showing the median of 3 runs on a 56 hyperthreads Linux machine
(Xeon "Haswell", core count matters since it is linked to the number of
worker threads Chrome typically creates):

- Size 16:
  - Syscalls: 101k
  - Total syscall time: 812ms
  - Peak committed memory: 36796kiB
- Size 126:
  - Syscalls: 47.9k
  - Total syscall time: 422ms
  - Peak committed memory: 36104kiB

So it *seems* to not impact peak committed memory. Nevertheless, only
bump the size to 127 on Linux, to assess the impact on performance bots.

Bug: 1250288
Change-Id: I83ee913fe57824be21a1b2306b21029b70f5625d
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3168880
Reviewed-by: Kentaro Hara <haraken@chromium.org>
Commit-Queue: Benoit L <lizeb@chromium.org>
Cr-Commit-Position: refs/heads/main@{#923342}
2 files changed
tree: b66a3765113b9d7d62c2841687be483b61c5c5bc
  1. android_webview/
  2. apps/
  3. ash/
  4. base/
  5. build/
  6. build_overrides/
  7. buildtools/
  8. cc/
  9. chrome/
  10. chromecast/
  11. chromeos/
  12. cloud_print/
  13. codelabs/
  14. components/
  15. content/
  16. courgette/
  17. crypto/
  18. dbus/
  19. device/
  20. docs/
  21. extensions/
  22. fuchsia/
  23. gin/
  24. google_apis/
  25. google_update/
  26. gpu/
  27. headless/
  28. infra/
  29. ios/
  30. ipc/
  31. jingle/
  32. media/
  33. mojo/
  34. native_client_sdk/
  35. net/
  36. pdf/
  37. ppapi/
  38. printing/
  39. remoting/
  40. rlz/
  41. sandbox/
  42. services/
  43. skia/
  44. sql/
  45. storage/
  46. styleguide/
  47. testing/
  48. third_party/
  49. tools/
  50. ui/
  51. url/
  52. weblayer/
  53. .clang-format
  54. .clang-tidy
  55. .eslintrc.js
  56. .git-blame-ignore-revs
  57. .gitattributes
  58. .gitignore
  59. .gn
  60. .mailmap
  61. .vpython
  62. .vpython3
  63. .yapfignore
  64. AUTHORS
  65. BUILD.gn
  66. CODE_OF_CONDUCT.md
  67. codereview.settings
  68. DEPS
  69. DIR_METADATA
  70. ENG_REVIEW_OWNERS
  71. LICENSE
  72. LICENSE.chromium_os
  73. OWNERS
  74. PRESUBMIT.py
  75. PRESUBMIT_test.py
  76. PRESUBMIT_test_mocks.py
  77. README.md
  78. WATCHLISTS
README.md

Logo Chromium

Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all users to experience the web.

The project's web site is https://www.chromium.org.

To check out the source code locally, don't use git clone! Instead, follow the instructions on how to get the code.

Documentation in the source is rooted in docs/README.md.

Learn how to Get Around the Chromium Source Code Directory Structure .

For historical reasons, there are some small top level directories. Now the guidance is that new top level directories are for product (e.g. Chrome, Android WebView, Ash). Even if these products have multiple executables, the code should be in subdirectories of the product.

If you found a bug, please file it at https://crbug.com/new.