1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2015-2016 Dmitry V. Levin <[email protected]>
3*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2015-2018 The strace developers.
4*cf84ac9aSAndroid Build Coastguard Worker * All rights reserved.
5*cf84ac9aSAndroid Build Coastguard Worker *
6*cf84ac9aSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
7*cf84ac9aSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions
8*cf84ac9aSAndroid Build Coastguard Worker * are met:
9*cf84ac9aSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
10*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
11*cf84ac9aSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
12*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
13*cf84ac9aSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
14*cf84ac9aSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products
15*cf84ac9aSAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
16*cf84ac9aSAndroid Build Coastguard Worker *
17*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18*cf84ac9aSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19*cf84ac9aSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20*cf84ac9aSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21*cf84ac9aSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22*cf84ac9aSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23*cf84ac9aSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24*cf84ac9aSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25*cf84ac9aSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27*cf84ac9aSAndroid Build Coastguard Worker */
28*cf84ac9aSAndroid Build Coastguard Worker
29*cf84ac9aSAndroid Build Coastguard Worker #if defined HAVE_FTRUNCATE && defined HAVE_FUTIMENS
30*cf84ac9aSAndroid Build Coastguard Worker
31*cf84ac9aSAndroid Build Coastguard Worker # ifndef TEST_SYSCALL_STR
32*cf84ac9aSAndroid Build Coastguard Worker # error TEST_SYSCALL_STR must be defined
33*cf84ac9aSAndroid Build Coastguard Worker # endif
34*cf84ac9aSAndroid Build Coastguard Worker # ifndef TEST_SYSCALL_INVOKE
35*cf84ac9aSAndroid Build Coastguard Worker # error TEST_SYSCALL_INVOKE must be defined
36*cf84ac9aSAndroid Build Coastguard Worker # endif
37*cf84ac9aSAndroid Build Coastguard Worker # ifndef PRINT_SYSCALL_HEADER
38*cf84ac9aSAndroid Build Coastguard Worker # error PRINT_SYSCALL_HEADER must be defined
39*cf84ac9aSAndroid Build Coastguard Worker # endif
40*cf84ac9aSAndroid Build Coastguard Worker # ifndef PRINT_SYSCALL_FOOTER
41*cf84ac9aSAndroid Build Coastguard Worker # error PRINT_SYSCALL_FOOTER must be defined
42*cf84ac9aSAndroid Build Coastguard Worker # endif
43*cf84ac9aSAndroid Build Coastguard Worker
44*cf84ac9aSAndroid Build Coastguard Worker # include <errno.h>
45*cf84ac9aSAndroid Build Coastguard Worker # include <stdio.h>
46*cf84ac9aSAndroid Build Coastguard Worker # include <stddef.h>
47*cf84ac9aSAndroid Build Coastguard Worker # include <time.h>
48*cf84ac9aSAndroid Build Coastguard Worker # include <unistd.h>
49*cf84ac9aSAndroid Build Coastguard Worker # include <sys/sysmacros.h>
50*cf84ac9aSAndroid Build Coastguard Worker
51*cf84ac9aSAndroid Build Coastguard Worker # include "print_fields.h"
52*cf84ac9aSAndroid Build Coastguard Worker # include "statx.h"
53*cf84ac9aSAndroid Build Coastguard Worker
54*cf84ac9aSAndroid Build Coastguard Worker # ifndef STRUCT_STAT
55*cf84ac9aSAndroid Build Coastguard Worker # define STRUCT_STAT struct stat
56*cf84ac9aSAndroid Build Coastguard Worker # define STRUCT_STAT_STR "struct stat"
57*cf84ac9aSAndroid Build Coastguard Worker # define STRUCT_STAT_IS_STAT64 0
58*cf84ac9aSAndroid Build Coastguard Worker # endif
59*cf84ac9aSAndroid Build Coastguard Worker # ifndef SAMPLE_SIZE
60*cf84ac9aSAndroid Build Coastguard Worker # define SAMPLE_SIZE ((libc_off_t) 43147718418ULL)
61*cf84ac9aSAndroid Build Coastguard Worker # endif
62*cf84ac9aSAndroid Build Coastguard Worker
63*cf84ac9aSAndroid Build Coastguard Worker typedef off_t libc_off_t;
64*cf84ac9aSAndroid Build Coastguard Worker
65*cf84ac9aSAndroid Build Coastguard Worker # define stat libc_stat
66*cf84ac9aSAndroid Build Coastguard Worker # define stat64 libc_stat64
67*cf84ac9aSAndroid Build Coastguard Worker # define statx libc_statx
68*cf84ac9aSAndroid Build Coastguard Worker # define statx_timestamp libc_statx_timestamp
69*cf84ac9aSAndroid Build Coastguard Worker # include <fcntl.h>
70*cf84ac9aSAndroid Build Coastguard Worker # include <sys/stat.h>
71*cf84ac9aSAndroid Build Coastguard Worker # undef statx_timestamp
72*cf84ac9aSAndroid Build Coastguard Worker # undef statx
73*cf84ac9aSAndroid Build Coastguard Worker # undef stat64
74*cf84ac9aSAndroid Build Coastguard Worker # undef stat
75*cf84ac9aSAndroid Build Coastguard Worker
76*cf84ac9aSAndroid Build Coastguard Worker # undef st_atime
77*cf84ac9aSAndroid Build Coastguard Worker # undef st_mtime
78*cf84ac9aSAndroid Build Coastguard Worker # undef st_ctime
79*cf84ac9aSAndroid Build Coastguard Worker # include "asm_stat.h"
80*cf84ac9aSAndroid Build Coastguard Worker
81*cf84ac9aSAndroid Build Coastguard Worker # if STRUCT_STAT_IS_STAT64
82*cf84ac9aSAndroid Build Coastguard Worker # undef HAVE_STRUCT_STAT_ST_MTIME_NSEC
83*cf84ac9aSAndroid Build Coastguard Worker # if defined MPERS_IS_m32
84*cf84ac9aSAndroid Build Coastguard Worker # ifdef HAVE_M32_STRUCT_STAT64_ST_MTIME_NSEC
85*cf84ac9aSAndroid Build Coastguard Worker # define HAVE_STRUCT_STAT_ST_MTIME_NSEC 1
86*cf84ac9aSAndroid Build Coastguard Worker # endif
87*cf84ac9aSAndroid Build Coastguard Worker # elif defined MPERS_IS_mx32
88*cf84ac9aSAndroid Build Coastguard Worker # ifdef HAVE_MX32_STRUCT_STAT64_ST_MTIME_NSEC
89*cf84ac9aSAndroid Build Coastguard Worker # define HAVE_STRUCT_STAT_ST_MTIME_NSEC 1
90*cf84ac9aSAndroid Build Coastguard Worker # endif
91*cf84ac9aSAndroid Build Coastguard Worker # elif defined HAVE_STRUCT_STAT64_ST_MTIME_NSEC
92*cf84ac9aSAndroid Build Coastguard Worker # define HAVE_STRUCT_STAT_ST_MTIME_NSEC 1
93*cf84ac9aSAndroid Build Coastguard Worker # endif /* MPERS_IS_m32 || MPERS_IS_mx32 || HAVE_STRUCT_STAT64_ST_MTIME_NSEC */
94*cf84ac9aSAndroid Build Coastguard Worker # else /* !STRUCT_STAT_IS_STAT64 */
95*cf84ac9aSAndroid Build Coastguard Worker # if defined MPERS_IS_m32
96*cf84ac9aSAndroid Build Coastguard Worker # undef HAVE_STRUCT_STAT_ST_MTIME_NSEC
97*cf84ac9aSAndroid Build Coastguard Worker # ifdef HAVE_M32_STRUCT_STAT_ST_MTIME_NSEC
98*cf84ac9aSAndroid Build Coastguard Worker # define HAVE_STRUCT_STAT_ST_MTIME_NSEC 1
99*cf84ac9aSAndroid Build Coastguard Worker # endif
100*cf84ac9aSAndroid Build Coastguard Worker # elif defined MPERS_IS_mx32
101*cf84ac9aSAndroid Build Coastguard Worker # undef HAVE_STRUCT_STAT_ST_MTIME_NSEC
102*cf84ac9aSAndroid Build Coastguard Worker # ifdef HAVE_MX32_STRUCT_STAT_ST_MTIME_NSEC
103*cf84ac9aSAndroid Build Coastguard Worker # define HAVE_STRUCT_STAT_ST_MTIME_NSEC 1
104*cf84ac9aSAndroid Build Coastguard Worker # endif
105*cf84ac9aSAndroid Build Coastguard Worker # endif /* MPERS_IS_m32 || MPERS_IS_mx32 */
106*cf84ac9aSAndroid Build Coastguard Worker # endif /* STRUCT_STAT_IS_STAT64 */
107*cf84ac9aSAndroid Build Coastguard Worker
108*cf84ac9aSAndroid Build Coastguard Worker # ifndef TEST_BOGUS_STRUCT_STAT
109*cf84ac9aSAndroid Build Coastguard Worker # define TEST_BOGUS_STRUCT_STAT 1
110*cf84ac9aSAndroid Build Coastguard Worker # endif
111*cf84ac9aSAndroid Build Coastguard Worker
112*cf84ac9aSAndroid Build Coastguard Worker # ifndef IS_FSTAT
113*cf84ac9aSAndroid Build Coastguard Worker # define IS_FSTAT 0
114*cf84ac9aSAndroid Build Coastguard Worker # endif
115*cf84ac9aSAndroid Build Coastguard Worker
116*cf84ac9aSAndroid Build Coastguard Worker # ifndef OLD_STAT
117*cf84ac9aSAndroid Build Coastguard Worker # define OLD_STAT 0
118*cf84ac9aSAndroid Build Coastguard Worker # endif
119*cf84ac9aSAndroid Build Coastguard Worker
120*cf84ac9aSAndroid Build Coastguard Worker # ifndef IS_STATX
121*cf84ac9aSAndroid Build Coastguard Worker # define IS_STATX 0
122*cf84ac9aSAndroid Build Coastguard Worker # endif
123*cf84ac9aSAndroid Build Coastguard Worker
124*cf84ac9aSAndroid Build Coastguard Worker static void
print_ftype(const unsigned int mode)125*cf84ac9aSAndroid Build Coastguard Worker print_ftype(const unsigned int mode)
126*cf84ac9aSAndroid Build Coastguard Worker {
127*cf84ac9aSAndroid Build Coastguard Worker if (S_ISREG(mode))
128*cf84ac9aSAndroid Build Coastguard Worker printf("S_IFREG");
129*cf84ac9aSAndroid Build Coastguard Worker else if (S_ISDIR(mode))
130*cf84ac9aSAndroid Build Coastguard Worker printf("S_IFDIR");
131*cf84ac9aSAndroid Build Coastguard Worker else if (S_ISCHR(mode))
132*cf84ac9aSAndroid Build Coastguard Worker printf("S_IFCHR");
133*cf84ac9aSAndroid Build Coastguard Worker else if (S_ISBLK(mode))
134*cf84ac9aSAndroid Build Coastguard Worker printf("S_IFBLK");
135*cf84ac9aSAndroid Build Coastguard Worker else
136*cf84ac9aSAndroid Build Coastguard Worker printf("%#o", mode & S_IFMT);
137*cf84ac9aSAndroid Build Coastguard Worker }
138*cf84ac9aSAndroid Build Coastguard Worker
139*cf84ac9aSAndroid Build Coastguard Worker static void
print_perms(const unsigned int mode)140*cf84ac9aSAndroid Build Coastguard Worker print_perms(const unsigned int mode)
141*cf84ac9aSAndroid Build Coastguard Worker {
142*cf84ac9aSAndroid Build Coastguard Worker printf("%#o", mode & ~S_IFMT);
143*cf84ac9aSAndroid Build Coastguard Worker }
144*cf84ac9aSAndroid Build Coastguard Worker
145*cf84ac9aSAndroid Build Coastguard Worker # if !IS_STATX
146*cf84ac9aSAndroid Build Coastguard Worker
147*cf84ac9aSAndroid Build Coastguard Worker static void
print_stat(const STRUCT_STAT * st)148*cf84ac9aSAndroid Build Coastguard Worker print_stat(const STRUCT_STAT *st)
149*cf84ac9aSAndroid Build Coastguard Worker {
150*cf84ac9aSAndroid Build Coastguard Worker printf("{st_dev=makedev(%u, %u)",
151*cf84ac9aSAndroid Build Coastguard Worker (unsigned int) major(zero_extend_signed_to_ull(st->st_dev)),
152*cf84ac9aSAndroid Build Coastguard Worker (unsigned int) minor(zero_extend_signed_to_ull(st->st_dev)));
153*cf84ac9aSAndroid Build Coastguard Worker printf(", st_ino=%llu", zero_extend_signed_to_ull(st->st_ino));
154*cf84ac9aSAndroid Build Coastguard Worker printf(", st_mode=");
155*cf84ac9aSAndroid Build Coastguard Worker print_ftype(st->st_mode);
156*cf84ac9aSAndroid Build Coastguard Worker printf("|");
157*cf84ac9aSAndroid Build Coastguard Worker print_perms(st->st_mode);
158*cf84ac9aSAndroid Build Coastguard Worker printf(", st_nlink=%llu", zero_extend_signed_to_ull(st->st_nlink));
159*cf84ac9aSAndroid Build Coastguard Worker printf(", st_uid=%llu", zero_extend_signed_to_ull(st->st_uid));
160*cf84ac9aSAndroid Build Coastguard Worker printf(", st_gid=%llu", zero_extend_signed_to_ull(st->st_gid));
161*cf84ac9aSAndroid Build Coastguard Worker # if OLD_STAT
162*cf84ac9aSAndroid Build Coastguard Worker printf(", st_blksize=0, st_blocks=0");
163*cf84ac9aSAndroid Build Coastguard Worker # else /* !OLD_STAT */
164*cf84ac9aSAndroid Build Coastguard Worker printf(", st_blksize=%llu", zero_extend_signed_to_ull(st->st_blksize));
165*cf84ac9aSAndroid Build Coastguard Worker printf(", st_blocks=%llu", zero_extend_signed_to_ull(st->st_blocks));
166*cf84ac9aSAndroid Build Coastguard Worker # endif /* OLD_STAT */
167*cf84ac9aSAndroid Build Coastguard Worker
168*cf84ac9aSAndroid Build Coastguard Worker switch (st->st_mode & S_IFMT) {
169*cf84ac9aSAndroid Build Coastguard Worker case S_IFCHR: case S_IFBLK:
170*cf84ac9aSAndroid Build Coastguard Worker printf(", st_rdev=makedev(%u, %u)",
171*cf84ac9aSAndroid Build Coastguard Worker (unsigned int) major(zero_extend_signed_to_ull(st->st_rdev)),
172*cf84ac9aSAndroid Build Coastguard Worker (unsigned int) minor(zero_extend_signed_to_ull(st->st_rdev)));
173*cf84ac9aSAndroid Build Coastguard Worker break;
174*cf84ac9aSAndroid Build Coastguard Worker default:
175*cf84ac9aSAndroid Build Coastguard Worker printf(", st_size=%llu", zero_extend_signed_to_ull(st->st_size));
176*cf84ac9aSAndroid Build Coastguard Worker }
177*cf84ac9aSAndroid Build Coastguard Worker
178*cf84ac9aSAndroid Build Coastguard Worker # if defined(HAVE_STRUCT_STAT_ST_MTIME_NSEC) && !OLD_STAT
179*cf84ac9aSAndroid Build Coastguard Worker # define TIME_NSEC(val) zero_extend_signed_to_ull(val)
180*cf84ac9aSAndroid Build Coastguard Worker # define HAVE_NSEC 1
181*cf84ac9aSAndroid Build Coastguard Worker # else
182*cf84ac9aSAndroid Build Coastguard Worker # define TIME_NSEC(val) 0ULL
183*cf84ac9aSAndroid Build Coastguard Worker # define HAVE_NSEC 0
184*cf84ac9aSAndroid Build Coastguard Worker # endif
185*cf84ac9aSAndroid Build Coastguard Worker
186*cf84ac9aSAndroid Build Coastguard Worker #define PRINT_ST_TIME(field) \
187*cf84ac9aSAndroid Build Coastguard Worker do { \
188*cf84ac9aSAndroid Build Coastguard Worker printf(", st_" #field "=%lld", \
189*cf84ac9aSAndroid Build Coastguard Worker sign_extend_unsigned_to_ll(st->st_ ## field)); \
190*cf84ac9aSAndroid Build Coastguard Worker print_time_t_nsec(sign_extend_unsigned_to_ll(st->st_ ## field), \
191*cf84ac9aSAndroid Build Coastguard Worker TIME_NSEC(st->st_ ## field ## _nsec), 1); \
192*cf84ac9aSAndroid Build Coastguard Worker if (HAVE_NSEC) \
193*cf84ac9aSAndroid Build Coastguard Worker printf(", st_" #field "_nsec=%llu", \
194*cf84ac9aSAndroid Build Coastguard Worker TIME_NSEC(st->st_ ## field ## _nsec)); \
195*cf84ac9aSAndroid Build Coastguard Worker } while (0)
196*cf84ac9aSAndroid Build Coastguard Worker
197*cf84ac9aSAndroid Build Coastguard Worker PRINT_ST_TIME(atime);
198*cf84ac9aSAndroid Build Coastguard Worker PRINT_ST_TIME(mtime);
199*cf84ac9aSAndroid Build Coastguard Worker PRINT_ST_TIME(ctime);
200*cf84ac9aSAndroid Build Coastguard Worker printf("}");
201*cf84ac9aSAndroid Build Coastguard Worker }
202*cf84ac9aSAndroid Build Coastguard Worker
203*cf84ac9aSAndroid Build Coastguard Worker # else /* !IS_STATX */
204*cf84ac9aSAndroid Build Coastguard Worker
205*cf84ac9aSAndroid Build Coastguard Worker static void
print_stat(const STRUCT_STAT * st)206*cf84ac9aSAndroid Build Coastguard Worker print_stat(const STRUCT_STAT *st)
207*cf84ac9aSAndroid Build Coastguard Worker {
208*cf84ac9aSAndroid Build Coastguard Worker # define PRINT_FIELD_U32_UID(field) \
209*cf84ac9aSAndroid Build Coastguard Worker do { \
210*cf84ac9aSAndroid Build Coastguard Worker if (st->field == (uint32_t) -1) \
211*cf84ac9aSAndroid Build Coastguard Worker printf(", %s=-1", #field); \
212*cf84ac9aSAndroid Build Coastguard Worker else \
213*cf84ac9aSAndroid Build Coastguard Worker printf(", %s=%llu", #field, \
214*cf84ac9aSAndroid Build Coastguard Worker (unsigned long long) st->field); \
215*cf84ac9aSAndroid Build Coastguard Worker } while (0)
216*cf84ac9aSAndroid Build Coastguard Worker
217*cf84ac9aSAndroid Build Coastguard Worker # define PRINT_FIELD_TIME(field) \
218*cf84ac9aSAndroid Build Coastguard Worker do { \
219*cf84ac9aSAndroid Build Coastguard Worker printf(", %s={tv_sec=%lld, tv_nsec=%u}", \
220*cf84ac9aSAndroid Build Coastguard Worker #field, (long long) st->field.tv_sec, \
221*cf84ac9aSAndroid Build Coastguard Worker (unsigned) st->field.tv_nsec); \
222*cf84ac9aSAndroid Build Coastguard Worker print_time_t_nsec(st->field.tv_sec, \
223*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(st->field.tv_nsec), \
224*cf84ac9aSAndroid Build Coastguard Worker 1); \
225*cf84ac9aSAndroid Build Coastguard Worker } while (0)
226*cf84ac9aSAndroid Build Coastguard Worker
227*cf84ac9aSAndroid Build Coastguard Worker printf("{stx_mask=");
228*cf84ac9aSAndroid Build Coastguard Worker printflags(statx_masks, st->stx_mask, "STATX_???");
229*cf84ac9aSAndroid Build Coastguard Worker
230*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_blksize);
231*cf84ac9aSAndroid Build Coastguard Worker
232*cf84ac9aSAndroid Build Coastguard Worker printf(", stx_attributes=");
233*cf84ac9aSAndroid Build Coastguard Worker printflags(statx_attrs, st->stx_attributes, "STATX_ATTR_???");
234*cf84ac9aSAndroid Build Coastguard Worker
235*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_nlink);
236*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U32_UID(stx_uid);
237*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U32_UID(stx_gid);
238*cf84ac9aSAndroid Build Coastguard Worker
239*cf84ac9aSAndroid Build Coastguard Worker printf(", stx_mode=");
240*cf84ac9aSAndroid Build Coastguard Worker print_ftype(st->stx_mode);
241*cf84ac9aSAndroid Build Coastguard Worker printf("|");
242*cf84ac9aSAndroid Build Coastguard Worker print_perms(st->stx_mode);
243*cf84ac9aSAndroid Build Coastguard Worker
244*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_ino);
245*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_size);
246*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_blocks);
247*cf84ac9aSAndroid Build Coastguard Worker
248*cf84ac9aSAndroid Build Coastguard Worker printf(", stx_attributes_mask=");
249*cf84ac9aSAndroid Build Coastguard Worker printflags(statx_attrs, st->stx_attributes_mask, "STATX_ATTR_???");
250*cf84ac9aSAndroid Build Coastguard Worker
251*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_TIME(stx_atime);
252*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_TIME(stx_btime);
253*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_TIME(stx_ctime);
254*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_TIME(stx_mtime);
255*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_rdev_major);
256*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_rdev_minor);
257*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_dev_major);
258*cf84ac9aSAndroid Build Coastguard Worker PRINT_FIELD_U(", ", *st, stx_dev_minor);
259*cf84ac9aSAndroid Build Coastguard Worker printf("}");
260*cf84ac9aSAndroid Build Coastguard Worker }
261*cf84ac9aSAndroid Build Coastguard Worker
262*cf84ac9aSAndroid Build Coastguard Worker # endif /* !IS_STATX */
263*cf84ac9aSAndroid Build Coastguard Worker
264*cf84ac9aSAndroid Build Coastguard Worker static int
create_sample(const char * fname,const libc_off_t size)265*cf84ac9aSAndroid Build Coastguard Worker create_sample(const char *fname, const libc_off_t size)
266*cf84ac9aSAndroid Build Coastguard Worker {
267*cf84ac9aSAndroid Build Coastguard Worker static const struct timespec ts[] = {
268*cf84ac9aSAndroid Build Coastguard Worker {-10843, 135}, {-10841, 246}
269*cf84ac9aSAndroid Build Coastguard Worker };
270*cf84ac9aSAndroid Build Coastguard Worker
271*cf84ac9aSAndroid Build Coastguard Worker (void) close(0);
272*cf84ac9aSAndroid Build Coastguard Worker if (open(fname, O_RDWR | O_CREAT | O_TRUNC, 0640)) {
273*cf84ac9aSAndroid Build Coastguard Worker perror(fname);
274*cf84ac9aSAndroid Build Coastguard Worker return 77;
275*cf84ac9aSAndroid Build Coastguard Worker }
276*cf84ac9aSAndroid Build Coastguard Worker if (ftruncate(0, size)) {
277*cf84ac9aSAndroid Build Coastguard Worker perror("ftruncate");
278*cf84ac9aSAndroid Build Coastguard Worker return 77;
279*cf84ac9aSAndroid Build Coastguard Worker }
280*cf84ac9aSAndroid Build Coastguard Worker if (futimens(0, ts)) {
281*cf84ac9aSAndroid Build Coastguard Worker perror("futimens");
282*cf84ac9aSAndroid Build Coastguard Worker return 77;
283*cf84ac9aSAndroid Build Coastguard Worker }
284*cf84ac9aSAndroid Build Coastguard Worker return 0;
285*cf84ac9aSAndroid Build Coastguard Worker }
286*cf84ac9aSAndroid Build Coastguard Worker
287*cf84ac9aSAndroid Build Coastguard Worker int
main(void)288*cf84ac9aSAndroid Build Coastguard Worker main(void)
289*cf84ac9aSAndroid Build Coastguard Worker {
290*cf84ac9aSAndroid Build Coastguard Worker # if IS_FSTAT
291*cf84ac9aSAndroid Build Coastguard Worker skip_if_unavailable("/proc/self/fd/");
292*cf84ac9aSAndroid Build Coastguard Worker # else
293*cf84ac9aSAndroid Build Coastguard Worker static const char full[] = "/dev/full";
294*cf84ac9aSAndroid Build Coastguard Worker # endif
295*cf84ac9aSAndroid Build Coastguard Worker static const char sample[] = "stat.sample";
296*cf84ac9aSAndroid Build Coastguard Worker TAIL_ALLOC_OBJECT_CONST_PTR(STRUCT_STAT, st);
297*cf84ac9aSAndroid Build Coastguard Worker
298*cf84ac9aSAndroid Build Coastguard Worker int rc;
299*cf84ac9aSAndroid Build Coastguard Worker
300*cf84ac9aSAndroid Build Coastguard Worker rc = create_sample(sample, SAMPLE_SIZE);
301*cf84ac9aSAndroid Build Coastguard Worker if (rc)
302*cf84ac9aSAndroid Build Coastguard Worker return rc;
303*cf84ac9aSAndroid Build Coastguard Worker
304*cf84ac9aSAndroid Build Coastguard Worker # if TEST_BOGUS_STRUCT_STAT
305*cf84ac9aSAndroid Build Coastguard Worker STRUCT_STAT *st_cut = tail_alloc(sizeof(long) * 4);
306*cf84ac9aSAndroid Build Coastguard Worker rc = TEST_SYSCALL_INVOKE(sample, st_cut);
307*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_HEADER(sample);
308*cf84ac9aSAndroid Build Coastguard Worker printf("%p", st_cut);
309*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_FOOTER(rc);
310*cf84ac9aSAndroid Build Coastguard Worker # endif
311*cf84ac9aSAndroid Build Coastguard Worker
312*cf84ac9aSAndroid Build Coastguard Worker # if !IS_FSTAT
313*cf84ac9aSAndroid Build Coastguard Worker rc = TEST_SYSCALL_INVOKE(full, st);
314*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_HEADER(full);
315*cf84ac9aSAndroid Build Coastguard Worker if (rc)
316*cf84ac9aSAndroid Build Coastguard Worker printf("%p", st);
317*cf84ac9aSAndroid Build Coastguard Worker else
318*cf84ac9aSAndroid Build Coastguard Worker print_stat(st);
319*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_FOOTER(rc);
320*cf84ac9aSAndroid Build Coastguard Worker # endif
321*cf84ac9aSAndroid Build Coastguard Worker
322*cf84ac9aSAndroid Build Coastguard Worker if ((rc = TEST_SYSCALL_INVOKE(sample, st))) {
323*cf84ac9aSAndroid Build Coastguard Worker if (errno != EOVERFLOW) {
324*cf84ac9aSAndroid Build Coastguard Worker rc = (errno == ENOSYS) ? 77 : 1;
325*cf84ac9aSAndroid Build Coastguard Worker perror(TEST_SYSCALL_STR);
326*cf84ac9aSAndroid Build Coastguard Worker return rc;
327*cf84ac9aSAndroid Build Coastguard Worker }
328*cf84ac9aSAndroid Build Coastguard Worker }
329*cf84ac9aSAndroid Build Coastguard Worker
330*cf84ac9aSAndroid Build Coastguard Worker # if IS_STATX
331*cf84ac9aSAndroid Build Coastguard Worker # define ST_SIZE_FIELD stx_size
332*cf84ac9aSAndroid Build Coastguard Worker # else
333*cf84ac9aSAndroid Build Coastguard Worker # define ST_SIZE_FIELD st_size
334*cf84ac9aSAndroid Build Coastguard Worker # endif
335*cf84ac9aSAndroid Build Coastguard Worker if (!rc && zero_extend_signed_to_ull(SAMPLE_SIZE) !=
336*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(st->ST_SIZE_FIELD)) {
337*cf84ac9aSAndroid Build Coastguard Worker fprintf(stderr, "Size mismatch: "
338*cf84ac9aSAndroid Build Coastguard Worker "requested size(%llu) != st_size(%llu)\n",
339*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(SAMPLE_SIZE),
340*cf84ac9aSAndroid Build Coastguard Worker zero_extend_signed_to_ull(st->ST_SIZE_FIELD));
341*cf84ac9aSAndroid Build Coastguard Worker fprintf(stderr, "The most likely reason for this is incorrect"
342*cf84ac9aSAndroid Build Coastguard Worker " definition of %s.\n"
343*cf84ac9aSAndroid Build Coastguard Worker "Here is some diagnostics that might help:\n",
344*cf84ac9aSAndroid Build Coastguard Worker STRUCT_STAT_STR);
345*cf84ac9aSAndroid Build Coastguard Worker
346*cf84ac9aSAndroid Build Coastguard Worker # define LOG_STAT_OFFSETOF_SIZEOF(object, member) \
347*cf84ac9aSAndroid Build Coastguard Worker fprintf(stderr, "offsetof(%s, %s) = %zu" \
348*cf84ac9aSAndroid Build Coastguard Worker ", sizeof(%s) = %zu\n", \
349*cf84ac9aSAndroid Build Coastguard Worker STRUCT_STAT_STR, #member, \
350*cf84ac9aSAndroid Build Coastguard Worker offsetof(STRUCT_STAT, member), \
351*cf84ac9aSAndroid Build Coastguard Worker #member, sizeof((object).member))
352*cf84ac9aSAndroid Build Coastguard Worker
353*cf84ac9aSAndroid Build Coastguard Worker # if IS_STATX
354*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_mask);
355*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_blksize);
356*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_attributes);
357*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_nlink);
358*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_uid);
359*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_gid);
360*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_mode);
361*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_ino);
362*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_size);
363*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_blocks);
364*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_attributes_mask);
365*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_atime);
366*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_btime);
367*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_ctime);
368*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_mtime);
369*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_rdev_major);
370*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_rdev_minor);
371*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_dev_major);
372*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, stx_dev_minor);
373*cf84ac9aSAndroid Build Coastguard Worker # else
374*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_dev);
375*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_ino);
376*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_mode);
377*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_nlink);
378*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_uid);
379*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_gid);
380*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_rdev);
381*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_size);
382*cf84ac9aSAndroid Build Coastguard Worker # if !OLD_STAT
383*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_blksize);
384*cf84ac9aSAndroid Build Coastguard Worker LOG_STAT_OFFSETOF_SIZEOF(*st, st_blocks);
385*cf84ac9aSAndroid Build Coastguard Worker # endif /* !OLD_STAT */
386*cf84ac9aSAndroid Build Coastguard Worker
387*cf84ac9aSAndroid Build Coastguard Worker # endif /* IS_STATX */
388*cf84ac9aSAndroid Build Coastguard Worker
389*cf84ac9aSAndroid Build Coastguard Worker return 1;
390*cf84ac9aSAndroid Build Coastguard Worker }
391*cf84ac9aSAndroid Build Coastguard Worker
392*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_HEADER(sample);
393*cf84ac9aSAndroid Build Coastguard Worker if (rc)
394*cf84ac9aSAndroid Build Coastguard Worker printf("%p", st);
395*cf84ac9aSAndroid Build Coastguard Worker else
396*cf84ac9aSAndroid Build Coastguard Worker print_stat(st);
397*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_FOOTER(rc);
398*cf84ac9aSAndroid Build Coastguard Worker
399*cf84ac9aSAndroid Build Coastguard Worker # if IS_STATX
400*cf84ac9aSAndroid Build Coastguard Worker
401*cf84ac9aSAndroid Build Coastguard Worker # define INVOKE() \
402*cf84ac9aSAndroid Build Coastguard Worker do { \
403*cf84ac9aSAndroid Build Coastguard Worker rc = TEST_SYSCALL_INVOKE(sample, st); \
404*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_HEADER(sample); \
405*cf84ac9aSAndroid Build Coastguard Worker if (rc) \
406*cf84ac9aSAndroid Build Coastguard Worker printf("%p", st); \
407*cf84ac9aSAndroid Build Coastguard Worker else \
408*cf84ac9aSAndroid Build Coastguard Worker print_stat(st); \
409*cf84ac9aSAndroid Build Coastguard Worker PRINT_SYSCALL_FOOTER(rc); \
410*cf84ac9aSAndroid Build Coastguard Worker } while (0)
411*cf84ac9aSAndroid Build Coastguard Worker
412*cf84ac9aSAndroid Build Coastguard Worker # define SET_FLAGS_INVOKE(flags, flags_str) \
413*cf84ac9aSAndroid Build Coastguard Worker do { \
414*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_FLAGS = flags; \
415*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_FLAGS_STR = flags_str; \
416*cf84ac9aSAndroid Build Coastguard Worker INVOKE(); \
417*cf84ac9aSAndroid Build Coastguard Worker } while (0)
418*cf84ac9aSAndroid Build Coastguard Worker
419*cf84ac9aSAndroid Build Coastguard Worker # define SET_MASK_INVOKE(mask, mask_str) \
420*cf84ac9aSAndroid Build Coastguard Worker do { \
421*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_MASK = mask; \
422*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_MASK_STR = mask_str; \
423*cf84ac9aSAndroid Build Coastguard Worker INVOKE(); \
424*cf84ac9aSAndroid Build Coastguard Worker } while (0)
425*cf84ac9aSAndroid Build Coastguard Worker
426*cf84ac9aSAndroid Build Coastguard Worker unsigned old_flags = TEST_SYSCALL_STATX_FLAGS;
427*cf84ac9aSAndroid Build Coastguard Worker const char *old_flags_str = TEST_SYSCALL_STATX_FLAGS_STR;
428*cf84ac9aSAndroid Build Coastguard Worker unsigned old_mask = TEST_SYSCALL_STATX_MASK;
429*cf84ac9aSAndroid Build Coastguard Worker const char *old_mask_str = TEST_SYSCALL_STATX_MASK_STR;
430*cf84ac9aSAndroid Build Coastguard Worker
431*cf84ac9aSAndroid Build Coastguard Worker SET_FLAGS_INVOKE(AT_SYMLINK_FOLLOW | 0xffff0000U,
432*cf84ac9aSAndroid Build Coastguard Worker "AT_STATX_SYNC_AS_STAT|AT_SYMLINK_FOLLOW|0xffff0000");
433*cf84ac9aSAndroid Build Coastguard Worker
434*cf84ac9aSAndroid Build Coastguard Worker SET_FLAGS_INVOKE(AT_STATX_SYNC_TYPE,
435*cf84ac9aSAndroid Build Coastguard Worker "AT_STATX_FORCE_SYNC|AT_STATX_DONT_SYNC");
436*cf84ac9aSAndroid Build Coastguard Worker
437*cf84ac9aSAndroid Build Coastguard Worker SET_FLAGS_INVOKE(0xffffff,
438*cf84ac9aSAndroid Build Coastguard Worker "AT_STATX_FORCE_SYNC|AT_STATX_DONT_SYNC|AT_SYMLINK_NOFOLLOW|"
439*cf84ac9aSAndroid Build Coastguard Worker "AT_REMOVEDIR|AT_SYMLINK_FOLLOW|AT_NO_AUTOMOUNT|AT_EMPTY_PATH|"
440*cf84ac9aSAndroid Build Coastguard Worker "0xff80ff");
441*cf84ac9aSAndroid Build Coastguard Worker
442*cf84ac9aSAndroid Build Coastguard Worker /* We're done playing with flags. */
443*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_FLAGS = old_flags;
444*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_FLAGS_STR = old_flags_str;
445*cf84ac9aSAndroid Build Coastguard Worker
446*cf84ac9aSAndroid Build Coastguard Worker SET_MASK_INVOKE(0, "0");
447*cf84ac9aSAndroid Build Coastguard Worker SET_MASK_INVOKE(0xfffff000U, "0xfffff000 /* STATX_??? */");
448*cf84ac9aSAndroid Build Coastguard Worker
449*cf84ac9aSAndroid Build Coastguard Worker SET_MASK_INVOKE(0xfffffffbU,
450*cf84ac9aSAndroid Build Coastguard Worker "STATX_TYPE|STATX_MODE|STATX_UID|STATX_GID|STATX_ATIME|"
451*cf84ac9aSAndroid Build Coastguard Worker "STATX_MTIME|STATX_CTIME|STATX_INO|STATX_SIZE|STATX_BLOCKS|"
452*cf84ac9aSAndroid Build Coastguard Worker "STATX_BTIME|0xfffff000");
453*cf84ac9aSAndroid Build Coastguard Worker
454*cf84ac9aSAndroid Build Coastguard Worker SET_MASK_INVOKE(STATX_UID, "STATX_UID");
455*cf84ac9aSAndroid Build Coastguard Worker
456*cf84ac9aSAndroid Build Coastguard Worker /* ...and with mask. */
457*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_MASK = old_mask;
458*cf84ac9aSAndroid Build Coastguard Worker TEST_SYSCALL_STATX_MASK_STR = old_mask_str;
459*cf84ac9aSAndroid Build Coastguard Worker
460*cf84ac9aSAndroid Build Coastguard Worker # endif /* IS_STATX */
461*cf84ac9aSAndroid Build Coastguard Worker
462*cf84ac9aSAndroid Build Coastguard Worker puts("+++ exited with 0 +++");
463*cf84ac9aSAndroid Build Coastguard Worker return 0;
464*cf84ac9aSAndroid Build Coastguard Worker }
465*cf84ac9aSAndroid Build Coastguard Worker
466*cf84ac9aSAndroid Build Coastguard Worker #else
467*cf84ac9aSAndroid Build Coastguard Worker
468*cf84ac9aSAndroid Build Coastguard Worker SKIP_MAIN_UNDEFINED("HAVE_FTRUNCATE && HAVE_FUTIMENS")
469*cf84ac9aSAndroid Build Coastguard Worker
470*cf84ac9aSAndroid Build Coastguard Worker #endif
471