mirror of
https://github.com/MariaDB/server.git
synced 2025-01-15 19:42:28 +01:00
MDEV-22059: MSAN report at replicate_ignore_table_grant
Analysis: ======== List of values provided for "replicate_ignore_table" and "replicate_do_table" are stored in HASH. When an empty list is provided the HASH structure doesn't get initialized. Existing code treats empty element list as an error and tries to clean the uninitialized HASH. This results in above MSAN issue. Fix: === The clean up should be initiated only when there is an error while parsing the 'replicate_do_table' or 'replicate_ignore_table' list and the HASH is in initialized state. Otherwise for empty list it should simply return success.
This commit is contained in:
parent
6e4e097bc2
commit
840fb495ce
1 changed files with 22 additions and 10 deletions
|
@ -350,16 +350,22 @@ Rpl_filter::set_do_table(const char* table_spec)
|
|||
int status;
|
||||
|
||||
if (do_table_inited)
|
||||
my_hash_reset(&do_table);
|
||||
|
||||
status= parse_filter_rule(table_spec, &Rpl_filter::add_do_table);
|
||||
|
||||
if (!do_table.records)
|
||||
{
|
||||
my_hash_free(&do_table);
|
||||
do_table_inited= 0;
|
||||
}
|
||||
|
||||
status= parse_filter_rule(table_spec, &Rpl_filter::add_do_table);
|
||||
|
||||
if (do_table_inited && status)
|
||||
{
|
||||
if (!do_table.records)
|
||||
{
|
||||
my_hash_free(&do_table);
|
||||
do_table_inited= 0;
|
||||
}
|
||||
}
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
|
@ -370,16 +376,22 @@ Rpl_filter::set_ignore_table(const char* table_spec)
|
|||
int status;
|
||||
|
||||
if (ignore_table_inited)
|
||||
my_hash_reset(&ignore_table);
|
||||
|
||||
status= parse_filter_rule(table_spec, &Rpl_filter::add_ignore_table);
|
||||
|
||||
if (!ignore_table.records)
|
||||
{
|
||||
my_hash_free(&ignore_table);
|
||||
ignore_table_inited= 0;
|
||||
}
|
||||
|
||||
status= parse_filter_rule(table_spec, &Rpl_filter::add_ignore_table);
|
||||
|
||||
if (ignore_table_inited && status)
|
||||
{
|
||||
if (!ignore_table.records)
|
||||
{
|
||||
my_hash_free(&ignore_table);
|
||||
ignore_table_inited= 0;
|
||||
}
|
||||
}
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue