Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c48192a7 authored by Joe Perches's avatar Joe Perches Committed by David S. Miller
Browse files

net/atm/lec.c: checkpatch cleanups



Convert #include <asm... to #include <linux...
Mostly 80 column wrapped.
Spacing cleanups
Convert printks to pr_<level>
Use print_hex_dump
Move embedded assigns out of tests
Move trailing statements to new lines
Remove unnecessary braces around single line statements
switch/case cleanups
Removed paren around returns
Use %pM
Moved leading continuation logical tests to end of previous line

Signed-off-by: default avatarJoe Perches <joe@perches.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 5ff7ef79
Loading
Loading
Loading
Loading
+136 −148
Original line number Original line Diff line number Diff line
@@ -18,7 +18,7 @@
#include <linux/skbuff.h>
#include <linux/skbuff.h>
#include <linux/ip.h>
#include <linux/ip.h>
#include <asm/byteorder.h>
#include <asm/byteorder.h>
#include <asm/uaccess.h>
#include <linux/uaccess.h>
#include <net/arp.h>
#include <net/arp.h>
#include <net/dst.h>
#include <net/dst.h>
#include <linux/proc_fs.h>
#include <linux/proc_fs.h>
@@ -87,14 +87,16 @@ static struct atm_vcc *lec_arp_resolve(struct lec_priv *priv,
				       int is_rdesc,
				       int is_rdesc,
				       struct lec_arp_table **ret_entry);
				       struct lec_arp_table **ret_entry);
static void lec_arp_update(struct lec_priv *priv, const unsigned char *mac_addr,
static void lec_arp_update(struct lec_priv *priv, const unsigned char *mac_addr,
			   const unsigned char *atm_addr, unsigned long remoteflag,
			   const unsigned char *atm_addr,
			   unsigned long remoteflag,
			   unsigned int targetless_le_arp);
			   unsigned int targetless_le_arp);
static void lec_flush_complete(struct lec_priv *priv, unsigned long tran_id);
static void lec_flush_complete(struct lec_priv *priv, unsigned long tran_id);
static int lec_mcast_make(struct lec_priv *priv, struct atm_vcc *vcc);
static int lec_mcast_make(struct lec_priv *priv, struct atm_vcc *vcc);
static void lec_set_flush_tran_id(struct lec_priv *priv,
static void lec_set_flush_tran_id(struct lec_priv *priv,
				  const unsigned char *atm_addr,
				  const unsigned char *atm_addr,
				  unsigned long tran_id);
				  unsigned long tran_id);
static void lec_vcc_added(struct lec_priv *priv, const struct atmlec_ioc *ioc_data,
static void lec_vcc_added(struct lec_priv *priv,
			  const struct atmlec_ioc *ioc_data,
			  struct atm_vcc *vcc,
			  struct atm_vcc *vcc,
			  void (*old_push)(struct atm_vcc *vcc,
			  void (*old_push)(struct atm_vcc *vcc,
					   struct sk_buff *skb));
					   struct sk_buff *skb));
@@ -112,7 +114,6 @@ static inline void lec_arp_put(struct lec_arp_table *entry)
		kfree(entry);
		kfree(entry);
}
}



static struct lane2_ops lane2_ops = {
static struct lane2_ops lane2_ops = {
	lane2_resolve,		/* resolve,             spec 3.1.3 */
	lane2_resolve,		/* resolve,             spec 3.1.3 */
	lane2_associate_req,	/* associate_req,       spec 3.1.4 */
	lane2_associate_req,	/* associate_req,       spec 3.1.4 */
@@ -150,7 +151,8 @@ static void lec_handle_bridge(struct sk_buff *skb, struct net_device *dev)
		mesg = (struct atmlec_msg *)skb2->data;
		mesg = (struct atmlec_msg *)skb2->data;
		mesg->type = l_topology_change;
		mesg->type = l_topology_change;
		buff += 4;
		buff += 4;
		mesg->content.normal.flag = *buff & 0x01;	/* 0x01 is topology change */
		mesg->content.normal.flag = *buff & 0x01;
					/* 0x01 is topology change */


		priv = netdev_priv(dev);
		priv = netdev_priv(dev);
		atm_force_charge(priv->lecd, skb2->truesize);
		atm_force_charge(priv->lecd, skb2->truesize);
@@ -263,14 +265,10 @@ static netdev_tx_t lec_start_xmit(struct sk_buff *skb,
	unsigned char rdesc[ETH_ALEN];	/* Token Ring route descriptor */
	unsigned char rdesc[ETH_ALEN];	/* Token Ring route descriptor */
#endif
#endif
	int is_rdesc;
	int is_rdesc;
#if DUMP_PACKETS > 0
	char buf[300];
	int i = 0;
#endif /* DUMP_PACKETS >0 */


	pr_debug("called\n");
	pr_debug("called\n");
	if (!priv->lecd) {
	if (!priv->lecd) {
		printk("%s:No lecd attached\n", dev->name);
		pr_info("%s:No lecd attached\n", dev->name);
		dev->stats.tx_errors++;
		dev->stats.tx_errors++;
		netif_stop_queue(dev);
		netif_stop_queue(dev);
		kfree_skb(skb);
		kfree_skb(skb);
@@ -315,23 +313,17 @@ static netdev_tx_t lec_start_xmit(struct sk_buff *skb,
	}
	}
#endif
#endif


#if DUMP_PACKETS > 0
	printk("%s: send datalen:%ld lecid:%4.4x\n", dev->name,
	       skb->len, priv->lecid);
#if DUMP_PACKETS >= 2
#if DUMP_PACKETS >= 2
	for (i = 0; i < skb->len && i < 99; i++) {
#define MAX_DUMP_SKB 99
		sprintf(buf + i * 3, "%2.2x ", 0xff & skb->data[i]);
	}
#elif DUMP_PACKETS >= 1
#elif DUMP_PACKETS >= 1
	for (i = 0; i < skb->len && i < 30; i++) {
#define MAX_DUMP_SKB 30
		sprintf(buf + i * 3, "%2.2x ", 0xff & skb->data[i]);
#endif
	}
#if DUMP_PACKETS >= 1
	printk(KERN_DEBUG "%s: send datalen:%ld lecid:%4.4x\n",
	       dev->name, skb->len, priv->lecid);
	print_hex_dump(KERN_DEBUG, "", DUMP_OFFSET, 16, 1,
		       skb->data, min(skb->len, MAX_DUMP_SKB), true);
#endif /* DUMP_PACKETS >= 1 */
#endif /* DUMP_PACKETS >= 1 */
	if (i == skb->len)
		printk("%s\n", buf);
	else
		printk("%s...\n", buf);
#endif /* DUMP_PACKETS > 0 */


	/* Minimum ethernet-frame size */
	/* Minimum ethernet-frame size */
#ifdef CONFIG_TR
#ifdef CONFIG_TR
@@ -385,7 +377,8 @@ static netdev_tx_t lec_start_xmit(struct sk_buff *skb,
		goto out;
		goto out;
	}
	}
#if DUMP_PACKETS > 0
#if DUMP_PACKETS > 0
	printk("%s:sending to vpi:%d vci:%d\n", dev->name, vcc->vpi, vcc->vci);
	printk(KERN_DEBUG "%s:sending to vpi:%d vci:%d\n",
	       dev->name, vcc->vpi, vcc->vci);
#endif /* DUMP_PACKETS > 0 */
#endif /* DUMP_PACKETS > 0 */


	while (entry && (skb2 = skb_dequeue(&entry->tx_wait))) {
	while (entry && (skb2 = skb_dequeue(&entry->tx_wait))) {
@@ -442,14 +435,12 @@ static int lec_atm_send(struct atm_vcc *vcc, struct sk_buff *skb)
	pr_debug("%s: msg from zeppelin:%d\n", dev->name, mesg->type);
	pr_debug("%s: msg from zeppelin:%d\n", dev->name, mesg->type);
	switch (mesg->type) {
	switch (mesg->type) {
	case l_set_mac_addr:
	case l_set_mac_addr:
		for (i = 0; i < 6; i++) {
		for (i = 0; i < 6; i++)
			dev->dev_addr[i] = mesg->content.normal.mac_addr[i];
			dev->dev_addr[i] = mesg->content.normal.mac_addr[i];
		}
		break;
		break;
	case l_del_mac_addr:
	case l_del_mac_addr:
		for (i = 0; i < 6; i++) {
		for (i = 0; i < 6; i++)
			dev->dev_addr[i] = 0;
			dev->dev_addr[i] = 0;
		}
		break;
		break;
	case l_addr_delete:
	case l_addr_delete:
		lec_addr_delete(priv, mesg->content.normal.atm_addr,
		lec_addr_delete(priv, mesg->content.normal.atm_addr,
@@ -497,13 +488,14 @@ static int lec_atm_send(struct atm_vcc *vcc, struct sk_buff *skb)
		priv->flush_timeout = (mesg->content.config.flush_timeout * HZ);
		priv->flush_timeout = (mesg->content.config.flush_timeout * HZ);
		priv->path_switching_delay =
		priv->path_switching_delay =
		    (mesg->content.config.path_switching_delay * HZ);
		    (mesg->content.config.path_switching_delay * HZ);
		priv->lane_version = mesg->content.config.lane_version;	/* LANE2 */
		priv->lane_version = mesg->content.config.lane_version;
					/* LANE2 */
		priv->lane2_ops = NULL;
		priv->lane2_ops = NULL;
		if (priv->lane_version > 1)
		if (priv->lane_version > 1)
			priv->lane2_ops = &lane2_ops;
			priv->lane2_ops = &lane2_ops;
		if (dev_set_mtu(dev, mesg->content.config.mtu))
		if (dev_set_mtu(dev, mesg->content.config.mtu))
			printk("%s: change_mtu to %d failed\n", dev->name,
			pr_info("%s: change_mtu to %d failed\n",
			       mesg->content.config.mtu);
				dev->name, mesg->content.config.mtu);
		priv->is_proxy = mesg->content.config.is_proxy;
		priv->is_proxy = mesg->content.config.is_proxy;
		break;
		break;
	case l_flush_tran_id:
	case l_flush_tran_id:
@@ -531,8 +523,7 @@ static int lec_atm_send(struct atm_vcc *vcc, struct sk_buff *skb)


				pr_debug("%s: entry found, responding to zeppelin\n",
				pr_debug("%s: entry found, responding to zeppelin\n",
					 dev->name);
					 dev->name);
				skb2 =
				skb2 = alloc_skb(sizeof(struct atmlec_msg),
				    alloc_skb(sizeof(struct atmlec_msg),
						 GFP_ATOMIC);
						 GFP_ATOMIC);
				if (skb2 == NULL)
				if (skb2 == NULL)
					break;
					break;
@@ -548,7 +539,7 @@ static int lec_atm_send(struct atm_vcc *vcc, struct sk_buff *skb)
#endif /* defined(CONFIG_BRIDGE) || defined(CONFIG_BRIDGE_MODULE) */
#endif /* defined(CONFIG_BRIDGE) || defined(CONFIG_BRIDGE_MODULE) */
		break;
		break;
	default:
	default:
		printk("%s: Unknown message type %d\n", dev->name, mesg->type);
		pr_info("%s: Unknown message type %d\n", dev->name, mesg->type);
		dev_kfree_skb(skb);
		dev_kfree_skb(skb);
		return -EINVAL;
		return -EINVAL;
	}
	}
@@ -569,14 +560,13 @@ static void lec_atm_close(struct atm_vcc *vcc)
	lec_arp_destroy(priv);
	lec_arp_destroy(priv);


	if (skb_peek(&sk_atm(vcc)->sk_receive_queue))
	if (skb_peek(&sk_atm(vcc)->sk_receive_queue))
		printk("%s lec_atm_close: closing with messages pending\n",
		pr_info("%s closing with messages pending\n", dev->name);
		       dev->name);
	while ((skb = skb_dequeue(&sk_atm(vcc)->sk_receive_queue)) != NULL) {
	while ((skb = skb_dequeue(&sk_atm(vcc)->sk_receive_queue)) != NULL) {
		atm_return(vcc, skb->truesize);
		atm_return(vcc, skb->truesize);
		dev_kfree_skb(skb);
		dev_kfree_skb(skb);
	}
	}


	printk("%s: Shut down!\n", dev->name);
	pr_info("%s: Shut down!\n", dev->name);
	module_put(THIS_MODULE);
	module_put(THIS_MODULE);
}
}


@@ -605,9 +595,8 @@ send_to_lecd(struct lec_priv *priv, atmlec_msg_type type,
	struct sk_buff *skb;
	struct sk_buff *skb;
	struct atmlec_msg *mesg;
	struct atmlec_msg *mesg;


	if (!priv || !priv->lecd) {
	if (!priv || !priv->lecd)
		return -1;
		return -1;
	}
	skb = alloc_skb(sizeof(struct atmlec_msg), GFP_ATOMIC);
	skb = alloc_skb(sizeof(struct atmlec_msg), GFP_ATOMIC);
	if (!skb)
	if (!skb)
		return -1;
		return -1;
@@ -767,9 +756,8 @@ static void lec_push(struct atm_vcc *vcc, struct sk_buff *skb)
			dev_kfree_skb(skb);
			dev_kfree_skb(skb);
			return;
			return;
		}
		}
		if (!hlist_empty(&priv->lec_arp_empty_ones)) {
		if (!hlist_empty(&priv->lec_arp_empty_ones))
			lec_arp_check_empties(priv, vcc, skb);
			lec_arp_check_empties(priv, vcc, skb);
		}
		skb_pull(skb, 2);	/* skip lec_id */
		skb_pull(skb, 2);	/* skip lec_id */
#ifdef CONFIG_TR
#ifdef CONFIG_TR
		if (priv->is_trdev)
		if (priv->is_trdev)
@@ -816,7 +804,8 @@ static int lec_vcc_attach(struct atm_vcc *vcc, void __user *arg)
	if (ioc_data.dev_num < 0 || ioc_data.dev_num >= MAX_LEC_ITF ||
	if (ioc_data.dev_num < 0 || ioc_data.dev_num >= MAX_LEC_ITF ||
	    !dev_lec[ioc_data.dev_num])
	    !dev_lec[ioc_data.dev_num])
		return -EINVAL;
		return -EINVAL;
	if (!(vpriv = kmalloc(sizeof(struct lec_vcc_priv), GFP_KERNEL)))
	vpriv = kmalloc(sizeof(struct lec_vcc_priv), GFP_KERNEL);
	if (!vpriv)
		return -ENOMEM;
		return -ENOMEM;
	vpriv->xoff = 0;
	vpriv->xoff = 0;
	vpriv->old_pop = vcc->pop;
	vpriv->old_pop = vcc->pop;
@@ -907,9 +896,8 @@ static int lecd_attach(struct atm_vcc *vcc, int arg)
	priv->flush_timeout = (4 * HZ);
	priv->flush_timeout = (4 * HZ);
	priv->path_switching_delay = (6 * HZ);
	priv->path_switching_delay = (6 * HZ);


	if (dev_lec[i]->flags & IFF_UP) {
	if (dev_lec[i]->flags & IFF_UP)
		netif_start_queue(dev_lec[i]);
		netif_start_queue(dev_lec[i]);
	}
	__module_get(THIS_MODULE);
	__module_get(THIS_MODULE);
	return i;
	return i;
}
}
@@ -1111,7 +1099,9 @@ static int lec_seq_show(struct seq_file *seq, void *v)
	else {
	else {
		struct lec_state *state = seq->private;
		struct lec_state *state = seq->private;
		struct net_device *dev = state->dev;
		struct net_device *dev = state->dev;
		struct lec_arp_table *entry = hlist_entry(state->node, struct lec_arp_table, next);
		struct lec_arp_table *entry = hlist_entry(state->node,
							  struct lec_arp_table,
							  next);


		seq_printf(seq, "%s ", dev->name);
		seq_printf(seq, "%s ", dev->name);
		lec_info(seq, entry);
		lec_info(seq, entry);
@@ -1191,7 +1181,7 @@ static int __init lane_module_init(void)
#endif
#endif


	register_atm_ioctl(&lane_ioctl_ops);
	register_atm_ioctl(&lane_ioctl_ops);
	printk("lec.c: " __DATE__ " " __TIME__ " initialized\n");
	pr_info("lec.c: " __DATE__ " " __TIME__ " initialized\n");
	return 0;
	return 0;
}
}


@@ -1280,13 +1270,13 @@ static int lane2_associate_req(struct net_device *dev, const u8 *lan_dst,
	struct lec_priv *priv = netdev_priv(dev);
	struct lec_priv *priv = netdev_priv(dev);


	if (compare_ether_addr(lan_dst, dev->dev_addr))
	if (compare_ether_addr(lan_dst, dev->dev_addr))
		return (0);	/* not our mac address */
		return 0;	/* not our mac address */


	kfree(priv->tlvs);	/* NULL if there was no previous association */
	kfree(priv->tlvs);	/* NULL if there was no previous association */


	priv->tlvs = kmemdup(tlvs, sizeoftlvs, GFP_KERNEL);
	priv->tlvs = kmemdup(tlvs, sizeoftlvs, GFP_KERNEL);
	if (priv->tlvs == NULL)
	if (priv->tlvs == NULL)
		return (0);
		return 0;
	priv->sizeoftlvs = sizeoftlvs;
	priv->sizeoftlvs = sizeoftlvs;


	skb = alloc_skb(sizeoftlvs, GFP_ATOMIC);
	skb = alloc_skb(sizeoftlvs, GFP_ATOMIC);
@@ -1296,12 +1286,12 @@ static int lane2_associate_req(struct net_device *dev, const u8 *lan_dst,
	skb_copy_to_linear_data(skb, tlvs, sizeoftlvs);
	skb_copy_to_linear_data(skb, tlvs, sizeoftlvs);
	retval = send_to_lecd(priv, l_associate_req, NULL, NULL, skb);
	retval = send_to_lecd(priv, l_associate_req, NULL, NULL, skb);
	if (retval != 0)
	if (retval != 0)
		printk("lec.c: lane2_associate_req() failed\n");
		pr_info("lec.c: lane2_associate_req() failed\n");
	/*
	/*
	 * If the previous association has changed we must
	 * If the previous association has changed we must
	 * somehow notify other LANE entities about the change
	 * somehow notify other LANE entities about the change
	 */
	 */
	return (1);
	return 1;
}
}


/*
/*
@@ -1334,12 +1324,12 @@ static void lane2_associate_ind(struct net_device *dev, const u8 *mac_addr,
	entry->sizeoftlvs = sizeoftlvs;
	entry->sizeoftlvs = sizeoftlvs;
#endif
#endif
#if 0
#if 0
	printk("lec.c: lane2_associate_ind()\n");
	pr_info("\n");
	printk("dump of tlvs, sizeoftlvs=%d\n", sizeoftlvs);
	pr_info("dump of tlvs, sizeoftlvs=%d\n", sizeoftlvs);
	while (i < sizeoftlvs)
	while (i < sizeoftlvs)
		printk("%02x ", tlvs[i++]);
		pr_cont("%02x ", tlvs[i++]);


	printk("\n");
	pr_cont("\n");
#endif
#endif


	/* tell MPOA about the TLVs we saw */
	/* tell MPOA about the TLVs we saw */
@@ -1359,7 +1349,7 @@ static void lane2_associate_ind(struct net_device *dev, const u8 *mac_addr,


#include <linux/types.h>
#include <linux/types.h>
#include <linux/timer.h>
#include <linux/timer.h>
#include <asm/param.h>
#include <linux/param.h>
#include <asm/atomic.h>
#include <asm/atomic.h>
#include <linux/inetdevice.h>
#include <linux/inetdevice.h>
#include <net/route.h>
#include <net/route.h>
@@ -1390,9 +1380,8 @@ static void lec_arp_init(struct lec_priv *priv)
{
{
	unsigned short i;
	unsigned short i;


	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++)
		INIT_HLIST_HEAD(&priv->lec_arp_tables[i]);
		INIT_HLIST_HEAD(&priv->lec_arp_tables[i]);
	}
	INIT_HLIST_HEAD(&priv->lec_arp_empty_ones);
	INIT_HLIST_HEAD(&priv->lec_arp_empty_ones);
	INIT_HLIST_HEAD(&priv->lec_no_forward);
	INIT_HLIST_HEAD(&priv->lec_no_forward);
	INIT_HLIST_HEAD(&priv->mcast_fwds);
	INIT_HLIST_HEAD(&priv->mcast_fwds);
@@ -1449,20 +1438,23 @@ lec_arp_remove(struct lec_priv *priv, struct lec_arp_table *to_remove)
	struct lec_arp_table *entry;
	struct lec_arp_table *entry;
	int i, remove_vcc = 1;
	int i, remove_vcc = 1;


	if (!to_remove) {
	if (!to_remove)
		return -1;
		return -1;
	}


	hlist_del(&to_remove->next);
	hlist_del(&to_remove->next);
	del_timer(&to_remove->timer);
	del_timer(&to_remove->timer);


	/* If this is the only MAC connected to this VCC, also tear down the VCC */
	/*
	 * If this is the only MAC connected to this VCC,
	 * also tear down the VCC
	 */
	if (to_remove->status >= ESI_FLUSH_PENDING) {
	if (to_remove->status >= ESI_FLUSH_PENDING) {
		/*
		/*
		 * ESI_FLUSH_PENDING, ESI_FORWARD_DIRECT
		 * ESI_FLUSH_PENDING, ESI_FORWARD_DIRECT
		 */
		 */
		for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
			hlist_for_each_entry(entry, node, &priv->lec_arp_tables[i], next) {
			hlist_for_each_entry(entry, node,
					     &priv->lec_arp_tables[i], next) {
				if (memcmp(to_remove->atm_addr,
				if (memcmp(to_remove->atm_addr,
					   entry->atm_addr, ATM_ESA_LEN) == 0) {
					   entry->atm_addr, ATM_ESA_LEN) == 0) {
					remove_vcc = 0;
					remove_vcc = 0;
@@ -1493,9 +1485,8 @@ static const char *get_status_string(unsigned char st)
		return "ESI_FLUSH_PENDING";
		return "ESI_FLUSH_PENDING";
	case ESI_FORWARD_DIRECT:
	case ESI_FORWARD_DIRECT:
		return "ESI_FORWARD_DIRECT";
		return "ESI_FORWARD_DIRECT";
	default:
		return "<UNKNOWN>";
	}
	}
	return "<UNKNOWN>";
}
}


static void dump_arp_table(struct lec_priv *priv)
static void dump_arp_table(struct lec_priv *priv)
@@ -1505,17 +1496,14 @@ static void dump_arp_table(struct lec_priv *priv)
	char buf[256];
	char buf[256];
	int i, j, offset;
	int i, j, offset;


	printk("Dump %p:\n", priv);
	pr_info("Dump %p:\n", priv);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry(rulla, node, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry(rulla, node,
				     &priv->lec_arp_tables[i], next) {
			offset = 0;
			offset = 0;
			offset += sprintf(buf, "%d: %p\n", i, rulla);
			offset += sprintf(buf, "%d: %p\n", i, rulla);
			offset += sprintf(buf + offset, "Mac:");
			offset += sprintf(buf + offset, "Mac: %pM",
			for (j = 0; j < ETH_ALEN; j++) {
					  rulla->mac_addr);
				offset += sprintf(buf + offset,
						  "%2.2x ",
						  rulla->mac_addr[j] & 0xff);
			}
			offset += sprintf(buf + offset, " Atm:");
			offset += sprintf(buf + offset, " Atm:");
			for (j = 0; j < ATM_ESA_LEN; j++) {
			for (j = 0; j < ATM_ESA_LEN; j++) {
				offset += sprintf(buf + offset,
				offset += sprintf(buf + offset,
@@ -1536,19 +1524,15 @@ static void dump_arp_table(struct lec_priv *priv)
				    "Flags:%x, Packets_flooded:%x, Status: %s ",
				    "Flags:%x, Packets_flooded:%x, Status: %s ",
				    rulla->flags, rulla->packets_flooded,
				    rulla->flags, rulla->packets_flooded,
				    get_status_string(rulla->status));
				    get_status_string(rulla->status));
			printk("%s\n", buf);
			pr_info("%s\n", buf);
		}
		}
	}
	}


	if (!hlist_empty(&priv->lec_no_forward))
	if (!hlist_empty(&priv->lec_no_forward))
		printk("No forward\n");
		pr_info("No forward\n");
	hlist_for_each_entry(rulla, node, &priv->lec_no_forward, next) {
	hlist_for_each_entry(rulla, node, &priv->lec_no_forward, next) {
		offset = 0;
		offset = 0;
		offset += sprintf(buf + offset, "Mac:");
		offset += sprintf(buf + offset, "Mac: %pM", rulla->mac_addr);
		for (j = 0; j < ETH_ALEN; j++) {
			offset += sprintf(buf + offset, "%2.2x ",
					  rulla->mac_addr[j] & 0xff);
		}
		offset += sprintf(buf + offset, " Atm:");
		offset += sprintf(buf + offset, " Atm:");
		for (j = 0; j < ATM_ESA_LEN; j++) {
		for (j = 0; j < ATM_ESA_LEN; j++) {
			offset += sprintf(buf + offset, "%2.2x ",
			offset += sprintf(buf + offset, "%2.2x ",
@@ -1566,18 +1550,14 @@ static void dump_arp_table(struct lec_priv *priv)
				  "Flags:%x, Packets_flooded:%x, Status: %s ",
				  "Flags:%x, Packets_flooded:%x, Status: %s ",
				  rulla->flags, rulla->packets_flooded,
				  rulla->flags, rulla->packets_flooded,
				  get_status_string(rulla->status));
				  get_status_string(rulla->status));
		printk("%s\n", buf);
		pr_info("%s\n", buf);
	}
	}


	if (!hlist_empty(&priv->lec_arp_empty_ones))
	if (!hlist_empty(&priv->lec_arp_empty_ones))
		printk("Empty ones\n");
		pr_info("Empty ones\n");
	hlist_for_each_entry(rulla, node, &priv->lec_arp_empty_ones, next) {
	hlist_for_each_entry(rulla, node, &priv->lec_arp_empty_ones, next) {
		offset = 0;
		offset = 0;
		offset += sprintf(buf + offset, "Mac:");
		offset += sprintf(buf + offset, "Mac: %pM", rulla->mac_addr);
		for (j = 0; j < ETH_ALEN; j++) {
			offset += sprintf(buf + offset, "%2.2x ",
					  rulla->mac_addr[j] & 0xff);
		}
		offset += sprintf(buf + offset, " Atm:");
		offset += sprintf(buf + offset, " Atm:");
		for (j = 0; j < ATM_ESA_LEN; j++) {
		for (j = 0; j < ATM_ESA_LEN; j++) {
			offset += sprintf(buf + offset, "%2.2x ",
			offset += sprintf(buf + offset, "%2.2x ",
@@ -1595,18 +1575,14 @@ static void dump_arp_table(struct lec_priv *priv)
				  "Flags:%x, Packets_flooded:%x, Status: %s ",
				  "Flags:%x, Packets_flooded:%x, Status: %s ",
				  rulla->flags, rulla->packets_flooded,
				  rulla->flags, rulla->packets_flooded,
				  get_status_string(rulla->status));
				  get_status_string(rulla->status));
		printk("%s", buf);
		pr_info("%s", buf);
	}
	}


	if (!hlist_empty(&priv->mcast_fwds))
	if (!hlist_empty(&priv->mcast_fwds))
		printk("Multicast Forward VCCs\n");
		pr_info("Multicast Forward VCCs\n");
	hlist_for_each_entry(rulla, node, &priv->mcast_fwds, next) {
	hlist_for_each_entry(rulla, node, &priv->mcast_fwds, next) {
		offset = 0;
		offset = 0;
		offset += sprintf(buf + offset, "Mac:");
		offset += sprintf(buf + offset, "Mac: %pM", rulla->mac_addr);
		for (j = 0; j < ETH_ALEN; j++) {
			offset += sprintf(buf + offset, "%2.2x ",
					  rulla->mac_addr[j] & 0xff);
		}
		offset += sprintf(buf + offset, " Atm:");
		offset += sprintf(buf + offset, " Atm:");
		for (j = 0; j < ATM_ESA_LEN; j++) {
		for (j = 0; j < ATM_ESA_LEN; j++) {
			offset += sprintf(buf + offset, "%2.2x ",
			offset += sprintf(buf + offset, "%2.2x ",
@@ -1624,7 +1600,7 @@ static void dump_arp_table(struct lec_priv *priv)
				  "Flags:%x, Packets_flooded:%x, Status: %s ",
				  "Flags:%x, Packets_flooded:%x, Status: %s ",
				  rulla->flags, rulla->packets_flooded,
				  rulla->flags, rulla->packets_flooded,
				  get_status_string(rulla->status));
				  get_status_string(rulla->status));
		printk("%s\n", buf);
		pr_info("%s\n", buf);
	}
	}


}
}
@@ -1650,14 +1626,16 @@ static void lec_arp_destroy(struct lec_priv *priv)


	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry_safe(entry, node, next,
					  &priv->lec_arp_tables[i], next) {
			lec_arp_remove(priv, entry);
			lec_arp_remove(priv, entry);
			lec_arp_put(entry);
			lec_arp_put(entry);
		}
		}
		INIT_HLIST_HEAD(&priv->lec_arp_tables[i]);
		INIT_HLIST_HEAD(&priv->lec_arp_tables[i]);
	}
	}


	hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_empty_ones, next) {
	hlist_for_each_entry_safe(entry, node, next,
				  &priv->lec_arp_empty_ones, next) {
		del_timer_sync(&entry->timer);
		del_timer_sync(&entry->timer);
		lec_arp_clear_vccs(entry);
		lec_arp_clear_vccs(entry);
		hlist_del(&entry->next);
		hlist_del(&entry->next);
@@ -1665,7 +1643,8 @@ static void lec_arp_destroy(struct lec_priv *priv)
	}
	}
	INIT_HLIST_HEAD(&priv->lec_arp_empty_ones);
	INIT_HLIST_HEAD(&priv->lec_arp_empty_ones);


	hlist_for_each_entry_safe(entry, node, next, &priv->lec_no_forward, next) {
	hlist_for_each_entry_safe(entry, node, next,
				  &priv->lec_no_forward, next) {
		del_timer_sync(&entry->timer);
		del_timer_sync(&entry->timer);
		lec_arp_clear_vccs(entry);
		lec_arp_clear_vccs(entry);
		hlist_del(&entry->next);
		hlist_del(&entry->next);
@@ -1698,10 +1677,9 @@ static struct lec_arp_table *lec_arp_find(struct lec_priv *priv,


	head = &priv->lec_arp_tables[HASH(mac_addr[ETH_ALEN - 1])];
	head = &priv->lec_arp_tables[HASH(mac_addr[ETH_ALEN - 1])];
	hlist_for_each_entry(entry, node, head, next) {
	hlist_for_each_entry(entry, node, head, next) {
		if (!compare_ether_addr(mac_addr, entry->mac_addr)) {
		if (!compare_ether_addr(mac_addr, entry->mac_addr))
			return entry;
			return entry;
	}
	}
	}
	return NULL;
	return NULL;
}
}


@@ -1712,7 +1690,7 @@ static struct lec_arp_table *make_entry(struct lec_priv *priv,


	to_return = kzalloc(sizeof(struct lec_arp_table), GFP_ATOMIC);
	to_return = kzalloc(sizeof(struct lec_arp_table), GFP_ATOMIC);
	if (!to_return) {
	if (!to_return) {
		printk("LEC: Arp entry kmalloc failed\n");
		pr_info("LEC: Arp entry kmalloc failed\n");
		return NULL;
		return NULL;
	}
	}
	memcpy(to_return->mac_addr, mac_addr, ETH_ALEN);
	memcpy(to_return->mac_addr, mac_addr, ETH_ALEN);
@@ -1802,7 +1780,8 @@ static void lec_arp_check_expire(struct work_struct *work)
restart:
restart:
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry_safe(entry, node, next,
					  &priv->lec_arp_tables[i], next) {
			if ((entry->flags) & LEC_REMOTE_FLAG &&
			if ((entry->flags) & LEC_REMOTE_FLAG &&
			    priv->topology_change)
			    priv->topology_change)
				time_to_check = priv->forward_delay_time;
				time_to_check = priv->forward_delay_time;
@@ -1811,9 +1790,9 @@ static void lec_arp_check_expire(struct work_struct *work)


			pr_debug("About to expire: %lx - %lx > %lx\n",
			pr_debug("About to expire: %lx - %lx > %lx\n",
				 now, entry->last_used, time_to_check);
				 now, entry->last_used, time_to_check);
			if (time_after(now, entry->last_used + time_to_check)
			if (time_after(now, entry->last_used + time_to_check) &&
			    && !(entry->flags & LEC_PERMANENT_FLAG)
			    !(entry->flags & LEC_PERMANENT_FLAG) &&
			    && !(entry->mac_addr[0] & 0x01)) {	/* LANE2: 7.1.20 */
			    !(entry->mac_addr[0] & 0x01)) {	/* LANE2: 7.1.20 */
				/* Remove entry */
				/* Remove entry */
				pr_debug("Entry timed out\n");
				pr_debug("Entry timed out\n");
				lec_arp_remove(priv, entry);
				lec_arp_remove(priv, entry);
@@ -1821,11 +1800,10 @@ static void lec_arp_check_expire(struct work_struct *work)
			} else {
			} else {
				/* Something else */
				/* Something else */
				if ((entry->status == ESI_VC_PENDING ||
				if ((entry->status == ESI_VC_PENDING ||
				     entry->status == ESI_ARP_PENDING)
				     entry->status == ESI_ARP_PENDING) &&
				    && time_after_eq(now,
				    time_after_eq(now,
						  entry->timestamp +
						  entry->timestamp +
						     priv->
						  priv->max_unknown_frame_time)) {
						     max_unknown_frame_time)) {
					entry->timestamp = jiffies;
					entry->timestamp = jiffies;
					entry->packets_flooded = 0;
					entry->packets_flooded = 0;
					if (entry->status == ESI_VC_PENDING)
					if (entry->status == ESI_VC_PENDING)
@@ -1834,8 +1812,7 @@ static void lec_arp_check_expire(struct work_struct *work)
							     entry->atm_addr,
							     entry->atm_addr,
							     NULL);
							     NULL);
				}
				}
				if (entry->status == ESI_FLUSH_PENDING
				if (entry->status == ESI_FLUSH_PENDING &&
				    &&
				    time_after_eq(now, entry->timestamp +
				    time_after_eq(now, entry->timestamp +
						  priv->path_switching_delay)) {
						  priv->path_switching_delay)) {
					struct sk_buff *skb;
					struct sk_buff *skb;
@@ -1863,7 +1840,8 @@ static void lec_arp_check_expire(struct work_struct *work)
 *
 *
 */
 */
static struct atm_vcc *lec_arp_resolve(struct lec_priv *priv,
static struct atm_vcc *lec_arp_resolve(struct lec_priv *priv,
				       const unsigned char *mac_to_find, int is_rdesc,
				       const unsigned char *mac_to_find,
				       int is_rdesc,
				       struct lec_arp_table **ret_entry)
				       struct lec_arp_table **ret_entry)
{
{
	unsigned long flags;
	unsigned long flags;
@@ -1899,9 +1877,8 @@ static struct atm_vcc *lec_arp_resolve(struct lec_priv *priv,
		 * If the LE_ARP cache entry is still pending, reset count to 0
		 * If the LE_ARP cache entry is still pending, reset count to 0
		 * so another LE_ARP request can be made for this frame.
		 * so another LE_ARP request can be made for this frame.
		 */
		 */
		if (entry->status == ESI_ARP_PENDING) {
		if (entry->status == ESI_ARP_PENDING)
			entry->no_tries = 0;
			entry->no_tries = 0;
		}
		/*
		/*
		 * Data direct VC not yet set up, check to see if the unknown
		 * Data direct VC not yet set up, check to see if the unknown
		 * frame count is greater than the limit. If the limit has
		 * frame count is greater than the limit. If the limit has
@@ -1969,9 +1946,10 @@ lec_addr_delete(struct lec_priv *priv, const unsigned char *atm_addr,
	pr_debug("\n");
	pr_debug("\n");
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry_safe(entry, node, next,
			if (!memcmp(atm_addr, entry->atm_addr, ATM_ESA_LEN)
					  &priv->lec_arp_tables[i], next) {
			    && (permanent ||
			if (!memcmp(atm_addr, entry->atm_addr, ATM_ESA_LEN) &&
			    (permanent ||
			     !(entry->flags & LEC_PERMANENT_FLAG))) {
			     !(entry->flags & LEC_PERMANENT_FLAG))) {
				lec_arp_remove(priv, entry);
				lec_arp_remove(priv, entry);
				lec_arp_put(entry);
				lec_arp_put(entry);
@@ -2008,7 +1986,8 @@ lec_arp_update(struct lec_priv *priv, const unsigned char *mac_addr,
				 * we have no entry in the cache. 7.1.30
				 * we have no entry in the cache. 7.1.30
				 */
				 */
	if (!hlist_empty(&priv->lec_arp_empty_ones)) {
	if (!hlist_empty(&priv->lec_arp_empty_ones)) {
		hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_empty_ones, next) {
		hlist_for_each_entry_safe(entry, node, next,
					  &priv->lec_arp_empty_ones, next) {
			if (memcmp(entry->atm_addr, atm_addr, ATM_ESA_LEN) == 0) {
			if (memcmp(entry->atm_addr, atm_addr, ATM_ESA_LEN) == 0) {
				hlist_del(&entry->next);
				hlist_del(&entry->next);
				del_timer(&entry->timer);
				del_timer(&entry->timer);
@@ -2052,7 +2031,8 @@ lec_arp_update(struct lec_priv *priv, const unsigned char *mac_addr,
	memcpy(entry->atm_addr, atm_addr, ATM_ESA_LEN);
	memcpy(entry->atm_addr, atm_addr, ATM_ESA_LEN);
	del_timer(&entry->timer);
	del_timer(&entry->timer);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry(tmp, node, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry(tmp, node,
				     &priv->lec_arp_tables[i], next) {
			if (entry != tmp &&
			if (entry != tmp &&
			    !memcmp(tmp->atm_addr, atm_addr, ATM_ESA_LEN)) {
			    !memcmp(tmp->atm_addr, atm_addr, ATM_ESA_LEN)) {
				/* Vcc to this host exists */
				/* Vcc to this host exists */
@@ -2097,14 +2077,13 @@ lec_vcc_added(struct lec_priv *priv, const struct atmlec_ioc *ioc_data,
	int i, found_entry = 0;
	int i, found_entry = 0;


	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	if (ioc_data->receive == 2) {
	/* Vcc for Multicast Forward. No timer, LANEv2 7.1.20 and 2.3.5.3 */
	/* Vcc for Multicast Forward. No timer, LANEv2 7.1.20 and 2.3.5.3 */

	if (ioc_data->receive == 2) {
		pr_debug("LEC_ARP: Attaching mcast forward\n");
		pr_debug("LEC_ARP: Attaching mcast forward\n");
#if 0
#if 0
		entry = lec_arp_find(priv, bus_mac);
		entry = lec_arp_find(priv, bus_mac);
		if (!entry) {
		if (!entry) {
			printk("LEC_ARP: Multicast entry not found!\n");
			pr_info("LEC_ARP: Multicast entry not found!\n");
			goto out;
			goto out;
		}
		}
		memcpy(entry->atm_addr, ioc_data->atm_addr, ATM_ESA_LEN);
		memcpy(entry->atm_addr, ioc_data->atm_addr, ATM_ESA_LEN);
@@ -2163,7 +2142,8 @@ lec_vcc_added(struct lec_priv *priv, const struct atmlec_ioc *ioc_data,
		 ioc_data->atm_addr[16], ioc_data->atm_addr[17],
		 ioc_data->atm_addr[16], ioc_data->atm_addr[17],
		 ioc_data->atm_addr[18], ioc_data->atm_addr[19]);
		 ioc_data->atm_addr[18], ioc_data->atm_addr[19]);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry(entry, node, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry(entry, node,
				     &priv->lec_arp_tables[i], next) {
			if (memcmp
			if (memcmp
			    (ioc_data->atm_addr, entry->atm_addr,
			    (ioc_data->atm_addr, entry->atm_addr,
			     ATM_ESA_LEN) == 0) {
			     ATM_ESA_LEN) == 0) {
@@ -2247,14 +2227,16 @@ static void lec_flush_complete(struct lec_priv *priv, unsigned long tran_id)
restart:
restart:
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry(entry, node, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry(entry, node,
			if (entry->flush_tran_id == tran_id
				     &priv->lec_arp_tables[i], next) {
			    && entry->status == ESI_FLUSH_PENDING) {
			if (entry->flush_tran_id == tran_id &&
			    entry->status == ESI_FLUSH_PENDING) {
				struct sk_buff *skb;
				struct sk_buff *skb;
				struct atm_vcc *vcc = entry->vcc;
				struct atm_vcc *vcc = entry->vcc;


				lec_arp_hold(entry);
				lec_arp_hold(entry);
				spin_unlock_irqrestore(&priv->lec_arp_lock, flags);
				spin_unlock_irqrestore(&priv->lec_arp_lock,
						       flags);
				while ((skb = skb_dequeue(&entry->tx_wait)) != NULL)
				while ((skb = skb_dequeue(&entry->tx_wait)) != NULL)
					lec_send(vcc, skb);
					lec_send(vcc, skb);
				entry->last_used = jiffies;
				entry->last_used = jiffies;
@@ -2280,7 +2262,8 @@ lec_set_flush_tran_id(struct lec_priv *priv,


	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++)
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++)
		hlist_for_each_entry(entry, node, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry(entry, node,
				     &priv->lec_arp_tables[i], next) {
			if (!memcmp(atm_addr, entry->atm_addr, ATM_ESA_LEN)) {
			if (!memcmp(atm_addr, entry->atm_addr, ATM_ESA_LEN)) {
				entry->flush_tran_id = tran_id;
				entry->flush_tran_id = tran_id;
				pr_debug("Set flush transaction id to %lx for %p\n",
				pr_debug("Set flush transaction id to %lx for %p\n",
@@ -2300,7 +2283,8 @@ static int lec_mcast_make(struct lec_priv *priv, struct atm_vcc *vcc)
	struct lec_vcc_priv *vpriv;
	struct lec_vcc_priv *vpriv;
	int err = 0;
	int err = 0;


	if (!(vpriv = kmalloc(sizeof(struct lec_vcc_priv), GFP_KERNEL)))
	vpriv = kmalloc(sizeof(struct lec_vcc_priv), GFP_KERNEL);
	if (!vpriv)
		return -ENOMEM;
		return -ENOMEM;
	vpriv->xoff = 0;
	vpriv->xoff = 0;
	vpriv->old_pop = vcc->pop;
	vpriv->old_pop = vcc->pop;
@@ -2340,18 +2324,19 @@ static void lec_vcc_close(struct lec_priv *priv, struct atm_vcc *vcc)
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);


	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
	for (i = 0; i < LEC_ARP_TABLE_SIZE; i++) {
		hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_tables[i], next) {
		hlist_for_each_entry_safe(entry, node, next,
					  &priv->lec_arp_tables[i], next) {
			if (vcc == entry->vcc) {
			if (vcc == entry->vcc) {
				lec_arp_remove(priv, entry);
				lec_arp_remove(priv, entry);
				lec_arp_put(entry);
				lec_arp_put(entry);
				if (priv->mcast_vcc == vcc) {
				if (priv->mcast_vcc == vcc)
					priv->mcast_vcc = NULL;
					priv->mcast_vcc = NULL;
			}
			}
		}
		}
	}
	}
	}


	hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_empty_ones, next) {
	hlist_for_each_entry_safe(entry, node, next,
				  &priv->lec_arp_empty_ones, next) {
		if (entry->vcc == vcc) {
		if (entry->vcc == vcc) {
			lec_arp_clear_vccs(entry);
			lec_arp_clear_vccs(entry);
			del_timer(&entry->timer);
			del_timer(&entry->timer);
@@ -2360,7 +2345,8 @@ static void lec_vcc_close(struct lec_priv *priv, struct atm_vcc *vcc)
		}
		}
	}
	}


	hlist_for_each_entry_safe(entry, node, next, &priv->lec_no_forward, next) {
	hlist_for_each_entry_safe(entry, node, next,
				  &priv->lec_no_forward, next) {
		if (entry->recv_vcc == vcc) {
		if (entry->recv_vcc == vcc) {
			lec_arp_clear_vccs(entry);
			lec_arp_clear_vccs(entry);
			del_timer(&entry->timer);
			del_timer(&entry->timer);
@@ -2401,14 +2387,16 @@ lec_arp_check_empties(struct lec_priv *priv,
		src = hdr->h_source;
		src = hdr->h_source;


	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	spin_lock_irqsave(&priv->lec_arp_lock, flags);
	hlist_for_each_entry_safe(entry, node, next, &priv->lec_arp_empty_ones, next) {
	hlist_for_each_entry_safe(entry, node, next,
				  &priv->lec_arp_empty_ones, next) {
		if (vcc == entry->vcc) {
		if (vcc == entry->vcc) {
			del_timer(&entry->timer);
			del_timer(&entry->timer);
			memcpy(entry->mac_addr, src, ETH_ALEN);
			memcpy(entry->mac_addr, src, ETH_ALEN);
			entry->status = ESI_FORWARD_DIRECT;
			entry->status = ESI_FORWARD_DIRECT;
			entry->last_used = jiffies;
			entry->last_used = jiffies;
			/* We might have got an entry */
			/* We might have got an entry */
			if ((tmp = lec_arp_find(priv, src))) {
			tmp = lec_arp_find(priv, src);
			if (tmp) {
				lec_arp_remove(priv, tmp);
				lec_arp_remove(priv, tmp);
				lec_arp_put(tmp);
				lec_arp_put(tmp);
			}
			}