1 /* getitimer -- Get the state of an interval timer. Linux/32 version.
2 Copyright (C) 2020-2023 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <http://www.gnu.org/licenses/>. */
21 #include <sys/types.h>
23 #include <tv32-compat.h>
26 __getitimer64 (__itimer_which_t which
, struct __itimerval64
*curr_value
)
28 #if __KERNEL_OLD_TIMEVAL_MATCHES_TIMEVAL64
29 return INLINE_SYSCALL_CALL (getitimer
, which
, curr_value
);
31 struct __itimerval32 curr_value_32
;
33 if (INLINE_SYSCALL_CALL (getitimer
, which
, &curr_value_32
) == -1)
36 curr_value
->it_interval
37 = valid_timeval32_to_timeval64 (curr_value_32
.it_interval
);
39 = valid_timeval32_to_timeval64 (curr_value_32
.it_value
);
45 libc_hidden_def (__getitimer64
)
47 __getitimer (__itimer_which_t which
, struct itimerval
*curr_value
)
49 struct __itimerval64 val64
;
50 if (__getitimer64 (which
, &val64
) != 0)
53 curr_value
->it_interval
54 = valid_timeval64_to_timeval (val64
.it_interval
);
56 = valid_timeval64_to_timeval (val64
.it_value
);
61 weak_alias (__getitimer
, getitimer
)