#ifndef _NET_DN_FIB_H #define _NET_DN_FIB_H #include extern const struct nla_policy rtm_dn_policy[]; struct dn_fib_res { struct fib_rule *r; struct dn_fib_info *fi; unsigned char prefixlen; unsigned char nh_sel; unsigned char type; unsigned char scope; }; struct dn_fib_nh { struct net_device *nh_dev; unsigned int nh_flags; unsigned char nh_scope; int nh_weight; int nh_power; int nh_oif; __le16 nh_gw; }; struct dn_fib_info { struct dn_fib_info *fib_next; struct dn_fib_info *fib_prev; int fib_treeref; atomic_t fib_clntref; int fib_dead; unsigned int fib_flags; int fib_protocol; __le16 fib_prefsrc; __u32 fib_priority; __u32 fib_metrics[RTAX_MAX]; int fib_nhs; int fib_power; struct dn_fib_nh fib_nh[0]; #define dn_fib_dev fib_nh[0].nh_dev }; #define DN_FIB_RES_RESET(res) ((res).nh_sel = 0) #define DN_FIB_RES_NH(res) ((res).fi->fib_nh[(res).nh_sel]) #define DN_FIB_RES_PREFSRC(res) ((res).fi->fib_prefsrc ? : __dn_fib_res_prefsrc(&res)) #define DN_FIB_RES_GW(res) (DN_FIB_RES_NH(res).nh_gw) #define DN_FIB_RES_DEV(res) (DN_FIB_RES_NH(res).nh_dev) #define DN_FIB_RES_OIF(res) (DN_FIB_RES_NH(res).nh_oif) typedef struct { __le16 datum; } dn_fib_key_t; typedef struct { __le16 datum; } dn_fib_hash_t; typedef struct { __u16 datum; } dn_fib_idx_t; struct dn_fib_node { struct dn_fib_node *fn_next; struct dn_fib_info *fn_info; #define DN_FIB_INFO(f) ((f)->fn_info) dn_fib_key_t fn_key; u8 fn_type; u8 fn_scope; u8 fn_state; }; struct dn_fib_table { struct hlist_node hlist; u32 n; int (*insert)(struct dn_fib_table *t, struct rtmsg *r, struct nlattr *attrs[], struct nlmsghdr *n, struct netlink_skb_parms *req); int (*delete)(struct dn_fib_table *t, struct rtmsg *r, struct nlattr *attrs[], struct nlmsghdr *n, struct netlink_skb_parms *req); int (*lookup)(struct dn_fib_table *t, const struct flowidn *fld, struct dn_fib_res *res); int (*flush)(struct dn_fib_table *t); int (*dump)(struct dn_fib_table *t, struct sk_buff *skb, struct netlink_callback *cb); unsigned char data[0]; }; #ifdef CONFIG_DECNET_ROUTER /* * dn_fib.c */ void dn_fib_init(void); void dn_fib_cleanup(void); int dn_fib_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg); struct dn_fib_info *dn_fib_create_info(const struct rtmsg *r, struct nlattr *attrs[], const struct nlmsghdr *nlh, int *errp); int dn_fib_semantic_match(int type, struct dn_fib_info *fi, const struct flowidn *fld, struct dn_fib_res *res); void dn_fib_release_info(struct dn_fib_info *fi); void dn_fib_flush(void); void dn_fib_select_multipath(const struct flowidn *fld, struct dn_fib_res *res); /* * dn_tables.c */ struct dn_fib_table *dn_fib_get_table(u32 n, int creat); struct dn_fib_table *dn_fib_empty_table(void); void dn_fib_table_init(void); void dn_fib_table_cleanup(void); /* * dn_rules.c */ void dn_fib_rules_init(void); void dn_fib_rules_cleanup(void); unsigned int dnet_addr_type(__le16 addr); int dn_fib_lookup(struct flowidn *fld, struct dn_fib_res *res); int dn_fib_dump(struct sk_buff *skb, struct netlink_callback *cb); void dn_fib_free_info(struct dn_fib_info *fi); static inline void dn_fib_info_put(struct dn_fib_info *fi) { if (atomic_dec_and_test(&fi->fib_clntref)) dn_fib_free_info(fi); } static inline void dn_fib_res_put(struct dn_fib_res *res) { if (res->fi) dn_fib_info_put(res->fi); if (res->r) fib_rule_put(res->r); } #else /* Endnode */ #define dn_fib_init() do { } while(0) #define dn_fib_cleanup() do { } while(0) #define dn_fib_lookup(fl, res) (-ESRCH) #define dn_fib_info_put(fi) do { } while(0) #define dn_fib_select_multipath(fl, res) do { } while(0) #define dn_fib_rules_policy(saddr,res,flags) (0) #define dn_fib_res_put(res) do { } while(0) #endif /* CONFIG_DECNET_ROUTER */ static inline __le16 dnet_make_mask(int n) { if (n) return cpu_to_le16(~((1 << (16 - n)) - 1)); return cpu_to_le16(0); } #endif /* _NET_DN_FIB_H */ >bridge111logplain -rw-r--r--drmP.h25758logplain -rw-r--r--drm_agpsupport.h3867logplain -rw-r--r--drm_atomic.h14443logplain -rw-r--r--drm_atomic_helper.h10607logplain -rw-r--r--drm_auth.h2260logplain -rw-r--r--drm_blend.h2700logplain -rw-r--r--drm_bridge.h7977logplain -rw-r--r--drm_cache.h1763logplain -rw-r--r--drm_color_mgmt.h2166logplain -rw-r--r--drm_connector.h28613logplain -rw-r--r--drm_crtc.h28999logplain -rw-r--r--drm_crtc_helper.h3301logplain -rw-r--r--drm_debugfs_crc.h2670logplain -rw-r--r--drm_displayid.h2850logplain -rw-r--r--drm_dp_dual_mode_helper.h4532logplain -rw-r--r--drm_dp_helper.h30638logplain -rw-r--r--drm_dp_mst_helper.h16260logplain -rw-r--r--drm_drv.h14861logplain -rw-r--r--drm_edid.h14335logplain -rw-r--r--drm_encoder.h8160logplain -rw-r--r--drm_encoder_slave.h6583logplain -rw-r--r--drm_fb_cma_helper.h1929logplain -rw-r--r--drm_fb_helper.h15125logplain -rw-r--r--drm_fixed.h4825logplain -rw-r--r--drm_flip_work.h3071logplain -rw-r--r--drm_fourcc.h2748logplain -rw-r--r--drm_framebuffer.h9623logplain -rw-r--r--drm_gem.h8052logplain -rw-r--r--drm_gem_cma_helper.h2286logplain -rw-r--r--drm_global.h2011logplain -rw-r--r--drm_hashtab.h3139logplain -rw-r--r--drm_irq.h6323logplain -rw-r--r--drm_legacy.h6933logplain -rw-r--r--drm_mem_util.h2468logplain -rw-r--r--drm_mipi_dsi.h10327logplain -rw-r--r--drm_mm.h11462logplain -rw-r--r--drm_mode_config.h23728logplain -rw-r--r--drm_mode_object.h4911logplain -rw-r--r--drm_modes.h17078logplain -rw-r--r--drm_modeset_helper.h1576logplain -rw-r--r--drm_modeset_helper_vtables.h41180logplain -rw-r--r--drm_modeset_lock.h4241logplain -rw-r--r--drm_of.h2034logplain -rw-r--r--drm_os_linux.h2230logplain -rw-r--r--drm_panel.h7079logplain -rw-r--r--drm_pciids.h68035logplain -rw-r--r--drm_plane.h19435logplain -rw-r--r--drm_plane_helper.h3186logplain -rw-r--r--drm_print.h3232logplain -rw-r--r--drm_property.h11460logplain -rw-r--r--drm_rect.h5103logplain -rw-r--r--drm_simple_kms_helper.h4090logplain -rw-r--r--drm_sysfs.h300logplain -rw-r--r--drm_vma_manager.h7840logplain -rw-r--r--gma_drm.h1033logplain d---------i2c109logplain