]> git.sur5r.net Git - freertos/blob - FreeRTOS-Plus/Source/FreeRTOS-Plus-TCP/include/FreeRTOS_DNS.h
Fix some build issues in older kernel demo projects.
[freertos] / FreeRTOS-Plus / Source / FreeRTOS-Plus-TCP / include / FreeRTOS_DNS.h
1 /*\r
2  * FreeRTOS+TCP V2.0.7\r
3  * Copyright (C) 2017 Amazon.com, Inc. or its affiliates.  All Rights Reserved.\r
4  *\r
5  * Permission is hereby granted, free of charge, to any person obtaining a copy of\r
6  * this software and associated documentation files (the "Software"), to deal in\r
7  * the Software without restriction, including without limitation the rights to\r
8  * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\r
9  * the Software, and to permit persons to whom the Software is furnished to do so,\r
10  * subject to the following conditions:\r
11  *\r
12  * The above copyright notice and this permission notice shall be included in all\r
13  * copies or substantial portions of the Software.\r
14  *\r
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\r
17  * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\r
18  * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\r
19  * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
20  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r
21  *\r
22  * http://aws.amazon.com/freertos\r
23  * http://www.FreeRTOS.org\r
24  */\r
25 \r
26 #ifndef FREERTOS_DNS_H\r
27 #define FREERTOS_DNS_H\r
28 \r
29 #ifdef __cplusplus\r
30 extern "C" {\r
31 #endif\r
32 \r
33 /* Application level configuration options. */\r
34 #include "FreeRTOSIPConfig.h"\r
35 #include "IPTraceMacroDefaults.h"\r
36 \r
37 \r
38 /* The Link-local Multicast Name Resolution (LLMNR)\r
39  * is included.\r
40  * Note that a special MAC address is required in addition to the NIC's actual\r
41  * MAC address: 01:00:5E:00:00:FC\r
42  *\r
43  * The target IP address will be 224.0.0.252\r
44  */\r
45 #if( ipconfigBYTE_ORDER == pdFREERTOS_BIG_ENDIAN )\r
46         #define ipLLMNR_IP_ADDR                 0xE00000FC\r
47 #else\r
48         #define ipLLMNR_IP_ADDR                 0xFC0000E0\r
49 #endif /* ipconfigBYTE_ORDER == pdFREERTOS_BIG_ENDIAN */\r
50 \r
51 #define ipLLMNR_PORT    5355 /* Standard LLMNR port. */\r
52 #define ipDNS_PORT              53      /* Standard DNS port. */\r
53 #define ipDHCP_CLIENT   67\r
54 #define ipDHCP_SERVER   68\r
55 #define ipNBNS_PORT             137     /* NetBIOS Name Service. */\r
56 #define ipNBDGM_PORT    138 /* Datagram Service, not included. */\r
57 \r
58 /*\r
59  * The following function should be provided by the user and return true if it\r
60  * matches the domain name.\r
61  */\r
62 extern BaseType_t xApplicationDNSQueryHook( const char *pcName );\r
63 \r
64 /*\r
65  * LLMNR is very similar to DNS, so is handled by the DNS routines.\r
66  */\r
67 uint32_t ulDNSHandlePacket( NetworkBufferDescriptor_t *pxNetworkBuffer );\r
68 \r
69 #if( ipconfigUSE_LLMNR == 1 )\r
70         extern const MACAddress_t xLLMNR_MacAdress;\r
71 #endif /* ipconfigUSE_LLMNR */\r
72 \r
73 #if( ipconfigUSE_NBNS != 0 )\r
74 \r
75         /*\r
76          * Inspect a NetBIOS Names-Service message.  If the name matches with ours\r
77          * (xApplicationDNSQueryHook returns true) an answer will be sent back.\r
78          * Note that LLMNR is a better protocol for name services on a LAN as it is\r
79          * less polluted\r
80          */\r
81         uint32_t ulNBNSHandlePacket (NetworkBufferDescriptor_t *pxNetworkBuffer );\r
82 \r
83 #endif /* ipconfigUSE_NBNS */\r
84 \r
85 #if( ipconfigUSE_DNS_CACHE != 0 )\r
86 \r
87         uint32_t FreeRTOS_dnslookup( const char *pcHostName );\r
88 \r
89 #endif /* ipconfigUSE_DNS_CACHE != 0 */\r
90 \r
91 #if( ipconfigDNS_USE_CALLBACKS != 0 )\r
92 \r
93         /*\r
94          * Users may define this type of function as a callback.\r
95          * It will be called when a DNS reply is received or when a timeout has been reached.\r
96          */\r
97         typedef void (* FOnDNSEvent ) ( const char * /* pcName */, void * /* pvSearchID */, uint32_t /* ulIPAddress */ );\r
98 \r
99         /*\r
100          * Asynchronous version of gethostbyname()\r
101          * xTimeout is in units of ms.\r
102          */\r
103         uint32_t FreeRTOS_gethostbyname_a( const char *pcHostName, FOnDNSEvent pCallback, void *pvSearchID, TickType_t xTimeout );\r
104         void FreeRTOS_gethostbyname_cancel( void *pvSearchID );\r
105 \r
106 #endif\r
107 \r
108 /*\r
109  * FULL, UP-TO-DATE AND MAINTAINED REFERENCE DOCUMENTATION FOR ALL THESE\r
110  * FUNCTIONS IS AVAILABLE ON THE FOLLOWING URL:\r
111  * _TBD_ Add URL\r
112  */\r
113 uint32_t FreeRTOS_gethostbyname( const char *pcHostName );\r
114 \r
115 \r
116 #ifdef __cplusplus\r
117 }       /* extern "C" */\r
118 #endif\r
119 \r
120 #endif /* FREERTOS_DNS_H */\r
121 \r
122 \r
123 \r
124 \r
125 \r
126 \r
127 \r
128 \r
129 \r
130 \r
131 \r
132 \r
133 \r