Lines Matching refs:np
65 #define np_info(np, fmt, ...) \ argument
66 pr_info("%s: " fmt, np->name, ##__VA_ARGS__)
67 #define np_err(np, fmt, ...) \ argument
68 pr_err("%s: " fmt, np->name, ##__VA_ARGS__)
69 #define np_notice(np, fmt, ...) \ argument
70 pr_notice("%s: " fmt, np->name, ##__VA_ARGS__)
285 static struct sk_buff *find_skb(struct netpoll *np, int len, int reserve) in find_skb() argument
300 netpoll_poll_dev(np->dev); in find_skb()
323 void netpoll_send_skb_on_dev(struct netpoll *np, struct sk_buff *skb, in netpoll_send_skb_on_dev() argument
333 npinfo = rcu_dereference_bh(np->dev->npinfo); in netpoll_send_skb_on_dev()
360 netpoll_poll_dev(np->dev); in netpoll_send_skb_on_dev()
378 void netpoll_send_udp(struct netpoll *np, const char *msg, int len) in netpoll_send_udp() argument
391 if (np->ipv6) in netpoll_send_udp()
396 total_len = ip_len + LL_RESERVED_SPACE(np->dev); in netpoll_send_udp()
398 skb = find_skb(np, total_len + np->dev->needed_tailroom, in netpoll_send_udp()
409 udph->source = htons(np->local_port); in netpoll_send_udp()
410 udph->dest = htons(np->remote_port); in netpoll_send_udp()
413 if (np->ipv6) { in netpoll_send_udp()
415 udph->check = csum_ipv6_magic(&np->local_ip.in6, in netpoll_send_udp()
416 &np->remote_ip.in6, in netpoll_send_udp()
435 ip6h->saddr = np->local_ip.in6; in netpoll_send_udp()
436 ip6h->daddr = np->remote_ip.in6; in netpoll_send_udp()
443 udph->check = csum_tcpudp_magic(np->local_ip.ip, in netpoll_send_udp()
444 np->remote_ip.ip, in netpoll_send_udp()
463 put_unaligned(np->local_ip.ip, &(iph->saddr)); in netpoll_send_udp()
464 put_unaligned(np->remote_ip.ip, &(iph->daddr)); in netpoll_send_udp()
472 ether_addr_copy(eth->h_source, np->dev->dev_addr); in netpoll_send_udp()
473 ether_addr_copy(eth->h_dest, np->remote_mac); in netpoll_send_udp()
475 skb->dev = np->dev; in netpoll_send_udp()
477 netpoll_send_skb(np, skb); in netpoll_send_udp()
481 void netpoll_print_options(struct netpoll *np) in netpoll_print_options() argument
483 np_info(np, "local port %d\n", np->local_port); in netpoll_print_options()
484 if (np->ipv6) in netpoll_print_options()
485 np_info(np, "local IPv6 address %pI6c\n", &np->local_ip.in6); in netpoll_print_options()
487 np_info(np, "local IPv4 address %pI4\n", &np->local_ip.ip); in netpoll_print_options()
488 np_info(np, "interface '%s'\n", np->dev_name); in netpoll_print_options()
489 np_info(np, "remote port %d\n", np->remote_port); in netpoll_print_options()
490 if (np->ipv6) in netpoll_print_options()
491 np_info(np, "remote IPv6 address %pI6c\n", &np->remote_ip.in6); in netpoll_print_options()
493 np_info(np, "remote IPv4 address %pI4\n", &np->remote_ip.ip); in netpoll_print_options()
494 np_info(np, "remote ethernet address %pM\n", np->remote_mac); in netpoll_print_options()
518 int netpoll_parse_options(struct netpoll *np, char *opt) in netpoll_parse_options() argument
528 if (kstrtou16(cur, 10, &np->local_port)) in netpoll_parse_options()
539 ipv6 = netpoll_parse_ip_addr(cur, &np->local_ip); in netpoll_parse_options()
543 np->ipv6 = (bool)ipv6; in netpoll_parse_options()
553 strlcpy(np->dev_name, cur, sizeof(np->dev_name)); in netpoll_parse_options()
564 np_info(np, "warning: whitespace is not allowed\n"); in netpoll_parse_options()
565 if (kstrtou16(cur, 10, &np->remote_port)) in netpoll_parse_options()
575 ipv6 = netpoll_parse_ip_addr(cur, &np->remote_ip); in netpoll_parse_options()
578 else if (ipversion_set && np->ipv6 != (bool)ipv6) in netpoll_parse_options()
581 np->ipv6 = (bool)ipv6; in netpoll_parse_options()
586 if (!mac_pton(cur, np->remote_mac)) in netpoll_parse_options()
590 netpoll_print_options(np); in netpoll_parse_options()
595 np_info(np, "couldn't parse config at '%s'!\n", cur); in netpoll_parse_options()
600 int __netpoll_setup(struct netpoll *np, struct net_device *ndev) in __netpoll_setup() argument
606 np->dev = ndev; in __netpoll_setup()
607 strlcpy(np->dev_name, ndev->name, IFNAMSIZ); in __netpoll_setup()
608 INIT_WORK(&np->cleanup_work, netpoll_async_cleanup); in __netpoll_setup()
612 np_err(np, "%s doesn't support polling, aborting\n", in __netpoll_setup()
613 np->dev_name); in __netpoll_setup()
631 ops = np->dev->netdev_ops; in __netpoll_setup()
642 npinfo->netpoll = np; in __netpoll_setup()
656 int netpoll_setup(struct netpoll *np) in netpoll_setup() argument
663 if (np->dev_name) { in netpoll_setup()
665 ndev = __dev_get_by_name(net, np->dev_name); in netpoll_setup()
668 np_err(np, "%s doesn't exist, aborting\n", np->dev_name); in netpoll_setup()
675 np_err(np, "%s is a slave device, aborting\n", np->dev_name); in netpoll_setup()
683 np_info(np, "device %s not up yet, forcing it\n", np->dev_name); in netpoll_setup()
688 np_err(np, "failed to open %s\n", ndev->name); in netpoll_setup()
697 np_notice(np, "timeout waiting for carrier\n"); in netpoll_setup()
709 np_notice(np, "carrier detect appears untrustworthy, waiting 4 seconds\n"); in netpoll_setup()
715 if (!np->local_ip.ip) { in netpoll_setup()
716 if (!np->ipv6) { in netpoll_setup()
720 np_err(np, "no IP address for %s, aborting\n", in netpoll_setup()
721 np->dev_name); in netpoll_setup()
726 np->local_ip.ip = in_dev->ifa_list->ifa_local; in netpoll_setup()
727 np_info(np, "local IP %pI4\n", &np->local_ip.ip); in netpoll_setup()
741 np->local_ip.in6 = ifp->addr; in netpoll_setup()
748 np_err(np, "no IPv6 address for %s, aborting\n", in netpoll_setup()
749 np->dev_name); in netpoll_setup()
752 np_info(np, "local IPv6 %pI6c\n", &np->local_ip.in6); in netpoll_setup()
754 np_err(np, "IPv6 is not supported %s, aborting\n", in netpoll_setup()
755 np->dev_name); in netpoll_setup()
765 err = __netpoll_setup(np, ndev); in netpoll_setup()
804 void __netpoll_cleanup(struct netpoll *np) in __netpoll_cleanup() argument
812 npinfo = rtnl_dereference(np->dev->npinfo); in __netpoll_cleanup()
821 ops = np->dev->netdev_ops; in __netpoll_cleanup()
823 ops->ndo_netpoll_cleanup(np->dev); in __netpoll_cleanup()
825 RCU_INIT_POINTER(np->dev->npinfo, NULL); in __netpoll_cleanup()
828 RCU_INIT_POINTER(np->dev->npinfo, NULL); in __netpoll_cleanup()
834 struct netpoll *np = container_of(work, struct netpoll, cleanup_work); in netpoll_async_cleanup() local
837 __netpoll_cleanup(np); in netpoll_async_cleanup()
839 kfree(np); in netpoll_async_cleanup()
842 void __netpoll_free_async(struct netpoll *np) in __netpoll_free_async() argument
844 schedule_work(&np->cleanup_work); in __netpoll_free_async()
848 void netpoll_cleanup(struct netpoll *np) in netpoll_cleanup() argument
851 if (!np->dev) in netpoll_cleanup()
853 __netpoll_cleanup(np); in netpoll_cleanup()
854 dev_put(np->dev); in netpoll_cleanup()
855 np->dev = NULL; in netpoll_cleanup()