netdev.h 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2019-03-18 ChenYong First version
  9. */
  10. #ifndef __NETDEV_H__
  11. #define __NETDEV_H__
  12. #include <rtthread.h>
  13. #ifdef __cplusplus
  14. extern "C" {
  15. #endif
  16. /* the maximum of all used hardware address lengths */
  17. #ifndef NETDEV_HWADDR_MAX_LEN
  18. #define NETDEV_HWADDR_MAX_LEN 8U
  19. #endif
  20. /* the maximum of dns server number supported */
  21. #ifndef NETDEV_DNS_SERVERS_NUM
  22. #define NETDEV_DNS_SERVERS_NUM 2U
  23. #endif
  24. #if NETDEV_IPV6
  25. /* the maximum of dns server number supported */
  26. #ifndef NETDEV_IPV6_NUM_ADDRESSES
  27. #define NETDEV_IPV6_NUM_ADDRESSES 3U
  28. #endif
  29. #endif /* NETDEV_IPV6 */
  30. /* whether the network interface device is 'up' (set by the network interface driver or application) */
  31. #define NETDEV_FLAG_UP 0x01U
  32. /* if set, the network interface device has broadcast capability, only supported in the 'lwIP' stack */
  33. #define NETDEV_FLAG_BROADCAST 0x02U
  34. /* if set, the network interface device has an active link (set by the network interface driver) */
  35. #define NETDEV_FLAG_LINK_UP 0x04U
  36. /* if set, the network interface device is an ethernet device using ARP, only supported in the 'lwIP' stack */
  37. #define NETDEV_FLAG_ETHARP 0x08U
  38. /* if set, the network interface device is an ethernet device, only supported in the 'lwIP' stack */
  39. #define NETDEV_FLAG_ETHERNET 0x10U
  40. /* if set, the network interface device has IGMP capability, only supported in the 'lwIP' stack */
  41. #define NETDEV_FLAG_IGMP 0x20U
  42. /* if set, the network interface device has MLD6 capability, only supported in the 'lwIP' stack */
  43. #define NETDEV_FLAG_MLD6 0x40U
  44. /* if set, the network interface device connected to internet successfully (set by the network interface driver) */
  45. #define NETDEV_FLAG_INTERNET_UP 0x80U
  46. /* if set, the network interface device has DHCP capability (set by the network interface device driver or application) */
  47. #define NETDEV_FLAG_DHCP 0x100U
  48. enum netdev_cb_type
  49. {
  50. NETDEV_CB_ADDR_IP, /* IP address */
  51. NETDEV_CB_ADDR_NETMASK, /* subnet mask */
  52. NETDEV_CB_ADDR_GATEWAY, /* netmask */
  53. NETDEV_CB_ADDR_DNS_SERVER, /* dns server */
  54. NETDEV_CB_STATUS_UP, /* changed to 'up' */
  55. NETDEV_CB_STATUS_DOWN, /* changed to 'down' */
  56. NETDEV_CB_STATUS_LINK_UP, /* changed to 'link up' */
  57. NETDEV_CB_STATUS_LINK_DOWN, /* changed to 'link down' */
  58. NETDEV_CB_STATUS_INTERNET_UP, /* changed to 'internet up' */
  59. NETDEV_CB_STATUS_INTERNET_DOWN, /* changed to 'internet down' */
  60. NETDEV_CB_STATUS_DHCP_ENABLE, /* enable DHCP capability */
  61. NETDEV_CB_STATUS_DHCP_DISABLE, /* disable DHCP capability */
  62. NETDEV_CB_REGISTER, /* netdev register */
  63. NETDEV_CB_DEFAULT_CHANGE, /* netdev default change */
  64. };
  65. struct netdev;
  66. /* function prototype for network interface device status or address change callback functions */
  67. typedef void (*netdev_callback_fn )(struct netdev *netdev, enum netdev_cb_type type);
  68. struct netdev_ops;
  69. /* network interface device object */
  70. struct netdev
  71. {
  72. rt_slist_t list;
  73. char name[RT_NAME_MAX]; /* network interface device name */
  74. ip_addr_t ip_addr; /* IP address */
  75. ip_addr_t netmask; /* subnet mask */
  76. ip_addr_t gw; /* gateway */
  77. #if NETDEV_IPV6
  78. ip_addr_t ip6_addr[NETDEV_IPV6_NUM_ADDRESSES]; /* array of IPv6 addresses */
  79. #endif /* NETDEV_IPV6 */
  80. ip_addr_t dns_servers[NETDEV_DNS_SERVERS_NUM]; /* DNS server */
  81. uint8_t hwaddr_len; /* hardware address length */
  82. uint8_t hwaddr[NETDEV_HWADDR_MAX_LEN]; /* hardware address */
  83. uint16_t flags; /* network interface device status flag */
  84. uint16_t mtu; /* maximum transfer unit (in bytes) */
  85. const struct netdev_ops *ops; /* network interface device operations */
  86. netdev_callback_fn status_callback; /* network interface device flags change callback */
  87. netdev_callback_fn addr_callback; /* network interface device address information change callback */
  88. #ifdef RT_USING_SAL
  89. void *sal_user_data; /* user-specific data for SAL */
  90. #endif /* RT_USING_SAL */
  91. void *user_data; /* user-specific data */
  92. };
  93. /* The list of network interface device */
  94. extern struct netdev *netdev_list;
  95. /* The default network interface device */
  96. extern struct netdev *netdev_default;
  97. /* The network interface device ping response object */
  98. struct netdev_ping_resp
  99. {
  100. ip_addr_t ip_addr; /* response IP address */
  101. uint16_t data_len; /* response data length */
  102. uint16_t ttl; /* time to live */
  103. uint32_t ticks; /* response time, unit tick */
  104. void *user_data; /* user-specific data */
  105. };
  106. /* The network interface device operations */
  107. struct netdev_ops
  108. {
  109. /* set network interface device hardware status operations */
  110. int (*set_up)(struct netdev *netdev);
  111. int (*set_down)(struct netdev *netdev);
  112. /* set network interface device address information operations */
  113. int (*set_addr_info)(struct netdev *netdev, ip_addr_t *ip_addr, ip_addr_t *netmask, ip_addr_t *gw);
  114. int (*set_dns_server)(struct netdev *netdev, uint8_t dns_num, ip_addr_t *dns_server);
  115. int (*set_dhcp)(struct netdev *netdev, rt_bool_t is_enabled);
  116. #ifdef RT_USING_FINSH
  117. /* set network interface device common network interface device operations */
  118. int (*ping)(struct netdev *netdev, const char *host, size_t data_len, uint32_t timeout, struct netdev_ping_resp *ping_resp);
  119. void (*netstat)(struct netdev *netdev);
  120. #endif
  121. /* set default network interface device in current network stack*/
  122. int (*set_default)(struct netdev *netdev);
  123. };
  124. /* The network interface device registered and unregistered*/
  125. int netdev_register(struct netdev *netdev, const char *name, void *user_data);
  126. int netdev_unregister(struct netdev *netdev);
  127. /* Get network interface device object */
  128. struct netdev *netdev_get_first_by_flags(uint16_t flags);
  129. struct netdev *netdev_get_by_ipaddr(ip_addr_t *ip_addr);
  130. struct netdev *netdev_get_by_name(const char *name);
  131. #ifdef RT_USING_SAL
  132. struct netdev *netdev_get_by_family(int family);
  133. int netdev_family_get(struct netdev *netdev);
  134. #endif /* RT_USING_SAL */
  135. /* Set default network interface device in list */
  136. void netdev_set_default(struct netdev *netdev);
  137. void netdev_set_default_change_callback(netdev_callback_fn register_callback);
  138. /* Set network interface device status */
  139. int netdev_set_up(struct netdev *netdev);
  140. int netdev_set_down(struct netdev *netdev);
  141. int netdev_dhcp_enabled(struct netdev *netdev, rt_bool_t is_enabled);
  142. /* Get network interface device status */
  143. #define netdev_is_up(netdev) (((netdev)->flags & NETDEV_FLAG_UP) ? (uint8_t)1 : (uint8_t)0)
  144. #define netdev_is_link_up(netdev) (((netdev)->flags & NETDEV_FLAG_LINK_UP) ? (uint8_t)1 : (uint8_t)0)
  145. #define netdev_is_internet_up(netdev) (((netdev)->flags & NETDEV_FLAG_INTERNET_UP) ? (uint8_t)1 : (uint8_t)0)
  146. #define netdev_is_dhcp_enabled(netdev) (((netdev)->flags & NETDEV_FLAG_DHCP) ? (uint8_t)1 : (uint8_t)0)
  147. /* Set network interface device address */
  148. int netdev_set_ipaddr(struct netdev *netdev, const ip_addr_t *ipaddr);
  149. int netdev_set_netmask(struct netdev *netdev, const ip_addr_t *netmask);
  150. int netdev_set_gw(struct netdev *netdev, const ip_addr_t *gw);
  151. int netdev_set_dns_server(struct netdev *netdev, uint8_t dns_num, const ip_addr_t *dns_server);
  152. /* Set network interface device callback, it can be called when the status or address changed */
  153. void netdev_set_register_callback(netdev_callback_fn status_callback);
  154. void netdev_set_status_callback(struct netdev *netdev, netdev_callback_fn status_callback);
  155. void netdev_set_addr_callback(struct netdev *netdev, netdev_callback_fn addr_callback);
  156. /* Set network interface device status and address, this function can only be called in the network interface device driver */
  157. void netdev_low_level_set_ipaddr(struct netdev *netdev, const ip_addr_t *ipaddr);
  158. void netdev_low_level_set_netmask(struct netdev *netdev, const ip_addr_t *netmask);
  159. void netdev_low_level_set_gw(struct netdev *netdev, const ip_addr_t *gw);
  160. void netdev_low_level_set_dns_server(struct netdev *netdev, uint8_t dns_num, const ip_addr_t *dns_server);
  161. void netdev_low_level_set_status(struct netdev *netdev, rt_bool_t is_up);
  162. void netdev_low_level_set_link_status(struct netdev *netdev, rt_bool_t is_up);
  163. void netdev_low_level_set_internet_status(struct netdev *netdev, rt_bool_t is_up);
  164. void netdev_low_level_set_dhcp_status(struct netdev *netdev, rt_bool_t is_enable);
  165. #ifdef __cplusplus
  166. }
  167. #endif
  168. #endif /* __NETDEV_H__ */