gettimeofday.h 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Author: Huacai Chen <chenhuacai@loongson.cn>
  4. *
  5. * Copyright (C) 2020-2022 Loongson Technology Corporation Limited
  6. */
  7. #ifndef __ASM_VDSO_GETTIMEOFDAY_H
  8. #define __ASM_VDSO_GETTIMEOFDAY_H
  9. #ifndef __ASSEMBLER__
  10. #include <asm/unistd.h>
  11. #include <asm/vdso/vdso.h>
  12. #ifdef CONFIG_GENERIC_GETTIMEOFDAY
  13. #define VDSO_HAS_CLOCK_GETRES 1
  14. static __always_inline long gettimeofday_fallback(
  15. struct __kernel_old_timeval *_tv,
  16. struct timezone *_tz)
  17. {
  18. register struct __kernel_old_timeval *tv asm("a0") = _tv;
  19. register struct timezone *tz asm("a1") = _tz;
  20. register long nr asm("a7") = __NR_gettimeofday;
  21. register long ret asm("a0");
  22. asm volatile(
  23. " syscall 0\n"
  24. : "=r" (ret)
  25. : "r" (nr), "r" (tv), "r" (tz)
  26. : "$t0", "$t1", "$t2", "$t3", "$t4", "$t5", "$t6", "$t7",
  27. "$t8", "memory");
  28. return ret;
  29. }
  30. static __always_inline long clock_gettime_fallback(
  31. clockid_t _clkid,
  32. struct __kernel_timespec *_ts)
  33. {
  34. register clockid_t clkid asm("a0") = _clkid;
  35. register struct __kernel_timespec *ts asm("a1") = _ts;
  36. register long nr asm("a7") = __NR_clock_gettime;
  37. register long ret asm("a0");
  38. asm volatile(
  39. " syscall 0\n"
  40. : "=r" (ret)
  41. : "r" (nr), "r" (clkid), "r" (ts)
  42. : "$t0", "$t1", "$t2", "$t3", "$t4", "$t5", "$t6", "$t7",
  43. "$t8", "memory");
  44. return ret;
  45. }
  46. static __always_inline int clock_getres_fallback(
  47. clockid_t _clkid,
  48. struct __kernel_timespec *_ts)
  49. {
  50. register clockid_t clkid asm("a0") = _clkid;
  51. register struct __kernel_timespec *ts asm("a1") = _ts;
  52. register long nr asm("a7") = __NR_clock_getres;
  53. register long ret asm("a0");
  54. asm volatile(
  55. " syscall 0\n"
  56. : "=r" (ret)
  57. : "r" (nr), "r" (clkid), "r" (ts)
  58. : "$t0", "$t1", "$t2", "$t3", "$t4", "$t5", "$t6", "$t7",
  59. "$t8", "memory");
  60. return ret;
  61. }
  62. static __always_inline u64 __arch_get_hw_counter(s32 clock_mode,
  63. const struct vdso_time_data *vd)
  64. {
  65. uint64_t count;
  66. __asm__ __volatile__(
  67. " rdtime.d %0, $zero\n"
  68. : "=r" (count));
  69. return count;
  70. }
  71. static inline bool loongarch_vdso_hres_capable(void)
  72. {
  73. return true;
  74. }
  75. #define __arch_vdso_hres_capable loongarch_vdso_hres_capable
  76. #endif /* CONFIG_GENERIC_GETTIMEOFDAY */
  77. #endif /* !__ASSEMBLER__ */
  78. #endif /* __ASM_VDSO_GETTIMEOFDAY_H */