erkin yucel / mbed-os

Dependents:   BLE_file_test BLE_Blink ExternalEncoder

Embed: (wiki syntax)

« Back to documentation index

lwip_dns.c File Reference

lwip_dns.c File Reference

DNS - host name to IP address resolver. More...

Go to the source code of this file.

Functions

static void dns_recv (void *arg, struct udp_pcb *pcb, struct pbuf *p, const ip_addr_t *addr, u16_t port)
 Receive input function for DNS response packets arriving for the dns UDP pcb.
static void dns_check_entries (void)
 Call dns_check_entry for each entry in dns_table - check all entries.
static void dns_call_found (u8_t idx, ip_addr_t *addr)
 dns_call_found() - call the found callback and check if there are duplicate entries for the given hostname.
static int dns_stricmp (const char *str1, const char *str2)
 A small but sufficient implementation for case insensitive strcmp.
void dns_init (void)
 Initialize the resolver: set up the UDP pcb and configure the default server (if DNS_SERVER_ADDRESS is set).
void dns_setserver (u8_t numdns, const ip_addr_t *dnsserver)
 Initialize one of the DNS servers.
const ip_addr_tdns_getserver (u8_t numdns)
 Obtain one of the currently configured DNS server.
void dns_tmr (void)
 The DNS resolver client timer - handle retries and timeouts and should be called every DNS_TMR_INTERVAL milliseconds (every second by default).
static err_t dns_lookup_local (const char *hostname, ip_addr_t *addr LWIP_DNS_ADDRTYPE_ARG(u8_t dns_addrtype))
 Scans the local host-list for a hostname.
int dns_local_removehost (const char *hostname, const ip_addr_t *addr)
 Remove all entries from the local host-list for a specific hostname and/or IP address.
err_t dns_local_addhost (const char *hostname, const ip_addr_t *addr)
 Add a hostname/IP address pair to the local host-list.
static err_t dns_lookup (const char *name, ip_addr_t *addr LWIP_DNS_ADDRTYPE_ARG(u8_t dns_addrtype))
 Look up a hostname in the array of known hostnames.
static u16_t dns_compare_name (const char *query, struct pbuf *p, u16_t start_offset)
 Compare the "dotted" name "query" with the encoded name "response" to make sure an answer from the DNS server matches the current dns_table entry (otherwise, answers might arrive late for hostname not on the list any more).
static u16_t dns_parse_name (struct pbuf *p, u16_t query_idx)
 Walk through a compact encoded DNS name and return the end of the name.
static err_t dns_send (u8_t idx)
 Send a DNS query packet.
static u8_t dns_alloc_pcb (void)
 dns_alloc_pcb() - allocates a new pcb (or reuses an existing one) to be used for sending a request
static void dns_check_entry (u8_t i)
 dns_check_entry() - see if entry has not yet been queried and, if so, sends out a query.
static void dns_correct_response (u8_t idx, u32_t ttl)
 Save TTL and call dns_call_found for correct response.
static err_t dns_enqueue (const char *name, size_t hostnamelen, dns_found_callback found, void *callback_arg LWIP_DNS_ADDRTYPE_ARG(u8_t dns_addrtype))
 Queues a new hostname to resolve and sends out a DNS query for that hostname.
err_t dns_gethostbyname (const char *hostname, ip_addr_t *addr, dns_found_callback found, void *callback_arg)
 Resolve a hostname (string) into an IP address.
err_t dns_gethostbyname_addrtype (const char *hostname, ip_addr_t *addr, dns_found_callback found, void *callback_arg, u8_t dns_addrtype)
 Like dns_gethostbyname, but returned address type can be controlled:

Variables

static struct
local_hostlist_entry
local_hostlist_dynamic
 Local host-list.

Detailed Description

DNS - host name to IP address resolver.

Definition in file lwip_dns.c.


Function Documentation

static u8_t dns_alloc_pcb ( void   ) [static]

dns_alloc_pcb() - allocates a new pcb (or reuses an existing one) to be used for sending a request

Returns:
an index into dns_pcbs

Definition at line 847 of file lwip_dns.c.

static void dns_call_found ( u8_t  idx,
ip_addr_t addr 
) [static]

dns_call_found() - call the found callback and check if there are duplicate entries for the given hostname.

If there are any, their found callback will be called and they will be removed.

Parameters:
idxdns table index of the entry that is resolved or removed
addrIP address for the hostname (or NULL on error or memory shortage)

Definition at line 889 of file lwip_dns.c.

static void dns_check_entries ( void   ) [static]

Call dns_check_entry for each entry in dns_table - check all entries.

Definition at line 1055 of file lwip_dns.c.

static void dns_check_entry ( u8_t  i ) [static]

dns_check_entry() - see if entry has not yet been queried and, if so, sends out a query.

Check an entry in the dns_table:

  • send out query for new entries
  • retry old pending entries on timeout (also with different servers)
  • remove completed entries from the table if their TTL has expired
Parameters:
iindex of the dns_table entry to check

Definition at line 977 of file lwip_dns.c.

static u16_t dns_compare_name ( const char *  query,
struct pbuf p,
u16_t  start_offset 
) [static]

Compare the "dotted" name "query" with the encoded name "response" to make sure an answer from the DNS server matches the current dns_table entry (otherwise, answers might arrive late for hostname not on the list any more).

Parameters:
queryhostname (not encoded) from the dns_table
ppbuf containing the encoded hostname in the DNS response
start_offsetoffset into p where the name starts
Returns:
0xFFFF: names differ, other: names equal -> offset behind name

See also:
RFC 1035 - 4.1.4. Message compression

Definition at line 665 of file lwip_dns.c.

static void dns_correct_response ( u8_t  idx,
u32_t  ttl 
) [static]

Save TTL and call dns_call_found for correct response.

Definition at line 1068 of file lwip_dns.c.

static err_t dns_enqueue ( const char *  name,
size_t  hostnamelen,
dns_found_callback  found,
void *callback_arg   LWIP_DNS_ADDRTYPE_ARGu8_t dns_addrtype 
) [static]

Queues a new hostname to resolve and sends out a DNS query for that hostname.

Parameters:
namethe hostname that is to be queried
hostnamelenlength of the hostname
founda callback function to be called on success, failure or timeout
callback_argargument to pass to the callback function
Returns:
a err_t return code.

Definition at line 1266 of file lwip_dns.c.

void dns_init ( void   )

Initialize the resolver: set up the UDP pcb and configure the default server (if DNS_SERVER_ADDRESS is set).

Definition at line 376 of file lwip_dns.c.

static u16_t dns_parse_name ( struct pbuf p,
u16_t  query_idx 
) [static]

Walk through a compact encoded DNS name and return the end of the name.

Parameters:
ppbuf containing the name
query_idxstart index into p pointing to encoded DNS name in the DNS server response
Returns:
index to end of the name

See also:
RFC 1035 - 4.1.4. Message compression

Definition at line 701 of file lwip_dns.c.

static void dns_recv ( void *  arg,
struct udp_pcb pcb,
struct pbuf p,
const ip_addr_t addr,
u16_t  port 
) [static]

Receive input function for DNS response packets arriving for the dns UDP pcb.

see udp.h

Definition at line 1102 of file lwip_dns.c.

static err_t dns_send ( u8_t  idx ) [static]

Send a DNS query packet.

Parameters:
idxthe DNS table entry index for which to send a request
Returns:
ERR_OK if packet is sent; an err_t indicating the problem otherwise

Definition at line 730 of file lwip_dns.c.

static int dns_stricmp ( const char *  str1,
const char *  str2 
) [static]

A small but sufficient implementation for case insensitive strcmp.

This can be defined to e.g. stricmp for windows or strcasecmp for linux.

Definition at line 343 of file lwip_dns.c.

void dns_tmr ( void   )

The DNS resolver client timer - handle retries and timeouts and should be called every DNS_TMR_INTERVAL milliseconds (every second by default).

Definition at line 456 of file lwip_dns.c.


Variable Documentation

Local host-list.

For hostnames in this list, no external name resolution is performed

Definition at line 296 of file lwip_dns.c.