diff options
author | guilhem@mysql.com <> | 2004-06-17 15:40:13 +0200 |
---|---|---|
committer | guilhem@mysql.com <> | 2004-06-17 15:40:13 +0200 |
commit | 69bea44bc905d30a545d817b5a8f1fd22206b5e0 (patch) | |
tree | 0b2d40c20563e0c37b0a9e86bee4f7b7c5919831 | |
parent | 2e04da08736a067a8f9d89c13bef3630a8bba166 (diff) | |
download | mariadb-git-69bea44bc905d30a545d817b5a8f1fd22206b5e0.tar.gz |
Fix for BUG#4017 "mysql_real_connect buffer overflow"
-rw-r--r-- | libmysql/libmysql.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/libmysql/libmysql.c b/libmysql/libmysql.c index c50193c5e2c..a0a4a26d971 100644 --- a/libmysql/libmysql.c +++ b/libmysql/libmysql.c @@ -1358,7 +1358,8 @@ mysql_real_connect(MYSQL *mysql,const char *host, const char *user, my_gethostbyname_r_free(); goto error; } - memcpy(&sock_addr.sin_addr,hp->h_addr, (size_t) hp->h_length); + memcpy(&sock_addr.sin_addr, hp->h_addr, + min(sizeof(sock_addr.sin_addr), (size_t) hp->h_length)); my_gethostbyname_r_free(); } sock_addr.sin_port = (ushort) htons((ushort) port); |