diff options
| author | Thomas Zimmermann <tzimmermann@suse.de> | 2021-12-17 11:33:33 +0100 | 
|---|---|---|
| committer | Thomas Zimmermann <tzimmermann@suse.de> | 2021-12-17 11:33:33 +0100 | 
| commit | 1758047057dbe329be712a31b79db7151b5871f8 (patch) | |
| tree | 00203eb55328f2feda70b3d37c964287b364796f /net/mctp/test/utils.c | |
| parent | bcae3af286f49bf4f6cda03f165fbe530f4a6bed (diff) | |
| parent | 1c405ca11bf563de1725e5ecfb4a74ee289d2ee9 (diff) | |
Merge drm/drm-next into drm-misc-next-fixes
Backmerging to bring drm-misc-next-fixes up to the latest state for
the current release cycle.
Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Diffstat (limited to 'net/mctp/test/utils.c')
| -rw-r--r-- | net/mctp/test/utils.c | 67 | 
1 files changed, 67 insertions, 0 deletions
diff --git a/net/mctp/test/utils.c b/net/mctp/test/utils.c new file mode 100644 index 000000000000..7b7918702592 --- /dev/null +++ b/net/mctp/test/utils.c @@ -0,0 +1,67 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include <linux/netdevice.h> +#include <linux/mctp.h> +#include <linux/if_arp.h> + +#include <net/mctpdevice.h> +#include <net/pkt_sched.h> + +#include "utils.h" + +static netdev_tx_t mctp_test_dev_tx(struct sk_buff *skb, +				    struct net_device *ndev) +{ +	kfree_skb(skb); +	return NETDEV_TX_OK; +} + +static const struct net_device_ops mctp_test_netdev_ops = { +	.ndo_start_xmit = mctp_test_dev_tx, +}; + +static void mctp_test_dev_setup(struct net_device *ndev) +{ +	ndev->type = ARPHRD_MCTP; +	ndev->mtu = MCTP_DEV_TEST_MTU; +	ndev->hard_header_len = 0; +	ndev->addr_len = 0; +	ndev->tx_queue_len = DEFAULT_TX_QUEUE_LEN; +	ndev->flags = IFF_NOARP; +	ndev->netdev_ops = &mctp_test_netdev_ops; +	ndev->needs_free_netdev = true; +} + +struct mctp_test_dev *mctp_test_create_dev(void) +{ +	struct mctp_test_dev *dev; +	struct net_device *ndev; +	int rc; + +	ndev = alloc_netdev(sizeof(*dev), "mctptest%d", NET_NAME_ENUM, +			    mctp_test_dev_setup); +	if (!ndev) +		return NULL; + +	dev = netdev_priv(ndev); +	dev->ndev = ndev; + +	rc = register_netdev(ndev); +	if (rc) { +		free_netdev(ndev); +		return NULL; +	} + +	rcu_read_lock(); +	dev->mdev = __mctp_dev_get(ndev); +	mctp_dev_hold(dev->mdev); +	rcu_read_unlock(); + +	return dev; +} + +void mctp_test_destroy_dev(struct mctp_test_dev *dev) +{ +	mctp_dev_put(dev->mdev); +	unregister_netdev(dev->ndev); +}  | 
