On Wed, Nov 30, 2022 at 12:08 AM Alexander Kanavin
<alex.kanavin@...> wrote:
On Tue, 29 Nov 2022 at 16:45, Stephen Jolley <sjolley.yp.pm@...> wrote:
We’d welcome a proposal/series on how to move forward with the Y2038 work for 32 bit platforms.
I have the following proposal:
1. A branch is made where:
a. "-D_TIME_BITS=64 -D_FILE_OFFSET_BITS=64" is enabled globally.
I have something like this on yoe/mut branch on contrib repo ( due to
musl removing the LFS hacks).
However there are packages which need to be fixed at build time.
b. qemu is always started with "-rtc base=2040-01-01", simulating
Y2038 actually occurring.
this is a good time machine :)
c. an additional runtime test verifies that both RTC clock and system
clock report 2040.
2. This branch is run through a-full on the autobuilder. Any uncovered
issues are filed as bugs.
3. Once *all* of the bugs are addressed, repeat point 2.
4. Once there are no more open bugs, 1a is merged into master.
Any fatal flaws in the plan?
Not much issues except that package fixes may need to be carried
locally for a while.
It's not hard to see that Y2038 problem is real and serious, e.g. on
qemux86 core-image-full-cmdline built from master:
root@qemux86:~# ls /
bin boot dev etc home lib lost+found media mnt proc
run sbin sys tmp usr var
root@qemux86:~# date -s "2040-01-01"
Sun Jan 1 00:00:00 UTC 2040
root@qemux86:~# ls /
bin boot dev etc home lib lost+found media mnt proc
run sbin sys tmp usr var
root@qemux86:~# ls /
-sh: ls: command not found
On qemux86_64 the same sequence works as expected, of course.
Alex