dmitry          Fri Dec 23 09:41:31 2005 EDT

  Modified files:              
    /php-src/ext/pdo    pdo_dbh.c 
  Log:
  Fixed memory corruption and termination through _zend_bailout()
  
  
http://cvs.php.net/viewcvs.cgi/php-src/ext/pdo/pdo_dbh.c?r1=1.106&r2=1.107&diff_format=u
Index: php-src/ext/pdo/pdo_dbh.c
diff -u php-src/ext/pdo/pdo_dbh.c:1.106 php-src/ext/pdo/pdo_dbh.c:1.107
--- php-src/ext/pdo/pdo_dbh.c:1.106     Tue Dec  6 02:24:41 2005
+++ php-src/ext/pdo/pdo_dbh.c   Fri Dec 23 09:41:31 2005
@@ -18,7 +18,7 @@
   +----------------------------------------------------------------------+
 */
 
-/* $Id: pdo_dbh.c,v 1.106 2005/12/06 02:24:41 sniper Exp $ */
+/* $Id: pdo_dbh.c,v 1.107 2005/12/23 09:41:31 dmitry Exp $ */
 
 /* The PDO Database Handle Class */
 
@@ -1313,6 +1313,8 @@
 
 static void dbh_free(pdo_dbh_t *dbh TSRMLS_DC)
 {
+       int i;
+
        if (--dbh->refcount)
                return;
 
@@ -1333,6 +1335,13 @@
        if (dbh->def_stmt_ctor_args) {
                zval_ptr_dtor(&dbh->def_stmt_ctor_args);
        }
+       
+       for (i = 0; i < PDO_DBH_DRIVER_METHOD_KIND__MAX; i++) {
+               if (dbh->cls_methods[i]) {
+                       zend_hash_destroy(dbh->cls_methods[i]);
+                       pefree(dbh->cls_methods[i], dbh->is_persistent);
+               }
+       }
 
        pefree(dbh, dbh->is_persistent);
 }
@@ -1349,9 +1358,6 @@
                efree(dbh->properties);
                dbh->properties = NULL;
        }
-       if (dbh->cls_methods) {
-               zend_hash_destroy(&dbh->cls_methods);
-       }
 
        if (!dbh->is_persistent) {
                dbh_free(dbh TSRMLS_CC);

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to