]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
powerpc/vdso: Provide clock_getres_time64()
authorThomas Weißschuh <thomas.weissschuh@linutronix.de>
Wed, 14 Jan 2026 07:26:05 +0000 (08:26 +0100)
committerThomas Gleixner <tglx@kernel.org>
Wed, 14 Jan 2026 13:57:39 +0000 (14:57 +0100)
For consistency with __vdso_clock_gettime64() there should also be a
64-bit variant of clock_getres(). This will allow the extension of
CONFIG_COMPAT_32BIT_TIME to the vDSO and finally the removal of 32-bit
time types from the kernel and UAPI.

Signed-off-by: Thomas Weißschuh <thomas.weissschuh@linutronix.de>
Signed-off-by: Thomas Gleixner <tglx@kernel.org>
Reviewed-by: Christophe Leroy (CS GROUP) <chleroy@kernel.org>
Link: https://patch.msgid.link/20260114-vdso-powerpc-align-v1-1-acf09373d568@linutronix.de
arch/powerpc/include/asm/vdso/gettimeofday.h
arch/powerpc/kernel/vdso/gettimeofday.S
arch/powerpc/kernel/vdso/vdso32.lds.S
arch/powerpc/kernel/vdso/vgettimeofday.c

index ab3df12c8d947ed3a5b0b173567ca8469afbf2d6..8ea397e26ad07d43a4b36f9269b608909a550ecd 100644 (file)
@@ -135,6 +135,8 @@ int __c_kernel_clock_gettime64(clockid_t clock, struct __kernel_timespec *ts,
                               const struct vdso_time_data *vd);
 int __c_kernel_clock_getres(clockid_t clock_id, struct old_timespec32 *res,
                            const struct vdso_time_data *vd);
+int __c_kernel_clock_getres_time64(clockid_t clock_id, struct __kernel_timespec *res,
+                                  const struct vdso_time_data *vd);
 #endif
 int __c_kernel_gettimeofday(struct __kernel_old_timeval *tv, struct timezone *tz,
                            const struct vdso_time_data *vd);
index 79c967212444732da50805fd086c6f2a3c75b0cc..1c8e51691bf8832eaf80469a07e9e3974ca913c3 100644 (file)
@@ -103,6 +103,18 @@ V_FUNCTION_BEGIN(__kernel_clock_getres)
        cvdso_call __c_kernel_clock_getres
 V_FUNCTION_END(__kernel_clock_getres)
 
+/*
+ * Exact prototype of clock_getres_time64()
+ *
+ * int __kernel_clock_getres(clockid_t clock_id, struct __timespec64 *res);
+ *
+ */
+#ifndef __powerpc64__
+V_FUNCTION_BEGIN(__kernel_clock_getres_time64)
+       cvdso_call __c_kernel_clock_getres_time64
+V_FUNCTION_END(__kernel_clock_getres_time64)
+#endif
+
 
 /*
  * Exact prototype of time()
index 72a1012b8a205c6357cecb4b53d2d8e1ff59b051..3f384a2526aebc95d0f25393c07245af8f540723 100644 (file)
@@ -124,6 +124,7 @@ VERSION
                __kernel_clock_gettime;
                __kernel_clock_gettime64;
                __kernel_clock_getres;
+               __kernel_clock_getres_time64;
                __kernel_time;
                __kernel_get_tbfreq;
                __kernel_sync_dicache;
index 6f5167d81af5f3e6e755dbda4307769e45a28421..3c194e1ab562094b65769bfc20c8ab6871d03489 100644 (file)
@@ -35,6 +35,12 @@ int __c_kernel_clock_getres(clockid_t clock_id, struct old_timespec32 *res,
 {
        return __cvdso_clock_getres_time32_data(vd, clock_id, res);
 }
+
+int __c_kernel_clock_getres_time64(clockid_t clock_id, struct __kernel_timespec *res,
+                                  const struct vdso_time_data *vd)
+{
+       return __cvdso_clock_getres_data(vd, clock_id, res);
+}
 #endif
 
 int __c_kernel_gettimeofday(struct __kernel_old_timeval *tv, struct timezone *tz,