device.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Management Component Transport Protocol (MCTP) - device implementation.
  4. *
  5. * Copyright (c) 2021 Code Construct
  6. * Copyright (c) 2021 Google
  7. */
  8. #include <linux/if_arp.h>
  9. #include <linux/if_link.h>
  10. #include <linux/mctp.h>
  11. #include <linux/netdevice.h>
  12. #include <linux/rcupdate.h>
  13. #include <linux/rtnetlink.h>
  14. #include <net/addrconf.h>
  15. #include <net/netlink.h>
  16. #include <net/mctp.h>
  17. #include <net/mctpdevice.h>
  18. #include <net/sock.h>
  19. struct mctp_dump_cb {
  20. unsigned long ifindex;
  21. size_t a_idx;
  22. };
  23. /* unlocked: caller must hold rcu_read_lock.
  24. * Returned mctp_dev has its refcount incremented, or NULL if unset.
  25. */
  26. struct mctp_dev *__mctp_dev_get(const struct net_device *dev)
  27. {
  28. struct mctp_dev *mdev = rcu_dereference(dev->mctp_ptr);
  29. /* RCU guarantees that any mdev is still live.
  30. * Zero refcount implies a pending free, return NULL.
  31. */
  32. if (mdev)
  33. if (!refcount_inc_not_zero(&mdev->refs))
  34. return NULL;
  35. return mdev;
  36. }
  37. /* Returned mctp_dev does not have refcount incremented. The returned pointer
  38. * remains live while rtnl_lock is held, as that prevents mctp_unregister()
  39. */
  40. struct mctp_dev *mctp_dev_get_rtnl(const struct net_device *dev)
  41. {
  42. return rtnl_dereference(dev->mctp_ptr);
  43. }
  44. static int mctp_addrinfo_size(void)
  45. {
  46. return NLMSG_ALIGN(sizeof(struct ifaddrmsg))
  47. + nla_total_size(1) // IFA_LOCAL
  48. + nla_total_size(1) // IFA_ADDRESS
  49. ;
  50. }
  51. /* flag should be NLM_F_MULTI for dump calls */
  52. static int mctp_fill_addrinfo(struct sk_buff *skb,
  53. struct mctp_dev *mdev, mctp_eid_t eid,
  54. int msg_type, u32 portid, u32 seq, int flag)
  55. {
  56. struct ifaddrmsg *hdr;
  57. struct nlmsghdr *nlh;
  58. nlh = nlmsg_put(skb, portid, seq,
  59. msg_type, sizeof(*hdr), flag);
  60. if (!nlh)
  61. return -EMSGSIZE;
  62. hdr = nlmsg_data(nlh);
  63. memset(hdr, 0, sizeof(*hdr));
  64. hdr->ifa_family = AF_MCTP;
  65. hdr->ifa_prefixlen = 0;
  66. hdr->ifa_flags = 0;
  67. hdr->ifa_scope = 0;
  68. hdr->ifa_index = mdev->dev->ifindex;
  69. if (nla_put_u8(skb, IFA_LOCAL, eid))
  70. goto cancel;
  71. if (nla_put_u8(skb, IFA_ADDRESS, eid))
  72. goto cancel;
  73. nlmsg_end(skb, nlh);
  74. return 0;
  75. cancel:
  76. nlmsg_cancel(skb, nlh);
  77. return -EMSGSIZE;
  78. }
  79. static int mctp_dump_dev_addrinfo(struct mctp_dev *mdev, struct sk_buff *skb,
  80. struct netlink_callback *cb)
  81. {
  82. struct mctp_dump_cb *mcb = (void *)cb->ctx;
  83. u32 portid, seq;
  84. int rc = 0;
  85. portid = NETLINK_CB(cb->skb).portid;
  86. seq = cb->nlh->nlmsg_seq;
  87. for (; mcb->a_idx < mdev->num_addrs; mcb->a_idx++) {
  88. rc = mctp_fill_addrinfo(skb, mdev, mdev->addrs[mcb->a_idx],
  89. RTM_NEWADDR, portid, seq, NLM_F_MULTI);
  90. if (rc < 0)
  91. break;
  92. }
  93. return rc;
  94. }
  95. static int mctp_dump_addrinfo(struct sk_buff *skb, struct netlink_callback *cb)
  96. {
  97. struct mctp_dump_cb *mcb = (void *)cb->ctx;
  98. struct net *net = sock_net(skb->sk);
  99. struct net_device *dev;
  100. struct ifaddrmsg *hdr;
  101. struct mctp_dev *mdev;
  102. int ifindex = 0, rc;
  103. /* Filter by ifindex if a header is provided */
  104. hdr = nlmsg_payload(cb->nlh, sizeof(*hdr));
  105. if (hdr) {
  106. ifindex = hdr->ifa_index;
  107. } else {
  108. if (cb->strict_check) {
  109. NL_SET_ERR_MSG(cb->extack, "mctp: Invalid header for addr dump request");
  110. return -EINVAL;
  111. }
  112. }
  113. rcu_read_lock();
  114. for_each_netdev_dump(net, dev, mcb->ifindex) {
  115. if (ifindex && ifindex != dev->ifindex)
  116. continue;
  117. mdev = __mctp_dev_get(dev);
  118. if (!mdev)
  119. continue;
  120. rc = mctp_dump_dev_addrinfo(mdev, skb, cb);
  121. mctp_dev_put(mdev);
  122. if (rc < 0)
  123. break;
  124. mcb->a_idx = 0;
  125. }
  126. rcu_read_unlock();
  127. return skb->len;
  128. }
  129. static void mctp_addr_notify(struct mctp_dev *mdev, mctp_eid_t eid, int msg_type,
  130. struct sk_buff *req_skb, struct nlmsghdr *req_nlh)
  131. {
  132. u32 portid = NETLINK_CB(req_skb).portid;
  133. struct net *net = dev_net(mdev->dev);
  134. struct sk_buff *skb;
  135. int rc = -ENOBUFS;
  136. skb = nlmsg_new(mctp_addrinfo_size(), GFP_KERNEL);
  137. if (!skb)
  138. goto out;
  139. rc = mctp_fill_addrinfo(skb, mdev, eid, msg_type,
  140. portid, req_nlh->nlmsg_seq, 0);
  141. if (rc < 0) {
  142. WARN_ON_ONCE(rc == -EMSGSIZE);
  143. goto out;
  144. }
  145. rtnl_notify(skb, net, portid, RTNLGRP_MCTP_IFADDR, req_nlh, GFP_KERNEL);
  146. return;
  147. out:
  148. kfree_skb(skb);
  149. rtnl_set_sk_err(net, RTNLGRP_MCTP_IFADDR, rc);
  150. }
  151. static const struct nla_policy ifa_mctp_policy[IFA_MAX + 1] = {
  152. [IFA_ADDRESS] = { .type = NLA_U8 },
  153. [IFA_LOCAL] = { .type = NLA_U8 },
  154. };
  155. static int mctp_rtm_newaddr(struct sk_buff *skb, struct nlmsghdr *nlh,
  156. struct netlink_ext_ack *extack)
  157. {
  158. struct net *net = sock_net(skb->sk);
  159. struct nlattr *tb[IFA_MAX + 1];
  160. struct net_device *dev;
  161. struct mctp_addr *addr;
  162. struct mctp_dev *mdev;
  163. struct ifaddrmsg *ifm;
  164. unsigned long flags;
  165. u8 *tmp_addrs;
  166. int rc;
  167. rc = nlmsg_parse(nlh, sizeof(*ifm), tb, IFA_MAX, ifa_mctp_policy,
  168. extack);
  169. if (rc < 0)
  170. return rc;
  171. ifm = nlmsg_data(nlh);
  172. if (tb[IFA_LOCAL])
  173. addr = nla_data(tb[IFA_LOCAL]);
  174. else if (tb[IFA_ADDRESS])
  175. addr = nla_data(tb[IFA_ADDRESS]);
  176. else
  177. return -EINVAL;
  178. /* find device */
  179. dev = __dev_get_by_index(net, ifm->ifa_index);
  180. if (!dev)
  181. return -ENODEV;
  182. mdev = mctp_dev_get_rtnl(dev);
  183. if (!mdev)
  184. return -ENODEV;
  185. if (!mctp_address_unicast(addr->s_addr))
  186. return -EINVAL;
  187. /* Prevent duplicates. Under RTNL so don't need to lock for reading */
  188. if (memchr(mdev->addrs, addr->s_addr, mdev->num_addrs))
  189. return -EEXIST;
  190. tmp_addrs = kmalloc(mdev->num_addrs + 1, GFP_KERNEL);
  191. if (!tmp_addrs)
  192. return -ENOMEM;
  193. memcpy(tmp_addrs, mdev->addrs, mdev->num_addrs);
  194. tmp_addrs[mdev->num_addrs] = addr->s_addr;
  195. /* Lock to write */
  196. spin_lock_irqsave(&mdev->addrs_lock, flags);
  197. mdev->num_addrs++;
  198. swap(mdev->addrs, tmp_addrs);
  199. spin_unlock_irqrestore(&mdev->addrs_lock, flags);
  200. kfree(tmp_addrs);
  201. mctp_addr_notify(mdev, addr->s_addr, RTM_NEWADDR, skb, nlh);
  202. mctp_route_add_local(mdev, addr->s_addr);
  203. return 0;
  204. }
  205. static int mctp_rtm_deladdr(struct sk_buff *skb, struct nlmsghdr *nlh,
  206. struct netlink_ext_ack *extack)
  207. {
  208. struct net *net = sock_net(skb->sk);
  209. struct nlattr *tb[IFA_MAX + 1];
  210. struct net_device *dev;
  211. struct mctp_addr *addr;
  212. struct mctp_dev *mdev;
  213. struct ifaddrmsg *ifm;
  214. unsigned long flags;
  215. u8 *pos;
  216. int rc;
  217. rc = nlmsg_parse(nlh, sizeof(*ifm), tb, IFA_MAX, ifa_mctp_policy,
  218. extack);
  219. if (rc < 0)
  220. return rc;
  221. ifm = nlmsg_data(nlh);
  222. if (tb[IFA_LOCAL])
  223. addr = nla_data(tb[IFA_LOCAL]);
  224. else if (tb[IFA_ADDRESS])
  225. addr = nla_data(tb[IFA_ADDRESS]);
  226. else
  227. return -EINVAL;
  228. /* find device */
  229. dev = __dev_get_by_index(net, ifm->ifa_index);
  230. if (!dev)
  231. return -ENODEV;
  232. mdev = mctp_dev_get_rtnl(dev);
  233. if (!mdev)
  234. return -ENODEV;
  235. pos = memchr(mdev->addrs, addr->s_addr, mdev->num_addrs);
  236. if (!pos)
  237. return -ENOENT;
  238. rc = mctp_route_remove_local(mdev, addr->s_addr);
  239. // we can ignore -ENOENT in the case a route was already removed
  240. if (rc < 0 && rc != -ENOENT)
  241. return rc;
  242. spin_lock_irqsave(&mdev->addrs_lock, flags);
  243. memmove(pos, pos + 1, mdev->num_addrs - 1 - (pos - mdev->addrs));
  244. mdev->num_addrs--;
  245. spin_unlock_irqrestore(&mdev->addrs_lock, flags);
  246. mctp_addr_notify(mdev, addr->s_addr, RTM_DELADDR, skb, nlh);
  247. return 0;
  248. }
  249. void mctp_dev_hold(struct mctp_dev *mdev)
  250. {
  251. refcount_inc(&mdev->refs);
  252. }
  253. void mctp_dev_put(struct mctp_dev *mdev)
  254. {
  255. if (mdev && refcount_dec_and_test(&mdev->refs)) {
  256. kfree(mdev->addrs);
  257. dev_put(mdev->dev);
  258. kfree_rcu(mdev, rcu);
  259. }
  260. }
  261. void mctp_dev_release_key(struct mctp_dev *dev, struct mctp_sk_key *key)
  262. __must_hold(&key->lock)
  263. {
  264. if (!dev)
  265. return;
  266. if (dev->ops && dev->ops->release_flow)
  267. dev->ops->release_flow(dev, key);
  268. key->dev = NULL;
  269. mctp_dev_put(dev);
  270. }
  271. void mctp_dev_set_key(struct mctp_dev *dev, struct mctp_sk_key *key)
  272. __must_hold(&key->lock)
  273. {
  274. mctp_dev_hold(dev);
  275. key->dev = dev;
  276. }
  277. static struct mctp_dev *mctp_add_dev(struct net_device *dev)
  278. {
  279. struct mctp_dev *mdev;
  280. ASSERT_RTNL();
  281. mdev = kzalloc_obj(*mdev);
  282. if (!mdev)
  283. return ERR_PTR(-ENOMEM);
  284. spin_lock_init(&mdev->addrs_lock);
  285. mdev->net = mctp_default_net(dev_net(dev));
  286. /* associate to net_device */
  287. refcount_set(&mdev->refs, 1);
  288. rcu_assign_pointer(dev->mctp_ptr, mdev);
  289. dev_hold(dev);
  290. mdev->dev = dev;
  291. return mdev;
  292. }
  293. static int mctp_fill_link_af(struct sk_buff *skb,
  294. const struct net_device *dev, u32 ext_filter_mask)
  295. {
  296. struct mctp_dev *mdev;
  297. mdev = mctp_dev_get_rtnl(dev);
  298. if (!mdev)
  299. return -ENODATA;
  300. if (nla_put_u32(skb, IFLA_MCTP_NET, mdev->net))
  301. return -EMSGSIZE;
  302. if (nla_put_u8(skb, IFLA_MCTP_PHYS_BINDING, mdev->binding))
  303. return -EMSGSIZE;
  304. return 0;
  305. }
  306. static size_t mctp_get_link_af_size(const struct net_device *dev,
  307. u32 ext_filter_mask)
  308. {
  309. struct mctp_dev *mdev;
  310. unsigned int ret;
  311. /* caller holds RCU */
  312. mdev = __mctp_dev_get(dev);
  313. if (!mdev)
  314. return 0;
  315. ret = nla_total_size(4); /* IFLA_MCTP_NET */
  316. ret += nla_total_size(1); /* IFLA_MCTP_PHYS_BINDING */
  317. mctp_dev_put(mdev);
  318. return ret;
  319. }
  320. static const struct nla_policy ifla_af_mctp_policy[IFLA_MCTP_MAX + 1] = {
  321. [IFLA_MCTP_NET] = { .type = NLA_U32 },
  322. };
  323. static int mctp_set_link_af(struct net_device *dev, const struct nlattr *attr,
  324. struct netlink_ext_ack *extack)
  325. {
  326. struct nlattr *tb[IFLA_MCTP_MAX + 1];
  327. struct mctp_dev *mdev;
  328. int rc;
  329. rc = nla_parse_nested(tb, IFLA_MCTP_MAX, attr, ifla_af_mctp_policy,
  330. NULL);
  331. if (rc)
  332. return rc;
  333. mdev = mctp_dev_get_rtnl(dev);
  334. if (!mdev)
  335. return 0;
  336. if (tb[IFLA_MCTP_NET])
  337. WRITE_ONCE(mdev->net, nla_get_u32(tb[IFLA_MCTP_NET]));
  338. return 0;
  339. }
  340. /* Matches netdev types that should have MCTP handling */
  341. static bool mctp_known(struct net_device *dev)
  342. {
  343. /* only register specific types (inc. NONE for TUN devices) */
  344. return dev->type == ARPHRD_MCTP ||
  345. dev->type == ARPHRD_LOOPBACK ||
  346. dev->type == ARPHRD_NONE;
  347. }
  348. static void mctp_unregister(struct net_device *dev)
  349. {
  350. struct mctp_dev *mdev;
  351. mdev = mctp_dev_get_rtnl(dev);
  352. if (!mdev)
  353. return;
  354. RCU_INIT_POINTER(mdev->dev->mctp_ptr, NULL);
  355. mctp_route_remove_dev(mdev);
  356. mctp_neigh_remove_dev(mdev);
  357. mctp_dev_put(mdev);
  358. }
  359. static int mctp_register(struct net_device *dev)
  360. {
  361. struct mctp_dev *mdev;
  362. /* Already registered? */
  363. if (rtnl_dereference(dev->mctp_ptr))
  364. return 0;
  365. /* only register specific types */
  366. if (!mctp_known(dev))
  367. return 0;
  368. mdev = mctp_add_dev(dev);
  369. if (IS_ERR(mdev))
  370. return PTR_ERR(mdev);
  371. return 0;
  372. }
  373. static int mctp_dev_notify(struct notifier_block *this, unsigned long event,
  374. void *ptr)
  375. {
  376. struct net_device *dev = netdev_notifier_info_to_dev(ptr);
  377. int rc;
  378. switch (event) {
  379. case NETDEV_REGISTER:
  380. rc = mctp_register(dev);
  381. if (rc)
  382. return notifier_from_errno(rc);
  383. break;
  384. case NETDEV_UNREGISTER:
  385. mctp_unregister(dev);
  386. break;
  387. }
  388. return NOTIFY_OK;
  389. }
  390. static int mctp_register_netdevice(struct net_device *dev,
  391. const struct mctp_netdev_ops *ops,
  392. enum mctp_phys_binding binding)
  393. {
  394. struct mctp_dev *mdev;
  395. mdev = mctp_add_dev(dev);
  396. if (IS_ERR(mdev))
  397. return PTR_ERR(mdev);
  398. mdev->ops = ops;
  399. mdev->binding = binding;
  400. return register_netdevice(dev);
  401. }
  402. int mctp_register_netdev(struct net_device *dev,
  403. const struct mctp_netdev_ops *ops,
  404. enum mctp_phys_binding binding)
  405. {
  406. int rc;
  407. rtnl_lock();
  408. rc = mctp_register_netdevice(dev, ops, binding);
  409. rtnl_unlock();
  410. return rc;
  411. }
  412. EXPORT_SYMBOL_GPL(mctp_register_netdev);
  413. void mctp_unregister_netdev(struct net_device *dev)
  414. {
  415. unregister_netdev(dev);
  416. }
  417. EXPORT_SYMBOL_GPL(mctp_unregister_netdev);
  418. static struct rtnl_af_ops mctp_af_ops = {
  419. .family = AF_MCTP,
  420. .fill_link_af = mctp_fill_link_af,
  421. .get_link_af_size = mctp_get_link_af_size,
  422. .set_link_af = mctp_set_link_af,
  423. };
  424. static struct notifier_block mctp_dev_nb = {
  425. .notifier_call = mctp_dev_notify,
  426. .priority = ADDRCONF_NOTIFY_PRIORITY,
  427. };
  428. static const struct rtnl_msg_handler mctp_device_rtnl_msg_handlers[] = {
  429. {.owner = THIS_MODULE, .protocol = PF_MCTP, .msgtype = RTM_NEWADDR,
  430. .doit = mctp_rtm_newaddr},
  431. {.owner = THIS_MODULE, .protocol = PF_MCTP, .msgtype = RTM_DELADDR,
  432. .doit = mctp_rtm_deladdr},
  433. {.owner = THIS_MODULE, .protocol = PF_MCTP, .msgtype = RTM_GETADDR,
  434. .dumpit = mctp_dump_addrinfo},
  435. };
  436. int __init mctp_device_init(void)
  437. {
  438. int err;
  439. register_netdevice_notifier(&mctp_dev_nb);
  440. err = rtnl_af_register(&mctp_af_ops);
  441. if (err)
  442. goto err_notifier;
  443. err = rtnl_register_many(mctp_device_rtnl_msg_handlers);
  444. if (err)
  445. goto err_af;
  446. return 0;
  447. err_af:
  448. rtnl_af_unregister(&mctp_af_ops);
  449. err_notifier:
  450. unregister_netdevice_notifier(&mctp_dev_nb);
  451. return err;
  452. }
  453. void __exit mctp_device_exit(void)
  454. {
  455. rtnl_unregister_many(mctp_device_rtnl_msg_handlers);
  456. rtnl_af_unregister(&mctp_af_ops);
  457. unregister_netdevice_notifier(&mctp_dev_nb);
  458. }