#
267654 |
|
19-Jun-2014 |
gjb |
Copy stable/9 to releng/9.3 as part of the 9.3-RELEASE cycle.
Approved by: re (implicit) Sponsored by: The FreeBSD Foundation |
#
261813 |
|
12-Feb-2014 |
jilles |
MFC r241046: libc: Use O_CLOEXEC for various internal file descriptors.
This fixes a race condition where another thread may fork(), unintentionally passing the descriptor to the child process.
This commit only adds O_CLOEXEC flags to open() or openat() calls where no fcntl(fd, F_SETFD, FD_CLOEXEC) follows.
|
#
237973 |
|
02-Jul-2012 |
obrien |
MFC: r228193: tweak the r137233 fix to r136283 -- Code was making two send() attempts vs. the comment documented "If we are working with a privileged socket, then take only one attempt". Make the code match.
|
#
237632 |
|
27-Jun-2012 |
eadler |
MFC r237286, r237523: Don't close an uninitialized descriptor.
PR: bin/167302 Approved by: cperciva (implicit)
|
#
225736 |
|
22-Sep-2011 |
kensmith |
Copy head to stable/9 as part of 9.0-RELEASE release cycle.
Approved by: re (implicit)
|
#
220157 |
|
30-Mar-2011 |
pluknet |
Use FD_CLOEXEC explicitly.
MFC after: 3 days
|
#
165903 |
|
08-Jan-2007 |
imp |
Per Regents of the University of Calfornia letter, remove advertising clause.
# If I've done so improperly on a file, please let me know.
|
#
161053 |
|
07-Aug-2006 |
phk |
Return length from fwopen() file callback instead of zero.
The symptom is that syslog() fails to log anything but the "ident" string if LOG_PERROR is specified to openlog(3) and the extensible printf is in action.
For unclear, likely quaint historical reasons, syslog uses fwopen() on a stack buffer, rather than using the more straightforward and faster snprintf().
Along the way, fflush(3) is called, and since the callback writer function returns zero instead of the length "written", __SERR naturally gets set on the filedescriptor.
The extensible printf, in difference from the normal printf refuses to output anything to an __SERR marked filedescriptor, and thus the actual syslog message is supressed.
MFC: after 2 weeks
|
#
158426 |
|
11-May-2006 |
davidxu |
Save errno before calling pthread_mutex_lock because pthread_mutex_lock may change errno unexpectly.
|
#
148657 |
|
02-Aug-2005 |
deischen |
Make syslog() use the internal (non-cancellation point) _usleep(). Prior to this it was calling the cancellable usleep() while holding a lock.
|
#
144815 |
|
08-Apr-2005 |
stefanf |
Use prototypes in the function definitions.
|
#
139440 |
|
30-Dec-2004 |
glebius |
Make syslog(3) thread safe.
PR: bin/72394 Submitted by: Dan Nelson Reviewed by: deischen MFC after: 2 weeks
|
#
139256 |
|
24-Dec-2004 |
glebius |
Restore standard behavior: log to console only when normal logging failed, not always.
PR: bin/75356 Submitted by: Mark Knight <markk knigma org> Pointy hat to: glebius MFC after: 3 days
|
#
137233 |
|
04-Nov-2004 |
glebius |
Protect against local flooder of /var/run/log. Do not loop forever in syslog(3) if we are a priveleged program (sshd, su, etc.).
- Make syslogd open an additional socket /var/run/logpriv, with 0600 permissions. - In libc, try to use this socket. - Do not loop forever if we are using this socket (partial backout of 1.31)
Reviewed by: dwmalone, Andrea Campi <andrea webcom it> Approved by: julian (mentor) MFC after: 1 month
|
#
136283 |
|
08-Oct-2004 |
glebius |
When send()ing to syslogd return ENOBUFS keep trying until success.
This fixes a case, when DoSed syslogd completely loses messages.
PR: bin/72366 Discussed with: dwmalone, millert@OpenBSD.org Approved by: julian (mentor) Obtained from: OpenBSD (rev. 1.17, 1.21 by millert) MFC after: 3 months
|
#
129091 |
|
10-May-2004 |
dds |
Remove a trailing newline, to behave as documented in syslog(3): "A trailing newline is added if none is present."
The code in syslogd, stderr, and console output always adds a newline at the EOL. However, the existing code never actually removed a trailing newline, and apparently relied on syslogd to convert it into a space character. Thus, the existing newline was converted to a trailing space at the EOL by syslogd, while stderr, and console output resulted in an empty line.
MFC after: 2 weeks
|
#
110635 |
|
10-Feb-2003 |
alfred |
Handle %%m properly in syslog format string. Previously it would expand the %m into the errno and then vfprintf would expand the % and the first character of the strerror(3) return causing possible data corruption.
|
#
106911 |
|
14-Nov-2002 |
ru |
Reset LogTag to NULL in closelog(3). This fixes mysterious crashes caused by dynamic PAM modules that call openlog(3) and closelog(3), e.g. ports/security/pam_pwdfile.
What happened here is that the module first registered its "ident" with openlog(3), then PAM library unloaded module with dlclose(3), and the next call to syslog(3) resulted in SIGSEGV.
MFC after: 3 days
|
#
97407 |
|
28-May-2002 |
alfred |
Assume __STDC__, remove non-__STDC__ code.
Submitted by: keramida
|
#
93399 |
|
29-Mar-2002 |
markm |
Do not use __progname directly (except in [gs]etprogname(3)). Also, make an internal _getprogname() that is used only inside libc. For libc, getprogname(3) is a weak symbol in case a function of the same name is defined in userland.
|
#
91940 |
|
09-Mar-2002 |
dwmalone |
If syslog fails to talk to syslogd, then it tries to write a message to the console in a final attempt to log something. Make this final attempt non-blocking so that a blocking console doesn't end up blocking process which attempt to syslog something.
In particular, this means you should be able to su and fix the problem if the console becomes blocking.
MFC after: 3 weeks
|
#
90045 |
|
31-Jan-2002 |
obrien |
* Remove __P and convert to ANSI prototypes. * Remove 'register'. (some functions had 7+ register functions...) * Fix SCM ID's.
|
#
89805 |
|
25-Jan-2002 |
dwmalone |
Use ctime_r to build the timestamp for syslog, so that we don't clobber a ctime buffer which is passed in.
PR: 34022 Submitted by: Hartmut Brandt <brandt@fokus.gmd.de> MFC after: 2 weeks
|
#
71579 |
|
24-Jan-2001 |
deischen |
Remove _THREAD_SAFE and make libc thread-safe by default by adding (weak definitions to) stubs for some of the pthread functions. If the threads library is linked in, the real pthread functions will pulled in.
Use the following convention for system calls wrapped by the threads library: __sys_foo - actual system call _foo - weak definition to __sys_foo foo - weak definition to __sys_foo
Change all libc uses of system calls wrapped by the threads library from foo to _foo. In order to define the prototypes for _foo(), we introduce namespace.h and un-namespace.h (suggested by bde). All files that need to reference these system calls, should include namespace.h before any standard includes, then include un-namespace.h after the standard includes and before any local includes. <db.h> is an exception and shouldn't be included in between namespace.h and un-namespace.h namespace.h will define foo to _foo, and un-namespace.h will undefine foo.
Try to eliminate some of the recursive calls to MT-safe functions in libc/stdio in preparation for adding a mutex to FILE. We have recursive mutexes, but would like to avoid using them if possible.
Remove uneeded includes of <errno.h> from a few files.
Add $FreeBSD$ to a few files in order to pass commitprep.
Approved by: -arch
|
#
56698 |
|
27-Jan-2000 |
jasone |
Simplify sytem call renaming. Instead of _foo() <-- _libc_foo <-- foo(), just use _foo() <-- foo(). In the case of a libpthread that doesn't do call conversion (such as linuxthreads and our upcoming libpthread), this is adequate. In the case of libc_r, we still need three names, which are now _thread_sys_foo() <-- _foo() <-- foo().
Convert all internal libc usage of: aio_suspend(), close(), fsync(), msync(), nanosleep(), open(), fcntl(), read(), and write() to _foo() instead of foo().
Remove all internal libc usage of: creat(), pause(), sleep(), system(), tcdrain(), wait(), and waitpid().
Make thread cancellation fully POSIX-compliant.
Suggested by: deischen
|
#
55837 |
|
12-Jan-2000 |
jasone |
Add three-tier symbol naming in support of POSIX thread cancellation points. For library functions, the pattern is __sleep() <-- _libc_sleep() <-- sleep(). The arrows represent weak aliases. For system calls, the pattern is _read() <-- _libc_read() <-- read().
|
#
50476 |
|
27-Aug-1999 |
peter |
$Id$ -> $FreeBSD$
|
#
35607 |
|
01-May-1998 |
brian |
Go back to version 1.16 - it was correct the way it was. Pointed out by: bde
|
#
35570 |
|
30-Apr-1998 |
brian |
connect() returns -1 on error - not 0.
|
#
34075 |
|
06-Mar-1998 |
brian |
We don't need to NUL terminate our sun_path. Pointed out by: Garrett Wollman <wollman@khavrinen.lcs.mit.edu>
|
#
34072 |
|
06-Mar-1998 |
brian |
Nul terminate sockaddr_un::sun_path Suggested by: Theo de Raadt <deraadt@openbsd.org>
|
#
34059 |
|
05-Mar-1998 |
brian |
Make SyslogAddr a sockaddr_un rather than a sockaddr. This wasn't a problem in practice as PATH_LOG and PATH_OLDLOG are both < sizeof sockaddr::sa_data.
|
#
24068 |
|
20-Mar-1997 |
jdp |
Add backward compatibility so that static executables built on modern FreeBSD systems will syslog properly on older systems that still name the logging socket "/dev/log". This includes pre-2.2 versions of FreeBSD as well as BSD/OS systems. If the connect to "/var/run/log" fails, the function now tries to connect to "/dev/log" as a fallback.
|
#
23668 |
|
11-Mar-1997 |
peter |
Merge from Lite2: filesystem include updates, duplicate group suppression, cleanups, filesystem whiteout support (unionfs), bidir popen().
|
#
22993 |
|
22-Feb-1997 |
peter |
Revert $FreeBSD$ to $Id$
|
#
21673 |
|
14-Jan-1997 |
jkh |
Make the long-awaited change from $Id$ to $FreeBSD$
This will make a number of things easier in the future, as well as (finally!) avoiding the Id-smashing problem which has plagued developers for so long.
Boy, I'm glad we're not using sup anymore. This update would have been insane otherwise.
|
#
17141 |
|
12-Jul-1996 |
jkh |
General -Wall warning cleanup, part I. Submitted-By: Kent Vander Velden <graphix@iastate.edu>
|
#
14332 |
|
02-Mar-1996 |
peter |
If the send() to the AF_UNIX socket to the syslogd fails, attempt to reconnect once using the saved openlog() parameters.
This helps one of the system startup race conditions. If syslogd takes too long to get going, some daemons can fail the connection and forever log to the console even though the syslogd is running. That is ..unfortunate..
|
#
11659 |
|
22-Oct-1995 |
phk |
Minor cleanup, mostly unused vars and missing #includes.
|
#
11606 |
|
21-Oct-1995 |
peter |
Add $Id$ since this version of the file has diverged from the BSD base a fair bit. I forgot to add it when I made the fixes some time ago.
|
#
11192 |
|
04-Oct-1995 |
peter |
Fix the problem that I aroused with the last commit..
What was happening, is if syslogd was not running, syslog() would do a strcat("\r\n") on a non-null-terminated buffer, and write it to the console.
This meant that sometimes extra characters could be written to the console during boot, depending on the stack contents.
This totally avoids the potential problem by using writev() like the rest of the does, and avoid modifying the buffer after the trouble we've gone to to carefully protect it.
This is actually a trivial fix, in spite of the long commit message.. :-) It only appeared during boot and shutdown with syslogd stopped.
|
#
10794 |
|
15-Sep-1995 |
peter |
Fix security bugs with a "new approach", using stdio's powerful buffer control hooks. It is similar to an unrolled multi-part snprintf(), in that a "FILE *" is attached to a string buffer. There is also an optimisation for the case where the syslog format string does not contain %m, which should improve performance of "informational" logging, like from ftpd.
|
#
10414 |
|
29-Aug-1995 |
ache |
National date/time representation in syslog logfiles looks ugly, change strftime to ctime. Logfiles must have default (english) date/time representation for access/view from various places.
|
#
8226 |
|
02-May-1995 |
ache |
Fix bracket error for LogMask Submitted by: Ruslan Belkin <rus@home2.UA.net>
|
#
1574 |
|
27-May-1994 |
rgrimes |
This commit was generated by cvs2svn to compensate for changes in r1573, which included commits to RCS files with non-trunk default branches.
|
#
1573 |
|
27-May-1994 |
rgrimes |
BSD 4.4 Lite Lib Sources
|