dev.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. #ifndef _NET_CORE_DEV_H
  3. #define _NET_CORE_DEV_H
  4. #include <linux/types.h>
  5. struct net;
  6. struct net_device;
  7. struct netdev_bpf;
  8. struct netdev_phys_item_id;
  9. struct netlink_ext_ack;
  10. /* Random bits of netdevice that don't need to be exposed */
  11. #define FLOW_LIMIT_HISTORY (1 << 7) /* must be ^2 and !overflow buckets */
  12. struct sd_flow_limit {
  13. u64 count;
  14. unsigned int num_buckets;
  15. unsigned int history_head;
  16. u16 history[FLOW_LIMIT_HISTORY];
  17. u8 buckets[];
  18. };
  19. extern int netdev_flow_limit_table_len;
  20. #ifdef CONFIG_PROC_FS
  21. int __init dev_proc_init(void);
  22. #else
  23. #define dev_proc_init() 0
  24. #endif
  25. void linkwatch_init_dev(struct net_device *dev);
  26. void linkwatch_forget_dev(struct net_device *dev);
  27. void linkwatch_run_queue(void);
  28. void dev_addr_flush(struct net_device *dev);
  29. int dev_addr_init(struct net_device *dev);
  30. void dev_addr_check(struct net_device *dev);
  31. /* sysctls not referred to from outside net/core/ */
  32. extern int netdev_budget;
  33. extern unsigned int netdev_budget_usecs;
  34. extern unsigned int sysctl_skb_defer_max;
  35. extern int netdev_tstamp_prequeue;
  36. extern int netdev_unregister_timeout_secs;
  37. extern int weight_p;
  38. extern int dev_weight_rx_bias;
  39. extern int dev_weight_tx_bias;
  40. /* rtnl helpers */
  41. extern struct list_head net_todo_list;
  42. void netdev_run_todo(void);
  43. /* netdev management, shared between various uAPI entry points */
  44. struct netdev_name_node {
  45. struct hlist_node hlist;
  46. struct list_head list;
  47. struct net_device *dev;
  48. const char *name;
  49. };
  50. int netdev_get_name(struct net *net, char *name, int ifindex);
  51. int dev_change_name(struct net_device *dev, const char *newname);
  52. #define netdev_for_each_altname(dev, namenode) \
  53. list_for_each_entry((namenode), &(dev)->name_node->list, list)
  54. int netdev_name_node_alt_create(struct net_device *dev, const char *name);
  55. int netdev_name_node_alt_destroy(struct net_device *dev, const char *name);
  56. int dev_validate_mtu(struct net_device *dev, int mtu,
  57. struct netlink_ext_ack *extack);
  58. int dev_set_mtu_ext(struct net_device *dev, int mtu,
  59. struct netlink_ext_ack *extack);
  60. int dev_get_phys_port_id(struct net_device *dev,
  61. struct netdev_phys_item_id *ppid);
  62. int dev_get_phys_port_name(struct net_device *dev,
  63. char *name, size_t len);
  64. int dev_change_proto_down(struct net_device *dev, bool proto_down);
  65. void dev_change_proto_down_reason(struct net_device *dev, unsigned long mask,
  66. u32 value);
  67. typedef int (*bpf_op_t)(struct net_device *dev, struct netdev_bpf *bpf);
  68. int dev_change_xdp_fd(struct net_device *dev, struct netlink_ext_ack *extack,
  69. int fd, int expected_fd, u32 flags);
  70. int dev_change_tx_queue_len(struct net_device *dev, unsigned long new_len);
  71. void dev_set_group(struct net_device *dev, int new_group);
  72. int dev_change_carrier(struct net_device *dev, bool new_carrier);
  73. void __dev_set_rx_mode(struct net_device *dev);
  74. static inline void netif_set_gso_max_size(struct net_device *dev,
  75. unsigned int size)
  76. {
  77. /* dev->gso_max_size is read locklessly from sk_setup_caps() */
  78. WRITE_ONCE(dev->gso_max_size, size);
  79. }
  80. static inline void netif_set_gso_max_segs(struct net_device *dev,
  81. unsigned int segs)
  82. {
  83. /* dev->gso_max_segs is read locklessly from sk_setup_caps() */
  84. WRITE_ONCE(dev->gso_max_segs, segs);
  85. }
  86. static inline void netif_set_gro_max_size(struct net_device *dev,
  87. unsigned int size)
  88. {
  89. /* This pairs with the READ_ONCE() in skb_gro_receive() */
  90. WRITE_ONCE(dev->gro_max_size, size);
  91. }
  92. #endif