Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
f31bf6f0
Commit
f31bf6f0
authored
Jan 19, 2020
by
Oleksandr Byelkin
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch '5.5' into 10.1
parents
02af6278
4d1c1b23
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
118 additions
and
43 deletions
+118
-43
mysql-test/r/connect_debug.result
mysql-test/r/connect_debug.result
+8
-0
mysql-test/r/insert_debug.result
mysql-test/r/insert_debug.result
+25
-0
mysql-test/r/uniques_crash-7912.result
mysql-test/r/uniques_crash-7912.result
+0
-11
mysql-test/t/connect_debug.test
mysql-test/t/connect_debug.test
+15
-0
mysql-test/t/insert_debug-master.opt
mysql-test/t/insert_debug-master.opt
+1
-0
mysql-test/t/insert_debug.test
mysql-test/t/insert_debug.test
+54
-0
mysql-test/t/uniques_crash-7912.test
mysql-test/t/uniques_crash-7912.test
+0
-26
sql-common/client.c
sql-common/client.c
+4
-1
sql/slave.cc
sql/slave.cc
+2
-2
sql/sql_acl.cc
sql/sql_acl.cc
+1
-0
sql/sql_class.h
sql/sql_class.h
+8
-3
No files found.
mysql-test/r/connect_debug.result
View file @
f31bf6f0
...
@@ -8,3 +8,11 @@ create user 'bad' identified by 'worse';
...
@@ -8,3 +8,11 @@ create user 'bad' identified by 'worse';
ERROR 2059 (HY000): Authentication plugin 'foo/bar' cannot be loaded: invalid plugin name
ERROR 2059 (HY000): Authentication plugin 'foo/bar' cannot be loaded: invalid plugin name
set global debug_dbug=@old_dbug;
set global debug_dbug=@old_dbug;
drop user bad;
drop user bad;
set global debug_dbug='+d,increase_srv_handshake_scramble_len';
connect(localhost,root,,test,MASTER_MYPORT,MYSQL_TMP_DIR/mysqld.1.sock);
ERROR HY000: Malformed packet
set global debug_dbug=@old_dbug;
set global debug_dbug='+d,poison_srv_handshake_scramble_len';
connect(localhost,root,,test,MASTER_MYPORT,MYSQL_TMP_DIR/mysqld.1.sock);
ERROR HY000: Malformed packet
set global debug_dbug=@old_dbug;
mysql-test/r/insert_debug.result
0 → 100644
View file @
f31bf6f0
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
CREATE TABLE t1(c1 VARCHAR(10) NOT NULL, c2 VARCHAR(10) NOT NULL, c3 VARCHAR(10) NOT NULL);
INSERT INTO t1(c1, c2, c3) VALUES('A1','B1','IT1'), ('A2','B2','IT1'), ('A3','B3','IT1'), ('A4','B4','IT1'), ('A5','B5','IT1'), ('A6','B6','IT1'), ('A7','B7','IT1');
CREATE TABLE t2(c1 VARCHAR(10) NOT NULL, c2 VARCHAR(10) NOT NULL, c3 VARCHAR(10) NOT NULL);
INSERT INTO t2(c1, c2, c3) VALUES ('A3','B3','IT2'), ('A2','B2','IT2'), ('A4','B4','IT2'), ('A5','B5','II2');
CREATE TABLE result(id BIGINT UNSIGNED NOT NULL AUTO_INCREMENT, c1 VARCHAR(10) NOT NULL, c2 VARCHAR(10),
c3 VARCHAR(10), update_count INT DEFAULT 0, UNIQUE KEY uniq_idx (c1,c2), PRIMARY KEY (id)) ENGINE = innodb;
SET DEBUG_SYNC = "ha_write_row_end WAIT_FOR flushed EXECUTE 1";
INSERT INTO result(c1, c2, c3) SELECT * FROM t1 ON DUPLICATE KEY UPDATE c2=t1.c2, c3='UT1', update_count=update_count+1;
INSERT INTO result(c1, c2, c3) SELECT * FROM t2 ON DUPLICATE KEY UPDATE c2=t2.c2, c3='UT2', update_count=update_count+1;
SET DEBUG_SYNC = "now SIGNAL flushed";
SELECT * FROM result;
id c1 c2 c3 update_count
1 A1 B1 IT1 0
2 A3 B3 UT1 1
3 A2 B2 UT1 1
4 A4 B4 UT1 1
5 A5 B5 UT1 1
9 A6 B6 IT1 0
10 A7 B7 IT1 0
DROP TABLE t1;
DROP TABLE t2;
DROP TABLE result;
SET DEBUG_SYNC = "RESET";
mysql-test/r/uniques_crash-7912.result
deleted
100644 → 0
View file @
02af6278
call mtr.add_suppression("Out of memory");
set sql_mode="";
drop table if exists t1,t2;
create table `t1` (`a` datetime not null) engine=InnoDB;
create table `t2` (`a` int not null) engine=innodb;
replace into t1 values (),();
insert into t2 values(0);
set session sort_buffer_size = 1024*1024*1024*1024;
delete d2 from t2 as d1, t1 as d2 where d1.a <=> d2.a;
drop table t2;
drop table t1;
mysql-test/t/connect_debug.test
View file @
f31bf6f0
...
@@ -21,3 +21,18 @@ create user 'bad' identified by 'worse';
...
@@ -21,3 +21,18 @@ create user 'bad' identified by 'worse';
--
exec
$MYSQL
--
default
-
auth
=
mysql_old_password
--
user
=
bad
--
password
=
worse
2
>&
1
--
exec
$MYSQL
--
default
-
auth
=
mysql_old_password
--
user
=
bad
--
password
=
worse
2
>&
1
set
global
debug_dbug
=@
old_dbug
;
set
global
debug_dbug
=@
old_dbug
;
drop
user
bad
;
drop
user
bad
;
#
# Bug#29630767 - USE OF UNINITIALIZED VALUE IN LIBMYSQL (CLIENT.CC FUNCTION RUN_PLUGIN_AUTH)
#
set
global
debug_dbug
=
'+d,increase_srv_handshake_scramble_len'
;
--
replace_result
$MYSQL_TMP_DIR
MYSQL_TMP_DIR
$MASTER_MYPORT
MASTER_MYPORT
--
error
2027
connect
con1
,
localhost
,
root
;
set
global
debug_dbug
=@
old_dbug
;
set
global
debug_dbug
=
'+d,poison_srv_handshake_scramble_len'
;
--
replace_result
$MYSQL_TMP_DIR
MYSQL_TMP_DIR
$MASTER_MYPORT
MASTER_MYPORT
--
error
2027
connect
con2
,
localhost
,
root
;
set
global
debug_dbug
=@
old_dbug
;
mysql-test/t/insert_debug-master.opt
0 → 100644
View file @
f31bf6f0
--innodb_autoinc_lock_mode=2
mysql-test/t/insert_debug.test
0 → 100644
View file @
f31bf6f0
source
include
/
have_innodb
.
inc
;
source
include
/
have_debug
.
inc
;
source
include
/
have_debug_sync
.
inc
;
SET
SESSION
TRANSACTION
ISOLATION
LEVEL
READ
COMMITTED
;
connect
(
con1
,
localhost
,
root
,,);
SET
SESSION
TRANSACTION
ISOLATION
LEVEL
READ
COMMITTED
;
connection
default
;
let
$conn0_id
=
`SELECT CONNECTION_ID()`
;
CREATE
TABLE
t1
(
c1
VARCHAR
(
10
)
NOT
NULL
,
c2
VARCHAR
(
10
)
NOT
NULL
,
c3
VARCHAR
(
10
)
NOT
NULL
);
INSERT
INTO
t1
(
c1
,
c2
,
c3
)
VALUES
(
'A1'
,
'B1'
,
'IT1'
),
(
'A2'
,
'B2'
,
'IT1'
),
(
'A3'
,
'B3'
,
'IT1'
),
(
'A4'
,
'B4'
,
'IT1'
),
(
'A5'
,
'B5'
,
'IT1'
),
(
'A6'
,
'B6'
,
'IT1'
),
(
'A7'
,
'B7'
,
'IT1'
);
CREATE
TABLE
t2
(
c1
VARCHAR
(
10
)
NOT
NULL
,
c2
VARCHAR
(
10
)
NOT
NULL
,
c3
VARCHAR
(
10
)
NOT
NULL
);
INSERT
INTO
t2
(
c1
,
c2
,
c3
)
VALUES
(
'A3'
,
'B3'
,
'IT2'
),
(
'A2'
,
'B2'
,
'IT2'
),
(
'A4'
,
'B4'
,
'IT2'
),
(
'A5'
,
'B5'
,
'II2'
);
CREATE
TABLE
result
(
id
BIGINT
UNSIGNED
NOT
NULL
AUTO_INCREMENT
,
c1
VARCHAR
(
10
)
NOT
NULL
,
c2
VARCHAR
(
10
),
c3
VARCHAR
(
10
),
update_count
INT
DEFAULT
0
,
UNIQUE
KEY
uniq_idx
(
c1
,
c2
),
PRIMARY
KEY
(
id
))
ENGINE
=
innodb
;
# Insert one row from 't1' into the 'result' table and wait on a debug sync
# point. The next insert statement from an session 2 inserts values that would
# lead to unique key clash, when this insert resumes.
# The subsequent inserts of this statement(after resume) will fail because of a
# clash with the unique index, and are expected to update the row which clashes
# with the unique key.
# Without the fix for bug#30194841 a stale auto increment value, would cause a
# collision with existing auto increment column value and ends up updating that
# colliding row, instead of the row colliding with the unique index.
SET
DEBUG_SYNC
=
"ha_write_row_end WAIT_FOR flushed EXECUTE 1"
;
send
INSERT
INTO
result
(
c1
,
c2
,
c3
)
SELECT
*
FROM
t1
ON
DUPLICATE
KEY
UPDATE
c2
=
t1
.
c2
,
c3
=
'UT1'
,
update_count
=
update_count
+
1
;
# While session 1 is waiting (after one insert), insert rows that will cause a clash
# with the inserts of session 1 on the unique key.
connection
con1
;
# Wait for the session 1 to hit the debug sync point.
let
$wait_condition
=
SELECT
1
FROM
information_schema
.
processlist
WHERE
id
=
$conn0_id
AND
state
LIKE
'%ha_write_row_end%'
;
--
source
include
/
wait_condition
.
inc
INSERT
INTO
result
(
c1
,
c2
,
c3
)
SELECT
*
FROM
t2
ON
DUPLICATE
KEY
UPDATE
c2
=
t2
.
c2
,
c3
=
'UT2'
,
update_count
=
update_count
+
1
;
# Signal to resume the insert statement in session 1
SET
DEBUG_SYNC
=
"now SIGNAL flushed"
;
connection
default
;
reap
;
SELECT
*
FROM
result
;
DROP
TABLE
t1
;
DROP
TABLE
t2
;
DROP
TABLE
result
;
SET
DEBUG_SYNC
=
"RESET"
;
mysql-test/t/uniques_crash-7912.test
deleted
100644 → 0
View file @
02af6278
#
# MDEV-7912
#
# multitable delete with wrongly set sort_buffer_size crashes in merge_buffers
--
source
include
/
have_innodb
.
inc
--
source
include
/
have_debug
.
inc
--
source
include
/
windows
.
inc
call
mtr
.
add_suppression
(
"Out of memory"
);
set
sql_mode
=
""
;
--
disable_warnings
drop
table
if
exists
t1
,
t2
;
create
table
`t1`
(
`a`
datetime
not
null
)
engine
=
InnoDB
;
create
table
`t2`
(
`a`
int
not
null
)
engine
=
innodb
;
replace
into
t1
values
(),();
insert
into
t2
values
(
0
);
set
session
sort_buffer_size
=
1024
*
1024
*
1024
*
1024
;
#Either fail with EE_OUTOFMEMORY, or succeed
--
error
0
,
5
delete
d2
from
t2
as
d1
,
t1
as
d2
where
d1
.
a
<=>
d2
.
a
;
--
enable_warnings
drop
table
t2
;
drop
table
t1
;
sql-common/client.c
View file @
f31bf6f0
...
@@ -3588,7 +3588,10 @@ CLI_MYSQL_REAL_CONNECT(MYSQL *mysql,const char *host, const char *user,
...
@@ -3588,7 +3588,10 @@ CLI_MYSQL_REAL_CONNECT(MYSQL *mysql,const char *host, const char *user,
scramble_data_len
=
pkt_scramble_len
;
scramble_data_len
=
pkt_scramble_len
;
scramble_plugin
=
scramble_data
+
scramble_data_len
;
scramble_plugin
=
scramble_data
+
scramble_data_len
;
if
(
scramble_data
+
scramble_data_len
>
pkt_end
)
if
(
scramble_data
+
scramble_data_len
>
pkt_end
)
scramble_data_len
=
pkt_end
-
scramble_data
;
{
set_mysql_error
(
mysql
,
CR_MALFORMED_PACKET
,
unknown_sqlstate
);
goto
error
;
}
}
}
else
else
{
{
...
...
sql/slave.cc
View file @
f31bf6f0
...
@@ -5920,7 +5920,7 @@ static int queue_event(Master_info* mi,const char* buf, ulong event_len)
...
@@ -5920,7 +5920,7 @@ static int queue_event(Master_info* mi,const char* buf, ulong event_len)
error
=
ER_SLAVE_HEARTBEAT_FAILURE
;
error
=
ER_SLAVE_HEARTBEAT_FAILURE
;
error_msg
.
append
(
STRING_WITH_LEN
(
"inconsistent heartbeat event content;"
));
error_msg
.
append
(
STRING_WITH_LEN
(
"inconsistent heartbeat event content;"
));
error_msg
.
append
(
STRING_WITH_LEN
(
"the event's data: log_file_name "
));
error_msg
.
append
(
STRING_WITH_LEN
(
"the event's data: log_file_name "
));
error_msg
.
append
(
hb
.
get_log_ident
(),
(
uint
)
strlen
(
hb
.
get_log_ident
()
));
error_msg
.
append
(
hb
.
get_log_ident
(),
(
uint
)
hb
.
get_ident_len
(
));
error_msg
.
append
(
STRING_WITH_LEN
(
" log_pos "
));
error_msg
.
append
(
STRING_WITH_LEN
(
" log_pos "
));
error_msg
.
append_ulonglong
(
hb
.
log_pos
);
error_msg
.
append_ulonglong
(
hb
.
log_pos
);
goto
err
;
goto
err
;
...
@@ -5947,7 +5947,7 @@ static int queue_event(Master_info* mi,const char* buf, ulong event_len)
...
@@ -5947,7 +5947,7 @@ static int queue_event(Master_info* mi,const char* buf, ulong event_len)
error
=
ER_SLAVE_HEARTBEAT_FAILURE
;
error
=
ER_SLAVE_HEARTBEAT_FAILURE
;
error_msg
.
append
(
STRING_WITH_LEN
(
"heartbeat is not compatible with local info;"
));
error_msg
.
append
(
STRING_WITH_LEN
(
"heartbeat is not compatible with local info;"
));
error_msg
.
append
(
STRING_WITH_LEN
(
"the event's data: log_file_name "
));
error_msg
.
append
(
STRING_WITH_LEN
(
"the event's data: log_file_name "
));
error_msg
.
append
(
hb
.
get_log_ident
(),
(
uint
)
strlen
(
hb
.
get_log_ident
()
));
error_msg
.
append
(
hb
.
get_log_ident
(),
(
uint
)
hb
.
get_ident_len
(
));
error_msg
.
append
(
STRING_WITH_LEN
(
" log_pos "
));
error_msg
.
append
(
STRING_WITH_LEN
(
" log_pos "
));
error_msg
.
append_ulonglong
(
hb
.
log_pos
);
error_msg
.
append_ulonglong
(
hb
.
log_pos
);
goto
err
;
goto
err
;
...
...
sql/sql_acl.cc
View file @
f31bf6f0
...
@@ -11430,6 +11430,7 @@ static bool send_server_handshake_packet(MPVIO_EXT *mpvio,
...
@@ -11430,6 +11430,7 @@ static bool send_server_handshake_packet(MPVIO_EXT *mpvio,
int2store
(
end
+
5
,
thd
->
client_capabilities
>>
16
);
int2store
(
end
+
5
,
thd
->
client_capabilities
>>
16
);
end
[
7
]
=
data_len
;
end
[
7
]
=
data_len
;
DBUG_EXECUTE_IF
(
"poison_srv_handshake_scramble_len"
,
end
[
7
]
=
-
100
;);
DBUG_EXECUTE_IF
(
"poison_srv_handshake_scramble_len"
,
end
[
7
]
=
-
100
;);
DBUG_EXECUTE_IF
(
"increase_srv_handshake_scramble_len"
,
end
[
7
]
=
50
;);
bzero
(
end
+
8
,
10
);
bzero
(
end
+
8
,
10
);
end
+=
18
;
end
+=
18
;
/* write scramble tail */
/* write scramble tail */
...
...
sql/sql_class.h
View file @
f31bf6f0
...
@@ -5161,16 +5161,21 @@ user_var_entry *get_variable(HASH *hash, LEX_STRING &name,
...
@@ -5161,16 +5161,21 @@ user_var_entry *get_variable(HASH *hash, LEX_STRING &name,
class
Unique
:
public
Sql_alloc
class
Unique
:
public
Sql_alloc
{
{
DYNAMIC_ARRAY
file_ptrs
;
DYNAMIC_ARRAY
file_ptrs
;
ulong
max_elements
;
ulong
max_elements
;
/* Total number of elements that will be stored in-memory */
ulonglong
max_in_memory_size
;
ulonglong
max_in_memory_size
;
IO_CACHE
file
;
IO_CACHE
file
;
TREE
tree
;
TREE
tree
;
uchar
*
record_pointers
;
uchar
*
record_pointers
;
/* Number of elements filtered out due to min_dupl_count when storing results
to table. See Unique::get */
ulong
filtered_out_elems
;
ulong
filtered_out_elems
;
bool
flush
();
bool
flush
();
uint
size
;
uint
size
;
uint
full_size
;
uint
full_size
;
/* Size of element + space needed to store the number of
uint
min_dupl_count
;
/* always 0 for unions, > 0 for intersections */
duplicates found for the element. */
uint
min_dupl_count
;
/* Minimum number of occurences of element required for
it to be written to record_pointers.
always 0 for unions, > 0 for intersections */
bool
with_counters
;
bool
with_counters
;
bool
merge
(
TABLE
*
table
,
uchar
*
buff
,
bool
without_last_merge
);
bool
merge
(
TABLE
*
table
,
uchar
*
buff
,
bool
without_last_merge
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment