mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-05 08:31:53 +00:00
Filter: value hashing
Added a code for computing hash of filter values. This is a split-commit of the neighboring aggregator branch with improved lvalue and attribute handling.
This commit is contained in:
parent
407eb388b7
commit
df5a08e7c7
@ -586,6 +586,75 @@ val_in_range(const struct f_val *v1, const struct f_val *v2)
|
|||||||
return F_CMP_ERROR;
|
return F_CMP_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint
|
||||||
|
val_hash(struct f_val *v)
|
||||||
|
{
|
||||||
|
u64 haux;
|
||||||
|
mem_hash_init(&haux);
|
||||||
|
mem_hash_mix_f_val(&haux, v);
|
||||||
|
return mem_hash_value(&haux);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
mem_hash_mix_f_val(u64 *h, struct f_val *v)
|
||||||
|
{
|
||||||
|
mem_hash_mix_num(h, v->type);
|
||||||
|
|
||||||
|
#define MX(k) mem_hash_mix(h, &IT(k), sizeof IT(k));
|
||||||
|
#define IT(k) v->val.k
|
||||||
|
|
||||||
|
switch (v->type)
|
||||||
|
{
|
||||||
|
case T_VOID:
|
||||||
|
break;
|
||||||
|
case T_INT:
|
||||||
|
case T_BOOL:
|
||||||
|
case T_PAIR:
|
||||||
|
case T_QUAD:
|
||||||
|
case T_ENUM:
|
||||||
|
MX(i);
|
||||||
|
break;
|
||||||
|
case T_EC:
|
||||||
|
case T_RD:
|
||||||
|
MX(ec);
|
||||||
|
break;
|
||||||
|
case T_LC:
|
||||||
|
MX(lc);
|
||||||
|
break;
|
||||||
|
case T_IP:
|
||||||
|
MX(ip);
|
||||||
|
break;
|
||||||
|
case T_NET:
|
||||||
|
mem_hash_mix_num(h, net_hash(IT(net)));
|
||||||
|
break;
|
||||||
|
case T_STRING:
|
||||||
|
mem_hash_mix_str(h, IT(s));
|
||||||
|
break;
|
||||||
|
case T_PATH_MASK:
|
||||||
|
mem_hash_mix(h, IT(path_mask), sizeof(*IT(path_mask)) + IT(path_mask)->len * sizeof (IT(path_mask)->item));
|
||||||
|
break;
|
||||||
|
case T_PATH:
|
||||||
|
case T_CLIST:
|
||||||
|
case T_ECLIST:
|
||||||
|
case T_LCLIST:
|
||||||
|
case T_BYTESTRING:
|
||||||
|
mem_hash_mix(h, IT(ad)->data, IT(ad)->length);
|
||||||
|
break;
|
||||||
|
case T_SET:
|
||||||
|
MX(t);
|
||||||
|
break;
|
||||||
|
case T_PREFIX_SET:
|
||||||
|
MX(ti);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case T_NONE:
|
||||||
|
case T_PATH_MASK_ITEM:
|
||||||
|
case T_ROUTE:
|
||||||
|
case T_ROUTES_BLOCK:
|
||||||
|
bug("Invalid type %s in f_val hashing", f_type_name(v->type));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* rte_format - format route information
|
* rte_format - format route information
|
||||||
*/
|
*/
|
||||||
|
@ -305,6 +305,9 @@ void val_format(const struct f_val *v, buffer *buf);
|
|||||||
char *val_format_str(struct linpool *lp, const struct f_val *v);
|
char *val_format_str(struct linpool *lp, const struct f_val *v);
|
||||||
const char *val_dump(const struct f_val *v);
|
const char *val_dump(const struct f_val *v);
|
||||||
|
|
||||||
|
uint val_hash(struct f_val *);
|
||||||
|
void mem_hash_mix_f_val(u64 *, struct f_val *);
|
||||||
|
|
||||||
static inline int val_is_ip4(const struct f_val *v)
|
static inline int val_is_ip4(const struct f_val *v)
|
||||||
{ return (v->type == T_IP) && ipa_is_ip4(v->val.ip); }
|
{ return (v->type == T_IP) && ipa_is_ip4(v->val.ip); }
|
||||||
int val_in_range(const struct f_val *v1, const struct f_val *v2);
|
int val_in_range(const struct f_val *v1, const struct f_val *v2);
|
||||||
|
Loading…
Reference in New Issue
Block a user