Linux clock_gettime(CLOCK_MONOTONIC)奇怪的非单调行为

2024-10-23 08:47:00
admin
原创
256
摘要:问题描述:各位,在我的应用程序中,我使用它clock_gettime(CLOCK_MONOTONIC)来测量帧之间的时间增量(游戏开发中的典型方法),有时我会遇到一个奇怪的行为clock_gettime(..)——返回的值有时不是单调的(即,上次时间大于当前时间)。目前,如果发生这种悖论,我只需跳过当前帧并开...

问题描述:

各位,在我的应用程序中,我使用它clock_gettime(CLOCK_MONOTONIC)来测量帧之间的时间增量(游戏开发中的典型方法),有时我会遇到一个奇怪的行为clock_gettime(..)——返回的值有时不是单调的(即,上次时间大于当前时间)。

目前,如果发生这种悖论,我只需跳过当前帧并开始处理下一帧。

问题是这怎么可能呢?这是 Linux POSIX 实现中的一个错误吗clock_gettime?我正在使用 Ubuntu Server Edition 10.04(内核 2.6.32-24,x86_64),gcc-4.4.3。


解决方案 1:

man clock_gettime说:

CLOCK_MONOTONIC_RAW(自 Linux 2.6.28 起;Linux 专用)

与 CLOCK_MONOTONIC 类似,但提供对不受 NTP 调整的原始硬件时间的访问。

由于CLOCK_MONOTONIC_RAW不受 NTP 调整的影响,所以我猜CLOCK_MONOTONIC可能是。

我们在使用 2.6.18 内核和某些特定 Itanium 处理器的 Redhat Enterprise 5.0 上也遇到了类似的问题。我们无法在同一操作系统上使用其他处理器重现此问题。该问题已在 RHEL 5.3 中修复,该版本使用了稍新的内核和一些 Redhat 补丁。

解决方案 2:

看起来像是

commit 0696b711e4be45fa104c12329f617beb29c03f78
Author: Lin Ming <ming.m.lin@intel.com>
Date:   Tue Nov 17 13:49:50 2009 +0800

timekeeping: Fix clock_gettime vsyscall time warp

Since commit 0a544198 "timekeeping: Move NTP adjusted clock
multiplier to struct timekeeper" the clock multiplier of vsyscall is updated with
the unmodified clock multiplier of the clock source and not with the
NTP adjusted multiplier of the timekeeper.

This causes user space observerable time warps:
new CLOCK-warp maximum: 120 nsecs,  00000025c337c537 -> 00000025c337c4bf

请参阅此处获取补丁。该补丁已包含在 2.6.32.19 中,但 Debian 团队可能尚未将其反向移植(?)。您应该查看一下。

解决方案 3:

尝试CLOCK_MONOTONIC_RAW

解决方案 4:

对我来说这听起来确实像是一个错误。也许你应该在Ubuntu 的错误跟踪器中报告它。

解决方案 5:

这是 Linux 的一个错误。单调时钟中的任何调整都无法使其倒退。您使用的是一个非常旧的内核和一个非常旧的发行版。

编辑:您确定需要跳过该帧吗?如果再次调用clock_gettime,会发生什么?

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   1565  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1354  
  信创国产芯片作为信息技术创新的核心领域,对于推动国家自主可控生态建设具有至关重要的意义。在全球科技竞争日益激烈的背景下,实现信息技术的自主可控,摆脱对国外技术的依赖,已成为保障国家信息安全和产业可持续发展的关键。国产芯片作为信创产业的基石,其发展水平直接影响着整个信创生态的构建与完善。通过不断提升国产芯片的技术实力、产...
国产信创系统   21  
  信创生态建设旨在实现信息技术领域的自主创新和安全可控,涵盖了从硬件到软件的全产业链。随着数字化转型的加速,信创生态建设的重要性日益凸显,它不仅关乎国家的信息安全,更是推动产业升级和经济高质量发展的关键力量。然而,在推进信创生态建设的过程中,面临着诸多复杂且严峻的挑战,需要深入剖析并寻找切实可行的解决方案。技术创新难题技...
信创操作系统   27  
  信创产业作为国家信息技术创新发展的重要领域,对于保障国家信息安全、推动产业升级具有关键意义。而国产芯片作为信创产业的核心基石,其研发进展备受关注。在信创国产芯片的研发征程中,面临着诸多复杂且艰巨的难点,这些难点犹如一道道关卡,阻碍着国产芯片的快速发展。然而,科研人员和相关企业并未退缩,积极探索并提出了一系列切实可行的解...
国产化替代产品目录   28  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用