Stubs and parsing for rename and timestamps (XCC)
[akaros.git] / tools / compilers / gcc-glibc / glibc-2.14.1-ros / sysdeps / ros / utimensat.c
1 /* Change access and modification times of open file.  Stub version.
2    Copyright (C) 2007 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
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.
9
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.
14
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
19
20 #include <errno.h>
21 #include <sys/stat.h>
22 #include <fcall.h>
23 #include <sys/time.h>
24 #include <ros/syscall.h>
25 #include <fcntl.h>
26
27 /* Change the access time of FILE to TSP[0] and
28    the modification time of FILE to TSP[1].  */
29
30 /* check futimens for notes.  additionally, we don't support the symlink flags
31  * yet. */
32 int
33 utimensat (int fd, const char *file, const struct timespec tsp[2],
34            int flags)
35 {
36   struct dir dir;
37   size_t mlen;
38   char mbuf[STATFIXLEN];
39   int ret;
40   int wstat_flags = 0;
41   struct timeval tv_now = {0};
42
43   if (file == NULL)
44   {
45     __set_errno (EINVAL);
46     return -1;
47   }
48   /* don't support the openat yet */
49   if (fd != AT_FDCWD && file[0] != '/')
50     {
51       __set_errno (EBADF);
52       return -1;
53     }
54
55
56   init_empty_dir(&dir);
57
58   /* copy-and-pasted with futimens */
59   if (!tsp) {
60         if (gettimeofday(&tv_now, 0) < 0)
61                 return -1;
62         dir.atime = tv_now.tv_sec;
63         dir.mtime = tv_now.tv_sec;
64         wstat_flags = WSTAT_ATIME | WSTAT_MTIME;
65   } else {
66         /* atime */
67     if (tsp[0].tv_nsec == UTIME_NOW) {
68                 if (gettimeofday(&tv_now, 0) < 0)
69                         return -1;
70                 dir.atime = tv_now.tv_sec;
71                 wstat_flags |= WSTAT_ATIME;
72         } else if (tsp[0].tv_nsec != UTIME_OMIT) {
73                 dir.atime = tsp[0].tv_sec;
74                 wstat_flags |= WSTAT_ATIME;
75         }
76         /* mtime */
77     if (tsp[1].tv_nsec == UTIME_NOW) {
78                 if (gettimeofday(&tv_now, 0) < 0)
79                         return -1;
80                 dir.mtime = tv_now.tv_sec;
81                 wstat_flags |= WSTAT_MTIME;
82         } else if (tsp[1].tv_nsec != UTIME_OMIT) {
83                 dir.mtime = tsp[1].tv_sec;
84                 wstat_flags |= WSTAT_MTIME;
85         }
86   }
87
88   if (!wstat_flags)
89         return 0;
90
91   mlen = convD2M(&dir, mbuf, STATFIXLEN);
92   ret = ros_syscall(SYS_wstat, file, strlen(file), mbuf, mlen, wstat_flags, 0);
93   return (ret == mlen ? 0 : -1);
94 }