Change the ai_addrlen type of struct addrinfo from size_t to socklen_t, per RFC 3493.
This commit is contained in:
@@ -40,14 +40,14 @@ struct sockaddr_in6
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef HAVE_STRUCT_ADDRINFO
|
#ifndef HAVE_STRUCT_ADDRINFO
|
||||||
struct addrinfo
|
struct addrinfo
|
||||||
{
|
{
|
||||||
int ai_flags;
|
int ai_flags;
|
||||||
int ai_family;
|
int ai_family;
|
||||||
int ai_socktype;
|
int ai_socktype;
|
||||||
int ai_protocol;
|
int ai_protocol;
|
||||||
size_t ai_addrlen;
|
socklen_t ai_addrlen; /* Follow rfc3493 struct addrinfo */
|
||||||
char *ai_cannonname;
|
char *ai_canonname;
|
||||||
struct sockaddr *ai_addr;
|
struct sockaddr *ai_addr;
|
||||||
struct addrinfo *ai_next;
|
struct addrinfo *ai_next;
|
||||||
};
|
};
|
||||||
|
@@ -713,7 +713,7 @@ singleipconnect(struct connectdata *conn,
|
|||||||
|
|
||||||
/* Connect TCP sockets, bind UDP */
|
/* Connect TCP sockets, bind UDP */
|
||||||
if(conn->socktype == SOCK_STREAM)
|
if(conn->socktype == SOCK_STREAM)
|
||||||
rc = connect(sockfd, ai->ai_addr, (socklen_t)ai->ai_addrlen);
|
rc = connect(sockfd, ai->ai_addr, ai->ai_addrlen);
|
||||||
else
|
else
|
||||||
rc = 0;
|
rc = 0;
|
||||||
|
|
||||||
|
14
lib/hostip.h
14
lib/hostip.h
@@ -94,13 +94,13 @@ typedef struct addrinfo Curl_addrinfo;
|
|||||||
/* OK, so some ipv4-only include tree probably have the addrinfo struct, but
|
/* OK, so some ipv4-only include tree probably have the addrinfo struct, but
|
||||||
to work even on those that don't, we provide our own look-alike! */
|
to work even on those that don't, we provide our own look-alike! */
|
||||||
struct Curl_addrinfo {
|
struct Curl_addrinfo {
|
||||||
int ai_flags;
|
int ai_flags;
|
||||||
int ai_family;
|
int ai_family;
|
||||||
int ai_socktype;
|
int ai_socktype;
|
||||||
int ai_protocol;
|
int ai_protocol;
|
||||||
size_t ai_addrlen;
|
socklen_t ai_addrlen; /* Follow rfc3493 struct addrinfo */
|
||||||
struct sockaddr *ai_addr;
|
char *ai_canonname;
|
||||||
char *ai_canonname;
|
struct sockaddr *ai_addr;
|
||||||
struct Curl_addrinfo *ai_next;
|
struct Curl_addrinfo *ai_next;
|
||||||
};
|
};
|
||||||
typedef struct Curl_addrinfo Curl_addrinfo;
|
typedef struct Curl_addrinfo Curl_addrinfo;
|
||||||
|
@@ -370,28 +370,34 @@ Curl_addrinfo *Curl_getaddrinfo(struct connectdata *conn,
|
|||||||
* Curl_he2ai() translates from a hostent struct to a Curl_addrinfo struct.
|
* Curl_he2ai() translates from a hostent struct to a Curl_addrinfo struct.
|
||||||
* The Curl_addrinfo is meant to work like the addrinfo struct does for IPv6
|
* The Curl_addrinfo is meant to work like the addrinfo struct does for IPv6
|
||||||
* stacks, but for all hosts and environments.
|
* stacks, but for all hosts and environments.
|
||||||
|
*
|
||||||
struct Curl_addrinfo {
|
* Curl_addrinfo defined in "lib/hostip.h"
|
||||||
int ai_flags;
|
*
|
||||||
int ai_family;
|
* struct Curl_addrinfo {
|
||||||
int ai_socktype;
|
* int ai_flags;
|
||||||
int ai_protocol;
|
* int ai_family;
|
||||||
size_t ai_addrlen;
|
* int ai_socktype;
|
||||||
struct sockaddr *ai_addr;
|
* int ai_protocol;
|
||||||
char *ai_canonname;
|
* socklen_t ai_addrlen; * Follow rfc3493 struct addrinfo *
|
||||||
struct addrinfo *ai_next;
|
* char *ai_canonname;
|
||||||
};
|
* struct sockaddr *ai_addr;
|
||||||
|
* struct Curl_addrinfo *ai_next;
|
||||||
struct hostent {
|
* };
|
||||||
char *h_name; * official name of host *
|
*
|
||||||
char **h_aliases; * alias list *
|
* hostent defined in <netdb.h>
|
||||||
int h_addrtype; * host address type *
|
*
|
||||||
int h_length; * length of address *
|
* struct hostent {
|
||||||
char **h_addr_list; * list of addresses *
|
* char *h_name;
|
||||||
}
|
* char **h_aliases;
|
||||||
#define h_addr h_addr_list[0] * for backward compatibility *
|
* int h_addrtype;
|
||||||
|
* int h_length;
|
||||||
*/
|
* char **h_addr_list;
|
||||||
|
* };
|
||||||
|
*
|
||||||
|
* for backward compatibility:
|
||||||
|
*
|
||||||
|
* #define h_addr h_addr_list[0]
|
||||||
|
*/
|
||||||
|
|
||||||
Curl_addrinfo *Curl_he2ai(struct hostent *he, int port)
|
Curl_addrinfo *Curl_he2ai(struct hostent *he, int port)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user