mirror of
https://github.com/adulau/aha.git
synced 2025-01-01 13:46:24 +00:00
0c4e85813d
Add inline for common usage of hardware header creation, and fix bug in IPV6 mcast where the assumption about negative return is an errno. Negative return from hard_header means not enough space was available,(ie -N bytes). Signed-off-by: Stephen Hemminger <shemminger@linux-foundation.org> Signed-off-by: David S. Miller <davem@davemloft.net>
37 lines
775 B
C
37 lines
775 B
C
#include <linux/in.h>
|
|
#include <linux/mm.h>
|
|
#include <linux/module.h>
|
|
#include <linux/netdevice.h>
|
|
#include <linux/skbuff.h>
|
|
|
|
#include <net/datalink.h>
|
|
|
|
static int pEII_request(struct datalink_proto *dl,
|
|
struct sk_buff *skb, unsigned char *dest_node)
|
|
{
|
|
struct net_device *dev = skb->dev;
|
|
|
|
skb->protocol = htons(ETH_P_IPX);
|
|
dev_hard_header(skb, dev, ETH_P_IPX, dest_node, NULL, skb->len);
|
|
return dev_queue_xmit(skb);
|
|
}
|
|
|
|
struct datalink_proto *make_EII_client(void)
|
|
{
|
|
struct datalink_proto *proto = kmalloc(sizeof(*proto), GFP_ATOMIC);
|
|
|
|
if (proto) {
|
|
proto->header_length = 0;
|
|
proto->request = pEII_request;
|
|
}
|
|
|
|
return proto;
|
|
}
|
|
|
|
void destroy_EII_client(struct datalink_proto *dl)
|
|
{
|
|
kfree(dl);
|
|
}
|
|
|
|
EXPORT_SYMBOL(destroy_EII_client);
|
|
EXPORT_SYMBOL(make_EII_client);
|