blob: 6dd2213c5eb216a0cc08f4d2c02b82f0f5abcd20 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#ifndef _NET_DN_FIB_H
3#define _NET_DN_FIB_H
4
Thomas Graf58d7d8f2013-03-21 07:45:28 +00005#include <linux/netlink.h>
Reshetova, Elenae0542dd2017-07-04 15:53:00 +03006#include <linux/refcount.h>
Thomas Graf58d7d8f2013-03-21 07:45:28 +00007
8extern const struct nla_policy rtm_dn_policy[];
Linus Torvalds1da177e2005-04-16 15:20:36 -07009
10struct dn_fib_res {
Steven Whitehousea8731cb2006-08-09 15:56:46 -070011 struct fib_rule *r;
Linus Torvalds1da177e2005-04-16 15:20:36 -070012 struct dn_fib_info *fi;
13 unsigned char prefixlen;
14 unsigned char nh_sel;
15 unsigned char type;
16 unsigned char scope;
17};
18
19struct dn_fib_nh {
20 struct net_device *nh_dev;
Eric Dumazet95c96172012-04-15 05:58:06 +000021 unsigned int nh_flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -070022 unsigned char nh_scope;
23 int nh_weight;
24 int nh_power;
25 int nh_oif;
Steven Whitehousec4ea94a2006-03-20 22:42:39 -080026 __le16 nh_gw;
Linus Torvalds1da177e2005-04-16 15:20:36 -070027};
28
29struct dn_fib_info {
30 struct dn_fib_info *fib_next;
31 struct dn_fib_info *fib_prev;
32 int fib_treeref;
Reshetova, Elenae0542dd2017-07-04 15:53:00 +030033 refcount_t fib_clntref;
Linus Torvalds1da177e2005-04-16 15:20:36 -070034 int fib_dead;
Eric Dumazet95c96172012-04-15 05:58:06 +000035 unsigned int fib_flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -070036 int fib_protocol;
Steven Whitehousec4ea94a2006-03-20 22:42:39 -080037 __le16 fib_prefsrc;
Linus Torvalds1da177e2005-04-16 15:20:36 -070038 __u32 fib_priority;
39 __u32 fib_metrics[RTAX_MAX];
Linus Torvalds1da177e2005-04-16 15:20:36 -070040 int fib_nhs;
41 int fib_power;
42 struct dn_fib_nh fib_nh[0];
43#define dn_fib_dev fib_nh[0].nh_dev
44};
45
46
47#define DN_FIB_RES_RESET(res) ((res).nh_sel = 0)
48#define DN_FIB_RES_NH(res) ((res).fi->fib_nh[(res).nh_sel])
49
50#define DN_FIB_RES_PREFSRC(res) ((res).fi->fib_prefsrc ? : __dn_fib_res_prefsrc(&res))
51#define DN_FIB_RES_GW(res) (DN_FIB_RES_NH(res).nh_gw)
52#define DN_FIB_RES_DEV(res) (DN_FIB_RES_NH(res).nh_dev)
53#define DN_FIB_RES_OIF(res) (DN_FIB_RES_NH(res).nh_oif)
54
55typedef struct {
Steven Whitehousec4ea94a2006-03-20 22:42:39 -080056 __le16 datum;
Linus Torvalds1da177e2005-04-16 15:20:36 -070057} dn_fib_key_t;
58
59typedef struct {
Steven Whitehousec4ea94a2006-03-20 22:42:39 -080060 __le16 datum;
Linus Torvalds1da177e2005-04-16 15:20:36 -070061} dn_fib_hash_t;
62
63typedef struct {
Steven Whitehousec4ea94a2006-03-20 22:42:39 -080064 __u16 datum;
Linus Torvalds1da177e2005-04-16 15:20:36 -070065} dn_fib_idx_t;
66
67struct dn_fib_node {
68 struct dn_fib_node *fn_next;
69 struct dn_fib_info *fn_info;
70#define DN_FIB_INFO(f) ((f)->fn_info)
71 dn_fib_key_t fn_key;
72 u8 fn_type;
73 u8 fn_scope;
74 u8 fn_state;
75};
76
77
78struct dn_fib_table {
Patrick McHardyabcab262006-08-10 23:11:47 -070079 struct hlist_node hlist;
Patrick McHardy2dfe55b2006-08-10 23:08:33 -070080 u32 n;
Linus Torvalds1da177e2005-04-16 15:20:36 -070081
82 int (*insert)(struct dn_fib_table *t, struct rtmsg *r,
Thomas Graf58d7d8f2013-03-21 07:45:28 +000083 struct nlattr *attrs[], struct nlmsghdr *n,
Linus Torvalds1da177e2005-04-16 15:20:36 -070084 struct netlink_skb_parms *req);
85 int (*delete)(struct dn_fib_table *t, struct rtmsg *r,
Thomas Graf58d7d8f2013-03-21 07:45:28 +000086 struct nlattr *attrs[], struct nlmsghdr *n,
Linus Torvalds1da177e2005-04-16 15:20:36 -070087 struct netlink_skb_parms *req);
David S. Millerbef55ae2011-03-12 17:17:10 -050088 int (*lookup)(struct dn_fib_table *t, const struct flowidn *fld,
Linus Torvalds1da177e2005-04-16 15:20:36 -070089 struct dn_fib_res *res);
90 int (*flush)(struct dn_fib_table *t);
91 int (*dump)(struct dn_fib_table *t, struct sk_buff *skb, struct netlink_callback *cb);
92
93 unsigned char data[0];
94};
95
96#ifdef CONFIG_DECNET_ROUTER
97/*
98 * dn_fib.c
99 */
Joe Perches59ddd962013-09-20 11:23:20 -0700100void dn_fib_init(void);
101void dn_fib_cleanup(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700102
Joe Perches59ddd962013-09-20 11:23:20 -0700103int dn_fib_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg);
104struct dn_fib_info *dn_fib_create_info(const struct rtmsg *r,
105 struct nlattr *attrs[],
106 const struct nlmsghdr *nlh, int *errp);
107int dn_fib_semantic_match(int type, struct dn_fib_info *fi,
108 const struct flowidn *fld, struct dn_fib_res *res);
109void dn_fib_release_info(struct dn_fib_info *fi);
110void dn_fib_flush(void);
111void dn_fib_select_multipath(const struct flowidn *fld, struct dn_fib_res *res);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700112
113/*
114 * dn_tables.c
115 */
Joe Perches59ddd962013-09-20 11:23:20 -0700116struct dn_fib_table *dn_fib_get_table(u32 n, int creat);
117struct dn_fib_table *dn_fib_empty_table(void);
118void dn_fib_table_init(void);
119void dn_fib_table_cleanup(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120
121/*
122 * dn_rules.c
123 */
Joe Perches59ddd962013-09-20 11:23:20 -0700124void dn_fib_rules_init(void);
125void dn_fib_rules_cleanup(void);
126unsigned int dnet_addr_type(__le16 addr);
127int dn_fib_lookup(struct flowidn *fld, struct dn_fib_res *res);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700128
Joe Perches59ddd962013-09-20 11:23:20 -0700129int dn_fib_dump(struct sk_buff *skb, struct netlink_callback *cb);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700130
Joe Perches59ddd962013-09-20 11:23:20 -0700131void dn_fib_free_info(struct dn_fib_info *fi);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700132
133static inline void dn_fib_info_put(struct dn_fib_info *fi)
134{
Reshetova, Elenae0542dd2017-07-04 15:53:00 +0300135 if (refcount_dec_and_test(&fi->fib_clntref))
Linus Torvalds1da177e2005-04-16 15:20:36 -0700136 dn_fib_free_info(fi);
137}
138
139static inline void dn_fib_res_put(struct dn_fib_res *res)
140{
141 if (res->fi)
142 dn_fib_info_put(res->fi);
143 if (res->r)
Steven Whitehousea8731cb2006-08-09 15:56:46 -0700144 fib_rule_put(res->r);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145}
146
Linus Torvalds1da177e2005-04-16 15:20:36 -0700147#else /* Endnode */
148
149#define dn_fib_init() do { } while(0)
150#define dn_fib_cleanup() do { } while(0)
151
152#define dn_fib_lookup(fl, res) (-ESRCH)
153#define dn_fib_info_put(fi) do { } while(0)
154#define dn_fib_select_multipath(fl, res) do { } while(0)
155#define dn_fib_rules_policy(saddr,res,flags) (0)
156#define dn_fib_res_put(res) do { } while(0)
157
158#endif /* CONFIG_DECNET_ROUTER */
159
Steven Whitehousec4ea94a2006-03-20 22:42:39 -0800160static inline __le16 dnet_make_mask(int n)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700161{
Harvey Harrisonc4106aa2008-11-27 00:12:47 -0800162 if (n)
163 return cpu_to_le16(~((1 << (16 - n)) - 1));
164 return cpu_to_le16(0);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700165}
166
167#endif /* _NET_DN_FIB_H */