summaryrefslogtreecommitdiff
path: root/ext/mysql/php_mysql.c
diff options
context:
space:
mode:
authorZeev Suraski <zeev@php.net>2000-02-19 22:41:53 +0000
committerZeev Suraski <zeev@php.net>2000-02-19 22:41:53 +0000
commitbf25d1cec9af0ec5bd751d3d5843c7d107478ab1 (patch)
tree0f10e7c239697cef812664dc6eb9dd0169b90f53 /ext/mysql/php_mysql.c
parentd7c9624c5b70e14337a0e1ba5168efbc9850a234 (diff)
downloadphp-git-bf25d1cec9af0ec5bd751d3d5843c7d107478ab1.tar.gz
Restore the singal protection in the MySQL module
Diffstat (limited to 'ext/mysql/php_mysql.c')
-rw-r--r--ext/mysql/php_mysql.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/ext/mysql/php_mysql.c b/ext/mysql/php_mysql.c
index c54584f8ad..b2ef035783 100644
--- a/ext/mysql/php_mysql.c
+++ b/ext/mysql/php_mysql.c
@@ -158,6 +158,7 @@ PHP_MYSQL_API php_mysql_globals mysql_globals;
DLEXPORT zend_module_entry *get_module(void) { return &mysql_module_entry; }
#endif
+void timeout(int sig);
#define CHECK_LINK(link) { if (link==-1) { php_error(E_WARNING,"MySQL: A link to the server could not be established"); RETURN_FALSE; } }
@@ -184,18 +185,24 @@ static void php_mysql_set_default_link(int id)
static void _close_mysql_link(MYSQL *link)
{
+ void (*handler) (int);
MySLS_FETCH();
+ handler = signal(SIGPIPE, SIG_IGN);
mysql_close(link);
+ signal(SIGPIPE,handler);
efree(link);
MySG(num_links)--;
}
static void _close_mysql_plink(MYSQL *link)
{
+ void (*handler) (int);
MySLS_FETCH();
+ handler = signal(SIGPIPE, SIG_IGN);
mysql_close(link);
+ signal(SIGPIPE,handler);
free(link);
MySG(num_persistent)--;
@@ -316,6 +323,7 @@ static void php_mysql_do_connect(INTERNAL_FUNCTION_PARAMETERS,int persistent)
char *hashed_details;
int hashed_details_length,port = MYSQL_PORT;
MYSQL *mysql;
+ void (*handler) (int);
MySLS_FETCH();
PLS_FETCH();
@@ -449,12 +457,14 @@ static void php_mysql_do_connect(INTERNAL_FUNCTION_PARAMETERS,int persistent)
RETURN_FALSE;
}
/* ensure that the link did not die */
+ handler=signal(SIGPIPE,SIG_IGN);
#if defined(HAVE_MYSQL_ERRNO) && defined(CR_SERVER_GONE_ERROR)
mysql_stat(le->ptr);
if (mysql_errno((MYSQL *)le->ptr) == CR_SERVER_GONE_ERROR) {
#else
if (!strcasecmp(mysql_stat(le->ptr),"mysql server has gone away")) { /* the link died */
#endif
+ signal(SIGPIPE,handler);
#if MYSQL_VERSION_ID > 32199 /* this lets us set the port number */
if (mysql_real_connect(le->ptr,host,user,passwd,NULL,port,socket,0)==NULL) {
#else
@@ -466,6 +476,7 @@ static void php_mysql_do_connect(INTERNAL_FUNCTION_PARAMETERS,int persistent)
RETURN_FALSE;
}
}
+ signal(SIGPIPE,handler);
mysql = (MYSQL *) le->ptr;
}
ZEND_REGISTER_RESOURCE(return_value, mysql, le_plink);