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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
c798a886
Commit
c798a886
authored
Jul 18, 2003
by
lenz@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge lgrimmer@build.mysql.com:/home/bk/mysql-4.0
into mysql.com:/space/my/mysql-4.0
parents
4166b73d
4d299ef1
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
56 additions
and
16 deletions
+56
-16
myisam/mi_check.c
myisam/mi_check.c
+18
-4
myisam/mi_key.c
myisam/mi_key.c
+1
-1
mysql-test/r/insert_select.result
mysql-test/r/insert_select.result
+5
-0
mysql-test/t/insert_select.test
mysql-test/t/insert_select.test
+10
-0
mysys/safemalloc.c
mysys/safemalloc.c
+3
-3
mysys/thr_lock.c
mysys/thr_lock.c
+14
-7
sql/sql_acl.cc
sql/sql_acl.cc
+5
-1
No files found.
myisam/mi_check.c
View file @
c798a886
...
@@ -896,7 +896,8 @@ int chk_data_link(MI_CHECK *param, MI_INFO *info,int extend)
...
@@ -896,7 +896,8 @@ int chk_data_link(MI_CHECK *param, MI_INFO *info,int extend)
if
(
_mi_rec_unpack
(
info
,
record
,
info
->
rec_buff
,
block_info
.
rec_len
)
==
if
(
_mi_rec_unpack
(
info
,
record
,
info
->
rec_buff
,
block_info
.
rec_len
)
==
MY_FILE_ERROR
)
MY_FILE_ERROR
)
{
{
mi_check_print_error
(
param
,
"Found wrong record at %s"
,
llstr
(
start_recpos
,
llbuff
));
mi_check_print_error
(
param
,
"Found wrong record at %s"
,
llstr
(
start_recpos
,
llbuff
));
got_error
=
1
;
got_error
=
1
;
}
}
else
else
...
@@ -3611,6 +3612,7 @@ err:
...
@@ -3611,6 +3612,7 @@ err:
void
update_auto_increment_key
(
MI_CHECK
*
param
,
MI_INFO
*
info
,
void
update_auto_increment_key
(
MI_CHECK
*
param
,
MI_INFO
*
info
,
my_bool
repair_only
)
my_bool
repair_only
)
{
{
byte
*
record
;
if
(
!
info
->
s
->
base
.
auto_key
||
if
(
!
info
->
s
->
base
.
auto_key
||
!
(((
ulonglong
)
1
<<
(
info
->
s
->
base
.
auto_key
-
1
)
!
(((
ulonglong
)
1
<<
(
info
->
s
->
base
.
auto_key
-
1
)
&
info
->
s
->
state
.
key_map
)))
&
info
->
s
->
state
.
key_map
)))
...
@@ -3624,13 +3626,24 @@ void update_auto_increment_key(MI_CHECK *param, MI_INFO *info,
...
@@ -3624,13 +3626,24 @@ void update_auto_increment_key(MI_CHECK *param, MI_INFO *info,
if
(
!
(
param
->
testflag
&
T_SILENT
)
&&
if
(
!
(
param
->
testflag
&
T_SILENT
)
&&
!
(
param
->
testflag
&
T_REP
))
!
(
param
->
testflag
&
T_REP
))
printf
(
"Updating MyISAM file: %s
\n
"
,
param
->
isam_file_name
);
printf
(
"Updating MyISAM file: %s
\n
"
,
param
->
isam_file_name
);
/* We have to use keyread here as a normal read uses info->rec_buff */
/*
We have to use an allocated buffer instead of info->rec_buff as
_mi_put_key_in_record() may use info->rec_buff
*/
if
(
!
(
record
=
(
byte
*
)
my_malloc
((
uint
)
info
->
s
->
base
.
pack_reclength
,
MYF
(
0
))))
{
mi_check_print_error
(
param
,
"Not enough memory for extra record"
);
return
;
}
mi_extra
(
info
,
HA_EXTRA_KEYREAD
,
0
);
mi_extra
(
info
,
HA_EXTRA_KEYREAD
,
0
);
if
(
mi_rlast
(
info
,
info
->
rec_buff
,
info
->
s
->
base
.
auto_key
-
1
))
if
(
mi_rlast
(
info
,
record
,
info
->
s
->
base
.
auto_key
-
1
))
{
{
if
(
my_errno
!=
HA_ERR_END_OF_FILE
)
if
(
my_errno
!=
HA_ERR_END_OF_FILE
)
{
{
mi_extra
(
info
,
HA_EXTRA_NO_KEYREAD
,
0
);
mi_extra
(
info
,
HA_EXTRA_NO_KEYREAD
,
0
);
my_free
((
char
*
)
record
,
MYF
(
0
));
mi_check_print_error
(
param
,
"%d when reading last record"
,
my_errno
);
mi_check_print_error
(
param
,
"%d when reading last record"
,
my_errno
);
return
;
return
;
}
}
...
@@ -3642,10 +3655,11 @@ void update_auto_increment_key(MI_CHECK *param, MI_INFO *info,
...
@@ -3642,10 +3655,11 @@ void update_auto_increment_key(MI_CHECK *param, MI_INFO *info,
ulonglong
auto_increment
=
(
repair_only
?
info
->
s
->
state
.
auto_increment
:
ulonglong
auto_increment
=
(
repair_only
?
info
->
s
->
state
.
auto_increment
:
param
->
auto_increment_value
);
param
->
auto_increment_value
);
info
->
s
->
state
.
auto_increment
=
0
;
info
->
s
->
state
.
auto_increment
=
0
;
update_auto_increment
(
info
,
info
->
rec_buff
);
update_auto_increment
(
info
,
record
);
set_if_bigger
(
info
->
s
->
state
.
auto_increment
,
auto_increment
);
set_if_bigger
(
info
->
s
->
state
.
auto_increment
,
auto_increment
);
}
}
mi_extra
(
info
,
HA_EXTRA_NO_KEYREAD
,
0
);
mi_extra
(
info
,
HA_EXTRA_NO_KEYREAD
,
0
);
my_free
((
char
*
)
record
,
MYF
(
0
));
update_state_info
(
param
,
info
,
UPDATE_AUTO_INC
);
update_state_info
(
param
,
info
,
UPDATE_AUTO_INC
);
return
;
return
;
}
}
...
...
myisam/mi_key.c
View file @
c798a886
...
@@ -264,7 +264,7 @@ static int _mi_put_key_in_record(register MI_INFO *info, uint keynr,
...
@@ -264,7 +264,7 @@ static int _mi_put_key_in_record(register MI_INFO *info, uint keynr,
byte
*
blob_ptr
;
byte
*
blob_ptr
;
DBUG_ENTER
(
"_mi_put_key_in_record"
);
DBUG_ENTER
(
"_mi_put_key_in_record"
);
if
(
info
->
blobs
&&
info
->
s
->
keyinfo
[
keynr
].
flag
&
HA_VAR_LENGTH_KEY
)
if
(
info
->
s
->
base
.
blobs
&&
info
->
s
->
keyinfo
[
keynr
].
flag
&
HA_VAR_LENGTH_KEY
)
{
{
if
(
!
(
blob_ptr
=
if
(
!
(
blob_ptr
=
mi_alloc_rec_buff
(
info
,
info
->
s
->
keyinfo
[
keynr
].
keylength
,
mi_alloc_rec_buff
(
info
,
info
->
s
->
keyinfo
[
keynr
].
keylength
,
...
...
mysql-test/r/insert_select.result
View file @
c798a886
...
@@ -587,3 +587,8 @@ a b
...
@@ -587,3 +587,8 @@ a b
3 t2:3
3 t2:3
2 t2:2
2 t2:2
drop table t1,t2;
drop table t1,t2;
CREATE TABLE t1 ( USID INTEGER UNSIGNED, ServerID TINYINT UNSIGNED, State ENUM ('unknown', 'Access-Granted', 'Session-Active', 'Session-Closed' ) NOT NULL DEFAULT 'unknown', SessionID CHAR(32), User CHAR(32) NOT NULL DEFAULT '<UNKNOWN>', NASAddr INTEGER UNSIGNED, NASPort INTEGER UNSIGNED, NASPortType INTEGER UNSIGNED, ConnectSpeed INTEGER UNSIGNED, CarrierType CHAR(32), CallingStationID CHAR(32), CalledStationID CHAR(32), AssignedAddr INTEGER UNSIGNED, SessionTime INTEGER UNSIGNED, PacketsIn INTEGER UNSIGNED, OctetsIn INTEGER UNSIGNED, PacketsOut INTEGER UNSIGNED, OctetsOut INTEGER UNSIGNED, TerminateCause INTEGER UNSIGNED, UnauthTime TINYINT UNSIGNED, AccessRequestTime DATETIME, AcctStartTime DATETIME, AcctLastTime DATETIME, LastModification TIMESTAMP NOT NULL);
CREATE TABLE t2 ( USID INTEGER UNSIGNED AUTO_INCREMENT, ServerID TINYINT UNSIGNED, State ENUM ('unknown', 'Access-Granted', 'Session-Active', 'Session-Closed' ) NOT NULL DEFAULT 'unknown', SessionID CHAR(32), User TEXT NOT NULL, NASAddr INTEGER UNSIGNED, NASPort INTEGER UNSIGNED, NASPortType INTEGER UNSIGNED, ConnectSpeed INTEGER UNSIGNED, CarrierType CHAR(32), CallingStationID CHAR(32), CalledStationID CHAR(32), AssignedAddr INTEGER UNSIGNED, SessionTime INTEGER UNSIGNED, PacketsIn INTEGER UNSIGNED, OctetsIn INTEGER UNSIGNED, PacketsOut INTEGER UNSIGNED, OctetsOut INTEGER UNSIGNED, TerminateCause INTEGER UNSIGNED, UnauthTime TINYINT UNSIGNED, AccessRequestTime DATETIME, AcctStartTime DATETIME, AcctLastTime DATETIME, LastModification TIMESTAMP NOT NULL, INDEX(USID,ServerID,NASAddr,SessionID), INDEX(AssignedAddr));
INSERT INTO t1 VALUES (39,42,'Access-Granted','46','491721000045',2130706433,17690,NULL,NULL,'Localnet','491721000045','49172200000',754974766,NULL,NULL,NULL,NULL,NULL,NULL,NULL,'2003-07-18 00:11:21',NULL,NULL,20030718001121);
INSERT INTO t2 SELECT USID, ServerID, State, SessionID, User, NASAddr, NASPort, NASPortType, ConnectSpeed, CarrierType, CallingStationID, CalledStationID, AssignedAddr, SessionTime, PacketsIn, OctetsIn, PacketsOut, OctetsOut, TerminateCause, UnauthTime, AccessRequestTime, AcctStartTime, AcctLastTime, LastModification from t1 LIMIT 1;
drop table t1,t2;
mysql-test/t/insert_select.test
View file @
c798a886
...
@@ -122,3 +122,13 @@ select * from t1;
...
@@ -122,3 +122,13 @@ select * from t1;
replace
into
t1
select
*
from
t2
;
replace
into
t1
select
*
from
t2
;
select
*
from
t1
;
select
*
from
t1
;
drop
table
t1
,
t2
;
drop
table
t1
,
t2
;
#
# Test that caused uninitialized memory access in auto_increment_key update
#
CREATE
TABLE
t1
(
USID
INTEGER
UNSIGNED
,
ServerID
TINYINT
UNSIGNED
,
State
ENUM
(
'unknown'
,
'Access-Granted'
,
'Session-Active'
,
'Session-Closed'
)
NOT
NULL
DEFAULT
'unknown'
,
SessionID
CHAR
(
32
),
User
CHAR
(
32
)
NOT
NULL
DEFAULT
'<UNKNOWN>'
,
NASAddr
INTEGER
UNSIGNED
,
NASPort
INTEGER
UNSIGNED
,
NASPortType
INTEGER
UNSIGNED
,
ConnectSpeed
INTEGER
UNSIGNED
,
CarrierType
CHAR
(
32
),
CallingStationID
CHAR
(
32
),
CalledStationID
CHAR
(
32
),
AssignedAddr
INTEGER
UNSIGNED
,
SessionTime
INTEGER
UNSIGNED
,
PacketsIn
INTEGER
UNSIGNED
,
OctetsIn
INTEGER
UNSIGNED
,
PacketsOut
INTEGER
UNSIGNED
,
OctetsOut
INTEGER
UNSIGNED
,
TerminateCause
INTEGER
UNSIGNED
,
UnauthTime
TINYINT
UNSIGNED
,
AccessRequestTime
DATETIME
,
AcctStartTime
DATETIME
,
AcctLastTime
DATETIME
,
LastModification
TIMESTAMP
NOT
NULL
);
CREATE
TABLE
t2
(
USID
INTEGER
UNSIGNED
AUTO_INCREMENT
,
ServerID
TINYINT
UNSIGNED
,
State
ENUM
(
'unknown'
,
'Access-Granted'
,
'Session-Active'
,
'Session-Closed'
)
NOT
NULL
DEFAULT
'unknown'
,
SessionID
CHAR
(
32
),
User
TEXT
NOT
NULL
,
NASAddr
INTEGER
UNSIGNED
,
NASPort
INTEGER
UNSIGNED
,
NASPortType
INTEGER
UNSIGNED
,
ConnectSpeed
INTEGER
UNSIGNED
,
CarrierType
CHAR
(
32
),
CallingStationID
CHAR
(
32
),
CalledStationID
CHAR
(
32
),
AssignedAddr
INTEGER
UNSIGNED
,
SessionTime
INTEGER
UNSIGNED
,
PacketsIn
INTEGER
UNSIGNED
,
OctetsIn
INTEGER
UNSIGNED
,
PacketsOut
INTEGER
UNSIGNED
,
OctetsOut
INTEGER
UNSIGNED
,
TerminateCause
INTEGER
UNSIGNED
,
UnauthTime
TINYINT
UNSIGNED
,
AccessRequestTime
DATETIME
,
AcctStartTime
DATETIME
,
AcctLastTime
DATETIME
,
LastModification
TIMESTAMP
NOT
NULL
,
INDEX
(
USID
,
ServerID
,
NASAddr
,
SessionID
),
INDEX
(
AssignedAddr
));
INSERT
INTO
t1
VALUES
(
39
,
42
,
'Access-Granted'
,
'46'
,
'491721000045'
,
2130706433
,
17690
,
NULL
,
NULL
,
'Localnet'
,
'491721000045'
,
'49172200000'
,
754974766
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
'2003-07-18 00:11:21'
,
NULL
,
NULL
,
20030718001121
);
INSERT
INTO
t2
SELECT
USID
,
ServerID
,
State
,
SessionID
,
User
,
NASAddr
,
NASPort
,
NASPortType
,
ConnectSpeed
,
CarrierType
,
CallingStationID
,
CalledStationID
,
AssignedAddr
,
SessionTime
,
PacketsIn
,
OctetsIn
,
PacketsOut
,
OctetsOut
,
TerminateCause
,
UnauthTime
,
AccessRequestTime
,
AcctStartTime
,
AcctLastTime
,
LastModification
from
t1
LIMIT
1
;
drop
table
t1
,
t2
;
mysys/safemalloc.c
View file @
c798a886
...
@@ -374,11 +374,11 @@ void TERMINATE(FILE *file)
...
@@ -374,11 +374,11 @@ void TERMINATE(FILE *file)
{
{
if
(
file
)
if
(
file
)
{
{
fprintf
(
file
,
"Warning: Not freed memory segments: %
d
\n
"
,
fprintf
(
file
,
"Warning: Not freed memory segments: %
u
\n
"
,
sf_malloc_count
);
sf_malloc_count
);
(
void
)
fflush
(
file
);
(
void
)
fflush
(
file
);
}
}
DBUG_PRINT
(
"safe"
,(
"sf_malloc_count: %
d
"
,
sf_malloc_count
));
DBUG_PRINT
(
"safe"
,(
"sf_malloc_count: %
u
"
,
sf_malloc_count
));
}
}
/*
/*
...
@@ -482,7 +482,7 @@ int _sanity(const char *filename, uint lineno)
...
@@ -482,7 +482,7 @@ int _sanity(const char *filename, uint lineno)
pthread_mutex_lock
(
&
THR_LOCK_malloc
);
pthread_mutex_lock
(
&
THR_LOCK_malloc
);
#ifndef PEDANTIC_SAFEMALLOC
#ifndef PEDANTIC_SAFEMALLOC
if
(
sf_malloc_tampered
&&
sf_malloc_count
<
0
)
if
(
sf_malloc_tampered
&&
(
int
)
sf_malloc_count
<
0
)
sf_malloc_count
=
0
;
sf_malloc_count
=
0
;
#endif
#endif
count
=
sf_malloc_count
;
count
=
sf_malloc_count
;
...
...
mysys/thr_lock.c
View file @
c798a886
...
@@ -172,10 +172,13 @@ static int check_lock(struct st_lock_list *list, const char* lock_type,
...
@@ -172,10 +172,13 @@ static int check_lock(struct st_lock_list *list, const char* lock_type,
return
0
;
return
0
;
}
}
static
void
check_locks
(
THR_LOCK
*
lock
,
const
char
*
where
,
static
void
check_locks
(
THR_LOCK
*
lock
,
const
char
*
where
,
my_bool
allow_no_locks
)
my_bool
allow_no_locks
)
{
{
uint
old_found_errors
=
found_errors
;
uint
old_found_errors
=
found_errors
;
DBUG_ENTER
(
"check_locks"
);
if
(
found_errors
<
MAX_FOUND_ERRORS
)
if
(
found_errors
<
MAX_FOUND_ERRORS
)
{
{
if
(
check_lock
(
&
lock
->
write
,
"write"
,
where
,
1
,
1
)
|
if
(
check_lock
(
&
lock
->
write
,
"write"
,
where
,
1
,
1
)
|
...
@@ -252,18 +255,21 @@ static void check_locks(THR_LOCK *lock, const char *where,
...
@@ -252,18 +255,21 @@ static void check_locks(THR_LOCK *lock, const char *where,
}
}
if
(
lock
->
read
.
data
)
if
(
lock
->
read
.
data
)
{
{
if
(
(
!
pthread_equal
(
lock
->
write
.
data
->
thread
,
if
(
!
pthread_equal
(
lock
->
write
.
data
->
thread
,
lock
->
read
.
data
->
thread
)
&&
lock
->
read
.
data
->
thread
)
&&
lock
->
write
.
data
->
type
>
TL_WRITE_DELAYED
&&
((
lock
->
write
.
data
->
type
>
TL_WRITE_DELAYED
&&
lock
->
write
.
data
->
type
!=
TL_WRITE_ONLY
)
||
lock
->
write
.
data
->
type
!=
TL_WRITE_ONLY
)
||
((
lock
->
write
.
data
->
type
==
TL_WRITE_CONCURRENT_INSERT
||
((
lock
->
write
.
data
->
type
==
TL_WRITE_CONCURRENT_INSERT
||
lock
->
write
.
data
->
type
==
TL_WRITE_ALLOW_WRITE
)
&&
lock
->
write
.
data
->
type
==
TL_WRITE_ALLOW_WRITE
)
&&
lock
->
read_no_write_count
))
lock
->
read_no_write_count
)
))
{
{
found_errors
++
;
found_errors
++
;
fprintf
(
stderr
,
fprintf
(
stderr
,
"Warning at '%s': Found lock of type %d that is write and read locked
\n
"
,
"Warning at '%s': Found lock of type %d that is write and read locked
\n
"
,
where
,
lock
->
write
.
data
->
type
);
where
,
lock
->
write
.
data
->
type
);
DBUG_PRINT
(
"warning"
,(
"At '%s': Found lock of type %d that is write and read locked
\n
"
,
where
,
lock
->
write
.
data
->
type
));
}
}
}
}
if
(
lock
->
read_wait
.
data
)
if
(
lock
->
read_wait
.
data
)
...
@@ -286,6 +292,7 @@ static void check_locks(THR_LOCK *lock, const char *where,
...
@@ -286,6 +292,7 @@ static void check_locks(THR_LOCK *lock, const char *where,
DBUG_PRINT
(
"error"
,(
"Found wrong lock"
));
DBUG_PRINT
(
"error"
,(
"Found wrong lock"
));
}
}
}
}
DBUG_VOID_RETURN
;
}
}
#else
/* EXTRA_DEBUG */
#else
/* EXTRA_DEBUG */
...
...
sql/sql_acl.cc
View file @
c798a886
...
@@ -1136,7 +1136,11 @@ find_acl_user(const char *host, const char *user)
...
@@ -1136,7 +1136,11 @@ find_acl_user(const char *host, const char *user)
{
{
ACL_USER
*
acl_user
=
dynamic_element
(
&
acl_users
,
i
,
ACL_USER
*
);
ACL_USER
*
acl_user
=
dynamic_element
(
&
acl_users
,
i
,
ACL_USER
*
);
DBUG_PRINT
(
"info"
,(
"strcmp('%s','%s'), compare_hostname('%s','%s'),"
,
DBUG_PRINT
(
"info"
,(
"strcmp('%s','%s'), compare_hostname('%s','%s'),"
,
user
,
acl_user
->
user
,(
host
),(
acl_user
->
host
)));
user
,
acl_user
->
user
?
acl_user
->
user
:
""
,
host
,
acl_user
->
host
.
hostname
?
acl_user
->
host
.
hostname
:
""
));
if
(
!
acl_user
->
user
&&
!
user
[
0
]
||
if
(
!
acl_user
->
user
&&
!
user
[
0
]
||
acl_user
->
user
&&
!
strcmp
(
user
,
acl_user
->
user
))
acl_user
->
user
&&
!
strcmp
(
user
,
acl_user
->
user
))
{
{
...
...
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