pgsql: Fix syslogger to not fail when log_rotation_age exceeds 2^31 mil - Mailing list pgsql-committers

From Tom Lane
Subject pgsql: Fix syslogger to not fail when log_rotation_age exceeds 2^31 mil
Date
Msg-id E1TaCEe-0003u3-J4@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Fix syslogger to not fail when log_rotation_age exceeds 2^31 milliseconds.

We need to avoid calling WaitLatch with timeouts exceeding INT_MAX.
Fortunately a simple clamp will do the trick, since no harm is done if
the wait times out before it's really time to rotate the log file.
Per bug #7670 (probably bug #7545 is the same thing, too).

In passing, fix bogus definition of log_rotation_age's maximum value in
guc.c --- it was numerically right, but only because MINS_PER_HOUR and
SECS_PER_MINUTE have the same value.

Back-patch to 9.2.  Before that, syslogger wasn't using WaitLatch.

Branch
------
REL9_2_STABLE

Details
-------
http://git.postgresql.org/pg/commitdiff/89067bc16a1d1ea5bf131b3529e01d208f2e34c0

Modified Files
--------------
src/backend/postmaster/syslogger.c |   17 +++++++++++++++--
src/backend/utils/misc/guc.c       |    2 +-
2 files changed, 16 insertions(+), 3 deletions(-)


pgsql-committers by date:

Previous
From: Tom Lane
Date:
Subject: pgsql: Assert that WaitLatch's timeout is not more than INT_MAX millise
Next
From: Tom Lane
Date:
Subject: pgsql: Fix syslogger to not fail when log_rotation_age exceeds 2^31 mil