NSAPI DNS query IP version check for non LWIP stacks.

pull/11375/head
Tymoteusz Bloch 2019-08-29 18:52:40 +02:00
parent 1798c246cc
commit b8a18e29bd
1 changed files with 13 additions and 4 deletions

View File

@ -504,8 +504,13 @@ static nsapi_size_or_error_t nsapi_dns_query_multiple(NetworkStack *stack, const
break; break;
} }
if (version != NSAPI_UNSPEC && (dns_addr.get_ip_version() != version)) {
retries = MBED_CONF_NSAPI_DNS_RETRIES;
index++;
continue;
}
// send the question // send the question
int len = dns_append_question(packet, 1, host, version); int len = dns_append_question(packet, 1, host, dns_addr.get_ip_version());
err = socket.sendto(dns_addr, packet, len); err = socket.sendto(dns_addr, packet, len);
// send may fail for various reasons, including wrong address type - move on // send may fail for various reasons, including wrong address type - move on
@ -1036,9 +1041,6 @@ static void nsapi_dns_query_async_send(void *ptr)
return; return;
} }
// send the question
int len = dns_append_question(packet, query->dns_message_id, query->host, query->version);
while (true) { while (true) {
SocketAddress dns_addr; SocketAddress dns_addr;
nsapi_size_or_error_t err = nsapi_dns_get_server_addr(query->stack, &(query->dns_server), &(query->total_attempts), &(query->send_success), &dns_addr, query->interface_name); nsapi_size_or_error_t err = nsapi_dns_get_server_addr(query->stack, &(query->dns_server), &(query->total_attempts), &(query->send_success), &dns_addr, query->interface_name);
@ -1048,6 +1050,13 @@ static void nsapi_dns_query_async_send(void *ptr)
return; return;
} }
if (query->version != NSAPI_UNSPEC && dns_addr.get_ip_version() != query->version) {
query->dns_server++;
continue;
}
// send the question
int len = dns_append_question(packet, query->dns_message_id, query->host, dns_addr.get_ip_version());
err = query->socket->sendto(dns_addr, packet, len); err = query->socket->sendto(dns_addr, packet, len);
if (err < 0) { if (err < 0) {