diff options
author | Darshan M N <darshan.m.n@oracle.com> | 2016-07-20 10:00:26 +0530 |
---|---|---|
committer | Sergey Vojtovich <svoj@mariadb.org> | 2016-10-12 19:06:24 +0400 |
commit | 1750d541712861c7bfbbc874dd559088832221c9 (patch) | |
tree | 3ec116281e5d73e7e2c8fe1289bfaf7a70939119 /sql/sql_servers.cc | |
parent | e5e8f407d62f431e0bf94cd65f88e06f4c19773e (diff) | |
download | mariadb-git-bb-10.2-mdev10813.tar.gz |
Bug#23631471 BUF_BLOCK_ALIGN() MAKES INCORRECT ASSUMPTIONS ABOUT CHUNK SIZEbb-10.2-mdev10813
Issue:
======
Currently the approach we take to find the chunk corresponding to a given
pointer uses srv_buf_pool_chunk_unit based on the assumption that
srv_buf_pool_chunk_unit is the total size of all pages in a buffer pool
chunk. We first step back by srv_buf_pool_chunk_unit bytes and use
std::map::upper_bound() to find the first chunk in the map whose key >= the
resulting pointer.
However, the real size of a chunk (and thus, the total size of its pages)
may differ from the value configured with innodb_buffer_pool_chunk_size
due to rounding up to the OS page size. So, in some cases the above logic
gives us the wrong chunk.
Fix:
====
We find out the chunk corresponding to the give pointer without using
srv_buf_pool_chunk_unit. This is done by using std::map::upper_bound()
to find the next chunk in the map which appears right after the pointer and
decrementing the iterator, which would give us the chunk the pointer
belongs to.
Contribution by Alexey Kopytov.
RB: 13347
Reviewed-by: Debarun Banerjee <debarun.banerjee@oracle.com>
Diffstat (limited to 'sql/sql_servers.cc')
0 files changed, 0 insertions, 0 deletions