device.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. /*
  2. * netifd - network interface daemon
  3. * Copyright (C) 2012 Felix Fietkau <nbd@openwrt.org>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License version 2
  7. * as published by the Free Software Foundation
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. */
  14. #ifndef __NETIFD_DEVICE_H
  15. #define __NETIFD_DEVICE_H
  16. #include <libubox/avl.h>
  17. #include <libubox/safe_list.h>
  18. #include <libubox/kvlist.h>
  19. #include <netinet/in.h>
  20. struct device;
  21. struct device_type;
  22. struct device_user;
  23. struct device_hotplug_ops;
  24. struct bridge_vlan;
  25. struct interface;
  26. typedef int (*device_state_cb)(struct device *, bool up);
  27. enum {
  28. DEV_ATTR_TYPE,
  29. DEV_ATTR_MTU,
  30. DEV_ATTR_MTU6,
  31. DEV_ATTR_MACADDR,
  32. DEV_ATTR_TXQUEUELEN,
  33. DEV_ATTR_ENABLED,
  34. DEV_ATTR_IPV6,
  35. DEV_ATTR_PROMISC,
  36. DEV_ATTR_RPFILTER,
  37. DEV_ATTR_ACCEPTLOCAL,
  38. DEV_ATTR_IGMPVERSION,
  39. DEV_ATTR_MLDVERSION,
  40. DEV_ATTR_NEIGHREACHABLETIME,
  41. DEV_ATTR_DADTRANSMITS,
  42. DEV_ATTR_MULTICAST_TO_UNICAST,
  43. DEV_ATTR_MULTICAST_ROUTER,
  44. DEV_ATTR_MULTICAST_FAST_LEAVE,
  45. DEV_ATTR_MULTICAST,
  46. DEV_ATTR_LEARNING,
  47. DEV_ATTR_UNICAST_FLOOD,
  48. DEV_ATTR_NEIGHGCSTALETIME,
  49. DEV_ATTR_SENDREDIRECTS,
  50. DEV_ATTR_NEIGHLOCKTIME,
  51. DEV_ATTR_ISOLATE,
  52. DEV_ATTR_IP6SEGMENTROUTING,
  53. DEV_ATTR_DROP_V4_UNICAST_IN_L2_MULTICAST,
  54. DEV_ATTR_DROP_V6_UNICAST_IN_L2_MULTICAST,
  55. DEV_ATTR_DROP_GRATUITOUS_ARP,
  56. DEV_ATTR_DROP_UNSOLICITED_NA,
  57. DEV_ATTR_ARP_ACCEPT,
  58. DEV_ATTR_AUTH,
  59. DEV_ATTR_AUTH_VLAN,
  60. DEV_ATTR_SPEED,
  61. DEV_ATTR_DUPLEX,
  62. DEV_ATTR_VLAN,
  63. DEV_ATTR_PAUSE,
  64. DEV_ATTR_ASYM_PAUSE,
  65. DEV_ATTR_RXPAUSE,
  66. DEV_ATTR_TXPAUSE,
  67. DEV_ATTR_AUTONEG,
  68. DEV_ATTR_GRO,
  69. DEV_ATTR_MASTER,
  70. DEV_ATTR_EEE,
  71. DEV_ATTR_TAGS,
  72. __DEV_ATTR_MAX,
  73. };
  74. enum dev_change_type {
  75. DEV_CONFIG_NO_CHANGE,
  76. DEV_CONFIG_APPLIED,
  77. DEV_CONFIG_RESTART,
  78. DEV_CONFIG_RECREATE,
  79. };
  80. struct device_type {
  81. struct list_head list;
  82. const char *name;
  83. bool bridge_capability;
  84. const char *name_prefix;
  85. const struct uci_blob_param_list *config_params;
  86. struct device *(*create)(const char *name, struct device_type *devtype,
  87. struct blob_attr *attr);
  88. void (*config_init)(struct device *);
  89. enum dev_change_type (*reload)(struct device *, struct blob_attr *);
  90. void (*vlan_update)(struct device *);
  91. void (*dump_info)(struct device *, struct blob_buf *buf);
  92. void (*dump_stats)(struct device *, struct blob_buf *buf);
  93. int (*check_state)(struct device *);
  94. void (*stp_init)(struct device *);
  95. void (*free)(struct device *);
  96. };
  97. enum {
  98. DEV_OPT_MTU = (1ULL << 0),
  99. DEV_OPT_MACADDR = (1ULL << 1),
  100. DEV_OPT_TXQUEUELEN = (1ULL << 2),
  101. DEV_OPT_IPV6 = (1ULL << 3),
  102. DEV_OPT_PROMISC = (1ULL << 4),
  103. DEV_OPT_RPFILTER = (1ULL << 5),
  104. DEV_OPT_ACCEPTLOCAL = (1ULL << 6),
  105. DEV_OPT_IGMPVERSION = (1ULL << 7),
  106. DEV_OPT_MLDVERSION = (1ULL << 8),
  107. DEV_OPT_NEIGHREACHABLETIME = (1ULL << 9),
  108. DEV_OPT_DEFAULT_MACADDR = (1ULL << 10),
  109. DEV_OPT_AUTH = (1ULL << 11),
  110. DEV_OPT_MTU6 = (1ULL << 12),
  111. DEV_OPT_DADTRANSMITS = (1ULL << 13),
  112. DEV_OPT_MULTICAST_TO_UNICAST = (1ULL << 14),
  113. DEV_OPT_MULTICAST_ROUTER = (1ULL << 15),
  114. DEV_OPT_MULTICAST = (1ULL << 16),
  115. DEV_OPT_LEARNING = (1ULL << 17),
  116. DEV_OPT_UNICAST_FLOOD = (1ULL << 18),
  117. DEV_OPT_NEIGHGCSTALETIME = (1ULL << 19),
  118. DEV_OPT_MULTICAST_FAST_LEAVE = (1ULL << 20),
  119. DEV_OPT_SENDREDIRECTS = (1ULL << 21),
  120. DEV_OPT_NEIGHLOCKTIME = (1ULL << 22),
  121. DEV_OPT_ISOLATE = (1ULL << 23),
  122. DEV_OPT_IP6SEGMENTROUTING = (1ULL << 24),
  123. DEV_OPT_DROP_V4_UNICAST_IN_L2_MULTICAST = (1ULL << 25),
  124. DEV_OPT_DROP_V6_UNICAST_IN_L2_MULTICAST = (1ULL << 26),
  125. DEV_OPT_DROP_GRATUITOUS_ARP = (1ULL << 27),
  126. DEV_OPT_DROP_UNSOLICITED_NA = (1ULL << 28),
  127. DEV_OPT_ARP_ACCEPT = (1ULL << 29),
  128. DEV_OPT_SPEED = (1ULL << 30),
  129. DEV_OPT_DUPLEX = (1ULL << 31),
  130. DEV_OPT_PAUSE = (1ULL << 32),
  131. DEV_OPT_ASYM_PAUSE = (1ULL << 33),
  132. DEV_OPT_RXPAUSE = (1ULL << 34),
  133. DEV_OPT_TXPAUSE = (1ULL << 35),
  134. DEV_OPT_AUTONEG = (1ULL << 36),
  135. DEV_OPT_GRO = (1ULL << 37),
  136. DEV_OPT_MASTER = (1ULL << 38),
  137. DEV_OPT_EEE = (1ULL << 39),
  138. };
  139. /* events broadcasted to all users of a device */
  140. enum device_event {
  141. DEV_EVENT_ADD,
  142. DEV_EVENT_REMOVE,
  143. DEV_EVENT_UPDATE_IFNAME,
  144. DEV_EVENT_UPDATE_IFINDEX,
  145. DEV_EVENT_SETUP,
  146. DEV_EVENT_TEARDOWN,
  147. DEV_EVENT_UP,
  148. DEV_EVENT_DOWN,
  149. DEV_EVENT_AUTH_UP,
  150. DEV_EVENT_LINK_UP,
  151. DEV_EVENT_LINK_DOWN,
  152. /* Topology changed (i.e. bridge member added) */
  153. DEV_EVENT_TOPO_CHANGE,
  154. __DEV_EVENT_MAX
  155. };
  156. /*
  157. * device dependency with callbacks
  158. */
  159. struct device_user {
  160. struct safe_list list;
  161. bool claimed;
  162. bool hotplug;
  163. bool alias;
  164. uint8_t ev_idx[__DEV_EVENT_MAX];
  165. struct device *dev;
  166. void (*cb)(struct device_user *, enum device_event);
  167. };
  168. struct device_settings {
  169. uint64_t flags;
  170. uint64_t valid_flags;
  171. unsigned int mtu;
  172. unsigned int mtu6;
  173. unsigned int txqueuelen;
  174. uint8_t macaddr[6];
  175. bool ipv6;
  176. bool promisc;
  177. unsigned int rpfilter;
  178. bool acceptlocal;
  179. unsigned int igmpversion;
  180. unsigned int mldversion;
  181. unsigned int neigh4reachabletime;
  182. unsigned int neigh6reachabletime;
  183. unsigned int neigh4gcstaletime;
  184. unsigned int neigh6gcstaletime;
  185. int neigh4locktime;
  186. unsigned int dadtransmits;
  187. bool multicast_to_unicast;
  188. unsigned int multicast_router;
  189. bool multicast_fast_leave;
  190. bool multicast;
  191. bool learning;
  192. bool unicast_flood;
  193. bool sendredirects;
  194. bool ip6segmentrouting;
  195. bool isolate;
  196. bool drop_v4_unicast_in_l2_multicast;
  197. bool drop_v6_unicast_in_l2_multicast;
  198. bool drop_gratuitous_arp;
  199. bool drop_unsolicited_na;
  200. bool arp_accept;
  201. bool auth;
  202. unsigned int speed;
  203. bool duplex;
  204. bool pause;
  205. bool asym_pause;
  206. bool rxpause;
  207. bool txpause;
  208. bool autoneg;
  209. bool gro;
  210. int master_ifindex;
  211. bool eee;
  212. };
  213. struct device_vlan_range {
  214. uint16_t start, end;
  215. };
  216. /*
  217. * link layer device. typically represents a linux network device.
  218. * can be used to support VLANs as well
  219. */
  220. struct device {
  221. struct device_type *type;
  222. struct avl_node avl;
  223. struct safe_list users;
  224. struct safe_list aliases;
  225. struct vlist_tree vlans;
  226. struct kvlist vlan_aliases;
  227. struct blob_attr *config_auth_vlans;
  228. struct blob_attr *auth_vlans;
  229. struct blob_attr *tags;
  230. char ifname[IFNAMSIZ];
  231. int ifindex;
  232. struct blob_attr *config;
  233. bool config_pending;
  234. bool sys_present;
  235. /* DEV_EVENT_ADD */
  236. bool present;
  237. /* DEV_EVENT_UP */
  238. int active;
  239. /* DEV_EVENT_LINK_UP */
  240. bool link_active;
  241. bool auth_status;
  242. bool external;
  243. bool disabled;
  244. bool deferred;
  245. bool hidden;
  246. bool current_config;
  247. bool iface_config;
  248. bool default_config;
  249. bool wireless;
  250. bool wireless_ap;
  251. bool wireless_proxyarp;
  252. bool wireless_isolate;
  253. bool bpdu_filter;
  254. struct interface *config_iface;
  255. struct device_vlan_range *extra_vlan;
  256. int n_extra_vlan;
  257. /* set interface up or down */
  258. device_state_cb set_state;
  259. const struct device_hotplug_ops *hotplug_ops;
  260. struct device_user parent;
  261. struct device_settings orig_settings;
  262. struct device_settings settings;
  263. };
  264. struct device_hotplug_ops {
  265. int (*prepare)(struct device *dev, struct device **bridge_dev);
  266. int (*add)(struct device *main, struct device *member, struct blob_attr *vlan);
  267. int (*del)(struct device *main, struct device *member, struct blob_attr *vlan);
  268. };
  269. enum bridge_vlan_flags {
  270. BRVLAN_F_SELF = (1 << 0),
  271. BRVLAN_F_PVID = (1 << 1),
  272. BRVLAN_F_UNTAGGED = (1 << 2),
  273. };
  274. struct bridge_vlan_port {
  275. const char *ifname;
  276. uint16_t flags;
  277. int8_t check;
  278. };
  279. struct bridge_vlan_hotplug_port {
  280. struct list_head list;
  281. struct bridge_vlan_port port;
  282. };
  283. struct bridge_vlan {
  284. struct vlist_node node;
  285. struct bridge_vlan_port *ports;
  286. int n_ports;
  287. struct list_head hotplug_ports;
  288. uint16_t vid;
  289. bool local;
  290. bool pending;
  291. };
  292. extern const struct uci_blob_param_list device_attr_list;
  293. extern struct device_type simple_device_type;
  294. extern struct device_type tunnel_device_type;
  295. void device_vlan_update(bool done);
  296. void device_stp_init(void);
  297. int device_type_add(struct device_type *devtype);
  298. struct device_type *device_type_get(const char *tname);
  299. struct device *device_create(const char *name, struct device_type *type,
  300. struct blob_attr *config);
  301. void device_merge_settings(struct device *dev, struct device_settings *n);
  302. void device_init_settings(struct device *dev, struct blob_attr **tb);
  303. void device_init_pending(void);
  304. enum dev_change_type
  305. device_apply_config(struct device *dev, struct device_type *type,
  306. struct blob_attr *config);
  307. void device_reset_config(void);
  308. void device_reset_old(void);
  309. int device_init_virtual(struct device *dev, struct device_type *type, const char *name);
  310. int device_init(struct device *dev, struct device_type *type, const char *ifname);
  311. void device_cleanup(struct device *dev);
  312. struct device *device_find(const char *name);
  313. struct device *__device_get(const char *name, int create, bool check_vlan);
  314. static inline struct device *device_get(const char *name, int create)
  315. {
  316. return __device_get(name, create, true);
  317. }
  318. void device_add_user(struct device_user *dep, struct device *dev);
  319. void device_remove_user(struct device_user *dep);
  320. const char *device_event_name(enum device_event ev);
  321. void __device_broadcast_event(struct device *dev, enum device_event ev);
  322. #define device_broadcast_event(dev, ev) do { \
  323. struct device *__ev_dev = (dev); \
  324. D(DEVICE, "%s: event (%s)", \
  325. (__ev_dev && __ev_dev->ifname[0] ? __ev_dev->ifname : "(none)"), \
  326. device_event_name(ev)); \
  327. __device_broadcast_event(__ev_dev, ev); \
  328. } while (0)
  329. void _device_set_present(struct device *dev, bool state);
  330. #define device_set_present(dev, state) do { \
  331. struct device *__ev_dev = (dev); \
  332. bool __ev_state = state; \
  333. D(DEVICE, "%s: set present=%d", \
  334. (__ev_dev && __ev_dev->ifname[0] ? __ev_dev->ifname : "(none)"), \
  335. __ev_state); \
  336. _device_set_present(__ev_dev, __ev_state); \
  337. } while (0)
  338. void device_set_link(struct device *dev, bool state);
  339. void device_set_ifindex(struct device *dev, int ifindex);
  340. int device_set_ifname(struct device *dev, const char *name);
  341. void device_refresh_present(struct device *dev);
  342. int device_claim(struct device_user *dep);
  343. void device_release(struct device_user *dep);
  344. int device_check_state(struct device *dev);
  345. void device_dump_status(struct blob_buf *b, struct device *dev);
  346. void device_free_unused(void);
  347. struct device *get_vlan_device_chain(const char *ifname, int create);
  348. void alias_notify_device(const char *name, struct device *dev);
  349. struct device *device_alias_get(const char *name);
  350. void device_set_auth_status(struct device *dev, bool value, struct blob_attr *vlans);
  351. static inline void
  352. device_set_deferred(struct device *dev, bool value)
  353. {
  354. dev->deferred = value;
  355. device_refresh_present(dev);
  356. }
  357. static inline void
  358. device_set_disabled(struct device *dev, bool value)
  359. {
  360. dev->disabled = value;
  361. device_refresh_present(dev);
  362. }
  363. static inline bool
  364. device_link_active(struct device *dev)
  365. {
  366. if (dev->settings.auth && !dev->auth_status)
  367. return false;
  368. return dev->link_active;
  369. }
  370. bool device_check_ip6segmentrouting(void);
  371. void device_hotplug_event(const char *name, bool add);
  372. #endif