Commit 18bb95b6 authored by Marko Mäkelä's avatar Marko Mäkelä

Merge 10.7 into 10.8

parents 00021a92 e67d46e4
/* Copyright (C) 2010, 2020, MariaDB Corporation. /* Copyright (C) 2010, 2022, MariaDB Corporation.
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
...@@ -37,6 +37,11 @@ ...@@ -37,6 +37,11 @@
# define MEM_GET_VBITS(a,b,len) __msan_copy_shadow(b,a,len) # define MEM_GET_VBITS(a,b,len) __msan_copy_shadow(b,a,len)
# define MEM_SET_VBITS(a,b,len) __msan_copy_shadow(a,b,len) # define MEM_SET_VBITS(a,b,len) __msan_copy_shadow(a,b,len)
# define REDZONE_SIZE 8 # define REDZONE_SIZE 8
# ifdef __linux__
# define MSAN_STAT_WORKAROUND(st) MEM_MAKE_DEFINED(st, sizeof(*st))
# else
# define MSAN_STAT_WORKAROUND(st) ((void) 0)
# endif
#elif defined(HAVE_VALGRIND_MEMCHECK_H) && defined(HAVE_valgrind) #elif defined(HAVE_VALGRIND_MEMCHECK_H) && defined(HAVE_valgrind)
# include <valgrind/memcheck.h> # include <valgrind/memcheck.h>
# define HAVE_MEM_CHECK # define HAVE_MEM_CHECK
...@@ -49,6 +54,7 @@ ...@@ -49,6 +54,7 @@
# define MEM_GET_VBITS(a,b,len) VALGRIND_GET_VBITS(a,b,len) # define MEM_GET_VBITS(a,b,len) VALGRIND_GET_VBITS(a,b,len)
# define MEM_SET_VBITS(a,b,len) VALGRIND_SET_VBITS(a,b,len) # define MEM_SET_VBITS(a,b,len) VALGRIND_SET_VBITS(a,b,len)
# define REDZONE_SIZE 8 # define REDZONE_SIZE 8
# define MSAN_STAT_WORKAROUND(st) ((void) 0)
#elif defined(__SANITIZE_ADDRESS__) && (!defined(_MSC_VER) || defined (__clang__)) #elif defined(__SANITIZE_ADDRESS__) && (!defined(_MSC_VER) || defined (__clang__))
# include <sanitizer/asan_interface.h> # include <sanitizer/asan_interface.h>
/* How to do manual poisoning: /* How to do manual poisoning:
...@@ -62,6 +68,7 @@ ...@@ -62,6 +68,7 @@
# define MEM_CHECK_DEFINED(a,len) ((void) 0) # define MEM_CHECK_DEFINED(a,len) ((void) 0)
# define MEM_GET_VBITS(a,b,len) ((void) 0) # define MEM_GET_VBITS(a,b,len) ((void) 0)
# define MEM_SET_VBITS(a,b,len) ((void) 0) # define MEM_SET_VBITS(a,b,len) ((void) 0)
# define MSAN_STAT_WORKAROUND(st) ((void) 0)
# define REDZONE_SIZE 8 # define REDZONE_SIZE 8
#else #else
# define MEM_UNDEFINED(a,len) ((void) 0) # define MEM_UNDEFINED(a,len) ((void) 0)
...@@ -73,6 +80,7 @@ ...@@ -73,6 +80,7 @@
# define MEM_GET_VBITS(a,b,len) ((void) 0) # define MEM_GET_VBITS(a,b,len) ((void) 0)
# define MEM_SET_VBITS(a,b,len) ((void) 0) # define MEM_SET_VBITS(a,b,len) ((void) 0)
# define REDZONE_SIZE 0 # define REDZONE_SIZE 0
# define MSAN_STAT_WORKAROUND(st) ((void) 0)
#endif /* __has_feature(memory_sanitizer) */ #endif /* __has_feature(memory_sanitizer) */
#ifdef HAVE_valgrind #ifdef HAVE_valgrind
......
/* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. /* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
Copyright (c) 2008, 2020, MariaDB Corporation. Copyright (c) 2008, 2022, MariaDB Corporation.
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
...@@ -332,6 +332,13 @@ int my_fstat(File Filedes, MY_STAT *stat_area, ...@@ -332,6 +332,13 @@ int my_fstat(File Filedes, MY_STAT *stat_area,
DBUG_PRINT("my",("fd: %d MyFlags: %lu", Filedes, MyFlags)); DBUG_PRINT("my",("fd: %d MyFlags: %lu", Filedes, MyFlags));
#ifdef _WIN32 #ifdef _WIN32
DBUG_RETURN(my_win_fstat(Filedes, stat_area)); DBUG_RETURN(my_win_fstat(Filedes, stat_area));
#elif defined HAVE_valgrind
{
int s= fstat(Filedes, stat_area);
if (!s)
MSAN_STAT_WORKAROUND(stat_area);
DBUG_RETURN(s);
}
#else #else
DBUG_RETURN(fstat(Filedes, (struct stat *) stat_area)); DBUG_RETURN(fstat(Filedes, (struct stat *) stat_area));
#endif #endif
...@@ -350,11 +357,14 @@ MY_STAT *my_stat(const char *path, MY_STAT *stat_area, myf my_flags) ...@@ -350,11 +357,14 @@ MY_STAT *my_stat(const char *path, MY_STAT *stat_area, myf my_flags)
my_flags))) my_flags)))
goto error; goto error;
#ifndef _WIN32 #ifndef _WIN32
if (! stat((char *) path, (struct stat *) stat_area) ) if (!stat((char *) path, (struct stat *) stat_area))
DBUG_RETURN(stat_area); {
MSAN_STAT_WORKAROUND(stat_area);
DBUG_RETURN(stat_area);
}
#else #else
if (! my_win_stat(path, stat_area) ) if (!my_win_stat(path, stat_area))
DBUG_RETURN(stat_area); DBUG_RETURN(stat_area);
#endif #endif
DBUG_PRINT("error",("Got errno: %d from stat", errno)); DBUG_PRINT("error",("Got errno: %d from stat", errno));
my_errno= errno; my_errno= errno;
......
/* /*
Copyright (c) 2001, 2011, Oracle and/or its affiliates Copyright (c) 2001, 2011, Oracle and/or its affiliates
Copyright (c) 2010, 2017, MariaDB Copyright (c) 2010, 2022, MariaDB
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
...@@ -113,7 +113,10 @@ int my_is_symlink(const char *filename __attribute__((unused))) ...@@ -113,7 +113,10 @@ int my_is_symlink(const char *filename __attribute__((unused)))
{ {
#if defined (HAVE_LSTAT) && defined (S_ISLNK) #if defined (HAVE_LSTAT) && defined (S_ISLNK)
struct stat stat_buff; struct stat stat_buff;
return !lstat(filename, &stat_buff) && S_ISLNK(stat_buff.st_mode); if (lstat(filename, &stat_buff))
return 0;
MSAN_STAT_WORKAROUND(&stat_buff);
return !!S_ISLNK(stat_buff.st_mode);
#elif defined (_WIN32) #elif defined (_WIN32)
DWORD dwAttr = GetFileAttributes(filename); DWORD dwAttr = GetFileAttributes(filename);
return (dwAttr != INVALID_FILE_ATTRIBUTES) && return (dwAttr != INVALID_FILE_ATTRIBUTES) &&
......
...@@ -163,6 +163,8 @@ Table_type dd_frm_type(THD *thd, char *path, LEX_CSTRING *engine_name, ...@@ -163,6 +163,8 @@ Table_type dd_frm_type(THD *thd, char *path, LEX_CSTRING *engine_name,
if (mysql_file_fstat(file, &state, MYF(MY_WME))) if (mysql_file_fstat(file, &state, MYF(MY_WME)))
goto err; goto err;
MSAN_STAT_WORKAROUND(&state);
if (mysql_file_seek(file, 0, SEEK_SET, MYF(MY_WME))) if (mysql_file_seek(file, 0, SEEK_SET, MYF(MY_WME)))
goto err; goto err;
......
...@@ -2491,11 +2491,11 @@ bool ddl_log_write_entry(DDL_LOG_ENTRY *ddl_log_entry, ...@@ -2491,11 +2491,11 @@ bool ddl_log_write_entry(DDL_LOG_ENTRY *ddl_log_entry,
if (unlikely(write_ddl_log_file_entry((*active_entry)->entry_pos))) if (unlikely(write_ddl_log_file_entry((*active_entry)->entry_pos)))
{ {
sql_print_error("DDL_LOG: Failed to write entry %u",
(*active_entry)->entry_pos);
ddl_log_release_memory_entry(*active_entry); ddl_log_release_memory_entry(*active_entry);
*active_entry= 0; *active_entry= 0;
error= TRUE; error= TRUE;
sql_print_error("DDL_LOG: Failed to write entry %u",
(*active_entry)->entry_pos);
} }
DBUG_RETURN(error); DBUG_RETURN(error);
} }
...@@ -2558,13 +2558,13 @@ bool ddl_log_write_execute_entry(uint first_entry, ...@@ -2558,13 +2558,13 @@ bool ddl_log_write_execute_entry(uint first_entry,
(*active_entry)->entry_pos, first_entry)); (*active_entry)->entry_pos, first_entry));
if (write_ddl_log_file_entry((*active_entry)->entry_pos)) if (write_ddl_log_file_entry((*active_entry)->entry_pos))
{ {
sql_print_error("DDL_LOG: Error writing execute entry %u",
(*active_entry)->entry_pos);
if (got_free_entry) if (got_free_entry)
{ {
ddl_log_release_memory_entry(*active_entry); ddl_log_release_memory_entry(*active_entry);
*active_entry= 0; *active_entry= 0;
} }
sql_print_error("DDL_LOG: Error writing execute entry %u",
(*active_entry)->entry_pos);
DBUG_RETURN(TRUE); DBUG_RETURN(TRUE);
} }
(void) ddl_log_sync_no_lock(); (void) ddl_log_sync_no_lock();
......
/* Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved. /* Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
Copyright (c) 2009, 2020, MariaDB Corporation. Copyright (c) 2009, 2022, MariaDB Corporation.
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
...@@ -72,6 +72,7 @@ int readfrm(const char *name, const uchar **frmdata, size_t *len) ...@@ -72,6 +72,7 @@ int readfrm(const char *name, const uchar **frmdata, size_t *len)
error= 2; error= 2;
if (mysql_file_fstat(file, &state, MYF(0))) if (mysql_file_fstat(file, &state, MYF(0)))
goto err; goto err;
MSAN_STAT_WORKAROUND(&state);
read_len= (size_t)MY_MIN(FRM_MAX_SIZE, state.st_size); // safety read_len= (size_t)MY_MIN(FRM_MAX_SIZE, state.st_size); // safety
// Read whole frm file // Read whole frm file
......
...@@ -464,6 +464,8 @@ sql_parse_prepare(const LEX_CSTRING *file_name, MEM_ROOT *mem_root, ...@@ -464,6 +464,8 @@ sql_parse_prepare(const LEX_CSTRING *file_name, MEM_ROOT *mem_root,
DBUG_RETURN(0); DBUG_RETURN(0);
} }
MSAN_STAT_WORKAROUND(&stat_info);
if (stat_info.st_size > INT_MAX-1) if (stat_info.st_size > INT_MAX-1)
{ {
my_error(ER_FPARSER_TOO_BIG_FILE, MYF(0), file_name->str); my_error(ER_FPARSER_TOO_BIG_FILE, MYF(0), file_name->str);
......
...@@ -1188,7 +1188,7 @@ static enum enum_server_command fetch_command(THD *thd, char *packet) ...@@ -1188,7 +1188,7 @@ static enum enum_server_command fetch_command(THD *thd, char *packet)
DISPATCH_COMMAND_CLOSE_CONNECTION request of THD shutdown DISPATCH_COMMAND_CLOSE_CONNECTION request of THD shutdown
(s. dispatch_command() description) (s. dispatch_command() description)
@retval @retval
DISPATCH_COMMAND_WOULDBLOCK - need to wait for asyncronous operations DISPATCH_COMMAND_WOULDBLOCK - need to wait for asynchronous operations
to finish. Only returned if parameter to finish. Only returned if parameter
'blocking' is false. 'blocking' is false.
*/ */
......
...@@ -290,7 +290,7 @@ buf_read_page_low( ...@@ -290,7 +290,7 @@ buf_read_page_low(
/* Trx sys header is so low in the latching order that we play /* Trx sys header is so low in the latching order that we play
safe and do not leave the i/o-completion to an asynchronous safe and do not leave the i/o-completion to an asynchronous
i/o-thread. Change buffer pages must always be read with i/o-thread. Change buffer pages must always be read with
syncronous i/o, to make sure they do not get involved in synchronous i/o, to make sure they do not get involved in
thread deadlocks. */ thread deadlocks. */
sync = true; sync = true;
} }
......
...@@ -188,11 +188,16 @@ void log_t::attach(log_file_t file, os_offset_t size) ...@@ -188,11 +188,16 @@ void log_t::attach(log_file_t file, os_offset_t size)
struct stat st; struct stat st;
if (!fstat(log.m_file, &st)) if (!fstat(log.m_file, &st))
{ {
MSAN_STAT_WORKAROUND(&st);
const auto st_dev= st.st_dev; const auto st_dev= st.st_dev;
if (!stat("/dev/shm", &st) && st.st_dev == st_dev) if (!stat("/dev/shm", &st))
ptr= my_mmap(0, size_t(size), {
srv_read_only_mode ? PROT_READ : PROT_READ | PROT_WRITE, MSAN_STAT_WORKAROUND(&st);
MAP_SHARED, log.m_file, 0); if (st.st_dev == st_dev)
ptr= my_mmap(0, size_t(size), srv_read_only_mode
? PROT_READ : PROT_READ | PROT_WRITE,
MAP_SHARED, log.m_file, 0);
}
} }
} }
#endif /* __linux__ */ #endif /* __linux__ */
......
...@@ -932,7 +932,7 @@ os_file_status_posix( ...@@ -932,7 +932,7 @@ os_file_status_posix(
if (!ret) { if (!ret) {
/* file exists, everything OK */ /* file exists, everything OK */
MSAN_STAT_WORKAROUND(&statinfo);
} else if (errno == ENOENT || errno == ENOTDIR || errno == ENAMETOOLONG) { } else if (errno == ENOENT || errno == ENOTDIR || errno == ENAMETOOLONG) {
/* file does not exist */ /* file does not exist */
return(true); return(true);
...@@ -1309,7 +1309,11 @@ os_file_create_func( ...@@ -1309,7 +1309,11 @@ os_file_create_func(
char b[20 + sizeof "/sys/dev/block/" ":" char b[20 + sizeof "/sys/dev/block/" ":"
"/../queue/physical_block_size"]; "/../queue/physical_block_size"];
int f; int f;
if (fstat(file, &st) || st.st_size & 4095) { if (fstat(file, &st)) {
goto skip_o_direct;
}
MSAN_STAT_WORKAROUND(&st);
if (st.st_size & 4095) {
goto skip_o_direct; goto skip_o_direct;
} }
if (snprintf(b, sizeof b, if (snprintf(b, sizeof b,
...@@ -1588,8 +1592,10 @@ bool os_file_close_func(os_file_t file) ...@@ -1588,8 +1592,10 @@ bool os_file_close_func(os_file_t file)
os_offset_t os_offset_t
os_file_get_size(os_file_t file) os_file_get_size(os_file_t file)
{ {
struct stat statbuf; struct stat statbuf;
return fstat(file, &statbuf) ? os_offset_t(-1) : statbuf.st_size; if (fstat(file, &statbuf)) return os_offset_t(-1);
MSAN_STAT_WORKAROUND(&statbuf);
return statbuf.st_size;
} }
/** Gets a file size. /** Gets a file size.
...@@ -1606,6 +1612,7 @@ os_file_get_size( ...@@ -1606,6 +1612,7 @@ os_file_get_size(
int ret = stat(filename, &s); int ret = stat(filename, &s);
if (ret == 0) { if (ret == 0) {
MSAN_STAT_WORKAROUND(&s);
file_size.m_total_size = s.st_size; file_size.m_total_size = s.st_size;
/* st_blocks is in 512 byte sized blocks */ /* st_blocks is in 512 byte sized blocks */
file_size.m_alloc_size = s.st_blocks * 512; file_size.m_alloc_size = s.st_blocks * 512;
...@@ -1650,6 +1657,8 @@ os_file_get_status_posix( ...@@ -1650,6 +1657,8 @@ os_file_get_status_posix(
return(DB_FAIL); return(DB_FAIL);
} }
MSAN_STAT_WORKAROUND(statinfo);
switch (statinfo->st_mode & S_IFMT) { switch (statinfo->st_mode & S_IFMT) {
case S_IFDIR: case S_IFDIR:
stat_info->type = OS_FILE_TYPE_DIR; stat_info->type = OS_FILE_TYPE_DIR;
...@@ -2763,7 +2772,7 @@ os_file_set_eof( ...@@ -2763,7 +2772,7 @@ os_file_set_eof(
#endif /* !_WIN32*/ #endif /* !_WIN32*/
/** Does a syncronous read or write depending upon the type specified /** Does a synchronous read or write depending upon the type specified
In case of partial reads/writes the function tries In case of partial reads/writes the function tries
NUM_RETRIES_ON_PARTIAL_IO times to read/write the complete data. NUM_RETRIES_ON_PARTIAL_IO times to read/write the complete data.
@param[in] type, IO flags @param[in] type, IO flags
...@@ -3249,6 +3258,7 @@ os_file_set_size( ...@@ -3249,6 +3258,7 @@ os_file_set_size(
if (fstat(file, &statbuf)) { if (fstat(file, &statbuf)) {
err = errno; err = errno;
} else { } else {
MSAN_STAT_WORKAROUND(&statbuf);
os_offset_t current_size = statbuf.st_size; os_offset_t current_size = statbuf.st_size;
if (current_size >= size) { if (current_size >= size) {
return true; return true;
...@@ -4126,7 +4136,10 @@ void fil_node_t::find_metadata(os_file_t file ...@@ -4126,7 +4136,10 @@ void fil_node_t::find_metadata(os_file_t file
#else #else
struct stat sbuf; struct stat sbuf;
if (!statbuf && !fstat(file, &sbuf)) if (!statbuf && !fstat(file, &sbuf))
{
MSAN_STAT_WORKAROUND(&sbuf);
statbuf= &sbuf; statbuf= &sbuf;
}
if (statbuf) if (statbuf)
block_size= statbuf->st_blksize; block_size= statbuf->st_blksize;
# ifdef UNIV_LINUX # ifdef UNIV_LINUX
...@@ -4159,6 +4172,7 @@ bool fil_node_t::read_page0() ...@@ -4159,6 +4172,7 @@ bool fil_node_t::read_page0()
struct stat statbuf; struct stat statbuf;
if (fstat(handle, &statbuf)) if (fstat(handle, &statbuf))
return false; return false;
MSAN_STAT_WORKAROUND(&statbuf);
os_offset_t size_bytes= statbuf.st_size; os_offset_t size_bytes= statbuf.st_size;
#else #else
os_offset_t size_bytes= os_file_get_size(handle); os_offset_t size_bytes= os_file_get_size(handle);
......
...@@ -119,7 +119,7 @@ TRANSACTIONAL_INLINE inline bool TrxUndoRsegsIterator::set_next() ...@@ -119,7 +119,7 @@ TRANSACTIONAL_INLINE inline bool TrxUndoRsegsIterator::set_next()
trx_id_t last_trx_no, tail_trx_no; trx_id_t last_trx_no, tail_trx_no;
{ {
#ifdef SUX_LOCK_GENERIC #ifdef SUX_LOCK_GENERIC
purge_sys.rseg->latch.rd_lock(); purge_sys.rseg->latch.rd_lock(SRW_LOCK_CALL);
#else #else
transactional_shared_lock_guard<srw_spin_lock> rg transactional_shared_lock_guard<srw_spin_lock> rg
{purge_sys.rseg->latch}; {purge_sys.rseg->latch};
...@@ -636,7 +636,7 @@ TRANSACTIONAL_TARGET static void trx_purge_truncate_history() ...@@ -636,7 +636,7 @@ TRANSACTIONAL_TARGET static void trx_purge_truncate_history()
if (rseg.space != &space) if (rseg.space != &space)
continue; continue;
#ifdef SUX_LOCK_GENERIC #ifdef SUX_LOCK_GENERIC
rseg.latch.rd_lock(); rseg.latch.rd_lock(SRW_LOCK_CALL);
#else #else
transactional_shared_lock_guard<srw_spin_lock> g{rseg.latch}; transactional_shared_lock_guard<srw_spin_lock> g{rseg.latch};
#endif #endif
......
...@@ -141,7 +141,6 @@ C_MODE_END ...@@ -141,7 +141,6 @@ C_MODE_END
C_MODE_START C_MODE_START
/* Dummy structures and interfaces to be used when compiling without S3 */ /* Dummy structures and interfaces to be used when compiling without S3 */
struct s3_info; struct s3_info;
typedef struct s3_info S3_INFO;
struct ms3_st; struct ms3_st;
C_MODE_END C_MODE_END
#endif /* WITH_S3_STORAGE_ENGINE */ #endif /* WITH_S3_STORAGE_ENGINE */
......
...@@ -87,7 +87,10 @@ int mi_status(MI_INFO *info, register MI_ISAMINFO *x, uint flag) ...@@ -87,7 +87,10 @@ int mi_status(MI_INFO *info, register MI_ISAMINFO *x, uint flag)
x->index_file_name = share->index_file_name; x->index_file_name = share->index_file_name;
} }
if ((flag & HA_STATUS_TIME) && !mysql_file_fstat(info->dfile, &state, MYF(0))) if ((flag & HA_STATUS_TIME) && !mysql_file_fstat(info->dfile, &state, MYF(0)))
{
MSAN_STAT_WORKAROUND(&state);
x->update_time=state.st_mtime; x->update_time=state.st_mtime;
}
else else
x->update_time=0; x->update_time=0;
if (flag & HA_STATUS_AUTO) if (flag & HA_STATUS_AUTO)
......
...@@ -36,6 +36,10 @@ SELECT 1; ...@@ -36,6 +36,10 @@ SELECT 1;
3.1 3.1
auto_increment auto_increment
connection master_1; connection master_1;
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
connection slave1_1; connection slave1_1;
connection master_1; connection master_1;
DROP TABLE IF EXISTS t1, t2; DROP TABLE IF EXISTS t1, t2;
...@@ -190,6 +194,7 @@ LAST_INSERT_ID() ...@@ -190,6 +194,7 @@ LAST_INSERT_ID()
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
MAX(id) MAX(id)
10000 10000
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
connection slave1_1; connection slave1_1;
SELECT id FROM t1 ORDER BY id; SELECT id FROM t1 ORDER BY id;
id id
......
...@@ -34,6 +34,10 @@ SELECT 1; ...@@ -34,6 +34,10 @@ SELECT 1;
1 1
auto_increment with partition auto_increment with partition
connection master_1; connection master_1;
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
connection slave1_1; connection slave1_1;
connection master_1; connection master_1;
DROP TABLE IF EXISTS t1, t2; DROP TABLE IF EXISTS t1, t2;
...@@ -188,6 +192,7 @@ LAST_INSERT_ID() ...@@ -188,6 +192,7 @@ LAST_INSERT_ID()
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
MAX(id) MAX(id)
10000 10000
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
connection slave1_1; connection slave1_1;
SELECT id FROM t1 ORDER BY id; SELECT id FROM t1 ORDER BY id;
id id
......
...@@ -413,6 +413,10 @@ connection master_1; ...@@ -413,6 +413,10 @@ connection master_1;
read only read only
connection master_1; connection master_1;
SET @original_spider_read_only_mode = @@SESSION.spider_read_only_mode;
SET SESSION spider_read_only_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
CREATE TABLE t1 ( CREATE TABLE t1 (
id int(11) NOT NULL, id int(11) NOT NULL,
...@@ -441,10 +445,19 @@ DELETE FROM t1; ...@@ -441,10 +445,19 @@ DELETE FROM t1;
ERROR HY000: Table 'auto_test_local.t1' is read only ERROR HY000: Table 'auto_test_local.t1' is read only
TRUNCATE t1; TRUNCATE t1;
ERROR HY000: Table 'auto_test_local.t1' is read only ERROR HY000: Table 'auto_test_local.t1' is read only
SET SESSION spider_read_only_mode = @original_spider_read_only_mode;
2.27 2.27
error mode error mode
connection master_1; connection master_1;
SET @original_spider_error_read_mode = @@SESSION.spider_error_read_mode;
SET @original_spider_error_write_mode = @@SESSION.spider_error_write_mode;
SET SESSION spider_error_read_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
SET SESSION spider_error_write_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
CREATE TABLE t1 ( CREATE TABLE t1 (
id int(11) NOT NULL, id int(11) NOT NULL,
...@@ -466,6 +479,8 @@ Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist ...@@ -466,6 +479,8 @@ Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist
TRUNCATE t1; TRUNCATE t1;
Warnings: Warnings:
Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist
SET SESSION spider_error_read_mode = @original_spider_error_read_mode;
SET SESSION spider_error_write_mode = @original_spider_error_write_mode;
3.0 3.0
is null is null
......
...@@ -97,6 +97,8 @@ if ($USE_CHILD_GROUP2) ...@@ -97,6 +97,8 @@ if ($USE_CHILD_GROUP2)
} }
} }
--connection master_1 --connection master_1
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
...@@ -222,6 +224,7 @@ SELECT MAX(id) FROM t1; ...@@ -222,6 +224,7 @@ SELECT MAX(id) FROM t1;
INSERT INTO t2 (id) VALUES (1000); INSERT INTO t2 (id) VALUES (1000);
SELECT LAST_INSERT_ID(); SELECT LAST_INSERT_ID();
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
......
...@@ -131,6 +131,8 @@ if ($HAVE_PARTITION) ...@@ -131,6 +131,8 @@ if ($HAVE_PARTITION)
} }
} }
--connection master_1 --connection master_1
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
...@@ -256,6 +258,7 @@ if ($HAVE_PARTITION) ...@@ -256,6 +258,7 @@ if ($HAVE_PARTITION)
INSERT INTO t2 (id) VALUES (1000); INSERT INTO t2 (id) VALUES (1000);
SELECT LAST_INSERT_ID(); SELECT LAST_INSERT_ID();
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
......
...@@ -1172,6 +1172,8 @@ let $MASTER_1_ENGINE_IS_SPIDER= ...@@ -1172,6 +1172,8 @@ let $MASTER_1_ENGINE_IS_SPIDER=
if ($MASTER_1_ENGINE_IS_SPIDER) if ($MASTER_1_ENGINE_IS_SPIDER)
{ {
--connection master_1 --connection master_1
SET @original_spider_read_only_mode = @@SESSION.spider_read_only_mode;
SET SESSION spider_read_only_mode = -1;
--disable_warnings --disable_warnings
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
--enable_warnings --enable_warnings
...@@ -1197,6 +1199,7 @@ if ($MASTER_1_ENGINE_IS_SPIDER) ...@@ -1197,6 +1199,7 @@ if ($MASTER_1_ENGINE_IS_SPIDER)
DELETE FROM t1; DELETE FROM t1;
--error 12518 --error 12518
TRUNCATE t1; TRUNCATE t1;
SET SESSION spider_read_only_mode = @original_spider_read_only_mode;
} }
if (!$MASTER_1_ENGINE_IS_SPIDER) if (!$MASTER_1_ENGINE_IS_SPIDER)
{ {
...@@ -1210,6 +1213,10 @@ if (!$MASTER_1_ENGINE_IS_SPIDER) ...@@ -1210,6 +1213,10 @@ if (!$MASTER_1_ENGINE_IS_SPIDER)
if ($MASTER_1_ENGINE_IS_SPIDER) if ($MASTER_1_ENGINE_IS_SPIDER)
{ {
--connection master_1 --connection master_1
SET @original_spider_error_read_mode = @@SESSION.spider_error_read_mode;
SET @original_spider_error_write_mode = @@SESSION.spider_error_write_mode;
SET SESSION spider_error_read_mode = -1;
SET SESSION spider_error_write_mode = -1;
--disable_warnings --disable_warnings
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
--enable_warnings --enable_warnings
...@@ -1227,6 +1234,8 @@ if ($MASTER_1_ENGINE_IS_SPIDER) ...@@ -1227,6 +1234,8 @@ if ($MASTER_1_ENGINE_IS_SPIDER)
INSERT INTO t1 (id) VALUES (1); INSERT INTO t1 (id) VALUES (1);
DELETE FROM t1; DELETE FROM t1;
TRUNCATE t1; TRUNCATE t1;
SET SESSION spider_error_read_mode = @original_spider_error_read_mode;
SET SESSION spider_error_write_mode = @original_spider_error_write_mode;
} }
if (!$MASTER_1_ENGINE_IS_SPIDER) if (!$MASTER_1_ENGINE_IS_SPIDER)
{ {
......
...@@ -36,6 +36,10 @@ SELECT 1; ...@@ -36,6 +36,10 @@ SELECT 1;
3.1 3.1
auto_increment auto_increment
connection master_1; connection master_1;
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
connection slave1_1; connection slave1_1;
connection master_1; connection master_1;
DROP TABLE IF EXISTS t1, t2; DROP TABLE IF EXISTS t1, t2;
...@@ -206,6 +210,7 @@ LAST_INSERT_ID() ...@@ -206,6 +210,7 @@ LAST_INSERT_ID()
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
MAX(id) MAX(id)
46 46
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
connection slave1_1; connection slave1_1;
SELECT id FROM t1 ORDER BY id; SELECT id FROM t1 ORDER BY id;
id id
......
...@@ -34,6 +34,10 @@ SELECT 1; ...@@ -34,6 +34,10 @@ SELECT 1;
1 1
auto_increment with partition auto_increment with partition
connection master_1; connection master_1;
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
connection slave1_1; connection slave1_1;
connection master_1; connection master_1;
DROP TABLE IF EXISTS t1, t2; DROP TABLE IF EXISTS t1, t2;
...@@ -204,6 +208,7 @@ LAST_INSERT_ID() ...@@ -204,6 +208,7 @@ LAST_INSERT_ID()
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
MAX(id) MAX(id)
26 26
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
connection slave1_1; connection slave1_1;
SELECT id FROM t1 ORDER BY id; SELECT id FROM t1 ORDER BY id;
id id
......
...@@ -306,6 +306,10 @@ UNLOCK TABLES; ...@@ -306,6 +306,10 @@ UNLOCK TABLES;
auto_increment auto_increment
connection master_1; connection master_1;
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
connection slave1_1; connection slave1_1;
connection master_1; connection master_1;
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
...@@ -399,6 +403,7 @@ LAST_INSERT_ID() ...@@ -399,6 +403,7 @@ LAST_INSERT_ID()
SELECT MAX(id) FROM t1; SELECT MAX(id) FROM t1;
MAX(id) MAX(id)
42 42
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
connection slave1_1; connection slave1_1;
SELECT id FROM t1 ORDER BY id; SELECT id FROM t1 ORDER BY id;
id id
...@@ -417,6 +422,10 @@ connection master_1; ...@@ -417,6 +422,10 @@ connection master_1;
read only read only
connection master_1; connection master_1;
SET @original_spider_read_only_mode = @@SESSION.spider_read_only_mode;
SET SESSION spider_read_only_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
CREATE TABLE t1 ( CREATE TABLE t1 (
id int(11) NOT NULL, id int(11) NOT NULL,
...@@ -445,10 +454,19 @@ DELETE FROM t1; ...@@ -445,10 +454,19 @@ DELETE FROM t1;
ERROR HY000: Table 'auto_test_local.t1' is read only ERROR HY000: Table 'auto_test_local.t1' is read only
TRUNCATE t1; TRUNCATE t1;
ERROR HY000: Table 'auto_test_local.t1' is read only ERROR HY000: Table 'auto_test_local.t1' is read only
SET SESSION spider_read_only_mode = @original_spider_read_only_mode;
2.27 2.27
error mode error mode
connection master_1; connection master_1;
SET @original_spider_error_read_mode = @@SESSION.spider_error_read_mode;
SET @original_spider_error_write_mode = @@SESSION.spider_error_write_mode;
SET SESSION spider_error_read_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
SET SESSION spider_error_write_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
CREATE TABLE t1 ( CREATE TABLE t1 (
id int(11) NOT NULL, id int(11) NOT NULL,
...@@ -470,6 +488,8 @@ Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist ...@@ -470,6 +488,8 @@ Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist
TRUNCATE t1; TRUNCATE t1;
Warnings: Warnings:
Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist
SET SESSION spider_error_read_mode = @original_spider_error_read_mode;
SET SESSION spider_error_write_mode = @original_spider_error_write_mode;
3.0 3.0
is null is null
......
...@@ -109,6 +109,10 @@ a b c ...@@ -109,6 +109,10 @@ a b c
2.26 2.26
auto_increment with partition auto_increment with partition
connection master_1; connection master_1;
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
connection slave1_1; connection slave1_1;
connection master_1; connection master_1;
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
...@@ -202,6 +206,7 @@ LAST_INSERT_ID() ...@@ -202,6 +206,7 @@ LAST_INSERT_ID()
SELECT MAX(id) FROM t1; SELECT MAX(id) FROM t1;
MAX(id) MAX(id)
26 26
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
connection slave1_1; connection slave1_1;
SELECT id FROM t1 ORDER BY id; SELECT id FROM t1 ORDER BY id;
id id
......
...@@ -97,6 +97,8 @@ if ($USE_CHILD_GROUP2) ...@@ -97,6 +97,8 @@ if ($USE_CHILD_GROUP2)
} }
} }
--connection master_1 --connection master_1
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
...@@ -222,6 +224,7 @@ SELECT MAX(id) FROM t1; ...@@ -222,6 +224,7 @@ SELECT MAX(id) FROM t1;
INSERT INTO t2 (id) VALUES (1000); INSERT INTO t2 (id) VALUES (1000);
SELECT LAST_INSERT_ID(); SELECT LAST_INSERT_ID();
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
......
...@@ -131,6 +131,8 @@ if ($HAVE_PARTITION) ...@@ -131,6 +131,8 @@ if ($HAVE_PARTITION)
} }
} }
--connection master_1 --connection master_1
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
...@@ -256,6 +258,7 @@ if ($HAVE_PARTITION) ...@@ -256,6 +258,7 @@ if ($HAVE_PARTITION)
INSERT INTO t2 (id) VALUES (1000); INSERT INTO t2 (id) VALUES (1000);
SELECT LAST_INSERT_ID(); SELECT LAST_INSERT_ID();
SELECT MAX(id) FROM t2; SELECT MAX(id) FROM t2;
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
......
...@@ -1049,6 +1049,8 @@ if ($USE_CHILD_GROUP2) ...@@ -1049,6 +1049,8 @@ if ($USE_CHILD_GROUP2)
} }
} }
--connection master_1 --connection master_1
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
...@@ -1120,6 +1122,7 @@ SELECT MAX(id) FROM t1; ...@@ -1120,6 +1122,7 @@ SELECT MAX(id) FROM t1;
INSERT INTO t1 (id) VALUES (1000); INSERT INTO t1 (id) VALUES (1000);
SELECT LAST_INSERT_ID(); SELECT LAST_INSERT_ID();
SELECT MAX(id) FROM t1; SELECT MAX(id) FROM t1;
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
...@@ -1172,6 +1175,8 @@ let $MASTER_1_ENGINE_IS_SPIDER= ...@@ -1172,6 +1175,8 @@ let $MASTER_1_ENGINE_IS_SPIDER=
if ($MASTER_1_ENGINE_IS_SPIDER) if ($MASTER_1_ENGINE_IS_SPIDER)
{ {
--connection master_1 --connection master_1
SET @original_spider_read_only_mode = @@SESSION.spider_read_only_mode;
SET SESSION spider_read_only_mode = -1;
--disable_warnings --disable_warnings
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
--enable_warnings --enable_warnings
...@@ -1197,6 +1202,7 @@ if ($MASTER_1_ENGINE_IS_SPIDER) ...@@ -1197,6 +1202,7 @@ if ($MASTER_1_ENGINE_IS_SPIDER)
DELETE FROM t1; DELETE FROM t1;
--error 12518 --error 12518
TRUNCATE t1; TRUNCATE t1;
SET SESSION spider_read_only_mode = @original_spider_read_only_mode;
} }
if (!$MASTER_1_ENGINE_IS_SPIDER) if (!$MASTER_1_ENGINE_IS_SPIDER)
{ {
...@@ -1210,6 +1216,10 @@ if (!$MASTER_1_ENGINE_IS_SPIDER) ...@@ -1210,6 +1216,10 @@ if (!$MASTER_1_ENGINE_IS_SPIDER)
if ($MASTER_1_ENGINE_IS_SPIDER) if ($MASTER_1_ENGINE_IS_SPIDER)
{ {
--connection master_1 --connection master_1
SET @original_spider_error_read_mode = @@SESSION.spider_error_read_mode;
SET @original_spider_error_write_mode = @@SESSION.spider_error_write_mode;
SET SESSION spider_error_read_mode = -1;
SET SESSION spider_error_write_mode = -1;
--disable_warnings --disable_warnings
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
--enable_warnings --enable_warnings
...@@ -1227,6 +1237,8 @@ if ($MASTER_1_ENGINE_IS_SPIDER) ...@@ -1227,6 +1237,8 @@ if ($MASTER_1_ENGINE_IS_SPIDER)
INSERT INTO t1 (id) VALUES (1); INSERT INTO t1 (id) VALUES (1);
DELETE FROM t1; DELETE FROM t1;
TRUNCATE t1; TRUNCATE t1;
SET SESSION spider_error_read_mode = @original_spider_error_read_mode;
SET SESSION spider_error_write_mode = @original_spider_error_write_mode;
} }
if (!$MASTER_1_ENGINE_IS_SPIDER) if (!$MASTER_1_ENGINE_IS_SPIDER)
{ {
......
...@@ -485,6 +485,8 @@ if ($HAVE_PARTITION) ...@@ -485,6 +485,8 @@ if ($HAVE_PARTITION)
} }
} }
--connection master_1 --connection master_1
SET @original_spider_auto_increment_mode = @@SESSION.spider_auto_increment_mode;
SET SESSION spider_auto_increment_mode = -1;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
...@@ -556,6 +558,7 @@ if ($HAVE_PARTITION) ...@@ -556,6 +558,7 @@ if ($HAVE_PARTITION)
INSERT INTO t1 (id) VALUES (1000); INSERT INTO t1 (id) VALUES (1000);
SELECT LAST_INSERT_ID(); SELECT LAST_INSERT_ID();
SELECT MAX(id) FROM t1; SELECT MAX(id) FROM t1;
SET SESSION spider_auto_increment_mode = @original_spider_auto_increment_mode;
if ($USE_REPLICATION) if ($USE_REPLICATION)
{ {
save_master_pos; save_master_pos;
......
...@@ -413,6 +413,10 @@ connection master_1; ...@@ -413,6 +413,10 @@ connection master_1;
read only read only
connection master_1; connection master_1;
SET @original_spider_read_only_mode = @@SESSION.spider_read_only_mode;
SET SESSION spider_read_only_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
CREATE TABLE t1 ( CREATE TABLE t1 (
id int(11) NOT NULL, id int(11) NOT NULL,
...@@ -441,10 +445,19 @@ DELETE FROM t1; ...@@ -441,10 +445,19 @@ DELETE FROM t1;
ERROR HY000: Table 'auto_test_local.t1' is read only ERROR HY000: Table 'auto_test_local.t1' is read only
TRUNCATE t1; TRUNCATE t1;
ERROR HY000: Table 'auto_test_local.t1' is read only ERROR HY000: Table 'auto_test_local.t1' is read only
SET SESSION spider_read_only_mode = @original_spider_read_only_mode;
2.27 2.27
error mode error mode
connection master_1; connection master_1;
SET @original_spider_error_read_mode = @@SESSION.spider_error_read_mode;
SET @original_spider_error_write_mode = @@SESSION.spider_error_write_mode;
SET SESSION spider_error_read_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
SET SESSION spider_error_write_mode = -1;
Warnings:
Warning 138 The option value -1 (use table value) is deprecated and will be removed in a future release
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
CREATE TABLE t1 ( CREATE TABLE t1 (
id int(11) NOT NULL, id int(11) NOT NULL,
...@@ -466,6 +479,8 @@ Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist ...@@ -466,6 +479,8 @@ Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist
TRUNCATE t1; TRUNCATE t1;
Warnings: Warnings:
Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist Error 1146 Table 'auto_test_remote.ter1_1' doesn't exist
SET SESSION spider_error_read_mode = @original_spider_error_read_mode;
SET SESSION spider_error_write_mode = @original_spider_error_write_mode;
3.0 3.0
is null is null
......
#
# MDEV-27228 Deprecate Spider plugin variables that result in excessive tweak
#
for master_1
for child2
child2_1
child2_2
child2_3
for child3
child3_1
child3_2
child3_3
connection master_1;
CREATE DATABASE auto_test_local;
USE auto_test_local;
# MDEV-27923 Deprecate spider_use_handler
SET spider_use_handler= 3;
Warnings:
Warning 1287 '@@spider_use_handler' is deprecated and will be removed in a future release
SHOW VARIABLES LIKE "spider_use_handler";
Variable_name Value
spider_use_handler 3
CREATE TABLE tbl_a (a INT) ENGINE=Spider COMMENT='uhd "3"';
Warnings:
Warning 1287 The table parameter 'uhd' is deprecated and will be removed in a future release
CREATE TABLE tbl_b (a INT) ENGINE=Spider COMMENT='use_handler "3"';
Warnings:
Warning 1287 The table parameter 'use_handler' is deprecated and will be removed in a future release
DROP DATABASE auto_test_local;
for master_1
for child2
child2_1
child2_2
child2_3
for child3
child3_1
child3_2
child3_3
...@@ -1172,6 +1172,8 @@ let $MASTER_1_ENGINE_IS_SPIDER= ...@@ -1172,6 +1172,8 @@ let $MASTER_1_ENGINE_IS_SPIDER=
if ($MASTER_1_ENGINE_IS_SPIDER) if ($MASTER_1_ENGINE_IS_SPIDER)
{ {
--connection master_1 --connection master_1
SET @original_spider_read_only_mode = @@SESSION.spider_read_only_mode;
SET SESSION spider_read_only_mode = -1;
--disable_warnings --disable_warnings
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
--enable_warnings --enable_warnings
...@@ -1197,6 +1199,7 @@ if ($MASTER_1_ENGINE_IS_SPIDER) ...@@ -1197,6 +1199,7 @@ if ($MASTER_1_ENGINE_IS_SPIDER)
DELETE FROM t1; DELETE FROM t1;
--error 12518 --error 12518
TRUNCATE t1; TRUNCATE t1;
SET SESSION spider_read_only_mode = @original_spider_read_only_mode;
} }
if (!$MASTER_1_ENGINE_IS_SPIDER) if (!$MASTER_1_ENGINE_IS_SPIDER)
{ {
...@@ -1210,6 +1213,10 @@ if (!$MASTER_1_ENGINE_IS_SPIDER) ...@@ -1210,6 +1213,10 @@ if (!$MASTER_1_ENGINE_IS_SPIDER)
if ($MASTER_1_ENGINE_IS_SPIDER) if ($MASTER_1_ENGINE_IS_SPIDER)
{ {
--connection master_1 --connection master_1
SET @original_spider_error_read_mode = @@SESSION.spider_error_read_mode;
SET @original_spider_error_write_mode = @@SESSION.spider_error_write_mode;
SET SESSION spider_error_read_mode = -1;
SET SESSION spider_error_write_mode = -1;
--disable_warnings --disable_warnings
DROP TABLE IF EXISTS t1; DROP TABLE IF EXISTS t1;
--enable_warnings --enable_warnings
...@@ -1227,6 +1234,8 @@ if ($MASTER_1_ENGINE_IS_SPIDER) ...@@ -1227,6 +1234,8 @@ if ($MASTER_1_ENGINE_IS_SPIDER)
INSERT INTO t1 (id) VALUES (1); INSERT INTO t1 (id) VALUES (1);
DELETE FROM t1; DELETE FROM t1;
TRUNCATE t1; TRUNCATE t1;
SET SESSION spider_error_read_mode = @original_spider_error_read_mode;
SET SESSION spider_error_write_mode = @original_spider_error_write_mode;
} }
if (!$MASTER_1_ENGINE_IS_SPIDER) if (!$MASTER_1_ENGINE_IS_SPIDER)
{ {
......
--echo #
--echo # MDEV-27228 Deprecate Spider plugin variables that result in excessive tweak
--echo #
--disable_query_log
--disable_result_log
--source test_init.inc
--enable_result_log
--enable_query_log
--connection master_1
CREATE DATABASE auto_test_local;
USE auto_test_local;
--echo # MDEV-27923 Deprecate spider_use_handler
SET spider_use_handler= 3;
SHOW VARIABLES LIKE "spider_use_handler";
eval CREATE TABLE tbl_a (a INT) $MASTER_1_ENGINE COMMENT='uhd "3"';
eval CREATE TABLE tbl_b (a INT) $MASTER_1_ENGINE COMMENT='use_handler "3"';
DROP DATABASE auto_test_local;
--disable_query_log
--disable_result_log
--source test_deinit.inc
--enable_result_log
--enable_query_log
This diff is collapsed.
...@@ -2009,6 +2009,16 @@ int st_spider_param_string_parse::print_param_error() ...@@ -2009,6 +2009,16 @@ int st_spider_param_string_parse::print_param_error()
} \ } \
break; \ break; \
} }
#define SPIDER_PARAM_DEPRECATED_WARNING(title_name) \
if (!strncasecmp(tmp_ptr, title_name, title_length) && create_table) \
{ \
THD *thd= current_thd; \
push_warning_printf(thd, Sql_condition::WARN_LEVEL_WARN, \
ER_WARN_DEPRECATED_SYNTAX, \
"The table parameter '%s' is deprecated and will be " \
"removed in a future release", \
title_name); \
}
/* /*
Set a given engine-defined option, which holds a string list, to the Set a given engine-defined option, which holds a string list, to the
...@@ -2409,6 +2419,7 @@ int spider_parse_connect_info( ...@@ -2409,6 +2419,7 @@ int spider_parse_connect_info(
option_struct && option_struct &&
option_struct->remote_table); option_struct->remote_table);
SPIDER_PARAM_INT_WITH_MAX("tcm", table_count_mode, 0, 3); SPIDER_PARAM_INT_WITH_MAX("tcm", table_count_mode, 0, 3);
SPIDER_PARAM_DEPRECATED_WARNING("uhd");
SPIDER_PARAM_LONG_LIST_WITH_MAX("uhd", use_handlers, 0, 3); SPIDER_PARAM_LONG_LIST_WITH_MAX("uhd", use_handlers, 0, 3);
SPIDER_PARAM_INT_WITH_MAX("upu", use_pushdown_udf, 0, 1); SPIDER_PARAM_INT_WITH_MAX("upu", use_pushdown_udf, 0, 1);
SPIDER_PARAM_INT_WITH_MAX("utc", use_table_charset, 0, 1); SPIDER_PARAM_INT_WITH_MAX("utc", use_table_charset, 0, 1);
...@@ -2492,6 +2503,7 @@ int spider_parse_connect_info( ...@@ -2492,6 +2503,7 @@ int spider_parse_connect_info(
SPIDER_PARAM_INT_WITH_MAX("sts_bg_mode", sts_bg_mode, 0, 2); SPIDER_PARAM_INT_WITH_MAX("sts_bg_mode", sts_bg_mode, 0, 2);
#endif #endif
SPIDER_PARAM_LONG_LIST_WITH_MAX("link_status", link_statuses, 0, 3); SPIDER_PARAM_LONG_LIST_WITH_MAX("link_status", link_statuses, 0, 3);
SPIDER_PARAM_DEPRECATED_WARNING("use_handler");
SPIDER_PARAM_LONG_LIST_WITH_MAX("use_handler", use_handlers, 0, 3); SPIDER_PARAM_LONG_LIST_WITH_MAX("use_handler", use_handlers, 0, 3);
SPIDER_PARAM_INT_WITH_MAX("casual_read", casual_read, 0, 63); SPIDER_PARAM_INT_WITH_MAX("casual_read", casual_read, 0, 63);
SPIDER_PARAM_INT("buffer_size", buffer_size, 0); SPIDER_PARAM_INT("buffer_size", buffer_size, 0);
......
...@@ -738,10 +738,11 @@ size_t my_vsnprintf_ex(CHARSET_INFO *cs, char *to, size_t n, ...@@ -738,10 +738,11 @@ size_t my_vsnprintf_ex(CHARSET_INFO *cs, char *to, size_t n,
} }
else if (*fmt == 'f' || *fmt == 'g') else if (*fmt == 'f' || *fmt == 'g')
{ {
double d;
#if __has_feature(memory_sanitizer) /* QQ: MSAN has double trouble? */ #if __has_feature(memory_sanitizer) /* QQ: MSAN has double trouble? */
__msan_check_mem_is_initialized(ap, sizeof(double)); __msan_check_mem_is_initialized(ap, sizeof(double));
#endif #endif
double d= va_arg(ap, double); d= va_arg(ap, double);
#if __has_feature(memory_sanitizer) /* QQ: MSAN has double trouble? */ #if __has_feature(memory_sanitizer) /* QQ: MSAN has double trouble? */
__msan_unpoison(&d, sizeof(double)); __msan_unpoison(&d, sizeof(double));
#endif #endif
......
...@@ -161,6 +161,8 @@ class aio_uring final : public tpool::aio ...@@ -161,6 +161,8 @@ class aio_uring final : public tpool::aio
} }
io_uring_cqe_seen(&aio->uring_, cqe); io_uring_cqe_seen(&aio->uring_, cqe);
if (iocb->m_ret_len != iocb->m_len && !iocb->m_err)
finish_synchronous(iocb);
// If we need to resubmit the IO operation, but the ring is full, // If we need to resubmit the IO operation, but the ring is full,
// we will follow the same path as for any other error codes. // we will follow the same path as for any other error codes.
......
...@@ -128,6 +128,8 @@ class aio_linux final : public aio ...@@ -128,6 +128,8 @@ class aio_linux final : public aio
{ {
iocb->m_ret_len= event.res; iocb->m_ret_len= event.res;
iocb->m_err= 0; iocb->m_err= 0;
if (iocb->m_ret_len != iocb->m_len)
finish_synchronous(iocb);
} }
iocb->m_internal_task.m_func= iocb->m_callback; iocb->m_internal_task.m_func= iocb->m_callback;
iocb->m_internal_task.m_arg= iocb; iocb->m_internal_task.m_arg= iocb;
......
...@@ -136,32 +136,7 @@ class simulated_aio : public aio ...@@ -136,32 +136,7 @@ class simulated_aio : public aio
static void simulated_aio_callback(void *param) static void simulated_aio_callback(void *param)
{ {
aiocb *cb= (aiocb *) param; aiocb *cb= (aiocb *) param;
#ifdef _WIN32 synchronous(cb);
size_t ret_len;
#else
ssize_t ret_len;
#endif
int err= 0;
switch (cb->m_opcode)
{
case aio_opcode::AIO_PREAD:
ret_len= pread(cb->m_fh, cb->m_buffer, cb->m_len, cb->m_offset);
break;
case aio_opcode::AIO_PWRITE:
ret_len= pwrite(cb->m_fh, cb->m_buffer, cb->m_len, cb->m_offset);
break;
default:
abort();
}
#ifdef _WIN32
if (static_cast<int>(ret_len) < 0)
err= GetLastError();
#else
if (ret_len < 0)
err= errno;
#endif
cb->m_ret_len = ret_len;
cb->m_err = err;
cb->m_internal_task.m_func= cb->m_callback; cb->m_internal_task.m_func= cb->m_callback;
thread_pool *pool= (thread_pool *)cb->m_internal; thread_pool *pool= (thread_pool *)cb->m_internal;
pool->submit_task(&cb->m_internal_task); pool->submit_task(&cb->m_internal_task);
......
...@@ -161,7 +161,7 @@ class aio ...@@ -161,7 +161,7 @@ class aio
{ {
public: public:
/** /**
Submit asyncronous IO. Submit asynchronous IO.
On completion, cb->m_callback is executed. On completion, cb->m_callback is executed.
*/ */
virtual int submit_io(aiocb *cb)= 0; virtual int submit_io(aiocb *cb)= 0;
...@@ -170,6 +170,10 @@ class aio ...@@ -170,6 +170,10 @@ class aio
/** "Unind" file to AIO handler (used on Windows only) */ /** "Unind" file to AIO handler (used on Windows only) */
virtual int unbind(const native_file_handle &fd)= 0; virtual int unbind(const native_file_handle &fd)= 0;
virtual ~aio(){}; virtual ~aio(){};
protected:
static void synchronous(aiocb *cb);
/** finish a partial read/write callback synchronously */
static void finish_synchronous(aiocb *cb);
}; };
class timer class timer
......
...@@ -51,6 +51,58 @@ namespace tpool ...@@ -51,6 +51,58 @@ namespace tpool
static const std::chrono::milliseconds LONG_TASK_DURATION = std::chrono::milliseconds(500); static const std::chrono::milliseconds LONG_TASK_DURATION = std::chrono::milliseconds(500);
static const int OVERSUBSCRIBE_FACTOR = 2; static const int OVERSUBSCRIBE_FACTOR = 2;
/**
Process the cb synchronously
*/
void aio::synchronous(aiocb *cb)
{
#ifdef _WIN32
size_t ret_len;
#else
ssize_t ret_len;
#endif
int err= 0;
switch (cb->m_opcode)
{
case aio_opcode::AIO_PREAD:
ret_len= pread(cb->m_fh, cb->m_buffer, cb->m_len, cb->m_offset);
break;
case aio_opcode::AIO_PWRITE:
ret_len= pwrite(cb->m_fh, cb->m_buffer, cb->m_len, cb->m_offset);
break;
default:
abort();
}
#ifdef _WIN32
if (static_cast<int>(ret_len) < 0)
err= GetLastError();
#else
if (ret_len < 0)
{
err= errno;
ret_len= 0;
}
#endif
cb->m_ret_len = ret_len;
cb->m_err = err;
if (!err && cb->m_ret_len != cb->m_len)
finish_synchronous(cb);
}
/**
A partial read/write has occured, continue synchronously.
*/
void aio::finish_synchronous(aiocb *cb)
{
assert(cb->m_ret_len != (unsigned int) cb->m_len && !cb->m_err);
/* partial read/write */
cb->m_buffer= (char *) cb->m_buffer + cb->m_ret_len;
cb->m_len-= (unsigned int) cb->m_ret_len;
cb->m_offset+= cb->m_ret_len;
synchronous(cb);
}
/** /**
Implementation of generic threadpool. Implementation of generic threadpool.
This threadpool consists of the following components This threadpool consists of the following components
......
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