0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-03 07:31:54 +00:00

RCU Unwinder can now retry without yielding

This commit is contained in:
Maria Matejka 2024-06-06 13:32:31 +02:00
parent 4104d668d9
commit 7c59ef3faa

View File

@ -494,7 +494,8 @@ static inline void locking_unwind(struct lock_order *desired)
struct rcu_unwinder { struct rcu_unwinder {
struct lock_order locking_stack; struct lock_order locking_stack;
u64 retry; u32 retry;
u8 fast;
jmp_buf buf; jmp_buf buf;
}; };
@ -511,15 +512,20 @@ static inline void _rcu_unwinder_unlock_(struct rcu_unwinder *o UNUSED)
if (setjmp(_i->buf)) { \ if (setjmp(_i->buf)) { \
rcu_read_unlock(); \ rcu_read_unlock(); \
locking_unwind(&_i->locking_stack); \ locking_unwind(&_i->locking_stack); \
birdloop_yield(); \ if (_i->fast) _i->fast = 0; \
if (!(++_i->retry % RCU_UNWIND_WARN)) \ else { \
log(L_WARN "Suspiciously many RCU_ANCHORs retried (%lu)" \ birdloop_yield(); \
" at %s:%d", _i->retry, __FILE__, __LINE__); \ if (!(++_i->retry % RCU_UNWIND_WARN)) \
log(L_WARN "Suspiciously many RCU_ANCHORs retried (%lu)" \
" at %s:%d", _i->retry, __FILE__, __LINE__); \
} \
} \ } \
_i->locking_stack = locking_stack; \ _i->locking_stack = locking_stack; \
rcu_read_lock(); \ rcu_read_lock(); \
#define RCU_RETRY(_i) do { if (_i) longjmp(_i->buf, 1); else bug("No rcu retry allowed here"); } while (0) #define RCU_RETRY(_i) do { if (_i) longjmp(_i->buf, 1); else bug("No rcu retry allowed here"); } while (0)
#define RCU_RETRY_FAST(_i) do { (_i)->fast++; RCU_RETRY(_i); } while (0)
#define RCU_WONT_RETRY ((struct rcu_unwinder *) NULL) #define RCU_WONT_RETRY ((struct rcu_unwinder *) NULL)
#endif #endif