Skip to content

Commit

Permalink
lib: Warn operator when fd limit is set too large
Browse files Browse the repository at this point in the history
It's unlikely that an operator will ever set a fd
limit of over 100k.  Let's warn the operator that
things are in a bit of a wonky state.

Fixes: FRRouting#15280
Signed-off-by: Donald Sharp <[email protected]>
  • Loading branch information
donaldsharp committed Feb 2, 2024
1 parent a2caf2b commit d023a0c
Showing 1 changed file with 5 additions and 0 deletions.
5 changes: 5 additions & 0 deletions lib/event.c
Original file line number Diff line number Diff line change
Expand Up @@ -543,6 +543,7 @@ static void initializer(void)
pthread_key_create(&thread_current, NULL);
}

#define STUPIDLY_LARGE_FD_SIZE 100000
struct event_loop *event_master_create(const char *name)
{
struct event_loop *rv;
Expand All @@ -569,6 +570,10 @@ struct event_loop *event_master_create(const char *name)
rv->fd_limit = (int)limit.rlim_cur;
}

if (rv->fd_limit > STUPIDLY_LARGE_FD_SIZE)
zlog_warn("FD Limit set: %u is stupidly large. Is this what you intended? Consider using --limit-fds",
rv->fd_limit);

rv->read = XCALLOC(MTYPE_EVENT_POLL,
sizeof(struct event *) * rv->fd_limit);

Expand Down

0 comments on commit d023a0c

Please sign in to comment.