]> granicus.if.org Git - php/commitdiff
Fix possible bug with persistent connections and mysqlnd
authorAndrey Hristov <andrey@php.net>
Tue, 24 Jun 2008 11:01:38 +0000 (11:01 +0000)
committerAndrey Hristov <andrey@php.net>
Tue, 24 Jun 2008 11:01:38 +0000 (11:01 +0000)
ext/mysql/php_mysql.c
ext/mysqli/mysqli_nonapi.c
ext/mysqlnd/mysqlnd.c
ext/mysqlnd/mysqlnd.h

index 140d94500391bcd7a4b31a01cb4b393076a9b237..0e5319cb2186b2733701dd137887b6ea5747b5a7 100644 (file)
@@ -791,7 +791,7 @@ static void php_mysql_do_connect(INTERNAL_FUNCTION_PARAMETERS, int persistent)
                                }
                        } else {
 #ifdef MYSQL_USE_MYSQLND
-                               mysqlnd_restart_psession(mysql->conn);
+                               mysqlnd_restart_psession(mysql->conn, MySG(mysqlnd_thd_zval_cache));
 #endif
                        }
                }
index 27e6b4ebd42e5313191dd435481bf387b11a8faf..8c67e307995fd0e719322e0a4128d771c27be548 100644 (file)
@@ -170,7 +170,7 @@ void mysqli_common_connect(INTERNAL_FUNCTION_PARAMETERS, zend_bool is_real_conne
                                                        if (!mysql_ping(mysql->mysql)) {
 #endif
 #ifdef MYSQLI_USE_MYSQLND
-                                                               mysqlnd_restart_psession(mysql->mysql);
+                                                               mysqlnd_restart_psession(mysql->mysql, MyG(mysqlnd_thd_zval_cache));
 #endif
                                                                MyG(num_active_persistent)++;
                                                                goto end;
index 6394e0f06a26de7139cfe1ad5afab7604c968e92..cd21ebed56d078483a66f2c4b65089fd27cd93b1 100644 (file)
@@ -442,7 +442,7 @@ MYSQLND_METHOD(mysqlnd_conn, set_server_option)(MYSQLND * const conn,
 
 
 /* {{{ _mysqlnd_restart_psession */
-PHPAPI void _mysqlnd_restart_psession(MYSQLND *conn TSRMLS_DC) 
+PHPAPI void _mysqlnd_restart_psession(MYSQLND *conn, MYSQLND_THD_ZVAL_PCACHE *cache TSRMLS_DC) 
 {
        DBG_ENTER("_mysqlnd_restart_psession");
        MYSQLND_INC_CONN_STATISTIC(&conn->stats, STAT_CONNECT_REUSED);
@@ -451,15 +451,27 @@ PHPAPI void _mysqlnd_restart_psession(MYSQLND *conn TSRMLS_DC)
                mnd_pefree(conn->last_message, conn->persistent);
                conn->last_message = NULL;
        }
+       conn->zval_cache = cache;
        DBG_VOID_RETURN;
 }
 /* }}} */
 
 
-/* {{{ mysqlnd_end_psession */
-PHPAPI void mysqlnd_end_psession(MYSQLND *conn)
+/* {{{ _mysqlnd_end_psession */
+PHPAPI void _mysqlnd_end_psession(MYSQLND *conn TSRMLS_DC)
 {
-
+       DBG_ENTER("_mysqlnd_end_psession");
+       /*
+         BEWARE!!!! This will have a problem with a query cache.
+         We need to move the data out of the zval cache before we end the psession.
+         Or we will use nirvana pointers!!
+       */
+       if (conn->zval_cache) {
+               DBG_INF("Freeing zval cache reference");
+               mysqlnd_palloc_free_thd_cache_reference(&conn->zval_cache);
+               conn->zval_cache = NULL;
+       }
+       DBG_VOID_RETURN;
 }
 /* }}} */
 
index 9e6c0e665d7a096a21eecefbad4fc9734ed9d3d9..cc6afab51cc100487c9be320a0155b6e3dda6c46 100644 (file)
 void mysqlnd_library_init(TSRMLS_D);
 void mysqlnd_library_end(TSRMLS_D);
 
-#define mysqlnd_restart_psession(conn) _mysqlnd_restart_psession((conn) TSRMLS_CC)
-PHPAPI void _mysqlnd_restart_psession(MYSQLND *conn TSRMLS_DC);
-PHPAPI void mysqlnd_end_psession(MYSQLND *conn);
+#define mysqlnd_restart_psession(conn, cache) _mysqlnd_restart_psession((conn), (cache) TSRMLS_CC)
+PHPAPI void _mysqlnd_restart_psession(MYSQLND *conn, MYSQLND_THD_ZVAL_PCACHE *cache TSRMLS_DC);
+#define mysqlnd_end_psession(conn) _mysqlnd_end_psession((conn) TSRMLS_CC)
+PHPAPI void _mysqlnd_end_psession(MYSQLND *conn TSRMLS_DC);
 PHPAPI void mysqlnd_minfo_print_hash(zval *values);
 #define mysqlnd_thread_safe()  TRUE