0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-02 15:11:53 +00:00

Nest: Fix handling of 64-bit rte_src.private_id

The commit 21213be523 expanded private_id
in route source to u64, but forgot to modify function arguments, so it
was still cropped at 32-bit, which may cause some collisions for L3VPN.
This patch fixes that.
This commit is contained in:
Ondrej Zajicek 2024-12-17 09:00:42 +01:00
parent 7e65bb83c7
commit 8d062e9312
2 changed files with 4 additions and 4 deletions

View File

@ -593,8 +593,8 @@ typedef struct ea_list {
#define EALF_BISECT 2 /* Use interval bisection for searching */ #define EALF_BISECT 2 /* Use interval bisection for searching */
#define EALF_CACHED 4 /* Attributes belonging to cached rta */ #define EALF_CACHED 4 /* Attributes belonging to cached rta */
struct rte_src *rt_find_source(struct proto *p, u32 id); struct rte_src *rt_find_source(struct proto *p, u64 id);
struct rte_src *rt_get_source(struct proto *p, u32 id); struct rte_src *rt_get_source(struct proto *p, u64 id);
static inline void rt_lock_source(struct rte_src *src) { src->uc++; } static inline void rt_lock_source(struct rte_src *src) { src->uc++; }
static inline void rt_unlock_source(struct rte_src *src) { src->uc--; } static inline void rt_unlock_source(struct rte_src *src) { src->uc--; }
void rt_prune_sources(void); void rt_prune_sources(void);

View File

@ -124,13 +124,13 @@ rte_src_init(void)
HASH_DEFINE_REHASH_FN(RSH, struct rte_src) HASH_DEFINE_REHASH_FN(RSH, struct rte_src)
struct rte_src * struct rte_src *
rt_find_source(struct proto *p, u32 id) rt_find_source(struct proto *p, u64 id)
{ {
return HASH_FIND(src_hash, RSH, p, id); return HASH_FIND(src_hash, RSH, p, id);
} }
struct rte_src * struct rte_src *
rt_get_source(struct proto *p, u32 id) rt_get_source(struct proto *p, u64 id)
{ {
struct rte_src *src = rt_find_source(p, id); struct rte_src *src = rt_find_source(p, id);