The year 2038 problem denotes unpredictable behaviour that will likely occur in the year 2038, for programs that use a 32-bit signed integer ‘time_t’ type that cannot represent timestamps on or after 2038-01-19 03:14:08 UTC. See Year 2038 problem for details.
The Gnulib module ‘year2038’ fixes this problem on some
platforms, by making time_t
wide enough to represent timestamps
after 2038. This has no effect on most current platforms, which have
timestamps that are already wide enough. However, ‘year2038’ by
default arranges for builds on legacy 32-bit Linux kernels running
glibc 2.34 and later to compile with ‘_TIME_BITS=64’ to get wider
timestamps. On older platforms that do not support timestamps after
the year 2038, ‘year2038’ causes configure
to issue a
warning but still proceed. On platforms that appear to support
post-2038 timestamps but where something prevents this from working,
configure
fails.
The default behavior of ‘year2038’ can be overridden by using the
configure
option --disable-year2038, which
suppresses support for post-2038 timestamps. This may be useful if
the package links to other libraries whose user-facing ABIs still
require time_t
to be 32-bit on your platform.
The Gnulib module ‘year2038-recommended’ is like ‘year2038’,
except it by default rejects platforms where time_t
cannot represent
timestamps after 2038. If this module is used and a 32-platform cannot support
64-bit time_t
, one can still fix the year-2038 problem by using
a 64-bit instead of a 32-bit build, as noted in the architecture list
below. If all else fails one can configure with
--disable-year2038; however, the resulting programs will
mishandle timestamps after 2038.
The Gnulib module ‘year2038-recommended’ is designed for packages intended for use on 32-bit platforms after the year 2038. If your package is commonly built on 32-bit platforms that will not be used after the year 2038, you can use the ‘year2038’ module instead, to save builders the trouble of configuring with --disable-year2038.
If the Gnulib module ‘largefile’ is used but neither
‘year2038’ nor ‘year2038-recommended’ is used,
configure
will have an option --enable-year2038
that causes configure
to behave as if ‘year2038’ was used.
This is for packages that have long used ‘largefile’ but have not
gotten around to upgrading their Gnulib module list to include
‘year2038’ or ‘year2038-recommended’.
See Large File Support.
With the ‘year2038-recommended’ module, configure
by
default should work on the following 32-bit platforms (or 32-bit ABIs
in bi-arch systems):
Whereas with ‘year2038-recommended’, configure
should
by default fail on earlier versions of the abovementioned platforms if
a version is listed, and it should also by default fail on all
versions of the following older 32-bit platforms or ABIs:
time_t
),
If you use the ‘year2038’ or ‘year2038-recommended’ modules,
and configure to support timestamps after the year 2038,
your code should not include ‘<utmp.h>’ or ‘<utmpx.h>’
directly, because these include files do not work with 64-bit timestamps
if the platform’s time_t
was traditionally 32 bits.
Your code can instead use the ‘readutmp’ module,
which works around this problem.