DNS - Platform
This module includes the platform abstraction for sending recursive DNS query to upstream DNS servers.
Summary
| Typedefs | |
|---|---|
| otPlatDnsUpstreamQuery | typedef struct otPlatDnsUpstreamQueryThis opaque type represents an upstream DNS query transaction.  | 
| Functions | |
|---|---|
| otPlatDnsCancelUpstreamQuery(otInstance *aInstance, otPlatDnsUpstreamQuery *aTxn) | voidCancels a transaction of upstream query.  | 
| otPlatDnsIsUpstreamQueryAvailable(otInstance *aInstance) | boolIndicates whether upstream DNS query functionality is available on the platform.  | 
| otPlatDnsStartUpstreamQuery(otInstance *aInstance, otPlatDnsUpstreamQuery *aTxn, const otMessage *aQuery) | voidStarts an upstream query transaction.  | 
| otPlatDnsUpstreamQueryDone(otInstance *aInstance, otPlatDnsUpstreamQuery *aTxn, otMessage *aResponse) | voidThe platform calls this function to finish DNS query.  | 
Typedefs
otPlatDnsUpstreamQuery
struct otPlatDnsUpstreamQuery otPlatDnsUpstreamQuery
This opaque type represents an upstream DNS query transaction.
Functions
otPlatDnsCancelUpstreamQuery
void otPlatDnsCancelUpstreamQuery( otInstance *aInstance, otPlatDnsUpstreamQuery *aTxn )
Cancels a transaction of upstream query.
The platform must call otPlatDnsUpstreamQueryDone to release the resources.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatDnsIsUpstreamQueryAvailable
bool otPlatDnsIsUpstreamQueryAvailable( otInstance *aInstance )
Indicates whether upstream DNS query functionality is available on the platform.
This function allows the platform to inform the OpenThread stack if no upstream DNS server is available.
This function is used to optimize query handling. If this function returns false (e.g., no upstream DNS server is currently available), one can avoid attempting an upstream resolution (which would likely time out) and instead immediately send an appropriate negative response (e.g., SERVFAIL) to the DNS client.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | ||||
| Return Values | 
 | 
otPlatDnsStartUpstreamQuery
void otPlatDnsStartUpstreamQuery( otInstance *aInstance, otPlatDnsUpstreamQuery *aTxn, const otMessage *aQuery )
Starts an upstream query transaction.
- In success case (and errors represented by DNS protocol messages), the platform is expected to call otPlatDnsUpstreamQueryDone.
- The OpenThread core may cancel a (possibly timeout) query transaction by calling otPlatDnsCancelUpstreamQuery, the platform must not callotPlatDnsUpstreamQueryDoneon a cancelled transaction.
| Details | |||||||
|---|---|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatDnsUpstreamQueryDone
void otPlatDnsUpstreamQueryDone( otInstance *aInstance, otPlatDnsUpstreamQuery *aTxn, otMessage *aResponse )
The platform calls this function to finish DNS query.
The transaction will be released, so the platform must not call on the same transaction twice. This function passes the ownership of aResponse to OpenThread stack.
Platform can pass NULL to close a transaction without a response.
| Details | |||||||
|---|---|---|---|---|---|---|---|
| Parameters | 
 | 
Resources
OpenThread API Reference topics originate from the source code, available on GitHub. For more information, or to contribute to our documentation, refer to Resources.