1 /* futimes -- change access and modification times of open file. Linux version.
2 Copyright (C) 2002-2018 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/>. */
29 /* Change the access time of the file associated with FD to TVP[0] and
30 the modification time of FILE to TVP[1].
32 Starting with 2.6.22 the Linux kernel has the utimensat syscall which
33 can be used to implement futimes. */
35 __futimes (int fd
, const struct timeval tvp
[2])
37 /* The utimensat system call expects timespec not timeval. */
38 struct timespec ts
[2];
41 if (tvp
[0].tv_usec
< 0 || tvp
[0].tv_usec
>= 1000000
42 || tvp
[1].tv_usec
< 0 || tvp
[1].tv_usec
>= 1000000)
43 return INLINE_SYSCALL_ERROR_RETURN_VALUE (EINVAL
);
45 TIMEVAL_TO_TIMESPEC (&tvp
[0], &ts
[0]);
46 TIMEVAL_TO_TIMESPEC (&tvp
[1], &ts
[1]);
49 return INLINE_SYSCALL (utimensat
, 4, fd
, NULL
, tvp
? &ts
: NULL
, 0);
51 weak_alias (__futimes
, futimes
)