blob: 477fea2c0a27b0b9716014f66da85db7ff6b838b [file] [log] [blame]
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +00001/*
2 * Copyright (c) 2009, 2010 Jeff Mahoney <jeffm@suse.com>
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +00003 * Copyright (c) 2011-2016 Dmitry V. Levin <ldv@altlinux.org>
Elliott Hughes28e98bc2018-06-14 16:59:04 -07004 * Copyright (c) 2011-2018 The strace developers.
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +00005 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. The name of the author may not be used to endorse or promote products
16 * derived from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 */
29
30#include "defs.h"
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +000031
32#include DEF_MPERS_TYPE(struct_blk_user_trace_setup)
33#include DEF_MPERS_TYPE(struct_blkpg_ioctl_arg)
34#include DEF_MPERS_TYPE(struct_blkpg_partition)
35
Elliott Hughesd35df492017-02-15 15:19:05 -080036#include <linux/ioctl.h>
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000037#include <linux/fs.h>
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000038
Elliott Hughesd35df492017-02-15 15:19:05 -080039typedef struct {
40 int op;
41 int flags;
42 int datalen;
43 void *data;
44} struct_blkpg_ioctl_arg;
45
46#define BLKPG_DEVNAMELTH 64
47#define BLKPG_VOLNAMELTH 64
48typedef struct {
49 int64_t start; /* starting offset in bytes */
50 int64_t length; /* length in bytes */
51 int pno; /* partition number */
52 char devname[BLKPG_DEVNAMELTH]; /* partition name, like sda5 or c0d1p2,
53 to be used in kernel messages */
54 char volname[BLKPG_VOLNAMELTH]; /* volume label */
55} struct_blkpg_partition;
56
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000057#define BLKTRACE_BDEV_SIZE 32
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +000058typedef struct blk_user_trace_setup {
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000059 char name[BLKTRACE_BDEV_SIZE]; /* output */
60 uint16_t act_mask; /* input */
61 uint32_t buf_size; /* input */
62 uint32_t buf_nr; /* input */
63 uint64_t start_lba;
64 uint64_t end_lba;
65 uint32_t pid;
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +000066} struct_blk_user_trace_setup;
67
Elliott Hughesc1873762018-12-19 15:13:36 -080068/* Provide fall-back definitions for BLK* ioctls */
69#define XLAT_MACROS_ONLY
70# include "xlat/block_ioctl_cmds.h"
71#undef XLAT_MACROS_ONLY
72
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +000073#include MPERS_DEFS
74
Elliott Hughes77c3ff82017-09-08 17:11:00 -070075#include "print_fields.h"
76
Dmitry V. Levin0ed617b2014-04-25 23:30:54 +000077#include "xlat/blkpg_ops.h"
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000078
79static void
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +000080print_blkpg_req(struct tcb *tcp, const struct_blkpg_ioctl_arg *blkpg)
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000081{
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +000082 struct_blkpg_partition p;
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000083
Elliott Hughes77c3ff82017-09-08 17:11:00 -070084 PRINT_FIELD_XVAL("{", *blkpg, op, blkpg_ops, "BLKPG_???");
85 PRINT_FIELD_D(", ", *blkpg, flags);
86 PRINT_FIELD_D(", ", *blkpg, datalen);
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000087
Elliott Hughes77c3ff82017-09-08 17:11:00 -070088 tprints(", data=");
Elliott Hughesd35df492017-02-15 15:19:05 -080089 if (!umove_or_printaddr(tcp, ptr_to_kulong(blkpg->data), &p)) {
Elliott Hughes77c3ff82017-09-08 17:11:00 -070090 PRINT_FIELD_D("{", p, start);
91 PRINT_FIELD_D(", ", p, length);
92 PRINT_FIELD_D(", ", p, pno);
93 PRINT_FIELD_CSTRING(", ", p, devname);
94 PRINT_FIELD_CSTRING(", ", p, volname);
Dmitry V. Levina0beac12015-07-05 15:15:03 +030095 tprints("}");
Dmitry V. Levin0a870582015-01-25 01:04:01 +000096 }
Dmitry V. Levina0beac12015-07-05 15:15:03 +030097 tprints("}");
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +000098}
99
Elliott Hughesd35df492017-02-15 15:19:05 -0800100MPERS_PRINTER_DECL(int, block_ioctl, struct tcb *const tcp,
101 const unsigned int code, const kernel_ulong_t arg)
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000102{
103 switch (code) {
Dmitry V. Levinbe284ca2011-01-16 23:07:51 +0000104 /* take arg as a value, not as a pointer */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000105 case BLKRASET:
106 case BLKFRASET:
Elliott Hughesd35df492017-02-15 15:19:05 -0800107 tprintf(", %" PRI_klu, arg);
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000108 break;
109
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300110 /* return an unsigned short */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000111 case BLKSECTGET:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300112 case BLKROTATIONAL:
113 if (entering(tcp))
114 return 0;
115 tprints(", ");
116 printnum_short(tcp, arg, "%hu");
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000117 break;
118
Dmitry V. Levinbe284ca2011-01-16 23:07:51 +0000119 /* return a signed int */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000120 case BLKROGET:
121 case BLKBSZGET:
122 case BLKSSZGET:
123 case BLKALIGNOFF:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300124 if (entering(tcp))
125 return 0;
Elliott Hughes28e98bc2018-06-14 16:59:04 -0700126 ATTRIBUTE_FALLTHROUGH;
Dmitry V. Levin0c9087c2016-05-26 12:36:56 +0000127 /* take a signed int */
128 case BLKROSET:
129 case BLKBSZSET:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300130 tprints(", ");
131 printnum_int(tcp, arg, "%d");
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000132 break;
133
Dmitry V. Levinbe284ca2011-01-16 23:07:51 +0000134 /* return an unsigned int */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000135 case BLKPBSZGET:
136 case BLKIOMIN:
137 case BLKIOOPT:
138 case BLKDISCARDZEROES:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300139 if (entering(tcp))
140 return 0;
141 tprints(", ");
142 printnum_int(tcp, arg, "%u");
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000143 break;
144
Dmitry V. Levinbe284ca2011-01-16 23:07:51 +0000145 /* return a signed long */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000146 case BLKRAGET:
147 case BLKFRAGET:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300148 if (entering(tcp))
149 return 0;
150 tprints(", ");
Dmitry V. Levin2479ef02015-08-18 14:58:27 +0000151 printnum_slong(tcp, arg);
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000152 break;
153
Dmitry V. Levinbe284ca2011-01-16 23:07:51 +0000154 /* returns an unsigned long */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000155 case BLKGETSIZE:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300156 if (entering(tcp))
157 return 0;
158 tprints(", ");
Dmitry V. Levin2479ef02015-08-18 14:58:27 +0000159 printnum_ulong(tcp, arg);
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000160 break;
161
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300162 /* returns an uint64_t */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000163 case BLKGETSIZE64:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300164 if (entering(tcp))
165 return 0;
166 tprints(", ");
167 printnum_int64(tcp, arg, "%" PRIu64);
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000168 break;
169
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300170 /* takes a pair of uint64_t */
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000171 case BLKDISCARD:
172 case BLKSECDISCARD:
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300173 case BLKZEROOUT:
174 tprints(", ");
Dmitry V. Levin46d25c22016-05-26 12:33:21 +0000175 printpair_int64(tcp, arg, "%" PRIu64);
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000176 break;
177
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300178 /* More complex types */
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300179 case BLKPG: {
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +0000180 struct_blkpg_ioctl_arg blkpg;
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300181
182 tprints(", ");
183 if (!umove_or_printaddr(tcp, arg, &blkpg))
184 print_blkpg_req(tcp, &blkpg);
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000185 break;
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300186 }
Dmitry V. Levinbe284ca2011-01-16 23:07:51 +0000187
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000188 case BLKTRACESETUP:
189 if (entering(tcp)) {
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +0000190 struct_blk_user_trace_setup buts;
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300191
192 tprints(", ");
193 if (umove_or_printaddr(tcp, arg, &buts))
194 break;
Elliott Hughes77c3ff82017-09-08 17:11:00 -0700195 PRINT_FIELD_U("{", buts, act_mask);
196 PRINT_FIELD_U(", ", buts, buf_size);
197 PRINT_FIELD_U(", ", buts, buf_nr);
198 PRINT_FIELD_U(", ", buts, start_lba);
199 PRINT_FIELD_U(", ", buts, end_lba);
200 PRINT_FIELD_U(", ", buts, pid);
201 return 0;
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300202 } else {
Dmitry V. Levin37d1b3d2016-05-26 10:43:51 +0000203 struct_blk_user_trace_setup buts;
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300204
Elliott Hughes77c3ff82017-09-08 17:11:00 -0700205 if (!syserror(tcp) && !umove(tcp, arg, &buts))
206 PRINT_FIELD_CSTRING(", ", buts, name);
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300207 tprints("}");
208 break;
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000209 }
Dmitry V. Levinbe284ca2011-01-16 23:07:51 +0000210
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300211 /* No arguments */
212 case BLKRRPART:
213 case BLKFLSBUF:
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000214 case BLKTRACESTART:
215 case BLKTRACESTOP:
216 case BLKTRACETEARDOWN:
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000217 break;
Dmitry V. Levina0beac12015-07-05 15:15:03 +0300218 default:
219 return RVAL_DECODED;
220 }
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000221
Elliott Hughes77c3ff82017-09-08 17:11:00 -0700222 return RVAL_IOCTL_DECODED;
Dmitry V. Levin4ef6db42011-01-15 20:15:31 +0000223}