这与“为什么我不能将我的 GNU/Linux 机器的日期设置为纪元? ”相关,但我相信不是重复的。
我发现我的一个 Linux 内核拒绝将时钟设置为纪元过去六分钟内的时间的尝试:
root@beaglebone:/# date 010100061970
date: cannot set date: Invalid argument
Thu 01 Jan 1970 12:06:00 AM UTC
root@beaglebone:/# date 010100071970
Thu 01 Jan 1970 12:07:00 AM UTC
但纪元过去七分钟就可以了。
有人知道为什么会这样吗?当我有机会时,我会检查内核源代码以获取线索。
(不,这不是一个实际问题,只是好奇心,因此可能更适合 Retrocomputing.se 或其他东西。我尝试以这种方式设置时钟是错误的,内核拒绝了它,这对我来说是一个好处。但是,尽管如此,还是很奇怪。)
我从其他证据中知道拒绝不是发生在命令中date
,而是发生在内核本身中。系统settimeofday
调用返回 -1,errno 设置为 EINVAL。
这是在运行内核 4.19.94-ti-r42 的 Debian 10 系统上。
我还在 Debian 11 机器、内核 5.10.179-1 上尝试过它,它的行为类似,尽管“禁区”是 1970 年初的整整两个月——我似乎无法设置早于 3 月的日期1.
更新:现在不仅问题得到了解答,而且奇怪的小谜团也得到了解决,即为什么我测试它的不同机器有不同的行为。我测试的第一台机器最近刚刚重新启动,它不允许我将时间设置为小于纪元过去七分钟的值。但第二台机器已经运行了几个月,它不允许我将时间设置为三月之前的日期——也就是说,不能在该纪元过去的前两个月内。但这是有道理的,因为表述约束的一种方式是(自 1970 年以来的时间)不能小于(自启动以来的时间)。
这是由提交e1d7ba873555 (“时间:始终确保 wall_to_monotonic 不是正值”)引起的。根据提交消息: