1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 1991, 1992 Paul Kranenburg <[email protected]>
3*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 1993 Branko Lankester <[email protected]>
4*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 1993, 1994, 1995, 1996 Rick Sladkey <[email protected]>
5*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 1996-1999 Wichert Akkerman <[email protected]>
6*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2002-2005 Roland McGrath <[email protected]>
7*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2009 Andreas Schwab <[email protected]>
8*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2012 H.J. Lu <[email protected]>
9*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2013 Denys Vlasenko <[email protected]>
10*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2014-2016 Dmitry V. Levin <[email protected]>
11*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2014-2018 The strace developers.
12*cf84ac9aSAndroid Build Coastguard Worker * All rights reserved.
13*cf84ac9aSAndroid Build Coastguard Worker *
14*cf84ac9aSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
15*cf84ac9aSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions
16*cf84ac9aSAndroid Build Coastguard Worker * are met:
17*cf84ac9aSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
18*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
19*cf84ac9aSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
20*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
21*cf84ac9aSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
22*cf84ac9aSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products
23*cf84ac9aSAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
24*cf84ac9aSAndroid Build Coastguard Worker *
25*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
26*cf84ac9aSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
27*cf84ac9aSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
28*cf84ac9aSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
29*cf84ac9aSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
30*cf84ac9aSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
31*cf84ac9aSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
32*cf84ac9aSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33*cf84ac9aSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
34*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35*cf84ac9aSAndroid Build Coastguard Worker */
36*cf84ac9aSAndroid Build Coastguard Worker
37*cf84ac9aSAndroid Build Coastguard Worker #include "defs.h"
38*cf84ac9aSAndroid Build Coastguard Worker
39*cf84ac9aSAndroid Build Coastguard Worker #include "xlat/whence_codes.h"
40*cf84ac9aSAndroid Build Coastguard Worker
41*cf84ac9aSAndroid Build Coastguard Worker /* Linux kernel has exactly one version of lseek:
42*cf84ac9aSAndroid Build Coastguard Worker * fs/read_write.c::SYSCALL_DEFINE3(lseek, unsigned, fd, off_t, offset, unsigned, origin)
43*cf84ac9aSAndroid Build Coastguard Worker * In kernel, off_t is always the same as (kernel's) long
44*cf84ac9aSAndroid Build Coastguard Worker * (see include/uapi/asm-generic/posix_types.h).
45*cf84ac9aSAndroid Build Coastguard Worker * Use test/x32_lseek.c to test lseek decoding.
46*cf84ac9aSAndroid Build Coastguard Worker */
SYS_FUNC(lseek)47*cf84ac9aSAndroid Build Coastguard Worker SYS_FUNC(lseek)
48*cf84ac9aSAndroid Build Coastguard Worker {
49*cf84ac9aSAndroid Build Coastguard Worker printfd(tcp, tcp->u_arg[0]);
50*cf84ac9aSAndroid Build Coastguard Worker
51*cf84ac9aSAndroid Build Coastguard Worker kernel_long_t offset;
52*cf84ac9aSAndroid Build Coastguard Worker
53*cf84ac9aSAndroid Build Coastguard Worker # ifndef current_klongsize
54*cf84ac9aSAndroid Build Coastguard Worker if (current_klongsize < sizeof(kernel_long_t)) {
55*cf84ac9aSAndroid Build Coastguard Worker offset = (int) tcp->u_arg[1];
56*cf84ac9aSAndroid Build Coastguard Worker } else
57*cf84ac9aSAndroid Build Coastguard Worker # endif /* !current_klongsize */
58*cf84ac9aSAndroid Build Coastguard Worker {
59*cf84ac9aSAndroid Build Coastguard Worker offset = tcp->u_arg[1];
60*cf84ac9aSAndroid Build Coastguard Worker }
61*cf84ac9aSAndroid Build Coastguard Worker
62*cf84ac9aSAndroid Build Coastguard Worker tprintf(", %" PRI_kld ", ", offset);
63*cf84ac9aSAndroid Build Coastguard Worker
64*cf84ac9aSAndroid Build Coastguard Worker printxval(whence_codes, tcp->u_arg[2], "SEEK_???");
65*cf84ac9aSAndroid Build Coastguard Worker
66*cf84ac9aSAndroid Build Coastguard Worker return RVAL_DECODED;
67*cf84ac9aSAndroid Build Coastguard Worker }
68*cf84ac9aSAndroid Build Coastguard Worker
69*cf84ac9aSAndroid Build Coastguard Worker /* llseek syscall takes explicitly two ulong arguments hi, lo,
70*cf84ac9aSAndroid Build Coastguard Worker * rather than one 64-bit argument for which ULONG_LONG works
71*cf84ac9aSAndroid Build Coastguard Worker * appropriate for the native byte order.
72*cf84ac9aSAndroid Build Coastguard Worker *
73*cf84ac9aSAndroid Build Coastguard Worker * See kernel's fs/read_write.c::SYSCALL_DEFINE5(llseek, ...)
74*cf84ac9aSAndroid Build Coastguard Worker *
75*cf84ac9aSAndroid Build Coastguard Worker * hi,lo are "unsigned longs" and combined exactly this way in kernel:
76*cf84ac9aSAndroid Build Coastguard Worker * ((loff_t) hi << 32) | lo
77*cf84ac9aSAndroid Build Coastguard Worker * Note that for architectures with kernel's long wider than userspace long
78*cf84ac9aSAndroid Build Coastguard Worker * (such as x32), combining code will use *kernel's*, i.e. *wide* longs
79*cf84ac9aSAndroid Build Coastguard Worker * for hi and lo.
80*cf84ac9aSAndroid Build Coastguard Worker */
SYS_FUNC(llseek)81*cf84ac9aSAndroid Build Coastguard Worker SYS_FUNC(llseek)
82*cf84ac9aSAndroid Build Coastguard Worker {
83*cf84ac9aSAndroid Build Coastguard Worker if (entering(tcp)) {
84*cf84ac9aSAndroid Build Coastguard Worker printfd(tcp, tcp->u_arg[0]);
85*cf84ac9aSAndroid Build Coastguard Worker tprintf(", %lld, ",
86*cf84ac9aSAndroid Build Coastguard Worker ((long long) tcp->u_arg[1] << 32)
87*cf84ac9aSAndroid Build Coastguard Worker | ((long long) tcp->u_arg[2]));
88*cf84ac9aSAndroid Build Coastguard Worker } else {
89*cf84ac9aSAndroid Build Coastguard Worker printnum_int64(tcp, tcp->u_arg[3], "%" PRIu64);
90*cf84ac9aSAndroid Build Coastguard Worker tprints(", ");
91*cf84ac9aSAndroid Build Coastguard Worker printxval(whence_codes, tcp->u_arg[4], "SEEK_???");
92*cf84ac9aSAndroid Build Coastguard Worker }
93*cf84ac9aSAndroid Build Coastguard Worker return 0;
94*cf84ac9aSAndroid Build Coastguard Worker }
95