diff options
| author | Daniel Stenberg <daniel@haxx.se> | 2004-06-30 11:48:19 +0000 | 
|---|---|---|
| committer | Daniel Stenberg <daniel@haxx.se> | 2004-06-30 11:48:19 +0000 | 
| commit | 4af08a19f85c577d9b1f2df892c82e34e473f31d (patch) | |
| tree | 4ca5f208bb6c84b203f385ca6113c3598f7a3f1e /lib | |
| parent | c14650caec03669b80324854c0a70dcc5301e59c (diff) | |
passing in a very long interface name could make a buffer overflow
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/if2ip.c | 5 | 
1 files changed, 4 insertions, 1 deletions
| diff --git a/lib/if2ip.c b/lib/if2ip.c index 237d1f758..b167b8df6 100644 --- a/lib/if2ip.c +++ b/lib/if2ip.c @@ -94,8 +94,11 @@ char *Curl_if2ip(const char *interface, char *buf, int buf_size)    }    else {      struct ifreq req; +    size_t len = strlen(interface);      memset(&req, 0, sizeof(req)); -    strcpy(req.ifr_name, interface); +    if(len >= sizeof(req.ifr_name)) +      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      if (SYS_ERROR == ioctl(dummy, SIOCGIFADDR, &req)) { | 
