mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-31 14:04:26 -04:00 
			
		
		
		
	* properly format/comment all patches * merge debloat patches * merge Kconfig patches * merge swconfig patches * merge hotplug patches * drop 200-fix_localversion.patch - upstream * drop 222-arm_zimage_none.patch - unused * drop 252-mv_cesa_depends.patch - no longer required * drop 410-mtd-move-forward-declaration-of-struct-mtd_info.patch - unused * drop 661-fq_codel_keep_dropped_stats.patch - outdated * drop 702-phy_add_aneg_done_function.patch - upstream * drop 840-rtc7301.patch - unused * drop 841-rtc_pt7c4338.patch - upstream * drop 921-use_preinit_as_init.patch - unused * drop spio-gpio-old and gpio-mmc - unused Signed-off-by: John Crispin <john@phrozen.org>
		
			
				
	
	
		
			35 lines
		
	
	
		
			1023 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			1023 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From: Alexander Duyck <alexander.h.duyck@redhat.com>
 | |
| Date: Thu, 22 Jan 2015 15:51:33 -0800
 | |
| Subject: [PATCH] fib_trie: Use empty_children instead of counting empty nodes
 | |
|  in stats collection
 | |
| 
 | |
| It doesn't make much sense to count the pointers ourselves when
 | |
| empty_children already has a count for the number of NULL pointers stored
 | |
| in the tnode.  As such save ourselves the cycles and just use
 | |
| empty_children.
 | |
| 
 | |
| Signed-off-by: Alexander Duyck <alexander.h.duyck@redhat.com>
 | |
| Signed-off-by: David S. Miller <davem@davemloft.net>
 | |
| ---
 | |
| 
 | |
| --- a/net/ipv4/fib_trie.c
 | |
| +++ b/net/ipv4/fib_trie.c
 | |
| @@ -1954,16 +1954,10 @@ static void trie_collect_stats(struct tr
 | |
|  			hlist_for_each_entry_rcu(li, &n->list, hlist)
 | |
|  				++s->prefixes;
 | |
|  		} else {
 | |
| -			unsigned long i;
 | |
| -
 | |
|  			s->tnodes++;
 | |
|  			if (n->bits < MAX_STAT_DEPTH)
 | |
|  				s->nodesizes[n->bits]++;
 | |
| -
 | |
| -			for (i = tnode_child_length(n); i--;) {
 | |
| -				if (!rcu_access_pointer(n->child[i]))
 | |
| -					s->nullpointers++;
 | |
| -			}
 | |
| +			s->nullpointers += n->empty_children;
 | |
|  		}
 | |
|  	}
 | |
|  	rcu_read_unlock();
 |