Page MenuHomeFreeBSD

syslogd: Only use peerlist during flag parsing
ClosedPublic

Authored by jfree on Aug 8 2023, 3:23 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Dec 28, 11:21 AM
Unknown Object (File)
Fri, Dec 27, 6:43 PM
Unknown Object (File)
Fri, Dec 27, 6:32 PM
Unknown Object (File)
Dec 13 2024, 3:17 AM
Unknown Object (File)
Dec 12 2024, 8:35 PM
Unknown Object (File)
Nov 29 2024, 8:23 AM
Unknown Object (File)
Nov 25 2024, 5:18 PM
Unknown Object (File)
Nov 23 2024, 11:40 PM
Subscribers

Details

Summary
Add logging sockets directly to the socklist, unless parsing flags. The
peerlist is still needed to temporarily hold socket information until
the configuration flags have been parsed.

It is tempting to remove the entire peerlist, but addsock() can not
determine if syslogd is in secure mode unless the flags have been
parsed.

Also, call pidfile_open() right after flag parsing so we can terminate
if another syslogd instance is already running.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

jfree requested review of this revision.Aug 8 2023, 3:23 PM
usr.sbin/syslogd/syslogd.c
514

Why does this have to be a macro?

This revision is now accepted and ready to land.Aug 11 2023, 2:49 PM
jfree retitled this revision from syslogd: Remove peerlist to syslogd: Only use peerlist during flag parsing.
jfree edited the summary of this revision. (Show Details)

Bring back peerlist -- see updated patch summary

This revision now requires review to proceed.Aug 20 2023, 10:14 PM

This diff is a bit on the large side. A few bits could have been split off into separate patches, e.g., changing the return type of allowaddr(). It can be tedious to split up patches, but it really does help when one has to read 20+ patches in a row. :) Just a general comment, I'm not asking you to split things further.

usr.sbin/syslogd/syslogd.c
500

style(9) discourages mixing declarations and initializations. The old code was ok.

3755

Can we make ai a pointer to const?

This revision is now accepted and ready to land.Aug 24 2023, 2:12 PM
usr.sbin/syslogd/syslogd.c
500

style(9) discourages mixing declarations and initializations. The old code was ok.

Maybe I am misinterpreting, but I don't think it discourages this...

"Variables may be initialized where declared especially when they are constant for the rest of the scope. Declarations may be placed before executable lines at the start of any block. Calls to complicated functions should be avoided when initializing variables."

The pe pointer value is constant for the remainder of the scope and I wouldn't call calloc() a particularly ambiguous or complex function.

usr.sbin/syslogd/syslogd.c
500

I read that as saying that calls to functions like device_get_softc(), which never fail, are ok, but function calls which require error handling or have side effects are not.

usr.sbin/syslogd/syslogd.c
500

I read that as saying that calls to functions like device_get_softc(), which never fail, are ok, but function calls which require error handling or have side effects are not.

Fair, that is a good way to approach it.

This revision was automatically updated to reflect the committed changes.