mirror of
https://github.com/curl/curl.git
synced 2026-05-30 05:17:30 +03:00
Song Ma found a memory leak in the if2ip code if you pass in an interface
name longer than the name field of the ifreq struct (typically 6 bytes), as then it wouldn't close the used dummy socket.
This commit is contained in:
parent
ea74b4b8e1
commit
c38c339480
2 changed files with 9 additions and 1 deletions
6
CHANGES
6
CHANGES
|
|
@ -6,6 +6,12 @@
|
|||
|
||||
Changelog
|
||||
|
||||
Daniel S (12 April 2007)
|
||||
- Song Ma found a memory leak in the if2ip code if you pass in an interface
|
||||
name longer than the name field of the ifreq struct (typically 6 bytes), as
|
||||
then it wouldn't close the used dummy socket. Bug #1698974
|
||||
(http://curl.haxx.se/bug/view.cgi?id=1698974)
|
||||
|
||||
Version 7.16.2 (11 April 2007)
|
||||
|
||||
Yang Tse (10 April 2007)
|
||||
|
|
|
|||
|
|
@ -98,8 +98,10 @@ char *Curl_if2ip(const char *interface, char *buf, int buf_size)
|
|||
struct ifreq req;
|
||||
size_t len = strlen(interface);
|
||||
memset(&req, 0, sizeof(req));
|
||||
if(len >= sizeof(req.ifr_name))
|
||||
if(len >= sizeof(req.ifr_name)) {
|
||||
sclose(dummy);
|
||||
return NULL; /* this can't be a fine interface name */
|
||||
}
|
||||
memcpy(req.ifr_name, interface, len+1);
|
||||
req.ifr_addr.sa_family = AF_INET;
|
||||
#ifdef IOCTL_3_ARGS
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue