]> git.baikalelectronics.ru Git - kernel.git/commit
gpio: Switch timestamps to ktime_get_ns()
authorLinus Walleij <linus.walleij@linaro.org>
Thu, 20 Feb 2020 14:56:24 +0000 (15:56 +0100)
committerLinus Walleij <linus.walleij@linaro.org>
Fri, 21 Feb 2020 15:29:38 +0000 (16:29 +0100)
commitf8850206e160bfe35de9ca2e726ab6d6b8cb77dd
tree544a8700772a327087c3a86815d2a8a465842ad2
parent1739a2d852265977836152be43073ead5c64d1ea
gpio: Switch timestamps to ktime_get_ns()

The existing use of ktime_get_real_ns() in the timestamps from
the GPIO events is dubious.

We have had several discussions about this timestamp, and it is
unclear whether userspace has ever taken into account that a
timestamp from ktime_get_real_ns() can actually move backwards
in time relative the previous timetamp, and userspace is more
likely to expect a monotonic counter.

Background:
https://lore.kernel.org/linux-gpio/CAK8P3a1Skvm48sje8FNDPLYqyz9Lf8q0qX1QETWtyZTxuX4k1g@mail.gmail.com/
https://marc.info/?l=linux-gpio&m=151661955709074&w=2

The change is ABI incompatible, but incompatible in a way that
is IMO more likely to fix future bugs rather than break current
userspace. To the best of my knowledge all userspace expects
a monotonic timestamp and users are just lucky that they very
seldom move backwards in time.

Cc: Arnd Bergmann <arnd@arndb.de>
Acked-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpiolib.c