Commit e7208bd9 authored by Nayuta Yanagisawa's avatar Nayuta Yanagisawa

MDEV-26158 SIGSEGV in spider_free_mem from ha_spider::open on INSERT

The server crashes due to passing NULL to spider_free().

In some cases, this == pt_handler_share_handlers[0] at the label
error_get_share in ha_spider::open().

In such cases, to nullify pt_handler_share_handlers[0]->wide_handler
is nothing but to nullify this->wide_handler. We should not do this
before freeing this->wide_handler.
parent edde9084
...@@ -659,13 +659,13 @@ int ha_spider::open( ...@@ -659,13 +659,13 @@ int ha_spider::open(
error_get_share: error_get_share:
if (wide_handler_alloc) if (wide_handler_alloc)
{ {
spider_free(spider_current_trx, wide_handler, MYF(0));
#ifdef WITH_PARTITION_STORAGE_ENGINE #ifdef WITH_PARTITION_STORAGE_ENGINE
if (pt_handler_share_handlers) if (pt_handler_share_handlers)
{ {
pt_handler_share_handlers[0]->wide_handler = NULL; pt_handler_share_handlers[0]->wide_handler = NULL;
} }
#endif #endif
spider_free(spider_current_trx, wide_handler, MYF(0));
spider->wide_handler = NULL; spider->wide_handler = NULL;
owner->wide_handler = NULL; owner->wide_handler = NULL;
owner->wide_handler_owner = FALSE; owner->wide_handler_owner = FALSE;
......
#
# MDEV-26158 SIGSEGV in spider_free_mem from ha_spider::open on INSERT
#
for master_1
for child2
child2_1
child2_2
child2_3
for child3
connection master_1;
CREATE DATABASE auto_test_local;
USE auto_test_local;
CREATE TABLE t (
c INT
) ENGINE=Spider DEFAULT CHARSET=utf8 COMMENT='table "tbl_a"'
PARTITION BY LIST COLUMNS(`c`) (
PARTITION `pt1` DEFAULT COMMENT = 'srv "s_2_1"'
);
INSERT INTO t SELECT * FROM t;
ERROR 42000: Unknown database 'auto_test_remote'
DROP DATABASE auto_test_local;
for master_1
for child2
child2_1
child2_2
child2_3
for child3
!include include/default_mysqld.cnf
!include ../my_1_1.cnf
!include ../my_2_1.cnf
--echo #
--echo # MDEV-26158 SIGSEGV in spider_free_mem from ha_spider::open on INSERT
--echo #
--disable_query_log
--disable_result_log
--source ../../t/test_init.inc
--enable_result_log
--enable_query_log
--connection master_1
CREATE DATABASE auto_test_local;
USE auto_test_local;
eval CREATE TABLE t (
c INT
) $MASTER_1_ENGINE $MASTER_1_CHARSET COMMENT='table "tbl_a"'
PARTITION BY LIST COLUMNS(`c`) (
PARTITION `pt1` DEFAULT COMMENT = 'srv "s_2_1"'
);
--error ER_BAD_DB_ERROR
INSERT INTO t SELECT * FROM t;
DROP DATABASE auto_test_local;
--disable_query_log
--disable_result_log
--source ../../t/test_deinit.inc
--enable_result_log
--enable_query_log
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment