diff options
author | unknown <serg@serg.mysql.com> | 2002-12-04 10:16:19 +0100 |
---|---|---|
committer | unknown <serg@serg.mysql.com> | 2002-12-04 10:16:19 +0100 |
commit | 5a0f1c749ea4882530d82b2704431e335895b28b (patch) | |
tree | c2682813bba0f73e16b3d8aefee0ef9f0a221967 /libmysql | |
parent | 80b143c111fc3df20e3fe2dcfe4880c30b001498 (diff) | |
parent | faefac308f722b9669bec622c34c269c9341e675 (diff) | |
download | mariadb-git-5a0f1c749ea4882530d82b2704431e335895b28b.tar.gz |
merged
libmysql/libmysql.c:
Auto merged
sql/opt_sum.cc:
Auto merged
support-files/mysql.server.sh:
Auto merged
Diffstat (limited to 'libmysql')
-rw-r--r-- | libmysql/libmysql.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/libmysql/libmysql.c b/libmysql/libmysql.c index c9a46eaf9ad..da6c445d161 100644 --- a/libmysql/libmysql.c +++ b/libmysql/libmysql.c @@ -348,7 +348,7 @@ net_safe_read(MYSQL *mysql) DBUG_PRINT("error",("Wrong connection or packet. fd: %s len: %d", vio_description(net->vio),len)); end_server(mysql); - net->last_errno=(net->last_errno == ER_NET_PACKET_TOO_LARGE ? + net->last_errno=(net->last_errno == ER_NET_PACKET_TOO_LARGE ? CR_NET_PACKET_TOO_LARGE: CR_SERVER_LOST); strmov(net->last_error,ER(net->last_errno)); @@ -934,7 +934,7 @@ static MYSQL_DATA *read_rows(MYSQL *mysql,MYSQL_FIELD *mysql_fields, ulong pkt_len; ulong len; uchar *cp; - char *to; + char *to, *end_to; MYSQL_DATA *result; MYSQL_ROWS **prev_ptr,*cur; NET *net = &mysql->net; @@ -972,6 +972,7 @@ static MYSQL_DATA *read_rows(MYSQL *mysql,MYSQL_FIELD *mysql_fields, *prev_ptr=cur; prev_ptr= &cur->next; to= (char*) (cur->data+fields+1); + end_to=to+pkt_len-1; for (field=0 ; field < fields ; field++) { if ((len=(ulong) net_field_length(&cp)) == NULL_LENGTH) @@ -981,6 +982,13 @@ static MYSQL_DATA *read_rows(MYSQL *mysql,MYSQL_FIELD *mysql_fields, else { cur->data[field] = to; + if (to+len > end_to) + { + free_rows(result); + net->last_errno=CR_UNKNOWN_ERROR; + strmov(net->last_error,ER(net->last_errno)); + DBUG_RETURN(0); + } memcpy(to,(char*) cp,len); to[len]=0; to+=len+1; cp+=len; |