Improve handling of pool_options::largest_required_pool_block
commitabcd0bc272314577a872af64a72e7810422e5d16
authorredi <redi@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 13 Nov 2018 22:57:53 +0000 (13 22:57 +0000)
committerredi <redi@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 13 Nov 2018 22:57:53 +0000 (13 22:57 +0000)
tree7215d345c266d8938cae0627f3d5592b824785d4
parent442581353dede7eefd73e3592b17313f2aa0220d
Improve handling of pool_options::largest_required_pool_block

Make the munge_options function round the largest_required_pool_block
value to a multiple of the smallest pool size (currently 8 bytes) to
avoid pools with odd sizes.

Ensure there is a pool large enough for blocks of the requested size.
Previously when largest_required_pool_block was exactly equal to one of
the pool_sizes[] values there would be no pool of that size. This patch
increases _M_npools by one, so there is a pool at least as large as the
requested value. It also reduces the size of the largest pool to be no
larger than needed.

* src/c++17/memory_resource.cc (munge_options): Round up value of
largest_required_pool_block to multiple of smallest pool size. Round
excessively large values down to largest pool size.
(select_num_pools): Increase number of pools by one unless it exactly
matches requested largest_required_pool_block.
(__pool_resource::_M_alloc_pools()): Make largest pool size equal
largest_required_pool_block.
* testsuite/20_util/unsynchronized_pool_resource/options.cc: Check
that pool_options::largest_required_pool_block is set appropriately.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@266089 138bc75d-0d04-0410-961f-82ee72b054a4
libstdc++-v3/ChangeLog
libstdc++-v3/src/c++17/memory_resource.cc
libstdc++-v3/testsuite/20_util/unsynchronized_pool_resource/options.cc