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

Revert "Adding a generic cork mechanism for events"

This reverts commit 6e841b3153.
This commit is contained in:
Maria Matejka 2022-07-28 19:22:48 +02:00
parent 6e841b3153
commit 03bf6b9087
6 changed files with 9 additions and 103 deletions

View File

@ -114,42 +114,17 @@ ev_send(event_list *l, event *e)
e->list = l; e->list = l;
struct event_cork *ec = e->cork; LOCK_DOMAIN(event, l->lock);
if (enlisted(&e->n))
uint ping = 0;
if (ec)
{ {
LOCK_DOMAIN(cork, ec->lock);
LOCK_DOMAIN(event, l->lock);
if (!enlisted(&e->n))
if (ec->count)
add_tail(&ec->events, &e->n);
else
{
add_tail(&l->events, &e->n);
ping = 1;
}
UNLOCK_DOMAIN(event, l->lock);
UNLOCK_DOMAIN(cork, ec->lock);
}
else
{
LOCK_DOMAIN(event, l->lock);
if (!enlisted(&e->n))
{
add_tail(&l->events, &e->n);
ping = 1;
}
UNLOCK_DOMAIN(event, l->lock); UNLOCK_DOMAIN(event, l->lock);
return;
} }
if (ping) add_tail(&l->events, &e->n);
birdloop_ping(l->loop); UNLOCK_DOMAIN(event, l->lock);
birdloop_ping(l->loop);
} }
void io_log_event(void *hook, void *data); void io_log_event(void *hook, void *data);
@ -249,40 +224,3 @@ ev_run_list_limited(event_list *l, uint limit)
return repeat; return repeat;
} }
void ev_cork(struct event_cork *ec)
{
LOCK_DOMAIN(cork, ec->lock);
ec->count++;
UNLOCK_DOMAIN(cork, ec->lock);
}
void ev_uncork(struct event_cork *ec)
{
LOCK_DOMAIN(cork, ec->lock);
if (--ec->count)
{
UNLOCK_DOMAIN(cork, ec->lock);
return;
}
node *n;
WALK_LIST_FIRST(n, ec->events)
{
event *e = SKIP_BACK(event, n, n);
event_list *el = e->list;
rem_node(&e->n);
LOCK_DOMAIN(event, el->lock);
add_tail(&el->events, &e->n);
UNLOCK_DOMAIN(event, el->lock);
birdloop_ping(el->loop);
}
UNLOCK_DOMAIN(cork, ec->lock);
birdloop_ping(&main_birdloop);
}

View File

@ -15,7 +15,6 @@
#include <stdatomic.h> #include <stdatomic.h>
DEFINE_DOMAIN(event); DEFINE_DOMAIN(event);
DEFINE_DOMAIN(cork);
typedef struct event { typedef struct event {
resource r; resource r;
@ -23,8 +22,6 @@ typedef struct event {
void *data; void *data;
node n; /* Internal link */ node n; /* Internal link */
struct event_list *list; /* List where this event is put in */ struct event_list *list; /* List where this event is put in */
struct event_cork *cork; /* Event execution limiter */
node cork_node;
} event; } event;
typedef struct event_list { typedef struct event_list {
@ -34,12 +31,6 @@ typedef struct event_list {
DOMAIN(event) lock; DOMAIN(event) lock;
} event_list; } event_list;
struct event_cork {
DOMAIN(cork) lock;
u32 count;
list events;
};
extern event_list global_event_list; extern event_list global_event_list;
extern event_list global_work_list; extern event_list global_work_list;
@ -53,13 +44,6 @@ static inline void ev_init_list(event_list *el, struct birdloop *loop, const cha
el->lock = DOMAIN_NEW(event, name); el->lock = DOMAIN_NEW(event, name);
} }
static inline void ev_init_cork(struct event_cork *ec, const char *name)
{
init_list(&ec->events);
ec->lock = DOMAIN_NEW(cork, name);
ec->count = 0;
};
void ev_send(event_list *, event *); void ev_send(event_list *, event *);
#define ev_send_loop(l, e) ev_send(birdloop_event_list((l)), (e)) #define ev_send_loop(l, e) ev_send(birdloop_event_list((l)), (e))
@ -72,20 +56,6 @@ int ev_run_list_limited(event_list *, uint);
#define LEGACY_EVENT_LIST(l) (((l) == &global_event_list) || ((l) == &global_work_list)) #define LEGACY_EVENT_LIST(l) (((l) == &global_event_list) || ((l) == &global_work_list))
void ev_cork(struct event_cork *);
void ev_uncork(struct event_cork *);
static inline u32 ev_corked(struct event_cork *ec)
{
if (!ec)
return 0;
LOCK_DOMAIN(cork, ec->lock);
u32 out = ec->count;
UNLOCK_DOMAIN(cork, ec->lock);
return out;
}
_Bool birdloop_inside(struct birdloop *loop); _Bool birdloop_inside(struct birdloop *loop);
static inline int static inline int

View File

@ -16,7 +16,6 @@ struct lock_order {
struct domain_generic *the_bird; struct domain_generic *the_bird;
struct domain_generic *proto; struct domain_generic *proto;
struct domain_generic *rtable; struct domain_generic *rtable;
struct domain_generic *cork;
struct domain_generic *event; struct domain_generic *event;
}; };

View File

@ -57,7 +57,6 @@ typedef struct birdsock {
uint fast_rx; /* RX has higher priority in event loop */ uint fast_rx; /* RX has higher priority in event loop */
uint rbsize; uint rbsize;
int (*rx_hook)(struct birdsock *, uint size); /* NULL=receiving turned off, returns 1 to clear rx buffer */ int (*rx_hook)(struct birdsock *, uint size); /* NULL=receiving turned off, returns 1 to clear rx buffer */
struct event_cork *cork; /* Cork to temporarily stop receiving data */
byte *tbuf, *tpos; /* NULL=allocate automatically */ byte *tbuf, *tpos; /* NULL=allocate automatically */
byte *ttx; /* Internal */ byte *ttx; /* Internal */

View File

@ -205,7 +205,7 @@ sk_stop(sock *s)
} }
static inline uint sk_want_events(sock *s) static inline uint sk_want_events(sock *s)
{ return ((s->rx_hook && !ev_corked(s->cork)) ? POLLIN : 0) | ((s->ttx != s->tpos) ? POLLOUT : 0); } { return (s->rx_hook ? POLLIN : 0) | ((s->ttx != s->tpos) ? POLLOUT : 0); }
/* /*
FIXME: this should be called from sock code FIXME: this should be called from sock code

View File

@ -2234,7 +2234,7 @@ io_loop(void)
{ {
pfd[nfds] = (struct pollfd) { .fd = -1 }; /* everything other set to 0 by this */ pfd[nfds] = (struct pollfd) { .fd = -1 }; /* everything other set to 0 by this */
s = SKIP_BACK(sock, n, n); s = SKIP_BACK(sock, n, n);
if (s->rx_hook && !ev_corked(s->cork)) if (s->rx_hook)
{ {
pfd[nfds].fd = s->fd; pfd[nfds].fd = s->fd;
pfd[nfds].events |= POLLIN; pfd[nfds].events |= POLLIN;