xref: /aosp_15_r20/external/strace/mtd.c (revision cf84ac9a129d8ea9952db616b4e9b904c4bdde56)
1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2012 Mike Frysinger <[email protected]>
3*cf84ac9aSAndroid Build Coastguard Worker  * Copyright (c) 2012-2018 The strace developers.
4*cf84ac9aSAndroid Build Coastguard Worker  *
5*cf84ac9aSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
6*cf84ac9aSAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
7*cf84ac9aSAndroid Build Coastguard Worker  * are met:
8*cf84ac9aSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright
9*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
10*cf84ac9aSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
11*cf84ac9aSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in the
12*cf84ac9aSAndroid Build Coastguard Worker  *    documentation and/or other materials provided with the distribution.
13*cf84ac9aSAndroid Build Coastguard Worker  * 3. The name of the author may not be used to endorse or promote products
14*cf84ac9aSAndroid Build Coastguard Worker  *    derived from this software without specific prior written permission.
15*cf84ac9aSAndroid Build Coastguard Worker  *
16*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17*cf84ac9aSAndroid Build Coastguard Worker  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18*cf84ac9aSAndroid Build Coastguard Worker  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19*cf84ac9aSAndroid Build Coastguard Worker  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20*cf84ac9aSAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21*cf84ac9aSAndroid Build Coastguard Worker  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22*cf84ac9aSAndroid Build Coastguard Worker  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23*cf84ac9aSAndroid Build Coastguard Worker  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24*cf84ac9aSAndroid Build Coastguard Worker  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25*cf84ac9aSAndroid Build Coastguard Worker  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*cf84ac9aSAndroid Build Coastguard Worker  */
27*cf84ac9aSAndroid Build Coastguard Worker 
28*cf84ac9aSAndroid Build Coastguard Worker #include "defs.h"
29*cf84ac9aSAndroid Build Coastguard Worker 
30*cf84ac9aSAndroid Build Coastguard Worker #ifdef HAVE_STRUCT_MTD_WRITE_REQ
31*cf84ac9aSAndroid Build Coastguard Worker 
32*cf84ac9aSAndroid Build Coastguard Worker # include DEF_MPERS_TYPE(struct_mtd_oob_buf)
33*cf84ac9aSAndroid Build Coastguard Worker 
34*cf84ac9aSAndroid Build Coastguard Worker # include <linux/ioctl.h>
35*cf84ac9aSAndroid Build Coastguard Worker # include <mtd/mtd-abi.h>
36*cf84ac9aSAndroid Build Coastguard Worker 
37*cf84ac9aSAndroid Build Coastguard Worker typedef struct mtd_oob_buf struct_mtd_oob_buf;
38*cf84ac9aSAndroid Build Coastguard Worker 
39*cf84ac9aSAndroid Build Coastguard Worker #endif /* HAVE_STRUCT_MTD_WRITE_REQ */
40*cf84ac9aSAndroid Build Coastguard Worker 
41*cf84ac9aSAndroid Build Coastguard Worker #include MPERS_DEFS
42*cf84ac9aSAndroid Build Coastguard Worker 
43*cf84ac9aSAndroid Build Coastguard Worker #ifdef HAVE_STRUCT_MTD_WRITE_REQ
44*cf84ac9aSAndroid Build Coastguard Worker 
45*cf84ac9aSAndroid Build Coastguard Worker # include "xlat/mtd_mode_options.h"
46*cf84ac9aSAndroid Build Coastguard Worker # include "xlat/mtd_file_mode_options.h"
47*cf84ac9aSAndroid Build Coastguard Worker # include "xlat/mtd_type_options.h"
48*cf84ac9aSAndroid Build Coastguard Worker # include "xlat/mtd_flags_options.h"
49*cf84ac9aSAndroid Build Coastguard Worker # include "xlat/mtd_otp_options.h"
50*cf84ac9aSAndroid Build Coastguard Worker # include "xlat/mtd_nandecc_options.h"
51*cf84ac9aSAndroid Build Coastguard Worker 
52*cf84ac9aSAndroid Build Coastguard Worker static void
decode_erase_info_user(struct tcb * const tcp,const kernel_ulong_t addr)53*cf84ac9aSAndroid Build Coastguard Worker decode_erase_info_user(struct tcb *const tcp, const kernel_ulong_t addr)
54*cf84ac9aSAndroid Build Coastguard Worker {
55*cf84ac9aSAndroid Build Coastguard Worker 	struct erase_info_user einfo;
56*cf84ac9aSAndroid Build Coastguard Worker 
57*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
58*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &einfo))
59*cf84ac9aSAndroid Build Coastguard Worker 		return;
60*cf84ac9aSAndroid Build Coastguard Worker 
61*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{start=%#x, length=%#x}", einfo.start, einfo.length);
62*cf84ac9aSAndroid Build Coastguard Worker }
63*cf84ac9aSAndroid Build Coastguard Worker 
64*cf84ac9aSAndroid Build Coastguard Worker static void
decode_erase_info_user64(struct tcb * const tcp,const kernel_ulong_t addr)65*cf84ac9aSAndroid Build Coastguard Worker decode_erase_info_user64(struct tcb *const tcp, const kernel_ulong_t addr)
66*cf84ac9aSAndroid Build Coastguard Worker {
67*cf84ac9aSAndroid Build Coastguard Worker 	struct erase_info_user64 einfo64;
68*cf84ac9aSAndroid Build Coastguard Worker 
69*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
70*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &einfo64))
71*cf84ac9aSAndroid Build Coastguard Worker 		return;
72*cf84ac9aSAndroid Build Coastguard Worker 
73*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{start=%#" PRIx64 ", length=%#" PRIx64 "}",
74*cf84ac9aSAndroid Build Coastguard Worker 		(uint64_t) einfo64.start, (uint64_t) einfo64.length);
75*cf84ac9aSAndroid Build Coastguard Worker }
76*cf84ac9aSAndroid Build Coastguard Worker 
77*cf84ac9aSAndroid Build Coastguard Worker static void
decode_mtd_oob_buf(struct tcb * const tcp,const kernel_ulong_t addr)78*cf84ac9aSAndroid Build Coastguard Worker decode_mtd_oob_buf(struct tcb *const tcp, const kernel_ulong_t addr)
79*cf84ac9aSAndroid Build Coastguard Worker {
80*cf84ac9aSAndroid Build Coastguard Worker 	struct_mtd_oob_buf mbuf;
81*cf84ac9aSAndroid Build Coastguard Worker 
82*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
83*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &mbuf))
84*cf84ac9aSAndroid Build Coastguard Worker 		return;
85*cf84ac9aSAndroid Build Coastguard Worker 
86*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{start=%#x, length=%#x, ptr=", mbuf.start, mbuf.length);
87*cf84ac9aSAndroid Build Coastguard Worker 	printaddr(ptr_to_kulong(mbuf.ptr));
88*cf84ac9aSAndroid Build Coastguard Worker 	tprints("}");
89*cf84ac9aSAndroid Build Coastguard Worker }
90*cf84ac9aSAndroid Build Coastguard Worker 
91*cf84ac9aSAndroid Build Coastguard Worker static void
decode_mtd_oob_buf64(struct tcb * const tcp,const kernel_ulong_t addr)92*cf84ac9aSAndroid Build Coastguard Worker decode_mtd_oob_buf64(struct tcb *const tcp, const kernel_ulong_t addr)
93*cf84ac9aSAndroid Build Coastguard Worker {
94*cf84ac9aSAndroid Build Coastguard Worker 	struct mtd_oob_buf64 mbuf64;
95*cf84ac9aSAndroid Build Coastguard Worker 
96*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
97*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &mbuf64))
98*cf84ac9aSAndroid Build Coastguard Worker 		return;
99*cf84ac9aSAndroid Build Coastguard Worker 
100*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{start=%#" PRIx64 ", length=%#x, usr_ptr=%#" PRIx64 "}",
101*cf84ac9aSAndroid Build Coastguard Worker 		(uint64_t) mbuf64.start, mbuf64.length,
102*cf84ac9aSAndroid Build Coastguard Worker 		(uint64_t) mbuf64.usr_ptr);
103*cf84ac9aSAndroid Build Coastguard Worker }
104*cf84ac9aSAndroid Build Coastguard Worker 
105*cf84ac9aSAndroid Build Coastguard Worker static void
decode_otp_info(struct tcb * const tcp,const kernel_ulong_t addr)106*cf84ac9aSAndroid Build Coastguard Worker decode_otp_info(struct tcb *const tcp, const kernel_ulong_t addr)
107*cf84ac9aSAndroid Build Coastguard Worker {
108*cf84ac9aSAndroid Build Coastguard Worker 	struct otp_info oinfo;
109*cf84ac9aSAndroid Build Coastguard Worker 
110*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
111*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &oinfo))
112*cf84ac9aSAndroid Build Coastguard Worker 		return;
113*cf84ac9aSAndroid Build Coastguard Worker 
114*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{start=%#x, length=%#x, locked=%u}",
115*cf84ac9aSAndroid Build Coastguard Worker 		oinfo.start, oinfo.length, oinfo.locked);
116*cf84ac9aSAndroid Build Coastguard Worker }
117*cf84ac9aSAndroid Build Coastguard Worker 
118*cf84ac9aSAndroid Build Coastguard Worker static void
decode_otp_select(struct tcb * const tcp,const kernel_ulong_t addr)119*cf84ac9aSAndroid Build Coastguard Worker decode_otp_select(struct tcb *const tcp, const kernel_ulong_t addr)
120*cf84ac9aSAndroid Build Coastguard Worker {
121*cf84ac9aSAndroid Build Coastguard Worker 	unsigned int i;
122*cf84ac9aSAndroid Build Coastguard Worker 
123*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
124*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &i))
125*cf84ac9aSAndroid Build Coastguard Worker 		return;
126*cf84ac9aSAndroid Build Coastguard Worker 
127*cf84ac9aSAndroid Build Coastguard Worker 	tprints("[");
128*cf84ac9aSAndroid Build Coastguard Worker 	printxval(mtd_otp_options, i, "MTD_OTP_???");
129*cf84ac9aSAndroid Build Coastguard Worker 	tprints("]");
130*cf84ac9aSAndroid Build Coastguard Worker }
131*cf84ac9aSAndroid Build Coastguard Worker 
132*cf84ac9aSAndroid Build Coastguard Worker static void
decode_mtd_write_req(struct tcb * const tcp,const kernel_ulong_t addr)133*cf84ac9aSAndroid Build Coastguard Worker decode_mtd_write_req(struct tcb *const tcp, const kernel_ulong_t addr)
134*cf84ac9aSAndroid Build Coastguard Worker {
135*cf84ac9aSAndroid Build Coastguard Worker 	struct mtd_write_req mreq;
136*cf84ac9aSAndroid Build Coastguard Worker 
137*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
138*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &mreq))
139*cf84ac9aSAndroid Build Coastguard Worker 		return;
140*cf84ac9aSAndroid Build Coastguard Worker 
141*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{start=%#" PRIx64 ", len=%#" PRIx64
142*cf84ac9aSAndroid Build Coastguard Worker 		", ooblen=%#" PRIx64 ", usr_data=%#" PRIx64
143*cf84ac9aSAndroid Build Coastguard Worker 		", usr_oob=%#" PRIx64 ", mode=",
144*cf84ac9aSAndroid Build Coastguard Worker 		(uint64_t) mreq.start, (uint64_t) mreq.len,
145*cf84ac9aSAndroid Build Coastguard Worker 		(uint64_t) mreq.ooblen, (uint64_t) mreq.usr_data,
146*cf84ac9aSAndroid Build Coastguard Worker 		(uint64_t) mreq.usr_oob);
147*cf84ac9aSAndroid Build Coastguard Worker 	printxval(mtd_mode_options, mreq.mode, "MTD_OPS_???");
148*cf84ac9aSAndroid Build Coastguard Worker 	tprints("}");
149*cf84ac9aSAndroid Build Coastguard Worker }
150*cf84ac9aSAndroid Build Coastguard Worker 
151*cf84ac9aSAndroid Build Coastguard Worker static void
decode_mtd_info_user(struct tcb * const tcp,const kernel_ulong_t addr)152*cf84ac9aSAndroid Build Coastguard Worker decode_mtd_info_user(struct tcb *const tcp, const kernel_ulong_t addr)
153*cf84ac9aSAndroid Build Coastguard Worker {
154*cf84ac9aSAndroid Build Coastguard Worker 	struct mtd_info_user minfo;
155*cf84ac9aSAndroid Build Coastguard Worker 
156*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
157*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &minfo))
158*cf84ac9aSAndroid Build Coastguard Worker 		return;
159*cf84ac9aSAndroid Build Coastguard Worker 
160*cf84ac9aSAndroid Build Coastguard Worker 	tprints("{type=");
161*cf84ac9aSAndroid Build Coastguard Worker 	printxval(mtd_type_options, minfo.type, "MTD_???");
162*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", flags=");
163*cf84ac9aSAndroid Build Coastguard Worker 	printflags(mtd_flags_options, minfo.flags, "MTD_???");
164*cf84ac9aSAndroid Build Coastguard Worker 	tprintf(", size=%#x, erasesize=%#x, writesize=%#x, oobsize=%#x"
165*cf84ac9aSAndroid Build Coastguard Worker 		", padding=%#" PRIx64 "}",
166*cf84ac9aSAndroid Build Coastguard Worker 		minfo.size, minfo.erasesize, minfo.writesize, minfo.oobsize,
167*cf84ac9aSAndroid Build Coastguard Worker 		(uint64_t) minfo.padding);
168*cf84ac9aSAndroid Build Coastguard Worker }
169*cf84ac9aSAndroid Build Coastguard Worker 
170*cf84ac9aSAndroid Build Coastguard Worker static void
decode_nand_oobinfo(struct tcb * const tcp,const kernel_ulong_t addr)171*cf84ac9aSAndroid Build Coastguard Worker decode_nand_oobinfo(struct tcb *const tcp, const kernel_ulong_t addr)
172*cf84ac9aSAndroid Build Coastguard Worker {
173*cf84ac9aSAndroid Build Coastguard Worker 	struct nand_oobinfo ninfo;
174*cf84ac9aSAndroid Build Coastguard Worker 	unsigned int i, j;
175*cf84ac9aSAndroid Build Coastguard Worker 
176*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
177*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &ninfo))
178*cf84ac9aSAndroid Build Coastguard Worker 		return;
179*cf84ac9aSAndroid Build Coastguard Worker 
180*cf84ac9aSAndroid Build Coastguard Worker 	tprints("{useecc=");
181*cf84ac9aSAndroid Build Coastguard Worker 	printxval(mtd_nandecc_options, ninfo.useecc, "MTD_NANDECC_???");
182*cf84ac9aSAndroid Build Coastguard Worker 	tprintf(", eccbytes=%#x", ninfo.eccbytes);
183*cf84ac9aSAndroid Build Coastguard Worker 
184*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", oobfree={");
185*cf84ac9aSAndroid Build Coastguard Worker 	for (i = 0; i < ARRAY_SIZE(ninfo.oobfree); ++i) {
186*cf84ac9aSAndroid Build Coastguard Worker 		if (i)
187*cf84ac9aSAndroid Build Coastguard Worker 			tprints("}, ");
188*cf84ac9aSAndroid Build Coastguard Worker 		tprints("{");
189*cf84ac9aSAndroid Build Coastguard Worker 		for (j = 0; j < ARRAY_SIZE(ninfo.oobfree[0]); ++j) {
190*cf84ac9aSAndroid Build Coastguard Worker 			if (j)
191*cf84ac9aSAndroid Build Coastguard Worker 				tprints(", ");
192*cf84ac9aSAndroid Build Coastguard Worker 			tprintf("%#x", ninfo.oobfree[i][j]);
193*cf84ac9aSAndroid Build Coastguard Worker 		}
194*cf84ac9aSAndroid Build Coastguard Worker 	}
195*cf84ac9aSAndroid Build Coastguard Worker 
196*cf84ac9aSAndroid Build Coastguard Worker 	tprints("}}, eccpos={");
197*cf84ac9aSAndroid Build Coastguard Worker 	for (i = 0; i < ARRAY_SIZE(ninfo.eccpos); ++i) {
198*cf84ac9aSAndroid Build Coastguard Worker 		if (i)
199*cf84ac9aSAndroid Build Coastguard Worker 			tprints(", ");
200*cf84ac9aSAndroid Build Coastguard Worker 		tprintf("%#x", ninfo.eccpos[i]);
201*cf84ac9aSAndroid Build Coastguard Worker 	}
202*cf84ac9aSAndroid Build Coastguard Worker 
203*cf84ac9aSAndroid Build Coastguard Worker 	tprints("}");
204*cf84ac9aSAndroid Build Coastguard Worker }
205*cf84ac9aSAndroid Build Coastguard Worker 
206*cf84ac9aSAndroid Build Coastguard Worker static void
decode_nand_ecclayout_user(struct tcb * const tcp,const kernel_ulong_t addr)207*cf84ac9aSAndroid Build Coastguard Worker decode_nand_ecclayout_user(struct tcb *const tcp, const kernel_ulong_t addr)
208*cf84ac9aSAndroid Build Coastguard Worker {
209*cf84ac9aSAndroid Build Coastguard Worker 	struct nand_ecclayout_user nlay;
210*cf84ac9aSAndroid Build Coastguard Worker 	unsigned int i;
211*cf84ac9aSAndroid Build Coastguard Worker 
212*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
213*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &nlay))
214*cf84ac9aSAndroid Build Coastguard Worker 		return;
215*cf84ac9aSAndroid Build Coastguard Worker 
216*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{eccbytes=%#x, eccpos={", nlay.eccbytes);
217*cf84ac9aSAndroid Build Coastguard Worker 	for (i = 0; i < ARRAY_SIZE(nlay.eccpos); ++i) {
218*cf84ac9aSAndroid Build Coastguard Worker 		if (i)
219*cf84ac9aSAndroid Build Coastguard Worker 			tprints(", ");
220*cf84ac9aSAndroid Build Coastguard Worker 		tprintf("%#x", nlay.eccpos[i]);
221*cf84ac9aSAndroid Build Coastguard Worker 	}
222*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("}, oobavail=%#x, oobfree={", nlay.oobavail);
223*cf84ac9aSAndroid Build Coastguard Worker 	for (i = 0; i < ARRAY_SIZE(nlay.oobfree); ++i) {
224*cf84ac9aSAndroid Build Coastguard Worker 		if (i)
225*cf84ac9aSAndroid Build Coastguard Worker 			tprints(", ");
226*cf84ac9aSAndroid Build Coastguard Worker 		tprintf("{offset=%#x, length=%#x}",
227*cf84ac9aSAndroid Build Coastguard Worker 			nlay.oobfree[i].offset, nlay.oobfree[i].length);
228*cf84ac9aSAndroid Build Coastguard Worker 	}
229*cf84ac9aSAndroid Build Coastguard Worker 	tprints("}");
230*cf84ac9aSAndroid Build Coastguard Worker }
231*cf84ac9aSAndroid Build Coastguard Worker 
232*cf84ac9aSAndroid Build Coastguard Worker static void
decode_mtd_ecc_stats(struct tcb * const tcp,const kernel_ulong_t addr)233*cf84ac9aSAndroid Build Coastguard Worker decode_mtd_ecc_stats(struct tcb *const tcp, const kernel_ulong_t addr)
234*cf84ac9aSAndroid Build Coastguard Worker {
235*cf84ac9aSAndroid Build Coastguard Worker 	struct mtd_ecc_stats es;
236*cf84ac9aSAndroid Build Coastguard Worker 
237*cf84ac9aSAndroid Build Coastguard Worker 	tprints(", ");
238*cf84ac9aSAndroid Build Coastguard Worker 	if (umove_or_printaddr(tcp, addr, &es))
239*cf84ac9aSAndroid Build Coastguard Worker 		return;
240*cf84ac9aSAndroid Build Coastguard Worker 
241*cf84ac9aSAndroid Build Coastguard Worker 	tprintf("{corrected=%#x, failed=%#x, badblocks=%#x, bbtblocks=%#x}",
242*cf84ac9aSAndroid Build Coastguard Worker 		es.corrected, es.failed, es.badblocks, es.bbtblocks);
243*cf84ac9aSAndroid Build Coastguard Worker }
244*cf84ac9aSAndroid Build Coastguard Worker 
MPERS_PRINTER_DECL(int,mtd_ioctl,struct tcb * const tcp,const unsigned int code,const kernel_ulong_t arg)245*cf84ac9aSAndroid Build Coastguard Worker MPERS_PRINTER_DECL(int, mtd_ioctl, struct tcb *const tcp,
246*cf84ac9aSAndroid Build Coastguard Worker 		   const unsigned int code, const kernel_ulong_t arg)
247*cf84ac9aSAndroid Build Coastguard Worker {
248*cf84ac9aSAndroid Build Coastguard Worker 	switch (code) {
249*cf84ac9aSAndroid Build Coastguard Worker 	case MEMERASE:
250*cf84ac9aSAndroid Build Coastguard Worker 	case MEMLOCK:
251*cf84ac9aSAndroid Build Coastguard Worker 	case MEMUNLOCK:
252*cf84ac9aSAndroid Build Coastguard Worker 	case MEMISLOCKED:
253*cf84ac9aSAndroid Build Coastguard Worker 		decode_erase_info_user(tcp, arg);
254*cf84ac9aSAndroid Build Coastguard Worker 		break;
255*cf84ac9aSAndroid Build Coastguard Worker 
256*cf84ac9aSAndroid Build Coastguard Worker 	case MEMERASE64:
257*cf84ac9aSAndroid Build Coastguard Worker 		decode_erase_info_user64(tcp, arg);
258*cf84ac9aSAndroid Build Coastguard Worker 		break;
259*cf84ac9aSAndroid Build Coastguard Worker 
260*cf84ac9aSAndroid Build Coastguard Worker 	case MEMWRITEOOB:
261*cf84ac9aSAndroid Build Coastguard Worker 	case MEMREADOOB:
262*cf84ac9aSAndroid Build Coastguard Worker 		decode_mtd_oob_buf(tcp, arg);
263*cf84ac9aSAndroid Build Coastguard Worker 		break;
264*cf84ac9aSAndroid Build Coastguard Worker 
265*cf84ac9aSAndroid Build Coastguard Worker 	case MEMWRITEOOB64:
266*cf84ac9aSAndroid Build Coastguard Worker 	case MEMREADOOB64:
267*cf84ac9aSAndroid Build Coastguard Worker 		decode_mtd_oob_buf64(tcp, arg);
268*cf84ac9aSAndroid Build Coastguard Worker 		break;
269*cf84ac9aSAndroid Build Coastguard Worker 
270*cf84ac9aSAndroid Build Coastguard Worker 	case MEMWRITE:
271*cf84ac9aSAndroid Build Coastguard Worker 		decode_mtd_write_req(tcp, arg);
272*cf84ac9aSAndroid Build Coastguard Worker 		break;
273*cf84ac9aSAndroid Build Coastguard Worker 
274*cf84ac9aSAndroid Build Coastguard Worker 	case OTPGETREGIONINFO:
275*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp))
276*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
277*cf84ac9aSAndroid Build Coastguard Worker 		ATTRIBUTE_FALLTHROUGH;
278*cf84ac9aSAndroid Build Coastguard Worker 	case OTPLOCK:
279*cf84ac9aSAndroid Build Coastguard Worker 		decode_otp_info(tcp, arg);
280*cf84ac9aSAndroid Build Coastguard Worker 		break;
281*cf84ac9aSAndroid Build Coastguard Worker 
282*cf84ac9aSAndroid Build Coastguard Worker 	case OTPSELECT:
283*cf84ac9aSAndroid Build Coastguard Worker 		decode_otp_select(tcp, arg);
284*cf84ac9aSAndroid Build Coastguard Worker 		break;
285*cf84ac9aSAndroid Build Coastguard Worker 
286*cf84ac9aSAndroid Build Coastguard Worker 	case MTDFILEMODE:
287*cf84ac9aSAndroid Build Coastguard Worker 		tprints(", ");
288*cf84ac9aSAndroid Build Coastguard Worker 		printxval64(mtd_file_mode_options, arg, "MTD_FILE_MODE_???");
289*cf84ac9aSAndroid Build Coastguard Worker 		break;
290*cf84ac9aSAndroid Build Coastguard Worker 
291*cf84ac9aSAndroid Build Coastguard Worker 	case MEMGETBADBLOCK:
292*cf84ac9aSAndroid Build Coastguard Worker 	case MEMSETBADBLOCK:
293*cf84ac9aSAndroid Build Coastguard Worker 		tprints(", ");
294*cf84ac9aSAndroid Build Coastguard Worker 		printnum_int64(tcp, arg, "%" PRIu64);
295*cf84ac9aSAndroid Build Coastguard Worker 		break;
296*cf84ac9aSAndroid Build Coastguard Worker 
297*cf84ac9aSAndroid Build Coastguard Worker 	case MEMGETINFO:
298*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp))
299*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
300*cf84ac9aSAndroid Build Coastguard Worker 		decode_mtd_info_user(tcp, arg);
301*cf84ac9aSAndroid Build Coastguard Worker 		break;
302*cf84ac9aSAndroid Build Coastguard Worker 
303*cf84ac9aSAndroid Build Coastguard Worker 	case MEMGETOOBSEL:
304*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp))
305*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
306*cf84ac9aSAndroid Build Coastguard Worker 		decode_nand_oobinfo(tcp, arg);
307*cf84ac9aSAndroid Build Coastguard Worker 		break;
308*cf84ac9aSAndroid Build Coastguard Worker 
309*cf84ac9aSAndroid Build Coastguard Worker 	case ECCGETLAYOUT:
310*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp))
311*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
312*cf84ac9aSAndroid Build Coastguard Worker 		decode_nand_ecclayout_user(tcp, arg);
313*cf84ac9aSAndroid Build Coastguard Worker 		break;
314*cf84ac9aSAndroid Build Coastguard Worker 
315*cf84ac9aSAndroid Build Coastguard Worker 	case ECCGETSTATS:
316*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp))
317*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
318*cf84ac9aSAndroid Build Coastguard Worker 		decode_mtd_ecc_stats(tcp, arg);
319*cf84ac9aSAndroid Build Coastguard Worker 		break;
320*cf84ac9aSAndroid Build Coastguard Worker 
321*cf84ac9aSAndroid Build Coastguard Worker 	case OTPGETREGIONCOUNT:
322*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp))
323*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
324*cf84ac9aSAndroid Build Coastguard Worker 		tprints(", ");
325*cf84ac9aSAndroid Build Coastguard Worker 		printnum_int(tcp, arg, "%u");
326*cf84ac9aSAndroid Build Coastguard Worker 		break;
327*cf84ac9aSAndroid Build Coastguard Worker 
328*cf84ac9aSAndroid Build Coastguard Worker 	case MEMGETREGIONCOUNT:
329*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp))
330*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
331*cf84ac9aSAndroid Build Coastguard Worker 		tprints(", ");
332*cf84ac9aSAndroid Build Coastguard Worker 		printnum_int(tcp, arg, "%d");
333*cf84ac9aSAndroid Build Coastguard Worker 		break;
334*cf84ac9aSAndroid Build Coastguard Worker 
335*cf84ac9aSAndroid Build Coastguard Worker 	case MEMGETREGIONINFO:
336*cf84ac9aSAndroid Build Coastguard Worker 		if (entering(tcp)) {
337*cf84ac9aSAndroid Build Coastguard Worker 			struct region_info_user rinfo;
338*cf84ac9aSAndroid Build Coastguard Worker 
339*cf84ac9aSAndroid Build Coastguard Worker 			tprints(", ");
340*cf84ac9aSAndroid Build Coastguard Worker 			if (umove_or_printaddr(tcp, arg, &rinfo))
341*cf84ac9aSAndroid Build Coastguard Worker 				break;
342*cf84ac9aSAndroid Build Coastguard Worker 			tprintf("{regionindex=%#x", rinfo.regionindex);
343*cf84ac9aSAndroid Build Coastguard Worker 			return 0;
344*cf84ac9aSAndroid Build Coastguard Worker 		} else {
345*cf84ac9aSAndroid Build Coastguard Worker 			struct region_info_user rinfo;
346*cf84ac9aSAndroid Build Coastguard Worker 
347*cf84ac9aSAndroid Build Coastguard Worker 			if (!syserror(tcp) && !umove(tcp, arg, &rinfo))
348*cf84ac9aSAndroid Build Coastguard Worker 				tprintf(", offset=%#x"
349*cf84ac9aSAndroid Build Coastguard Worker 					", erasesize=%#x"
350*cf84ac9aSAndroid Build Coastguard Worker 					", numblocks=%#x}",
351*cf84ac9aSAndroid Build Coastguard Worker 					rinfo.offset,
352*cf84ac9aSAndroid Build Coastguard Worker 					rinfo.erasesize,
353*cf84ac9aSAndroid Build Coastguard Worker 					rinfo.numblocks);
354*cf84ac9aSAndroid Build Coastguard Worker 			tprints("}");
355*cf84ac9aSAndroid Build Coastguard Worker 			break;
356*cf84ac9aSAndroid Build Coastguard Worker 		}
357*cf84ac9aSAndroid Build Coastguard Worker 
358*cf84ac9aSAndroid Build Coastguard Worker 	default:
359*cf84ac9aSAndroid Build Coastguard Worker 		return RVAL_DECODED;
360*cf84ac9aSAndroid Build Coastguard Worker 	}
361*cf84ac9aSAndroid Build Coastguard Worker 
362*cf84ac9aSAndroid Build Coastguard Worker 	return RVAL_IOCTL_DECODED;
363*cf84ac9aSAndroid Build Coastguard Worker }
364*cf84ac9aSAndroid Build Coastguard Worker 
365*cf84ac9aSAndroid Build Coastguard Worker #endif /* HAVE_STRUCT_MTD_WRITE_REQ */
366