diff options
| author | Andrey Hristov <andrey@php.net> | 2014-02-17 18:37:59 +0200 |
|---|---|---|
| committer | Andrey Hristov <andrey@php.net> | 2014-02-17 18:37:59 +0200 |
| commit | f83e88e3ea07568a89e6b159df4d650238b38070 (patch) | |
| tree | 6ccb79febb2b2f1c656359f2a3036ca32c8d5b53 /ext/mysqlnd/mysqlnd_ps.c | |
| parent | 90325ba7ef0368cc2c3b27956502739b5cb068ee (diff) | |
| parent | b2cd56c3cb9e752e3d0e4accb99d0f2e1ac71632 (diff) | |
| download | php-git-f83e88e3ea07568a89e6b159df4d650238b38070.tar.gz | |
Merge branch 'PHP-5.6'
Diffstat (limited to 'ext/mysqlnd/mysqlnd_ps.c')
| -rw-r--r-- | ext/mysqlnd/mysqlnd_ps.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/ext/mysqlnd/mysqlnd_ps.c b/ext/mysqlnd/mysqlnd_ps.c index 2d270c9b2f..07913e0dc1 100644 --- a/ext/mysqlnd/mysqlnd_ps.c +++ b/ext/mysqlnd/mysqlnd_ps.c @@ -105,6 +105,26 @@ MYSQLND_METHOD(mysqlnd_stmt, store_result)(MYSQLND_STMT * const s TSRMLS_DC) ret = result->m.store_result_fetch_data(conn, result, result->meta, TRUE TSRMLS_CC); if (PASS == ret) { + /* Overflow ? */ + MYSQLND_RES_BUFFERED * set = result->stored_data; + if (set->row_count) { + /* don't try to allocate more than possible - mnd_XXalloc expects size_t, and it can have narrower range than uint64_t */ + if (set->row_count * result->meta->field_count * sizeof(zval *) > SIZE_MAX) { + SET_OOM_ERROR(*conn->error_info); + DBG_RETURN(NULL); + } + /* if pecalloc is used valgrind barks gcc version 4.3.1 20080507 (prerelease) [gcc-4_3-branch revision 135036] (SUSE Linux) */ + set->data = mnd_emalloc((size_t)(set->row_count * result->meta->field_count * sizeof(zval *))); + if (!set->data) { + SET_OOM_ERROR(*conn->error_info); + DBG_RETURN(NULL); + } + memset(set->data, 0, (size_t)(set->row_count * result->meta->field_count * sizeof(zval *))); + } + /* Position at the first row */ + set->data_cursor = set->data; + + /* libmysql API docs say it should be so for SELECT statements */ stmt->upsert_status->affected_rows = stmt->result->stored_data->row_count; |
