diff options
author | Marko Mäkelä <marko.makela@mariadb.com> | 2019-10-14 16:38:28 +0300 |
---|---|---|
committer | Marko Mäkelä <marko.makela@mariadb.com> | 2019-10-14 16:38:28 +0300 |
commit | ae702d76438d15c84e0e113031366b0a8da47b9f (patch) | |
tree | fe33bed68bf51d73ed687a9641900c22131d7aa8 /strings | |
parent | 2920377aa088b565aa4d2bbaa2fdbb3004d2933a (diff) | |
download | mariadb-git-ae702d76438d15c84e0e113031366b0a8da47b9f.tar.gz |
MDEV-20813: Remove the buf_flush_init_for_writing() assertion
Old InnoDB/XtraDB versions only initialized FIL_PAGE_TYPE for
B-tree pages (to FIL_PAGE_INDEX), and left it uninitialized
(possibly containing FIL_PAGE_INDEX) for others. In MySQL
or MariaDB 5.5, the field is initialized on almost all pages,
but still not all of them.
In MariaDB 10.2 and later, buf_flush_init_for_writing() would
initialize the FIL_PAGE_TYPE on such old pages, but only after
passing the debug assertion that we are now removing from 10.1.
There, we will be able to modify fil_crypt_rotate_page() so
that it will skip the key rotation for pages that contain 0
in FIL_PAGE_TYPE.
In MariaDB 10.1, there is no logic that would initialize
FIL_PAGE_TYPE on data pages in old data files after an update.
So, encryption key rotation may routinely cause page flushes
on pages that contain 0 in FIL_PAGE_TYPE.
Diffstat (limited to 'strings')
0 files changed, 0 insertions, 0 deletions