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
3ce55920
Commit
3ce55920
authored
Jan 24, 2013
by
Venkata Sidagam
Browse files
Options
Browse Files
Download
Plain Diff
Bug #11752803 SERVER CRASHES IF MAX_CONNECTIONS DECREASED BELOW
CERTAIN LEVEL Merging from 5.1 to 5.5
parents
c156de4e
d0181929
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
14 deletions
+8
-14
mysys/thr_alarm.c
mysys/thr_alarm.c
+8
-14
No files found.
mysys/thr_alarm.c
View file @
3ce55920
...
@@ -51,6 +51,8 @@ static QUEUE alarm_queue;
...
@@ -51,6 +51,8 @@ static QUEUE alarm_queue;
static
uint
max_used_alarms
=
0
;
static
uint
max_used_alarms
=
0
;
pthread_t
alarm_thread
;
pthread_t
alarm_thread
;
#define MY_THR_ALARM_QUEUE_EXTENT 10
#ifdef USE_ALARM_THREAD
#ifdef USE_ALARM_THREAD
static
void
*
alarm_handler
(
void
*
arg
);
static
void
*
alarm_handler
(
void
*
arg
);
#define reschedule_alarms() mysql_cond_signal(&COND_alarm)
#define reschedule_alarms() mysql_cond_signal(&COND_alarm)
...
@@ -73,8 +75,8 @@ void init_thr_alarm(uint max_alarms)
...
@@ -73,8 +75,8 @@ void init_thr_alarm(uint max_alarms)
DBUG_ENTER
(
"init_thr_alarm"
);
DBUG_ENTER
(
"init_thr_alarm"
);
alarm_aborted
=
0
;
alarm_aborted
=
0
;
next_alarm_expire_time
=
~
(
time_t
)
0
;
next_alarm_expire_time
=
~
(
time_t
)
0
;
init_queue
(
&
alarm_queue
,
max_alarms
+
1
,
offsetof
(
ALARM
,
expire_time
),
0
,
init_queue
_ex
(
&
alarm_queue
,
max_alarms
+
1
,
offsetof
(
ALARM
,
expire_time
),
0
,
compare_ulong
,
NullS
);
compare_ulong
,
NullS
,
MY_THR_ALARM_QUEUE_EXTENT
);
sigfillset
(
&
full_signal_set
);
/* Neaded to block signals */
sigfillset
(
&
full_signal_set
);
/* Neaded to block signals */
mysql_mutex_init
(
key_LOCK_alarm
,
&
LOCK_alarm
,
MY_MUTEX_INIT_FAST
);
mysql_mutex_init
(
key_LOCK_alarm
,
&
LOCK_alarm
,
MY_MUTEX_INIT_FAST
);
mysql_cond_init
(
key_COND_alarm
,
&
COND_alarm
,
NULL
);
mysql_cond_init
(
key_COND_alarm
,
&
COND_alarm
,
NULL
);
...
@@ -125,7 +127,10 @@ void resize_thr_alarm(uint max_alarms)
...
@@ -125,7 +127,10 @@ void resize_thr_alarm(uint max_alarms)
than max_alarms
than max_alarms
*/
*/
if
(
alarm_queue
.
elements
<
max_alarms
)
if
(
alarm_queue
.
elements
<
max_alarms
)
{
resize_queue
(
&
alarm_queue
,
max_alarms
+
1
);
resize_queue
(
&
alarm_queue
,
max_alarms
+
1
);
max_used_alarms
=
alarm_queue
.
elements
;
}
mysql_mutex_unlock
(
&
LOCK_alarm
);
mysql_mutex_unlock
(
&
LOCK_alarm
);
}
}
...
@@ -180,17 +185,6 @@ my_bool thr_alarm(thr_alarm_t *alrm, uint sec, ALARM *alarm_data)
...
@@ -180,17 +185,6 @@ my_bool thr_alarm(thr_alarm_t *alrm, uint sec, ALARM *alarm_data)
if
(
alarm_queue
.
elements
>=
max_used_alarms
)
if
(
alarm_queue
.
elements
>=
max_used_alarms
)
{
{
if
(
alarm_queue
.
elements
==
alarm_queue
.
max_elements
)
{
DBUG_PRINT
(
"info"
,
(
"alarm queue full"
));
fprintf
(
stderr
,
"Warning: thr_alarm queue is full
\n
"
);
*
alrm
=
0
;
/* No alarm */
mysql_mutex_unlock
(
&
LOCK_alarm
);
#ifndef USE_ONE_SIGNAL_HAND
pthread_sigmask
(
SIG_SETMASK
,
&
old_mask
,
NULL
);
#endif
DBUG_RETURN
(
1
);
}
max_used_alarms
=
alarm_queue
.
elements
+
1
;
max_used_alarms
=
alarm_queue
.
elements
+
1
;
}
}
reschedule
=
(
ulong
)
next_alarm_expire_time
>
(
ulong
)
now
+
sec
;
reschedule
=
(
ulong
)
next_alarm_expire_time
>
(
ulong
)
now
+
sec
;
...
@@ -214,7 +208,7 @@ my_bool thr_alarm(thr_alarm_t *alrm, uint sec, ALARM *alarm_data)
...
@@ -214,7 +208,7 @@ my_bool thr_alarm(thr_alarm_t *alrm, uint sec, ALARM *alarm_data)
alarm_data
->
alarmed
=
0
;
alarm_data
->
alarmed
=
0
;
alarm_data
->
thread
=
current_my_thread_var
->
pthread_self
;
alarm_data
->
thread
=
current_my_thread_var
->
pthread_self
;
alarm_data
->
thread_id
=
current_my_thread_var
->
id
;
alarm_data
->
thread_id
=
current_my_thread_var
->
id
;
queue_insert
(
&
alarm_queue
,
(
uchar
*
)
alarm_data
);
queue_insert
_safe
(
&
alarm_queue
,
(
uchar
*
)
alarm_data
);
/* Reschedule alarm if the current one has more than sec left */
/* Reschedule alarm if the current one has more than sec left */
if
(
reschedule
)
if
(
reschedule
)
...
...
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