mirror of
https://github.com/apache/nuttx.git
synced 2026-06-08 01:42:58 +08:00
Regular → Executable
+2
-3
@@ -177,7 +177,7 @@ void dns_semgive(void);
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int dns_bind(void);
|
||||
int dns_bind(sa_family_t family);
|
||||
|
||||
/****************************************************************************
|
||||
* Name: dns_query
|
||||
@@ -187,7 +187,6 @@ int dns_bind(void);
|
||||
* return its IP address in 'ipaddr'
|
||||
*
|
||||
* Input Parameters:
|
||||
* sd - The socket descriptor previously initialized by dsn_bind().
|
||||
* hostname - The hostname string to be resolved.
|
||||
* addr - The location to return the IP addresses associated with the
|
||||
* hostname.
|
||||
@@ -200,7 +199,7 @@ int dns_bind(void);
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int dns_query(int sd, FAR const char *hostname, FAR union dns_addr_u *addr,
|
||||
int dns_query(FAR const char *hostname, FAR union dns_addr_u *addr,
|
||||
FAR int *naddr);
|
||||
|
||||
/****************************************************************************
|
||||
|
||||
Regular → Executable
+2
-2
@@ -61,7 +61,7 @@
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int dns_bind(void)
|
||||
int dns_bind(sa_family_t family)
|
||||
{
|
||||
struct timeval tv;
|
||||
int sd;
|
||||
@@ -77,7 +77,7 @@ int dns_bind(void)
|
||||
|
||||
/* Create a new socket */
|
||||
|
||||
sd = socket(PF_INET, SOCK_DGRAM, 0);
|
||||
sd = socket(family, SOCK_DGRAM, 0);
|
||||
if (sd < 0)
|
||||
{
|
||||
ret = -get_errno();
|
||||
|
||||
Regular → Executable
+15
-8
@@ -50,6 +50,7 @@
|
||||
|
||||
#include <string.h>
|
||||
#include <time.h>
|
||||
#include <unistd.h>
|
||||
#include <errno.h>
|
||||
#include <debug.h>
|
||||
#include <assert.h>
|
||||
@@ -85,7 +86,6 @@
|
||||
|
||||
struct dns_query_s
|
||||
{
|
||||
int sd; /* DNS server socket */
|
||||
int result; /* Explanation of the failure */
|
||||
FAR const char *hostname; /* Hostname to lookup */
|
||||
FAR union dns_addr_u *addr; /* Location to return host address */
|
||||
@@ -583,6 +583,13 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
int retries;
|
||||
int ret;
|
||||
|
||||
int sd = dns_bind(addr->sa_family);
|
||||
if (sd < 0)
|
||||
{
|
||||
query->result = sd;
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Loop while receive timeout errors occur and there are remaining
|
||||
* retries.
|
||||
*/
|
||||
@@ -592,7 +599,7 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
#ifdef CONFIG_NET_IPv6
|
||||
/* Send the IPv6 query */
|
||||
|
||||
ret = dns_send_query(query->sd, query->hostname,
|
||||
ret = dns_send_query(sd, query->hostname,
|
||||
(FAR union dns_addr_u *)addr,
|
||||
DNS_RECTYPE_AAAA, &qinfo);
|
||||
if (ret < 0)
|
||||
@@ -604,7 +611,7 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
{
|
||||
/* Obtain the IPv6 response */
|
||||
|
||||
ret = dns_recv_response(query->sd, &query->addr[next],
|
||||
ret = dns_recv_response(sd, &query->addr[next],
|
||||
*query->naddr - next, &qinfo);
|
||||
if (ret >= 0)
|
||||
{
|
||||
@@ -621,7 +628,7 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
#ifdef CONFIG_NET_IPv4
|
||||
/* Send the IPv4 query */
|
||||
|
||||
ret = dns_send_query(query->sd, query->hostname,
|
||||
ret = dns_send_query(sd, query->hostname,
|
||||
(FAR union dns_addr_u *)addr,
|
||||
DNS_RECTYPE_A, &qinfo);
|
||||
if (ret < 0)
|
||||
@@ -633,7 +640,7 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
{
|
||||
/* Obtain the IPv4 response */
|
||||
|
||||
ret = dns_recv_response(query->sd, &query->addr[next],
|
||||
ret = dns_recv_response(sd, &query->addr[next],
|
||||
*query->naddr - next, &qinfo);
|
||||
if (ret >= 0)
|
||||
{
|
||||
@@ -659,6 +666,7 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
*/
|
||||
|
||||
*query->naddr = next;
|
||||
close(sd);
|
||||
return 1;
|
||||
}
|
||||
else if (query->result != -EAGAIN)
|
||||
@@ -667,6 +675,7 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
}
|
||||
}
|
||||
|
||||
close(sd);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -682,7 +691,6 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
* return its IP address in 'ipaddr'
|
||||
*
|
||||
* Input Parameters:
|
||||
* sd - The socket descriptor previously initialized by dsn_bind().
|
||||
* hostname - The hostname string to be resolved.
|
||||
* addr - The location to return the IP addresses associated with the
|
||||
* hostname.
|
||||
@@ -695,7 +703,7 @@ static int dns_query_callback(FAR void *arg, FAR struct sockaddr *addr,
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
int dns_query(int sd, FAR const char *hostname, FAR union dns_addr_u *addr,
|
||||
int dns_query(FAR const char *hostname, FAR union dns_addr_u *addr,
|
||||
FAR int *naddr)
|
||||
{
|
||||
FAR struct dns_query_s query;
|
||||
@@ -703,7 +711,6 @@ int dns_query(int sd, FAR const char *hostname, FAR union dns_addr_u *addr,
|
||||
|
||||
/* Set up the query info structure */
|
||||
|
||||
query.sd = sd;
|
||||
query.result = -EADDRNOTAVAIL;
|
||||
query.hostname = hostname;
|
||||
query.addr = addr;
|
||||
|
||||
Regular → Executable
+1
-17
@@ -432,25 +432,9 @@ static int lib_find_answer(FAR const char *name, FAR struct hostent_s *host,
|
||||
static int lib_dns_query(FAR const char *hostname,
|
||||
FAR union dns_addr_u *addr, int *naddr)
|
||||
{
|
||||
int sd;
|
||||
int ret;
|
||||
|
||||
/* Create and bind a socket to the DNS server */
|
||||
|
||||
sd = dns_bind();
|
||||
if (sd < 0)
|
||||
{
|
||||
return sd;
|
||||
}
|
||||
|
||||
/* Perform the query to get the IP address */
|
||||
|
||||
ret = dns_query(sd, hostname, addr, naddr);
|
||||
|
||||
/* Release the socket */
|
||||
|
||||
close(sd);
|
||||
return ret;
|
||||
return dns_query(hostname, addr, naddr);
|
||||
}
|
||||
#endif /* CONFIG_NETDB_DNSCLIENT */
|
||||
|
||||
|
||||
Reference in New Issue
Block a user