mirror of
				https://github.com/openvswitch/ovs
				synced 2025-10-21 14:49:41 +00:00 
			
		
		
		
	tag: Be more precise about choosing tags to add, in tag_set_add().
It is not necessary to add a "tag" if all of the bits in it are already present in some member of the set. This commit adds that optimization.
This commit is contained in:
		
							
								
								
									
										27
									
								
								lib/tag.c
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								lib/tag.c
									
									
									
									
									
								
							| @@ -61,11 +61,36 @@ tag_set_init(struct tag_set *set) | |||||||
|     memset(set, 0, sizeof *set); |     memset(set, 0, sizeof *set); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static bool | ||||||
|  | tag_is_worth_adding(const struct tag_set *set, tag_type tag) | ||||||
|  | { | ||||||
|  |     if (!tag) { | ||||||
|  |         /* Nothing to add. */ | ||||||
|  |         return false; | ||||||
|  |     } else if ((set->total & tag) != tag) { | ||||||
|  |         /* 'set' doesn't have all the bits in 'tag', so we need to add it. */ | ||||||
|  |         return true; | ||||||
|  |     } else { | ||||||
|  |         /* We can drop it if some member of 'set' already includes all of the | ||||||
|  |          * 1-bits in 'tag'.  (tag_set_intersects() does a different test: | ||||||
|  |          * whether some member of 'set' has at least two 1-bit in common with | ||||||
|  |          * 'tag'.) */ | ||||||
|  |         int i; | ||||||
|  |  | ||||||
|  |         for (i = 0; i < TAG_SET_SIZE; i++) { | ||||||
|  |             if ((set->tags[i] & tag) == tag) { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| /* Adds 'tag' to 'set'. */ | /* Adds 'tag' to 'set'. */ | ||||||
| void | void | ||||||
| tag_set_add(struct tag_set *set, tag_type tag) | tag_set_add(struct tag_set *set, tag_type tag) | ||||||
| { | { | ||||||
|     if (tag && (!tag_is_valid(tag) || !tag_set_intersects(set, tag))) { |     if (tag_is_worth_adding(set, tag)) { | ||||||
|         /* XXX We could do better by finding the set member to which we would |         /* XXX We could do better by finding the set member to which we would | ||||||
|          * add the fewest number of 1-bits.  This would reduce the amount of |          * add the fewest number of 1-bits.  This would reduce the amount of | ||||||
|          * ambiguity, since e.g. three 1-bits match 3 * 2 / 2 = 3 unique tags |          * ambiguity, since e.g. three 1-bits match 3 * 2 / 2 = 3 unique tags | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user