fib_rules.c 35 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * net/core/fib_rules.c Generic Routing Rules
  4. *
  5. * Authors: Thomas Graf <tgraf@suug.ch>
  6. */
  7. #include <linux/types.h>
  8. #include <linux/kernel.h>
  9. #include <linux/slab.h>
  10. #include <linux/list.h>
  11. #include <linux/module.h>
  12. #include <net/net_namespace.h>
  13. #include <net/inet_dscp.h>
  14. #include <net/sock.h>
  15. #include <net/fib_rules.h>
  16. #include <net/ip_tunnels.h>
  17. #include <linux/indirect_call_wrapper.h>
  18. #if defined(CONFIG_IPV6) && defined(CONFIG_IPV6_MULTIPLE_TABLES)
  19. #ifdef CONFIG_IP_MULTIPLE_TABLES
  20. #define INDIRECT_CALL_MT(f, f2, f1, ...) \
  21. INDIRECT_CALL_INET(f, f2, f1, __VA_ARGS__)
  22. #else
  23. #define INDIRECT_CALL_MT(f, f2, f1, ...) INDIRECT_CALL_1(f, f2, __VA_ARGS__)
  24. #endif
  25. #elif defined(CONFIG_IP_MULTIPLE_TABLES)
  26. #define INDIRECT_CALL_MT(f, f2, f1, ...) INDIRECT_CALL_1(f, f1, __VA_ARGS__)
  27. #else
  28. #define INDIRECT_CALL_MT(f, f2, f1, ...) f(__VA_ARGS__)
  29. #endif
  30. static const struct fib_kuid_range fib_kuid_range_unset = {
  31. KUIDT_INIT(0),
  32. KUIDT_INIT(~0),
  33. };
  34. bool fib_rule_matchall(const struct fib_rule *rule)
  35. {
  36. if (READ_ONCE(rule->iifindex) || READ_ONCE(rule->oifindex) ||
  37. rule->mark || rule->tun_id || rule->flags)
  38. return false;
  39. if (rule->suppress_ifgroup != -1 || rule->suppress_prefixlen != -1)
  40. return false;
  41. if (!uid_eq(rule->uid_range.start, fib_kuid_range_unset.start) ||
  42. !uid_eq(rule->uid_range.end, fib_kuid_range_unset.end))
  43. return false;
  44. if (fib_rule_port_range_set(&rule->sport_range))
  45. return false;
  46. if (fib_rule_port_range_set(&rule->dport_range))
  47. return false;
  48. return true;
  49. }
  50. EXPORT_SYMBOL_GPL(fib_rule_matchall);
  51. int fib_default_rule_add(struct fib_rules_ops *ops,
  52. u32 pref, u32 table)
  53. {
  54. struct fib_rule *r;
  55. r = kzalloc(ops->rule_size, GFP_KERNEL_ACCOUNT);
  56. if (r == NULL)
  57. return -ENOMEM;
  58. refcount_set(&r->refcnt, 1);
  59. r->action = FR_ACT_TO_TBL;
  60. r->pref = pref;
  61. r->table = table;
  62. r->proto = RTPROT_KERNEL;
  63. r->fr_net = ops->fro_net;
  64. r->uid_range = fib_kuid_range_unset;
  65. r->suppress_prefixlen = -1;
  66. r->suppress_ifgroup = -1;
  67. /* The lock is not required here, the list in unreachable
  68. * at the moment this function is called */
  69. list_add_tail(&r->list, &ops->rules_list);
  70. return 0;
  71. }
  72. EXPORT_SYMBOL(fib_default_rule_add);
  73. static u32 fib_default_rule_pref(struct fib_rules_ops *ops)
  74. {
  75. struct list_head *pos;
  76. struct fib_rule *rule;
  77. if (!list_empty(&ops->rules_list)) {
  78. pos = ops->rules_list.next;
  79. if (pos->next != &ops->rules_list) {
  80. rule = list_entry(pos->next, struct fib_rule, list);
  81. if (rule->pref)
  82. return rule->pref - 1;
  83. }
  84. }
  85. return 0;
  86. }
  87. static void notify_rule_change(int event, struct fib_rule *rule,
  88. struct fib_rules_ops *ops, struct nlmsghdr *nlh,
  89. u32 pid);
  90. static struct fib_rules_ops *lookup_rules_ops(const struct net *net,
  91. int family)
  92. {
  93. struct fib_rules_ops *ops;
  94. rcu_read_lock();
  95. list_for_each_entry_rcu(ops, &net->rules_ops, list) {
  96. if (ops->family == family) {
  97. if (!try_module_get(ops->owner))
  98. ops = NULL;
  99. rcu_read_unlock();
  100. return ops;
  101. }
  102. }
  103. rcu_read_unlock();
  104. return NULL;
  105. }
  106. static void rules_ops_put(struct fib_rules_ops *ops)
  107. {
  108. if (ops)
  109. module_put(ops->owner);
  110. }
  111. static void flush_route_cache(struct fib_rules_ops *ops)
  112. {
  113. if (ops->flush_cache)
  114. ops->flush_cache(ops);
  115. }
  116. static int __fib_rules_register(struct fib_rules_ops *ops)
  117. {
  118. int err = -EEXIST;
  119. struct fib_rules_ops *o;
  120. struct net *net;
  121. net = ops->fro_net;
  122. if (ops->rule_size < sizeof(struct fib_rule))
  123. return -EINVAL;
  124. if (ops->match == NULL || ops->configure == NULL ||
  125. ops->compare == NULL || ops->fill == NULL ||
  126. ops->action == NULL)
  127. return -EINVAL;
  128. spin_lock(&net->rules_mod_lock);
  129. list_for_each_entry(o, &net->rules_ops, list)
  130. if (ops->family == o->family)
  131. goto errout;
  132. list_add_tail_rcu(&ops->list, &net->rules_ops);
  133. err = 0;
  134. errout:
  135. spin_unlock(&net->rules_mod_lock);
  136. return err;
  137. }
  138. struct fib_rules_ops *
  139. fib_rules_register(const struct fib_rules_ops *tmpl, struct net *net)
  140. {
  141. struct fib_rules_ops *ops;
  142. int err;
  143. ops = kmemdup(tmpl, sizeof(*ops), GFP_KERNEL);
  144. if (ops == NULL)
  145. return ERR_PTR(-ENOMEM);
  146. INIT_LIST_HEAD(&ops->rules_list);
  147. ops->fro_net = net;
  148. err = __fib_rules_register(ops);
  149. if (err) {
  150. kfree(ops);
  151. ops = ERR_PTR(err);
  152. }
  153. return ops;
  154. }
  155. EXPORT_SYMBOL_GPL(fib_rules_register);
  156. static void fib_rules_cleanup_ops(struct fib_rules_ops *ops)
  157. {
  158. struct fib_rule *rule, *tmp;
  159. list_for_each_entry_safe(rule, tmp, &ops->rules_list, list) {
  160. list_del_rcu(&rule->list);
  161. if (ops->delete)
  162. ops->delete(rule);
  163. fib_rule_put(rule);
  164. }
  165. }
  166. void fib_rules_unregister(struct fib_rules_ops *ops)
  167. {
  168. struct net *net = ops->fro_net;
  169. spin_lock(&net->rules_mod_lock);
  170. list_del_rcu(&ops->list);
  171. spin_unlock(&net->rules_mod_lock);
  172. fib_rules_cleanup_ops(ops);
  173. kfree_rcu(ops, rcu);
  174. }
  175. EXPORT_SYMBOL_GPL(fib_rules_unregister);
  176. static int uid_range_set(struct fib_kuid_range *range)
  177. {
  178. return uid_valid(range->start) && uid_valid(range->end);
  179. }
  180. static struct fib_kuid_range nla_get_kuid_range(struct nlattr **tb)
  181. {
  182. struct fib_rule_uid_range *in;
  183. struct fib_kuid_range out;
  184. in = (struct fib_rule_uid_range *)nla_data(tb[FRA_UID_RANGE]);
  185. out.start = make_kuid(current_user_ns(), in->start);
  186. out.end = make_kuid(current_user_ns(), in->end);
  187. return out;
  188. }
  189. static int nla_put_uid_range(struct sk_buff *skb, struct fib_kuid_range *range)
  190. {
  191. struct fib_rule_uid_range out = {
  192. from_kuid_munged(current_user_ns(), range->start),
  193. from_kuid_munged(current_user_ns(), range->end)
  194. };
  195. return nla_put(skb, FRA_UID_RANGE, sizeof(out), &out);
  196. }
  197. static int nla_get_port_range(struct nlattr *pattr,
  198. struct fib_rule_port_range *port_range)
  199. {
  200. const struct fib_rule_port_range *pr = nla_data(pattr);
  201. if (!fib_rule_port_range_valid(pr))
  202. return -EINVAL;
  203. port_range->start = pr->start;
  204. port_range->end = pr->end;
  205. return 0;
  206. }
  207. static int nla_put_port_range(struct sk_buff *skb, int attrtype,
  208. struct fib_rule_port_range *range)
  209. {
  210. return nla_put(skb, attrtype, sizeof(*range), range);
  211. }
  212. static bool fib_rule_iif_match(const struct fib_rule *rule, int iifindex,
  213. const struct flowi *fl)
  214. {
  215. u8 iif_is_l3_master = READ_ONCE(rule->iif_is_l3_master);
  216. return iif_is_l3_master ? l3mdev_fib_rule_iif_match(fl, iifindex) :
  217. fl->flowi_iif == iifindex;
  218. }
  219. static bool fib_rule_oif_match(const struct fib_rule *rule, int oifindex,
  220. const struct flowi *fl)
  221. {
  222. u8 oif_is_l3_master = READ_ONCE(rule->oif_is_l3_master);
  223. return oif_is_l3_master ? l3mdev_fib_rule_oif_match(fl, oifindex) :
  224. fl->flowi_oif == oifindex;
  225. }
  226. static int fib_rule_match(struct fib_rule *rule, struct fib_rules_ops *ops,
  227. struct flowi *fl, int flags,
  228. struct fib_lookup_arg *arg)
  229. {
  230. int iifindex, oifindex, ret = 0;
  231. iifindex = READ_ONCE(rule->iifindex);
  232. if (iifindex && !fib_rule_iif_match(rule, iifindex, fl))
  233. goto out;
  234. oifindex = READ_ONCE(rule->oifindex);
  235. if (oifindex && !fib_rule_oif_match(rule, oifindex, fl))
  236. goto out;
  237. if ((rule->mark ^ fl->flowi_mark) & rule->mark_mask)
  238. goto out;
  239. if (rule->tun_id && (rule->tun_id != fl->flowi_tun_key.tun_id))
  240. goto out;
  241. if (rule->l3mdev && !l3mdev_fib_rule_match(rule->fr_net, fl, arg))
  242. goto out;
  243. if (uid_lt(fl->flowi_uid, rule->uid_range.start) ||
  244. uid_gt(fl->flowi_uid, rule->uid_range.end))
  245. goto out;
  246. ret = INDIRECT_CALL_MT(ops->match,
  247. fib6_rule_match,
  248. fib4_rule_match,
  249. rule, fl, flags);
  250. out:
  251. return (rule->flags & FIB_RULE_INVERT) ? !ret : ret;
  252. }
  253. int fib_rules_lookup(struct fib_rules_ops *ops, struct flowi *fl,
  254. int flags, struct fib_lookup_arg *arg)
  255. {
  256. struct fib_rule *rule;
  257. int err;
  258. rcu_read_lock();
  259. list_for_each_entry_rcu(rule, &ops->rules_list, list) {
  260. jumped:
  261. if (!fib_rule_match(rule, ops, fl, flags, arg))
  262. continue;
  263. if (rule->action == FR_ACT_GOTO) {
  264. struct fib_rule *target;
  265. target = rcu_dereference(rule->ctarget);
  266. if (target == NULL) {
  267. continue;
  268. } else {
  269. rule = target;
  270. goto jumped;
  271. }
  272. } else if (rule->action == FR_ACT_NOP)
  273. continue;
  274. else
  275. err = INDIRECT_CALL_MT(ops->action,
  276. fib6_rule_action,
  277. fib4_rule_action,
  278. rule, fl, flags, arg);
  279. if (!err && ops->suppress && INDIRECT_CALL_MT(ops->suppress,
  280. fib6_rule_suppress,
  281. fib4_rule_suppress,
  282. rule, flags, arg))
  283. continue;
  284. if (err != -EAGAIN) {
  285. if ((arg->flags & FIB_LOOKUP_NOREF) ||
  286. likely(refcount_inc_not_zero(&rule->refcnt))) {
  287. arg->rule = rule;
  288. goto out;
  289. }
  290. break;
  291. }
  292. }
  293. err = -ESRCH;
  294. out:
  295. rcu_read_unlock();
  296. return err;
  297. }
  298. EXPORT_SYMBOL_GPL(fib_rules_lookup);
  299. static int call_fib_rule_notifier(struct notifier_block *nb,
  300. enum fib_event_type event_type,
  301. struct fib_rule *rule, int family,
  302. struct netlink_ext_ack *extack)
  303. {
  304. struct fib_rule_notifier_info info = {
  305. .info.family = family,
  306. .info.extack = extack,
  307. .rule = rule,
  308. };
  309. return call_fib_notifier(nb, event_type, &info.info);
  310. }
  311. static int call_fib_rule_notifiers(struct net *net,
  312. enum fib_event_type event_type,
  313. struct fib_rule *rule,
  314. struct fib_rules_ops *ops,
  315. struct netlink_ext_ack *extack)
  316. {
  317. struct fib_rule_notifier_info info = {
  318. .info.family = ops->family,
  319. .info.extack = extack,
  320. .rule = rule,
  321. };
  322. ASSERT_RTNL_NET(net);
  323. /* Paired with READ_ONCE() in fib_rules_seq() */
  324. WRITE_ONCE(ops->fib_rules_seq, ops->fib_rules_seq + 1);
  325. return call_fib_notifiers(net, event_type, &info.info);
  326. }
  327. /* Called with rcu_read_lock() */
  328. int fib_rules_dump(struct net *net, struct notifier_block *nb, int family,
  329. struct netlink_ext_ack *extack)
  330. {
  331. struct fib_rules_ops *ops;
  332. struct fib_rule *rule;
  333. int err = 0;
  334. ops = lookup_rules_ops(net, family);
  335. if (!ops)
  336. return -EAFNOSUPPORT;
  337. list_for_each_entry_rcu(rule, &ops->rules_list, list) {
  338. err = call_fib_rule_notifier(nb, FIB_EVENT_RULE_ADD,
  339. rule, family, extack);
  340. if (err)
  341. break;
  342. }
  343. rules_ops_put(ops);
  344. return err;
  345. }
  346. EXPORT_SYMBOL_GPL(fib_rules_dump);
  347. unsigned int fib_rules_seq_read(const struct net *net, int family)
  348. {
  349. unsigned int fib_rules_seq;
  350. struct fib_rules_ops *ops;
  351. ops = lookup_rules_ops(net, family);
  352. if (!ops)
  353. return 0;
  354. /* Paired with WRITE_ONCE() in call_fib_rule_notifiers() */
  355. fib_rules_seq = READ_ONCE(ops->fib_rules_seq);
  356. rules_ops_put(ops);
  357. return fib_rules_seq;
  358. }
  359. EXPORT_SYMBOL_GPL(fib_rules_seq_read);
  360. static struct fib_rule *rule_find(struct fib_rules_ops *ops,
  361. struct fib_rule_hdr *frh,
  362. struct nlattr **tb,
  363. struct fib_rule *rule,
  364. bool user_priority)
  365. {
  366. struct fib_rule *r;
  367. list_for_each_entry(r, &ops->rules_list, list) {
  368. if (rule->action && r->action != rule->action)
  369. continue;
  370. if (rule->table && r->table != rule->table)
  371. continue;
  372. if (user_priority && r->pref != rule->pref)
  373. continue;
  374. if (rule->iifname[0] &&
  375. memcmp(r->iifname, rule->iifname, IFNAMSIZ))
  376. continue;
  377. if (rule->oifname[0] &&
  378. memcmp(r->oifname, rule->oifname, IFNAMSIZ))
  379. continue;
  380. if (rule->mark && r->mark != rule->mark)
  381. continue;
  382. if (rule->suppress_ifgroup != -1 &&
  383. r->suppress_ifgroup != rule->suppress_ifgroup)
  384. continue;
  385. if (rule->suppress_prefixlen != -1 &&
  386. r->suppress_prefixlen != rule->suppress_prefixlen)
  387. continue;
  388. if (rule->mark_mask && r->mark_mask != rule->mark_mask)
  389. continue;
  390. if (rule->tun_id && r->tun_id != rule->tun_id)
  391. continue;
  392. if (rule->l3mdev && r->l3mdev != rule->l3mdev)
  393. continue;
  394. if (uid_range_set(&rule->uid_range) &&
  395. (!uid_eq(r->uid_range.start, rule->uid_range.start) ||
  396. !uid_eq(r->uid_range.end, rule->uid_range.end)))
  397. continue;
  398. if (rule->ip_proto && r->ip_proto != rule->ip_proto)
  399. continue;
  400. if (rule->proto && r->proto != rule->proto)
  401. continue;
  402. if (fib_rule_port_range_set(&rule->sport_range) &&
  403. !fib_rule_port_range_compare(&r->sport_range,
  404. &rule->sport_range))
  405. continue;
  406. if (rule->sport_mask && r->sport_mask != rule->sport_mask)
  407. continue;
  408. if (fib_rule_port_range_set(&rule->dport_range) &&
  409. !fib_rule_port_range_compare(&r->dport_range,
  410. &rule->dport_range))
  411. continue;
  412. if (rule->dport_mask && r->dport_mask != rule->dport_mask)
  413. continue;
  414. if (!ops->compare(r, frh, tb))
  415. continue;
  416. return r;
  417. }
  418. return NULL;
  419. }
  420. #ifdef CONFIG_NET_L3_MASTER_DEV
  421. static int fib_nl2rule_l3mdev(struct nlattr *nla, struct fib_rule *nlrule,
  422. struct netlink_ext_ack *extack)
  423. {
  424. nlrule->l3mdev = nla_get_u8(nla);
  425. if (nlrule->l3mdev != 1) {
  426. NL_SET_ERR_MSG(extack, "Invalid l3mdev attribute");
  427. return -1;
  428. }
  429. return 0;
  430. }
  431. #else
  432. static int fib_nl2rule_l3mdev(struct nlattr *nla, struct fib_rule *nlrule,
  433. struct netlink_ext_ack *extack)
  434. {
  435. NL_SET_ERR_MSG(extack, "l3mdev support is not enabled in kernel");
  436. return -1;
  437. }
  438. #endif
  439. static int fib_nl2rule_port_mask(const struct nlattr *mask_attr,
  440. const struct fib_rule_port_range *range,
  441. u16 *port_mask,
  442. struct netlink_ext_ack *extack)
  443. {
  444. if (!fib_rule_port_range_valid(range)) {
  445. NL_SET_ERR_MSG_ATTR(extack, mask_attr,
  446. "Cannot specify port mask without port value");
  447. return -EINVAL;
  448. }
  449. if (fib_rule_port_is_range(range)) {
  450. NL_SET_ERR_MSG_ATTR(extack, mask_attr,
  451. "Cannot specify port mask for port range");
  452. return -EINVAL;
  453. }
  454. if (range->start & ~nla_get_u16(mask_attr)) {
  455. NL_SET_ERR_MSG_ATTR(extack, mask_attr, "Invalid port mask");
  456. return -EINVAL;
  457. }
  458. *port_mask = nla_get_u16(mask_attr);
  459. return 0;
  460. }
  461. static int fib_nl2rule(struct net *net, struct nlmsghdr *nlh,
  462. struct netlink_ext_ack *extack,
  463. struct fib_rules_ops *ops,
  464. struct nlattr *tb[],
  465. struct fib_rule **rule,
  466. bool *user_priority)
  467. {
  468. struct fib_rule_hdr *frh = nlmsg_data(nlh);
  469. struct fib_rule *nlrule = NULL;
  470. int err = -EINVAL;
  471. if (frh->src_len)
  472. if (!tb[FRA_SRC] ||
  473. frh->src_len > (ops->addr_size * 8) ||
  474. nla_len(tb[FRA_SRC]) != ops->addr_size) {
  475. NL_SET_ERR_MSG(extack, "Invalid source address");
  476. goto errout;
  477. }
  478. if (frh->dst_len)
  479. if (!tb[FRA_DST] ||
  480. frh->dst_len > (ops->addr_size * 8) ||
  481. nla_len(tb[FRA_DST]) != ops->addr_size) {
  482. NL_SET_ERR_MSG(extack, "Invalid dst address");
  483. goto errout;
  484. }
  485. nlrule = kzalloc(ops->rule_size, GFP_KERNEL_ACCOUNT);
  486. if (!nlrule) {
  487. err = -ENOMEM;
  488. goto errout;
  489. }
  490. refcount_set(&nlrule->refcnt, 1);
  491. nlrule->fr_net = net;
  492. if (tb[FRA_PRIORITY]) {
  493. nlrule->pref = nla_get_u32(tb[FRA_PRIORITY]);
  494. *user_priority = true;
  495. }
  496. nlrule->proto = nla_get_u8_default(tb[FRA_PROTOCOL], RTPROT_UNSPEC);
  497. if (tb[FRA_IIFNAME]) {
  498. nlrule->iifindex = -1;
  499. nla_strscpy(nlrule->iifname, tb[FRA_IIFNAME], IFNAMSIZ);
  500. }
  501. if (tb[FRA_OIFNAME]) {
  502. nlrule->oifindex = -1;
  503. nla_strscpy(nlrule->oifname, tb[FRA_OIFNAME], IFNAMSIZ);
  504. }
  505. if (tb[FRA_FWMARK]) {
  506. nlrule->mark = nla_get_u32(tb[FRA_FWMARK]);
  507. if (nlrule->mark)
  508. /* compatibility: if the mark value is non-zero all bits
  509. * are compared unless a mask is explicitly specified.
  510. */
  511. nlrule->mark_mask = 0xFFFFFFFF;
  512. }
  513. if (tb[FRA_FWMASK])
  514. nlrule->mark_mask = nla_get_u32(tb[FRA_FWMASK]);
  515. if (tb[FRA_TUN_ID])
  516. nlrule->tun_id = nla_get_be64(tb[FRA_TUN_ID]);
  517. if (tb[FRA_L3MDEV] &&
  518. fib_nl2rule_l3mdev(tb[FRA_L3MDEV], nlrule, extack) < 0)
  519. goto errout_free;
  520. nlrule->action = frh->action;
  521. nlrule->flags = frh->flags;
  522. nlrule->table = frh_get_table(frh, tb);
  523. if (tb[FRA_SUPPRESS_PREFIXLEN])
  524. nlrule->suppress_prefixlen = nla_get_u32(tb[FRA_SUPPRESS_PREFIXLEN]);
  525. else
  526. nlrule->suppress_prefixlen = -1;
  527. if (tb[FRA_SUPPRESS_IFGROUP])
  528. nlrule->suppress_ifgroup = nla_get_u32(tb[FRA_SUPPRESS_IFGROUP]);
  529. else
  530. nlrule->suppress_ifgroup = -1;
  531. if (tb[FRA_GOTO]) {
  532. if (nlrule->action != FR_ACT_GOTO) {
  533. NL_SET_ERR_MSG(extack, "Unexpected goto");
  534. goto errout_free;
  535. }
  536. nlrule->target = nla_get_u32(tb[FRA_GOTO]);
  537. } else if (nlrule->action == FR_ACT_GOTO) {
  538. NL_SET_ERR_MSG(extack, "Missing goto target for action goto");
  539. goto errout_free;
  540. }
  541. if (nlrule->l3mdev && nlrule->table) {
  542. NL_SET_ERR_MSG(extack, "l3mdev and table are mutually exclusive");
  543. goto errout_free;
  544. }
  545. if (tb[FRA_UID_RANGE]) {
  546. if (current_user_ns() != net->user_ns) {
  547. err = -EPERM;
  548. NL_SET_ERR_MSG(extack, "No permission to set uid");
  549. goto errout_free;
  550. }
  551. nlrule->uid_range = nla_get_kuid_range(tb);
  552. if (!uid_range_set(&nlrule->uid_range) ||
  553. !uid_lte(nlrule->uid_range.start, nlrule->uid_range.end)) {
  554. NL_SET_ERR_MSG(extack, "Invalid uid range");
  555. goto errout_free;
  556. }
  557. } else {
  558. nlrule->uid_range = fib_kuid_range_unset;
  559. }
  560. if (tb[FRA_IP_PROTO])
  561. nlrule->ip_proto = nla_get_u8(tb[FRA_IP_PROTO]);
  562. if (tb[FRA_SPORT_RANGE]) {
  563. err = nla_get_port_range(tb[FRA_SPORT_RANGE],
  564. &nlrule->sport_range);
  565. if (err) {
  566. NL_SET_ERR_MSG(extack, "Invalid sport range");
  567. goto errout_free;
  568. }
  569. if (!fib_rule_port_is_range(&nlrule->sport_range))
  570. nlrule->sport_mask = U16_MAX;
  571. }
  572. if (tb[FRA_SPORT_MASK]) {
  573. err = fib_nl2rule_port_mask(tb[FRA_SPORT_MASK],
  574. &nlrule->sport_range,
  575. &nlrule->sport_mask, extack);
  576. if (err)
  577. goto errout_free;
  578. }
  579. if (tb[FRA_DPORT_RANGE]) {
  580. err = nla_get_port_range(tb[FRA_DPORT_RANGE],
  581. &nlrule->dport_range);
  582. if (err) {
  583. NL_SET_ERR_MSG(extack, "Invalid dport range");
  584. goto errout_free;
  585. }
  586. if (!fib_rule_port_is_range(&nlrule->dport_range))
  587. nlrule->dport_mask = U16_MAX;
  588. }
  589. if (tb[FRA_DPORT_MASK]) {
  590. err = fib_nl2rule_port_mask(tb[FRA_DPORT_MASK],
  591. &nlrule->dport_range,
  592. &nlrule->dport_mask, extack);
  593. if (err)
  594. goto errout_free;
  595. }
  596. *rule = nlrule;
  597. return 0;
  598. errout_free:
  599. kfree(nlrule);
  600. errout:
  601. return err;
  602. }
  603. static int fib_nl2rule_rtnl(struct fib_rule *nlrule,
  604. struct fib_rules_ops *ops,
  605. struct nlattr *tb[],
  606. struct netlink_ext_ack *extack)
  607. {
  608. if (!tb[FRA_PRIORITY])
  609. nlrule->pref = fib_default_rule_pref(ops);
  610. /* Backward jumps are prohibited to avoid endless loops */
  611. if (tb[FRA_GOTO] && nlrule->target <= nlrule->pref) {
  612. NL_SET_ERR_MSG(extack, "Backward goto not supported");
  613. return -EINVAL;
  614. }
  615. if (tb[FRA_IIFNAME]) {
  616. struct net_device *dev;
  617. dev = __dev_get_by_name(nlrule->fr_net, nlrule->iifname);
  618. if (dev) {
  619. nlrule->iifindex = dev->ifindex;
  620. nlrule->iif_is_l3_master = netif_is_l3_master(dev);
  621. }
  622. }
  623. if (tb[FRA_OIFNAME]) {
  624. struct net_device *dev;
  625. dev = __dev_get_by_name(nlrule->fr_net, nlrule->oifname);
  626. if (dev) {
  627. nlrule->oifindex = dev->ifindex;
  628. nlrule->oif_is_l3_master = netif_is_l3_master(dev);
  629. }
  630. }
  631. return 0;
  632. }
  633. static int rule_exists(struct fib_rules_ops *ops, struct fib_rule_hdr *frh,
  634. struct nlattr **tb, struct fib_rule *rule)
  635. {
  636. struct fib_rule *r;
  637. list_for_each_entry(r, &ops->rules_list, list) {
  638. if (r->action != rule->action)
  639. continue;
  640. if (r->table != rule->table)
  641. continue;
  642. if (r->pref != rule->pref)
  643. continue;
  644. if (memcmp(r->iifname, rule->iifname, IFNAMSIZ))
  645. continue;
  646. if (memcmp(r->oifname, rule->oifname, IFNAMSIZ))
  647. continue;
  648. if (r->mark != rule->mark)
  649. continue;
  650. if (r->suppress_ifgroup != rule->suppress_ifgroup)
  651. continue;
  652. if (r->suppress_prefixlen != rule->suppress_prefixlen)
  653. continue;
  654. if (r->mark_mask != rule->mark_mask)
  655. continue;
  656. if (r->tun_id != rule->tun_id)
  657. continue;
  658. if (r->l3mdev != rule->l3mdev)
  659. continue;
  660. if (!uid_eq(r->uid_range.start, rule->uid_range.start) ||
  661. !uid_eq(r->uid_range.end, rule->uid_range.end))
  662. continue;
  663. if (r->ip_proto != rule->ip_proto)
  664. continue;
  665. if (r->proto != rule->proto)
  666. continue;
  667. if (!fib_rule_port_range_compare(&r->sport_range,
  668. &rule->sport_range))
  669. continue;
  670. if (r->sport_mask != rule->sport_mask)
  671. continue;
  672. if (!fib_rule_port_range_compare(&r->dport_range,
  673. &rule->dport_range))
  674. continue;
  675. if (r->dport_mask != rule->dport_mask)
  676. continue;
  677. if (!ops->compare(r, frh, tb))
  678. continue;
  679. return 1;
  680. }
  681. return 0;
  682. }
  683. static const struct nla_policy fib_rule_policy[FRA_MAX + 1] = {
  684. [FRA_UNSPEC] = { .strict_start_type = FRA_DPORT_RANGE + 1 },
  685. [FRA_IIFNAME] = { .type = NLA_STRING, .len = IFNAMSIZ - 1 },
  686. [FRA_OIFNAME] = { .type = NLA_STRING, .len = IFNAMSIZ - 1 },
  687. [FRA_PRIORITY] = { .type = NLA_U32 },
  688. [FRA_FWMARK] = { .type = NLA_U32 },
  689. [FRA_FLOW] = { .type = NLA_U32 },
  690. [FRA_TUN_ID] = { .type = NLA_U64 },
  691. [FRA_FWMASK] = { .type = NLA_U32 },
  692. [FRA_TABLE] = { .type = NLA_U32 },
  693. [FRA_SUPPRESS_PREFIXLEN] = { .type = NLA_U32 },
  694. [FRA_SUPPRESS_IFGROUP] = { .type = NLA_U32 },
  695. [FRA_GOTO] = { .type = NLA_U32 },
  696. [FRA_L3MDEV] = { .type = NLA_U8 },
  697. [FRA_UID_RANGE] = { .len = sizeof(struct fib_rule_uid_range) },
  698. [FRA_PROTOCOL] = { .type = NLA_U8 },
  699. [FRA_IP_PROTO] = { .type = NLA_U8 },
  700. [FRA_SPORT_RANGE] = { .len = sizeof(struct fib_rule_port_range) },
  701. [FRA_DPORT_RANGE] = { .len = sizeof(struct fib_rule_port_range) },
  702. [FRA_DSCP] = NLA_POLICY_MAX(NLA_U8, INET_DSCP_MASK >> 2),
  703. [FRA_FLOWLABEL] = { .type = NLA_BE32 },
  704. [FRA_FLOWLABEL_MASK] = { .type = NLA_BE32 },
  705. [FRA_SPORT_MASK] = { .type = NLA_U16 },
  706. [FRA_DPORT_MASK] = { .type = NLA_U16 },
  707. [FRA_DSCP_MASK] = NLA_POLICY_MASK(NLA_U8, INET_DSCP_MASK >> 2),
  708. };
  709. int fib_newrule(struct net *net, struct sk_buff *skb, struct nlmsghdr *nlh,
  710. struct netlink_ext_ack *extack, bool rtnl_held)
  711. {
  712. struct fib_rule *rule = NULL, *r, *last = NULL;
  713. int err = -EINVAL, unresolved = 0;
  714. struct fib_rules_ops *ops = NULL;
  715. struct nlattr *tb[FRA_MAX + 1];
  716. bool user_priority = false;
  717. struct fib_rule_hdr *frh;
  718. frh = nlmsg_payload(nlh, sizeof(*frh));
  719. if (!frh) {
  720. NL_SET_ERR_MSG(extack, "Invalid msg length");
  721. goto errout;
  722. }
  723. ops = lookup_rules_ops(net, frh->family);
  724. if (!ops) {
  725. err = -EAFNOSUPPORT;
  726. NL_SET_ERR_MSG(extack, "Rule family not supported");
  727. goto errout;
  728. }
  729. err = nlmsg_parse_deprecated(nlh, sizeof(*frh), tb, FRA_MAX,
  730. fib_rule_policy, extack);
  731. if (err < 0) {
  732. NL_SET_ERR_MSG(extack, "Error parsing msg");
  733. goto errout;
  734. }
  735. err = fib_nl2rule(net, nlh, extack, ops, tb, &rule, &user_priority);
  736. if (err)
  737. goto errout;
  738. if (!rtnl_held)
  739. rtnl_net_lock(net);
  740. err = fib_nl2rule_rtnl(rule, ops, tb, extack);
  741. if (err)
  742. goto errout_free;
  743. if ((nlh->nlmsg_flags & NLM_F_EXCL) &&
  744. rule_exists(ops, frh, tb, rule)) {
  745. err = -EEXIST;
  746. goto errout_free;
  747. }
  748. err = ops->configure(rule, skb, frh, tb, extack);
  749. if (err < 0)
  750. goto errout_free;
  751. err = call_fib_rule_notifiers(net, FIB_EVENT_RULE_ADD, rule, ops,
  752. extack);
  753. if (err < 0)
  754. goto errout_free;
  755. list_for_each_entry(r, &ops->rules_list, list) {
  756. if (r->pref == rule->target) {
  757. RCU_INIT_POINTER(rule->ctarget, r);
  758. break;
  759. }
  760. }
  761. if (rcu_dereference_protected(rule->ctarget, 1) == NULL)
  762. unresolved = 1;
  763. list_for_each_entry(r, &ops->rules_list, list) {
  764. if (r->pref > rule->pref)
  765. break;
  766. last = r;
  767. }
  768. if (last)
  769. list_add_rcu(&rule->list, &last->list);
  770. else
  771. list_add_rcu(&rule->list, &ops->rules_list);
  772. if (ops->unresolved_rules) {
  773. /*
  774. * There are unresolved goto rules in the list, check if
  775. * any of them are pointing to this new rule.
  776. */
  777. list_for_each_entry(r, &ops->rules_list, list) {
  778. if (r->action == FR_ACT_GOTO &&
  779. r->target == rule->pref &&
  780. rtnl_dereference(r->ctarget) == NULL) {
  781. rcu_assign_pointer(r->ctarget, rule);
  782. if (--ops->unresolved_rules == 0)
  783. break;
  784. }
  785. }
  786. }
  787. if (rule->action == FR_ACT_GOTO)
  788. ops->nr_goto_rules++;
  789. if (unresolved)
  790. ops->unresolved_rules++;
  791. if (rule->tun_id)
  792. ip_tunnel_need_metadata();
  793. fib_rule_get(rule);
  794. if (!rtnl_held)
  795. rtnl_net_unlock(net);
  796. notify_rule_change(RTM_NEWRULE, rule, ops, nlh, NETLINK_CB(skb).portid);
  797. fib_rule_put(rule);
  798. flush_route_cache(ops);
  799. rules_ops_put(ops);
  800. return 0;
  801. errout_free:
  802. if (!rtnl_held)
  803. rtnl_net_unlock(net);
  804. kfree(rule);
  805. errout:
  806. rules_ops_put(ops);
  807. return err;
  808. }
  809. EXPORT_SYMBOL_GPL(fib_newrule);
  810. static int fib_nl_newrule(struct sk_buff *skb, struct nlmsghdr *nlh,
  811. struct netlink_ext_ack *extack)
  812. {
  813. return fib_newrule(sock_net(skb->sk), skb, nlh, extack, false);
  814. }
  815. int fib_delrule(struct net *net, struct sk_buff *skb, struct nlmsghdr *nlh,
  816. struct netlink_ext_ack *extack, bool rtnl_held)
  817. {
  818. struct fib_rule *rule = NULL, *nlrule = NULL;
  819. struct fib_rules_ops *ops = NULL;
  820. struct nlattr *tb[FRA_MAX+1];
  821. bool user_priority = false;
  822. struct fib_rule_hdr *frh;
  823. int err = -EINVAL;
  824. frh = nlmsg_payload(nlh, sizeof(*frh));
  825. if (!frh) {
  826. NL_SET_ERR_MSG(extack, "Invalid msg length");
  827. goto errout;
  828. }
  829. ops = lookup_rules_ops(net, frh->family);
  830. if (ops == NULL) {
  831. err = -EAFNOSUPPORT;
  832. NL_SET_ERR_MSG(extack, "Rule family not supported");
  833. goto errout;
  834. }
  835. err = nlmsg_parse_deprecated(nlh, sizeof(*frh), tb, FRA_MAX,
  836. fib_rule_policy, extack);
  837. if (err < 0) {
  838. NL_SET_ERR_MSG(extack, "Error parsing msg");
  839. goto errout;
  840. }
  841. err = fib_nl2rule(net, nlh, extack, ops, tb, &nlrule, &user_priority);
  842. if (err)
  843. goto errout;
  844. if (!rtnl_held)
  845. rtnl_net_lock(net);
  846. err = fib_nl2rule_rtnl(nlrule, ops, tb, extack);
  847. if (err)
  848. goto errout_free;
  849. rule = rule_find(ops, frh, tb, nlrule, user_priority);
  850. if (!rule) {
  851. err = -ENOENT;
  852. goto errout_free;
  853. }
  854. if (rule->flags & FIB_RULE_PERMANENT) {
  855. err = -EPERM;
  856. goto errout_free;
  857. }
  858. if (ops->delete) {
  859. err = ops->delete(rule);
  860. if (err)
  861. goto errout_free;
  862. }
  863. if (rule->tun_id)
  864. ip_tunnel_unneed_metadata();
  865. list_del_rcu(&rule->list);
  866. if (rule->action == FR_ACT_GOTO) {
  867. ops->nr_goto_rules--;
  868. if (rtnl_dereference(rule->ctarget) == NULL)
  869. ops->unresolved_rules--;
  870. }
  871. /*
  872. * Check if this rule is a target to any of them. If so,
  873. * adjust to the next one with the same preference or
  874. * disable them. As this operation is eventually very
  875. * expensive, it is only performed if goto rules, except
  876. * current if it is goto rule, have actually been added.
  877. */
  878. if (ops->nr_goto_rules > 0) {
  879. struct fib_rule *n, *r;
  880. n = list_next_entry(rule, list);
  881. if (&n->list == &ops->rules_list || n->pref != rule->pref)
  882. n = NULL;
  883. list_for_each_entry(r, &ops->rules_list, list) {
  884. if (rtnl_dereference(r->ctarget) != rule)
  885. continue;
  886. rcu_assign_pointer(r->ctarget, n);
  887. if (!n)
  888. ops->unresolved_rules++;
  889. }
  890. }
  891. call_fib_rule_notifiers(net, FIB_EVENT_RULE_DEL, rule, ops, NULL);
  892. if (!rtnl_held)
  893. rtnl_net_unlock(net);
  894. notify_rule_change(RTM_DELRULE, rule, ops, nlh, NETLINK_CB(skb).portid);
  895. fib_rule_put(rule);
  896. flush_route_cache(ops);
  897. rules_ops_put(ops);
  898. kfree(nlrule);
  899. return 0;
  900. errout_free:
  901. if (!rtnl_held)
  902. rtnl_net_unlock(net);
  903. kfree(nlrule);
  904. errout:
  905. rules_ops_put(ops);
  906. return err;
  907. }
  908. EXPORT_SYMBOL_GPL(fib_delrule);
  909. static int fib_nl_delrule(struct sk_buff *skb, struct nlmsghdr *nlh,
  910. struct netlink_ext_ack *extack)
  911. {
  912. return fib_delrule(sock_net(skb->sk), skb, nlh, extack, false);
  913. }
  914. static inline size_t fib_rule_nlmsg_size(struct fib_rules_ops *ops,
  915. struct fib_rule *rule)
  916. {
  917. size_t payload = NLMSG_ALIGN(sizeof(struct fib_rule_hdr))
  918. + nla_total_size(IFNAMSIZ) /* FRA_IIFNAME */
  919. + nla_total_size(IFNAMSIZ) /* FRA_OIFNAME */
  920. + nla_total_size(4) /* FRA_PRIORITY */
  921. + nla_total_size(4) /* FRA_TABLE */
  922. + nla_total_size(4) /* FRA_SUPPRESS_PREFIXLEN */
  923. + nla_total_size(4) /* FRA_SUPPRESS_IFGROUP */
  924. + nla_total_size(4) /* FRA_FWMARK */
  925. + nla_total_size(4) /* FRA_FWMASK */
  926. + nla_total_size_64bit(8) /* FRA_TUN_ID */
  927. + nla_total_size(sizeof(struct fib_kuid_range))
  928. + nla_total_size(1) /* FRA_PROTOCOL */
  929. + nla_total_size(1) /* FRA_IP_PROTO */
  930. + nla_total_size(sizeof(struct fib_rule_port_range)) /* FRA_SPORT_RANGE */
  931. + nla_total_size(sizeof(struct fib_rule_port_range)) /* FRA_DPORT_RANGE */
  932. + nla_total_size(2) /* FRA_SPORT_MASK */
  933. + nla_total_size(2); /* FRA_DPORT_MASK */
  934. if (ops->nlmsg_payload)
  935. payload += ops->nlmsg_payload(rule);
  936. return payload;
  937. }
  938. static int fib_nl_fill_rule(struct sk_buff *skb, struct fib_rule *rule,
  939. u32 pid, u32 seq, int type, int flags,
  940. struct fib_rules_ops *ops)
  941. {
  942. struct nlmsghdr *nlh;
  943. struct fib_rule_hdr *frh;
  944. nlh = nlmsg_put(skb, pid, seq, type, sizeof(*frh), flags);
  945. if (nlh == NULL)
  946. return -EMSGSIZE;
  947. frh = nlmsg_data(nlh);
  948. frh->family = ops->family;
  949. frh->table = rule->table < 256 ? rule->table : RT_TABLE_COMPAT;
  950. if (nla_put_u32(skb, FRA_TABLE, rule->table))
  951. goto nla_put_failure;
  952. if (nla_put_u32(skb, FRA_SUPPRESS_PREFIXLEN, rule->suppress_prefixlen))
  953. goto nla_put_failure;
  954. frh->res1 = 0;
  955. frh->res2 = 0;
  956. frh->action = rule->action;
  957. frh->flags = rule->flags;
  958. if (nla_put_u8(skb, FRA_PROTOCOL, rule->proto))
  959. goto nla_put_failure;
  960. if (rule->action == FR_ACT_GOTO &&
  961. rcu_access_pointer(rule->ctarget) == NULL)
  962. frh->flags |= FIB_RULE_UNRESOLVED;
  963. if (rule->iifname[0]) {
  964. if (nla_put_string(skb, FRA_IIFNAME, rule->iifname))
  965. goto nla_put_failure;
  966. if (READ_ONCE(rule->iifindex) == -1)
  967. frh->flags |= FIB_RULE_IIF_DETACHED;
  968. }
  969. if (rule->oifname[0]) {
  970. if (nla_put_string(skb, FRA_OIFNAME, rule->oifname))
  971. goto nla_put_failure;
  972. if (READ_ONCE(rule->oifindex) == -1)
  973. frh->flags |= FIB_RULE_OIF_DETACHED;
  974. }
  975. if ((rule->pref &&
  976. nla_put_u32(skb, FRA_PRIORITY, rule->pref)) ||
  977. (rule->mark &&
  978. nla_put_u32(skb, FRA_FWMARK, rule->mark)) ||
  979. ((rule->mark_mask || rule->mark) &&
  980. nla_put_u32(skb, FRA_FWMASK, rule->mark_mask)) ||
  981. (rule->target &&
  982. nla_put_u32(skb, FRA_GOTO, rule->target)) ||
  983. (rule->tun_id &&
  984. nla_put_be64(skb, FRA_TUN_ID, rule->tun_id, FRA_PAD)) ||
  985. (rule->l3mdev &&
  986. nla_put_u8(skb, FRA_L3MDEV, rule->l3mdev)) ||
  987. (uid_range_set(&rule->uid_range) &&
  988. nla_put_uid_range(skb, &rule->uid_range)) ||
  989. (fib_rule_port_range_set(&rule->sport_range) &&
  990. nla_put_port_range(skb, FRA_SPORT_RANGE, &rule->sport_range)) ||
  991. (rule->sport_mask && nla_put_u16(skb, FRA_SPORT_MASK,
  992. rule->sport_mask)) ||
  993. (fib_rule_port_range_set(&rule->dport_range) &&
  994. nla_put_port_range(skb, FRA_DPORT_RANGE, &rule->dport_range)) ||
  995. (rule->dport_mask && nla_put_u16(skb, FRA_DPORT_MASK,
  996. rule->dport_mask)) ||
  997. (rule->ip_proto && nla_put_u8(skb, FRA_IP_PROTO, rule->ip_proto)))
  998. goto nla_put_failure;
  999. if (rule->suppress_ifgroup != -1) {
  1000. if (nla_put_u32(skb, FRA_SUPPRESS_IFGROUP, rule->suppress_ifgroup))
  1001. goto nla_put_failure;
  1002. }
  1003. if (ops->fill(rule, skb, frh) < 0)
  1004. goto nla_put_failure;
  1005. nlmsg_end(skb, nlh);
  1006. return 0;
  1007. nla_put_failure:
  1008. nlmsg_cancel(skb, nlh);
  1009. return -EMSGSIZE;
  1010. }
  1011. static int dump_rules(struct sk_buff *skb, struct netlink_callback *cb,
  1012. struct fib_rules_ops *ops)
  1013. {
  1014. int idx = 0;
  1015. struct fib_rule *rule;
  1016. int err = 0;
  1017. rcu_read_lock();
  1018. list_for_each_entry_rcu(rule, &ops->rules_list, list) {
  1019. if (idx < cb->args[1])
  1020. goto skip;
  1021. err = fib_nl_fill_rule(skb, rule, NETLINK_CB(cb->skb).portid,
  1022. cb->nlh->nlmsg_seq, RTM_NEWRULE,
  1023. NLM_F_MULTI, ops);
  1024. if (err)
  1025. break;
  1026. skip:
  1027. idx++;
  1028. }
  1029. rcu_read_unlock();
  1030. cb->args[1] = idx;
  1031. rules_ops_put(ops);
  1032. return err;
  1033. }
  1034. static int fib_valid_dumprule_req(const struct nlmsghdr *nlh,
  1035. struct netlink_ext_ack *extack)
  1036. {
  1037. struct fib_rule_hdr *frh;
  1038. frh = nlmsg_payload(nlh, sizeof(*frh));
  1039. if (!frh) {
  1040. NL_SET_ERR_MSG(extack, "Invalid header for fib rule dump request");
  1041. return -EINVAL;
  1042. }
  1043. if (frh->dst_len || frh->src_len || frh->tos || frh->table ||
  1044. frh->res1 || frh->res2 || frh->action || frh->flags) {
  1045. NL_SET_ERR_MSG(extack,
  1046. "Invalid values in header for fib rule dump request");
  1047. return -EINVAL;
  1048. }
  1049. if (nlmsg_attrlen(nlh, sizeof(*frh))) {
  1050. NL_SET_ERR_MSG(extack, "Invalid data after header in fib rule dump request");
  1051. return -EINVAL;
  1052. }
  1053. return 0;
  1054. }
  1055. static int fib_nl_dumprule(struct sk_buff *skb, struct netlink_callback *cb)
  1056. {
  1057. const struct nlmsghdr *nlh = cb->nlh;
  1058. struct net *net = sock_net(skb->sk);
  1059. struct fib_rules_ops *ops;
  1060. int err, idx = 0, family;
  1061. if (cb->strict_check) {
  1062. err = fib_valid_dumprule_req(nlh, cb->extack);
  1063. if (err < 0)
  1064. return err;
  1065. }
  1066. family = rtnl_msg_family(nlh);
  1067. if (family != AF_UNSPEC) {
  1068. /* Protocol specific dump request */
  1069. ops = lookup_rules_ops(net, family);
  1070. if (ops == NULL)
  1071. return -EAFNOSUPPORT;
  1072. return dump_rules(skb, cb, ops);
  1073. }
  1074. err = 0;
  1075. rcu_read_lock();
  1076. list_for_each_entry_rcu(ops, &net->rules_ops, list) {
  1077. if (idx < cb->args[0] || !try_module_get(ops->owner))
  1078. goto skip;
  1079. err = dump_rules(skb, cb, ops);
  1080. if (err < 0)
  1081. break;
  1082. cb->args[1] = 0;
  1083. skip:
  1084. idx++;
  1085. }
  1086. rcu_read_unlock();
  1087. cb->args[0] = idx;
  1088. return err;
  1089. }
  1090. static void notify_rule_change(int event, struct fib_rule *rule,
  1091. struct fib_rules_ops *ops, struct nlmsghdr *nlh,
  1092. u32 pid)
  1093. {
  1094. struct net *net;
  1095. struct sk_buff *skb;
  1096. int err = -ENOMEM;
  1097. net = ops->fro_net;
  1098. skb = nlmsg_new(fib_rule_nlmsg_size(ops, rule), GFP_KERNEL);
  1099. if (skb == NULL)
  1100. goto errout;
  1101. err = fib_nl_fill_rule(skb, rule, pid, nlh->nlmsg_seq, event, 0, ops);
  1102. if (err < 0) {
  1103. /* -EMSGSIZE implies BUG in fib_rule_nlmsg_size() */
  1104. WARN_ON(err == -EMSGSIZE);
  1105. kfree_skb(skb);
  1106. goto errout;
  1107. }
  1108. rtnl_notify(skb, net, pid, ops->nlgroup, nlh, GFP_KERNEL);
  1109. return;
  1110. errout:
  1111. rtnl_set_sk_err(net, ops->nlgroup, err);
  1112. }
  1113. static void attach_rules(struct list_head *rules, struct net_device *dev)
  1114. {
  1115. struct fib_rule *rule;
  1116. list_for_each_entry(rule, rules, list) {
  1117. if (rule->iifindex == -1 &&
  1118. strcmp(dev->name, rule->iifname) == 0) {
  1119. WRITE_ONCE(rule->iifindex, dev->ifindex);
  1120. WRITE_ONCE(rule->iif_is_l3_master,
  1121. netif_is_l3_master(dev));
  1122. }
  1123. if (rule->oifindex == -1 &&
  1124. strcmp(dev->name, rule->oifname) == 0) {
  1125. WRITE_ONCE(rule->oifindex, dev->ifindex);
  1126. WRITE_ONCE(rule->oif_is_l3_master,
  1127. netif_is_l3_master(dev));
  1128. }
  1129. }
  1130. }
  1131. static void detach_rules(struct list_head *rules, struct net_device *dev)
  1132. {
  1133. struct fib_rule *rule;
  1134. list_for_each_entry(rule, rules, list) {
  1135. if (rule->iifindex == dev->ifindex) {
  1136. WRITE_ONCE(rule->iifindex, -1);
  1137. WRITE_ONCE(rule->iif_is_l3_master, false);
  1138. }
  1139. if (rule->oifindex == dev->ifindex) {
  1140. WRITE_ONCE(rule->oifindex, -1);
  1141. WRITE_ONCE(rule->oif_is_l3_master, false);
  1142. }
  1143. }
  1144. }
  1145. static int fib_rules_event(struct notifier_block *this, unsigned long event,
  1146. void *ptr)
  1147. {
  1148. struct net_device *dev = netdev_notifier_info_to_dev(ptr);
  1149. struct net *net = dev_net(dev);
  1150. struct fib_rules_ops *ops;
  1151. ASSERT_RTNL();
  1152. switch (event) {
  1153. case NETDEV_REGISTER:
  1154. list_for_each_entry(ops, &net->rules_ops, list)
  1155. attach_rules(&ops->rules_list, dev);
  1156. break;
  1157. case NETDEV_CHANGENAME:
  1158. list_for_each_entry(ops, &net->rules_ops, list) {
  1159. detach_rules(&ops->rules_list, dev);
  1160. attach_rules(&ops->rules_list, dev);
  1161. }
  1162. break;
  1163. case NETDEV_UNREGISTER:
  1164. list_for_each_entry(ops, &net->rules_ops, list)
  1165. detach_rules(&ops->rules_list, dev);
  1166. break;
  1167. }
  1168. return NOTIFY_DONE;
  1169. }
  1170. static struct notifier_block fib_rules_notifier = {
  1171. .notifier_call = fib_rules_event,
  1172. };
  1173. static int __net_init fib_rules_net_init(struct net *net)
  1174. {
  1175. INIT_LIST_HEAD(&net->rules_ops);
  1176. spin_lock_init(&net->rules_mod_lock);
  1177. return 0;
  1178. }
  1179. static void __net_exit fib_rules_net_exit(struct net *net)
  1180. {
  1181. WARN_ON_ONCE(!list_empty(&net->rules_ops));
  1182. }
  1183. static struct pernet_operations fib_rules_net_ops = {
  1184. .init = fib_rules_net_init,
  1185. .exit = fib_rules_net_exit,
  1186. };
  1187. static const struct rtnl_msg_handler fib_rules_rtnl_msg_handlers[] __initconst = {
  1188. {.msgtype = RTM_NEWRULE, .doit = fib_nl_newrule,
  1189. .flags = RTNL_FLAG_DOIT_PERNET},
  1190. {.msgtype = RTM_DELRULE, .doit = fib_nl_delrule,
  1191. .flags = RTNL_FLAG_DOIT_PERNET},
  1192. {.msgtype = RTM_GETRULE, .dumpit = fib_nl_dumprule,
  1193. .flags = RTNL_FLAG_DUMP_UNLOCKED},
  1194. };
  1195. static int __init fib_rules_init(void)
  1196. {
  1197. int err;
  1198. rtnl_register_many(fib_rules_rtnl_msg_handlers);
  1199. err = register_pernet_subsys(&fib_rules_net_ops);
  1200. if (err < 0)
  1201. goto fail;
  1202. err = register_netdevice_notifier(&fib_rules_notifier);
  1203. if (err < 0)
  1204. goto fail_unregister;
  1205. return 0;
  1206. fail_unregister:
  1207. unregister_pernet_subsys(&fib_rules_net_ops);
  1208. fail:
  1209. rtnl_unregister_many(fib_rules_rtnl_msg_handlers);
  1210. return err;
  1211. }
  1212. subsys_initcall(fib_rules_init);