utils.c 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <linux/netdevice.h>
  3. #include <linux/mctp.h>
  4. #include <linux/if_arp.h>
  5. #include <net/mctp.h>
  6. #include <net/mctpdevice.h>
  7. #include <net/pkt_sched.h>
  8. #include "utils.h"
  9. static netdev_tx_t mctp_test_dev_tx(struct sk_buff *skb,
  10. struct net_device *ndev)
  11. {
  12. kfree_skb(skb);
  13. return NETDEV_TX_OK;
  14. }
  15. static const struct net_device_ops mctp_test_netdev_ops = {
  16. .ndo_start_xmit = mctp_test_dev_tx,
  17. };
  18. static void mctp_test_dev_setup(struct net_device *ndev)
  19. {
  20. ndev->type = ARPHRD_MCTP;
  21. ndev->mtu = MCTP_DEV_TEST_MTU;
  22. ndev->hard_header_len = 0;
  23. ndev->addr_len = 0;
  24. ndev->tx_queue_len = DEFAULT_TX_QUEUE_LEN;
  25. ndev->flags = IFF_NOARP;
  26. ndev->netdev_ops = &mctp_test_netdev_ops;
  27. ndev->needs_free_netdev = true;
  28. }
  29. struct mctp_test_dev *mctp_test_create_dev(void)
  30. {
  31. struct mctp_test_dev *dev;
  32. struct net_device *ndev;
  33. int rc;
  34. ndev = alloc_netdev(sizeof(*dev), "mctptest%d", NET_NAME_ENUM,
  35. mctp_test_dev_setup);
  36. if (!ndev)
  37. return NULL;
  38. dev = netdev_priv(ndev);
  39. dev->ndev = ndev;
  40. rc = register_netdev(ndev);
  41. if (rc) {
  42. free_netdev(ndev);
  43. return NULL;
  44. }
  45. rcu_read_lock();
  46. dev->mdev = __mctp_dev_get(ndev);
  47. dev->mdev->net = mctp_default_net(dev_net(ndev));
  48. rcu_read_unlock();
  49. return dev;
  50. }
  51. void mctp_test_destroy_dev(struct mctp_test_dev *dev)
  52. {
  53. mctp_dev_put(dev->mdev);
  54. unregister_netdev(dev->ndev);
  55. }