Commit 35199781 authored by Martin Schwidefsky's avatar Martin Schwidefsky

s390/cputime: fix 31-bit compile

git commit 8461b63c
"s390: translate cputime magic constants to macros"
introduce a built error for 31-bit:

  kernel/built-in.o: In function `posix_cpu_timer_set':
  posix-cpu-timers.c:(.text+0x2a8cc): undefined reference to `__udivdi3'

The original code is actually broken for 31-bit and has been
corrected by the above commit by forcing the compiler to use
64-bit arithmetic through the CPUTIME_PER_USEC define.

To fix the compile error replace the 64-bit division with
a call to __div().
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent 8622384f
...@@ -94,7 +94,7 @@ static inline cputime_t secs_to_cputime(const unsigned int s) ...@@ -94,7 +94,7 @@ static inline cputime_t secs_to_cputime(const unsigned int s)
static inline cputime_t timespec_to_cputime(const struct timespec *value) static inline cputime_t timespec_to_cputime(const struct timespec *value)
{ {
unsigned long long ret = value->tv_sec * CPUTIME_PER_SEC; unsigned long long ret = value->tv_sec * CPUTIME_PER_SEC;
return (__force cputime_t)(ret + (value->tv_nsec * CPUTIME_PER_USEC) / NSEC_PER_USEC); return (__force cputime_t)(ret + __div(value->tv_nsec * CPUTIME_PER_USEC, NSEC_PER_USEC));
} }
static inline void cputime_to_timespec(const cputime_t cputime, static inline void cputime_to_timespec(const cputime_t cputime,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment