Hi, Oleksandr! On Jul 01, Oleksandr Byelkin wrote:
revision-id: b29ec61724d (mariadb-10.6.2-41-gb29ec61724d) parent(s): 83684fc9a4d author: Oleksandr Byelkin <sanja@mariadb.com> committer: Oleksandr Byelkin <sanja@mariadb.com> timestamp: 2021-07-01 11:20:29 +0200 message:
MDEV-25906: SIGSEGV in flush_tables_with_read_lock on FTWRL or FTFE | SIGSEGV in ha_maria::extra
Fixed check of derived tables of all kinds (view, derived, information schema).
diff --git a/sql/sql_reload.cc b/sql/sql_reload.cc index 0fa2fa10df8..e41da9680b0 100644 --- a/sql/sql_reload.cc +++ b/sql/sql_reload.cc @@ -592,10 +592,19 @@ bool flush_tables_with_read_lock(THD *thd, TABLE_LIST *all_tables) for (TABLE_LIST *table_list= all_tables; table_list; table_list= table_list->next_global) { - if (!(table_list->is_view() || - table_list->table->file->ha_table_flags() & HA_CAN_EXPORT)) + /* + We allow all deriveds and view here, but prohibit information_schema + tables (explicitly) and performance_schema tables (implicetly: + engine do not suport export) + */ + if (table_list->is_non_derived() && + (!table_list->is_base_table() || + !(table_list->table->file->ha_table_flags() & HA_CAN_EXPORT))) { - my_error(ER_ILLEGAL_HA, MYF(0),table_list->table->file->table_type(), + my_error(ER_ILLEGAL_HA, MYF(0), + (table_list->is_base_table() ? + table_list->table->file->table_type(): + "information_schema"),
I'd say if you want to detect I_S tables, you should test for table_list->schema_table. It's not clear what your condition actually does. And there is no such engine "information_schema", so the message is misleading. In fact, this should be access denied. For both. Like: mysqltest: At line 12: query 'flush table information_schema.collations for export' failed: ER_DBACCESS_DENIED_ERROR (1044): Access denied for user 'foo'@'localhost' to database 'information_schema' this is from a test file that only does flush table information_schema.collations for export.
table_list->db.str, table_list->table_name.str); goto error_reset_bits; } @@ -607,7 +616,8 @@ bool flush_tables_with_read_lock(THD *thd, TABLE_LIST *all_tables) for (auto table_list= all_tables; table_list; table_list= table_list->next_global) { - if (!table_list->is_view() && + if (table_list->table &&
why do you check for table_list->table ? Can it happen that table_list->table == NULL and table_list->is_base_table() == true?
+ table_list->is_base_table() && table_list->table->file->extra(HA_EXTRA_FLUSH)) goto error_reset_bits; }
Regards, Sergei VP of MariaDB Server Engineering and security@mariadb.org