1. 19 6月, 2018 1 次提交
  2. 19 5月, 2018 1 次提交
    • A
      timekeeping: Remove timespec64 hack · 4f0fad9a
      Arnd Bergmann 提交于
      At this point, we have converted most of the kernel to use timespec64
      consistently in place of timespec, so it seems it's time to make
      timespec64 the native structure and define timespec in terms of that
      one on 64-bit architectures.
      
      Starting with gcc-5, the compiler can completely optimize away the
      timespec_to_timespec64 and timespec64_to_timespec functions on 64-bit
      architectures. With older compilers, we introduce a couple of extra
      copies of local variables, but those are easily avoided by using
      the timespec64 based interfaces consistently, as we do in most of the
      important code paths already.
      
      The main upside of removing the hack is that printing the tv_sec
      field of a timespec64 structure can now use the %lld format
      string on all architectures without a cast to time64_t. Without
      this patch, the field is a 'long' type and would have to be printed
      using %ld on 64-bit architectures.
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: Stephen Boyd <sboyd@kernel.org>
      Cc: y2038@lists.linaro.org
      Cc: John Stultz <john.stultz@linaro.org>
      Link: https://lkml.kernel.org/r/20180427134016.2525989-2-arnd@arndb.de
      4f0fad9a
  3. 19 4月, 2018 2 次提交
  4. 19 3月, 2018 1 次提交
    • A
      y2038: Introduce struct __kernel_old_timeval · a84d1169
      Arnd Bergmann 提交于
      Dealing with 'struct timeval' users in the y2038 series is a bit tricky:
      
      We have two definitions of timeval that are visible to user space,
      one comes from glibc (or some other C library), the other comes from
      linux/time.h. The kernel copy is what we want to be used for a number of
      structures defined by the kernel itself, e.g. elf_prstatus (used it core
      dumps), sysinfo and rusage (used in system calls).  These generally tend
      to be used for passing time intervals rather than absolute (epoch-based)
      times, so they do not suffer from the y2038 overflow. Some of them
      could be changed to use 64-bit timestamps by creating new system calls,
      others like the core files cannot easily be changed.
      
      An application using these interfaces likely also uses gettimeofday()
      or other interfaces that use absolute times, and pass 'struct timeval'
      pointers directly into kernel interfaces, so glibc must redefine their
      timeval based on a 64-bit time_t when they introduce their y2038-safe
      interfaces.
      
      The only reasonable way forward I see is to remove the 'timeval'
      definion from the kernel's uapi headers, and change the interfaces that
      we do not want to (or cannot) duplicate for 64-bit times to use a new
      __kernel_old_timeval definition instead. This type should be avoided
      for all new interfaces (those can use 64-bit nanoseconds, or the 64-bit
      version of timespec instead), and should be used with great care when
      converting existing interfaces from timeval, to be sure they don't suffer
      from the y2038 overflow, and only with consensus for the particular user
      that using __kernel_old_timeval is better than moving to a 64-bit based
      interface. The structure name is intentionally chosen to not conflict
      with user space types, and to be ugly enough to discourage its use.
      
      Note that ioctl based interfaces that pass a bare 'timeval' pointer
      cannot change to '__kernel_old_timeval' because the user space source
      code refers to 'timeval' instead, and we don't want to modify the user
      space sources if possible. However, any application that relies on a
      structure to contain an embedded 'timeval' (e.g. by passing a pointer
      to the member into a function call that expects a timeval pointer) is
      broken when that structure gets converted to __kernel_old_timeval. I
      don't see any way around that, and we have to rely on the compiler to
      produce a warning or compile failure that will alert users when they
      recompile their sources against a new libc.
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: Stephen Boyd <sboyd@kernel.org>
      Cc: John Stultz <john.stultz@linaro.org>
      Cc: Al Viro <viro@zeniv.linux.org.uk>
      Link: https://lkml.kernel.org/r/20180315161739.576085-1-arnd@arndb.de
      a84d1169
  5. 31 10月, 2017 3 次提交
    • A
      time: Move time_t conversion helpers to time32.h · abc8f96e
      Arnd Bergmann 提交于
      On 64-bit architectures, the timespec64 based helpers in linux/time.h
      are defined as macros pointing to their timespec based counterparts.
      This made sense when they were first introduced, but as we are migrating
      away from timespec in general, it's much less intuitive now.
      
      This changes the macros to work in the exact opposite way: we always
      provide the timespec64 based helpers and define the old interfaces as
      macros for them. Now we can move those macros into linux/time32.h, which
      already contains the respective helpers for 32-bit architectures.
      
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@kernel.org>
      Cc: Miroslav Lichvar <mlichvar@redhat.com>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Prarit Bhargava <prarit@redhat.com>
      Cc: Stephen Boyd <stephen.boyd@linaro.org>
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      abc8f96e
    • A
      time: Remove unused functions · 85bf19e7
      Arnd Bergmann 提交于
      The (slow but) ongoing work on conversion from timespec to timespec64
      has led some timespec based helper functions to become unused.
      
      No new code should use them, so we can remove the functions entirely.
      I'm planning to obsolete additional interfaces next and remove
      more of these.
      
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@kernel.org>
      Cc: Miroslav Lichvar <mlichvar@redhat.com>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Prarit Bhargava <prarit@redhat.com>
      Cc: Stephen Boyd <stephen.boyd@linaro.org>
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      85bf19e7
    • A
      timekeeping: Consolidate timekeeping_inject_offset code · e0956dcc
      Arnd Bergmann 提交于
      The code to check the adjtimex() or clock_adjtime() arguments is spread
      out across multiple files for presumably only historic reasons. As a
      preparatation for a rework to get rid of the use of 'struct timeval'
      and 'struct timespec' in there, this moves all the portions into
      kernel/time/timekeeping.c and marks them as 'static'.
      
      The warp_clock() function here is not as closely related as the others,
      but I feel it still makes sense to move it here in order to consolidate
      all callers of timekeeping_inject_offset().
      
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@kernel.org>
      Cc: Miroslav Lichvar <mlichvar@redhat.com>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Prarit Bhargava <prarit@redhat.com>
      Cc: Stephen Boyd <stephen.boyd@linaro.org>
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      [jstultz: Whitespace fixup]
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      e0956dcc
  6. 17 10月, 2017 1 次提交
  7. 26 6月, 2017 2 次提交
  8. 14 6月, 2017 3 次提交
  9. 13 5月, 2017 1 次提交
  10. 15 4月, 2017 1 次提交
  11. 01 2月, 2017 1 次提交
  12. 25 12月, 2016 1 次提交
  13. 01 9月, 2016 1 次提交
    • V
      time: Avoid undefined behaviour in timespec64_add_safe() · 469e857f
      Vegard Nossum 提交于
      I ran into this:
      
          ================================================================================
          UBSAN: Undefined behaviour in kernel/time/time.c:783:2
          signed integer overflow:
          5273 + 9223372036854771711 cannot be represented in type 'long int'
          CPU: 0 PID: 17363 Comm: trinity-c0 Not tainted 4.8.0-rc1+ #88
          Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.9.3-0-ge2fc41e-prebuilt.qemu-project.org
          04/01/2014
           0000000000000000 ffff88011457f8f0 ffffffff82344f50 0000000041b58ab3
           ffffffff84f98080 ffffffff82344ea4 ffff88011457f918 ffff88011457f8c8
           ffff88011457f8e0 7fffffffffffefff ffff88011457f6d8 dffffc0000000000
          Call Trace:
           [<ffffffff82344f50>] dump_stack+0xac/0xfc
           [<ffffffff82344ea4>] ? _atomic_dec_and_lock+0xc4/0xc4
           [<ffffffff8242f4c8>] ubsan_epilogue+0xd/0x8a
           [<ffffffff8242fc04>] handle_overflow+0x202/0x23d
           [<ffffffff8242fa02>] ? val_to_string.constprop.6+0x11e/0x11e
           [<ffffffff823c7837>] ? debug_smp_processor_id+0x17/0x20
           [<ffffffff8131b581>] ? __sigqueue_free.part.13+0x51/0x70
           [<ffffffff8146d4e0>] ? rcu_is_watching+0x110/0x110
           [<ffffffff8242fc4d>] __ubsan_handle_add_overflow+0xe/0x10
           [<ffffffff81476ef8>] timespec64_add_safe+0x298/0x340
           [<ffffffff81476c60>] ? timespec_add_safe+0x330/0x330
           [<ffffffff812f7990>] ? wait_noreap_copyout+0x1d0/0x1d0
           [<ffffffff8184bf18>] poll_select_set_timeout+0xf8/0x170
           [<ffffffff8184be20>] ? poll_schedule_timeout+0x2b0/0x2b0
           [<ffffffff813aa9bb>] ? __might_sleep+0x5b/0x260
           [<ffffffff833c8a87>] __sys_recvmmsg+0x107/0x790
           [<ffffffff833c8980>] ? SyS_recvmsg+0x20/0x20
           [<ffffffff81486378>] ? hrtimer_start_range_ns+0x3b8/0x1380
           [<ffffffff845f8bfb>] ? _raw_spin_unlock_irqrestore+0x3b/0x60
           [<ffffffff8148bcea>] ? do_setitimer+0x39a/0x8e0
           [<ffffffff813aa9bb>] ? __might_sleep+0x5b/0x260
           [<ffffffff833c9110>] ? __sys_recvmmsg+0x790/0x790
           [<ffffffff833c91e9>] SyS_recvmmsg+0xd9/0x160
           [<ffffffff833c9110>] ? __sys_recvmmsg+0x790/0x790
           [<ffffffff823c7853>] ? __this_cpu_preempt_check+0x13/0x20
           [<ffffffff8162f680>] ? __context_tracking_exit.part.3+0x30/0x1b0
           [<ffffffff833c9110>] ? __sys_recvmmsg+0x790/0x790
           [<ffffffff81007bd3>] do_syscall_64+0x1b3/0x4b0
           [<ffffffff845f936a>] entry_SYSCALL64_slow_path+0x25/0x25
          ================================================================================
      
      Line 783 is this:
      
      783         set_normalized_timespec64(&res, lhs.tv_sec + rhs.tv_sec,
      784                         lhs.tv_nsec + rhs.tv_nsec);
      
      In other words, since lhs.tv_sec and rhs.tv_sec are both time64_t, this
      is a signed addition which will cause undefined behaviour on overflow.
      
      Note that this is not currently a huge concern since the kernel should be
      built with -fno-strict-overflow by default, but could be a problem in the
      future, a problem with older compilers, or other compilers than gcc.
      
      The easiest way to avoid the overflow is to cast one of the arguments to
      unsigned (so the addition will be done using unsigned arithmetic).
      
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@kernel.org>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Prarit Bhargava <prarit@redhat.com>
      Signed-off-by: NVegard Nossum <vegard.nossum@oracle.com>
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      469e857f
  14. 20 5月, 2016 2 次提交
  15. 23 4月, 2016 1 次提交
    • B
      time: Introduce do_sys_settimeofday64() · 86d34732
      Baolin Wang 提交于
      The do_sys_settimeofday() function uses a timespec, which is not year
      2038 safe on 32bit systems.
      
      Thus this patch introduces do_sys_settimeofday64(), which allows us to
      transition users of do_sys_settimeofday() to using 64bit time types.
      
      Cc: Prarit Bhargava <prarit@redhat.com>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@kernel.org>
      Signed-off-by: NBaolin Wang <baolin.wang@linaro.org>
      [jstultz: Include errno-base.h to avoid build issue on some arches]
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      86d34732
  16. 29 2月, 2016 1 次提交
    • D
      Handle ISO 8601 leap seconds and encodings of midnight in mktime64() · ede5147d
      David Howells 提交于
      Handle the following ISO 8601 features in mktime64():
      
       (1) Leap seconds.
      
           Leap seconds are indicated by the seconds parameter being the value
           60.  Handle this by treating it the same as 00 of the following
           minute.
      
           It has been pointed out that a minute may contain two leap seconds.
           However, pending discussion of what that looks like and how to handle
           it, I'm not going to concern myself with it.
      
       (2) Alternate encodings of midnight.
      
           Two different encodings of midnight are permitted - 00:00:00 and
           24:00:00 - the first is midnight today and the second is midnight
           tomorrow and is exactly equivalent to the first with tomorrow's date.
      
      As it happens, we don't actually need to change mktime64() to handle either
      of these - just comment them as valid parameters.
      
      These facility will be used by the X.509 parser.  Doing it in mktime64()
      makes the policy common to the whole kernel and easier to find.
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      Acked-by: NArnd Bergmann <arnd@arndb.de>
      cc: John Stultz <john.stultz@linaro.org>
      cc: Rudolf Polzer <rpolzer@google.com>
      cc: One Thousand Gnomes <gnomes@lxorguk.ukuu.org.uk>
      ede5147d
  17. 18 8月, 2015 2 次提交
    • B
      time: Introduce timespec64_to_jiffies()/jiffies_to_timespec64() · 9ca30850
      Baolin Wang 提交于
      The conversion between struct timespec and jiffies is not year 2038
      safe on 32bit systems. Introduce timespec64_to_jiffies() and
      jiffies_to_timespec64() functions which use struct timespec64 to
      make it ready for 2038 issue.
      
      Cc: Prarit Bhargava <prarit@redhat.com>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Ingo Molnar <mingo@kernel.org>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Signed-off-by: NBaolin Wang <baolin.wang@linaro.org>
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      9ca30850
    • K
      time: Fix nanosecond file time rounding in timespec_trunc() · de4a95fa
      Karsten Blees 提交于
      timespec_trunc() avoids rounding if granularity <= nanoseconds-per-jiffie
      (or TICK_NSEC). This optimization assumes that:
      
       1. current_kernel_time().tv_nsec is already rounded to TICK_NSEC (i.e.
          with HZ=1000 you'd get 1000000, 2000000, 3000000... but never 1000001).
          This is no longer true (probably since hrtimers introduced in 2.6.16).
      
       2. TICK_NSEC is evenly divisible by all possible granularities. This may
          be true for HZ=100, 250, 1000, but obviously not for HZ=300 /
          TICK_NSEC=3333333 (introduced in 2.6.20).
      
      Thus, sub-second portions of in-core file times are not rounded to on-disk
      granularity. I.e. file times may change when the inode is re-read from disk
      or when the file system is remounted.
      
      This affects all file systems with file time granularities > 1 ns and < 1s,
      e.g. CEPH (1000 ns), UDF (1000 ns), CIFS (100 ns), NTFS (100 ns) and FUSE
      (configurable from user mode via struct fuse_init_out.time_gran).
      
      Steps to reproduce with e.g. UDF:
      
        $ dd if=/dev/zero of=udfdisk count=10000 && mkudffs udfdisk
        $ mkdir udf && mount udfdisk udf
        $ touch udf/test && stat -c %y udf/test
        2015-06-09 10:22:56.130006767 +0200
        $ umount udf && mount udfdisk udf
        $ stat -c %y udf/test
        2015-06-09 10:22:56.130006000 +0200
      
      Remounting truncates the mtime to 1 µs.
      
      Fix the rounding in timespec_trunc() and update the documentation.
      
      timespec_trunc() is exclusively used to calculate inode's [acm]time (mostly
      via current_fs_time()), and always with super_block.s_time_gran as second
      argument. So this can safely be changed without side effects.
      
      Note: This does _not_ fix the issue for FAT's 2 second mtime resolution,
      as super_block.s_time_gran isn't prepared to handle different ctime /
      mtime / atime resolutions nor resolutions > 1 second.
      
      Cc: Prarit Bhargava <prarit@redhat.com>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Ingo Molnar <mingo@kernel.org>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Signed-off-by: NKarsten Blees <blees@dcon.de>
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      de4a95fa
  18. 29 7月, 2015 1 次提交
    • F
      jiffies: Remove HZ > USEC_PER_SEC special case · e0758676
      Frederic Weisbecker 提交于
      HZ never goes much further 1000 and a bit. And if we ever reach one tick
      per microsecond, we might be having a problem.
      
      Lets stop maintaining this special case, just leave a paranoid check.
      Reviewed-by: NRik van Riel <riel@redhat.com>
      Cc: Christoph Lameter <cl@linux.com>
      Cc: Ingo Molnar <mingo@kernel.org>
      Cc; John Stultz <john.stultz@linaro.org>
      Cc: Peter Zijlstra <peterz@infradead.org>
      Cc: Preeti U Murthy <preeti@linux.vnet.ibm.com>
      Cc: Rik van Riel <riel@redhat.com>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Viresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: NFrederic Weisbecker <fweisbec@gmail.com>
      e0758676
  19. 10 6月, 2015 1 次提交
  20. 23 5月, 2015 1 次提交
  21. 19 5月, 2015 2 次提交
  22. 08 1月, 2015 1 次提交
  23. 05 12月, 2014 1 次提交
  24. 22 11月, 2014 1 次提交
  25. 13 9月, 2014 1 次提交
    • A
      jiffies: Fix timeval conversion to jiffies · d78c9300
      Andrew Hunter 提交于
      timeval_to_jiffies tried to round a timeval up to an integral number
      of jiffies, but the logic for doing so was incorrect: intervals
      corresponding to exactly N jiffies would become N+1. This manifested
      itself particularly repeatedly stopping/starting an itimer:
      
      setitimer(ITIMER_PROF, &val, NULL);
      setitimer(ITIMER_PROF, NULL, &val);
      
      would add a full tick to val, _even if it was exactly representable in
      terms of jiffies_ (say, the result of a previous rounding.)  Doing
      this repeatedly would cause unbounded growth in val.  So fix the math.
      
      Here's what was wrong with the conversion: we essentially computed
      (eliding seconds)
      
      jiffies = usec  * (NSEC_PER_USEC/TICK_NSEC)
      
      by using scaling arithmetic, which took the best approximation of
      NSEC_PER_USEC/TICK_NSEC with denominator of 2^USEC_JIFFIE_SC =
      x/(2^USEC_JIFFIE_SC), and computed:
      
      jiffies = (usec * x) >> USEC_JIFFIE_SC
      
      and rounded this calculation up in the intermediate form (since we
      can't necessarily exactly represent TICK_NSEC in usec.) But the
      scaling arithmetic is a (very slight) *over*approximation of the true
      value; that is, instead of dividing by (1 usec/ 1 jiffie), we
      effectively divided by (1 usec/1 jiffie)-epsilon (rounding
      down). This would normally be fine, but we want to round timeouts up,
      and we did so by adding 2^USEC_JIFFIE_SC - 1 before the shift; this
      would be fine if our division was exact, but dividing this by the
      slightly smaller factor was equivalent to adding just _over_ 1 to the
      final result (instead of just _under_ 1, as desired.)
      
      In particular, with HZ=1000, we consistently computed that 10000 usec
      was 11 jiffies; the same was true for any exact multiple of
      TICK_NSEC.
      
      We could possibly still round in the intermediate form, adding
      something less than 2^USEC_JIFFIE_SC - 1, but easier still is to
      convert usec->nsec, round in nanoseconds, and then convert using
      time*spec*_to_jiffies.  This adds one constant multiplication, and is
      not observably slower in microbenchmarks on recent x86 hardware.
      
      Tested: the following program:
      
      int main() {
        struct itimerval zero = {{0, 0}, {0, 0}};
        /* Initially set to 10 ms. */
        struct itimerval initial = zero;
        initial.it_interval.tv_usec = 10000;
        setitimer(ITIMER_PROF, &initial, NULL);
        /* Save and restore several times. */
        for (size_t i = 0; i < 10; ++i) {
          struct itimerval prev;
          setitimer(ITIMER_PROF, &zero, &prev);
          /* on old kernels, this goes up by TICK_USEC every iteration */
          printf("previous value: %ld %ld %ld %ld\n",
                 prev.it_interval.tv_sec, prev.it_interval.tv_usec,
                 prev.it_value.tv_sec, prev.it_value.tv_usec);
          setitimer(ITIMER_PROF, &prev, NULL);
        }
          return 0;
      }
      
      Cc: stable@vger.kernel.org
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Paul Turner <pjt@google.com>
      Cc: Richard Cochran <richardcochran@gmail.com>
      Cc: Prarit Bhargava <prarit@redhat.com>
      Reviewed-by: NPaul Turner <pjt@google.com>
      Reported-by: NAaron Jacobs <jacobsa@google.com>
      Signed-off-by: NAndrew Hunter <ahh@google.com>
      [jstultz: Tweaked to apply to 3.17-rc]
      Signed-off-by: NJohn Stultz <john.stultz@linaro.org>
      d78c9300
  26. 24 7月, 2014 3 次提交
  27. 23 6月, 2014 1 次提交
  28. 19 6月, 2013 1 次提交
  29. 16 3月, 2013 1 次提交