1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker * Check decoding of ioctl SG_IO v4 commands.
3*cf84ac9aSAndroid Build Coastguard Worker *
4*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2017 Dmitry V. Levin <[email protected]>
5*cf84ac9aSAndroid Build Coastguard Worker * All rights reserved.
6*cf84ac9aSAndroid Build Coastguard Worker *
7*cf84ac9aSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
8*cf84ac9aSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions
9*cf84ac9aSAndroid Build Coastguard Worker * are met:
10*cf84ac9aSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
11*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
12*cf84ac9aSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
13*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
14*cf84ac9aSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
15*cf84ac9aSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products
16*cf84ac9aSAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
17*cf84ac9aSAndroid Build Coastguard Worker *
18*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19*cf84ac9aSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20*cf84ac9aSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21*cf84ac9aSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22*cf84ac9aSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23*cf84ac9aSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*cf84ac9aSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*cf84ac9aSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*cf84ac9aSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*cf84ac9aSAndroid Build Coastguard Worker */
29*cf84ac9aSAndroid Build Coastguard Worker
30*cf84ac9aSAndroid Build Coastguard Worker #include "tests.h"
31*cf84ac9aSAndroid Build Coastguard Worker
32*cf84ac9aSAndroid Build Coastguard Worker #ifdef HAVE_LINUX_BSG_H
33*cf84ac9aSAndroid Build Coastguard Worker
34*cf84ac9aSAndroid Build Coastguard Worker # include <inttypes.h>
35*cf84ac9aSAndroid Build Coastguard Worker # include <stdio.h>
36*cf84ac9aSAndroid Build Coastguard Worker # include <sys/ioctl.h>
37*cf84ac9aSAndroid Build Coastguard Worker # include <sys/uio.h>
38*cf84ac9aSAndroid Build Coastguard Worker # include <linux/bsg.h>
39*cf84ac9aSAndroid Build Coastguard Worker
40*cf84ac9aSAndroid Build Coastguard Worker # include "xlat/scsi_sg_commands.h"
41*cf84ac9aSAndroid Build Coastguard Worker
42*cf84ac9aSAndroid Build Coastguard Worker int
main(void)43*cf84ac9aSAndroid Build Coastguard Worker main(void)
44*cf84ac9aSAndroid Build Coastguard Worker {
45*cf84ac9aSAndroid Build Coastguard Worker ioctl(-1, SG_IO, 0);
46*cf84ac9aSAndroid Build Coastguard Worker printf("ioctl(-1, SG_IO, NULL) = -1 EBADF (%m)\n");
47*cf84ac9aSAndroid Build Coastguard Worker
48*cf84ac9aSAndroid Build Coastguard Worker TAIL_ALLOC_OBJECT_CONST_PTR(struct sg_io_v4, sg_io);
49*cf84ac9aSAndroid Build Coastguard Worker fill_memory(sg_io, sizeof(*sg_io));
50*cf84ac9aSAndroid Build Coastguard Worker
51*cf84ac9aSAndroid Build Coastguard Worker const void *const efault = sg_io + 1;
52*cf84ac9aSAndroid Build Coastguard Worker ioctl(-1, SG_IO, efault);
53*cf84ac9aSAndroid Build Coastguard Worker printf("ioctl(-1, SG_IO, %p) = -1 EBADF (%m)\n", efault);
54*cf84ac9aSAndroid Build Coastguard Worker
55*cf84ac9aSAndroid Build Coastguard Worker ioctl(-1, SG_IO, sg_io);
56*cf84ac9aSAndroid Build Coastguard Worker printf("ioctl(-1, SG_IO, [%u]) = -1 EBADF (%m)\n", sg_io->guard);
57*cf84ac9aSAndroid Build Coastguard Worker
58*cf84ac9aSAndroid Build Coastguard Worker TAIL_ALLOC_OBJECT_CONST_PTR(unsigned int, pguard);
59*cf84ac9aSAndroid Build Coastguard Worker *pguard = (unsigned char) 'Q';
60*cf84ac9aSAndroid Build Coastguard Worker ioctl(-1, SG_IO, pguard);
61*cf84ac9aSAndroid Build Coastguard Worker printf("ioctl(-1, SG_IO, {guard='Q', %p}) = -1 EBADF (%m)\n", pguard + 1);
62*cf84ac9aSAndroid Build Coastguard Worker
63*cf84ac9aSAndroid Build Coastguard Worker sg_io->guard = (unsigned char) 'Q';
64*cf84ac9aSAndroid Build Coastguard Worker sg_io->protocol = 0;
65*cf84ac9aSAndroid Build Coastguard Worker sg_io->subprotocol = 1;
66*cf84ac9aSAndroid Build Coastguard Worker sg_io->flags = -1U;
67*cf84ac9aSAndroid Build Coastguard Worker sg_io->info = -1U;
68*cf84ac9aSAndroid Build Coastguard Worker sg_io->request = (kernel_ulong_t) 0xfacefeedfffffff1ULL;
69*cf84ac9aSAndroid Build Coastguard Worker sg_io->response = (kernel_ulong_t) 0xfacefeedfffffff2ULL;
70*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_xferp = (kernel_ulong_t) 0xfacefeedfffffff3ULL;
71*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_xferp = (kernel_ulong_t) 0xfacefeedfffffff4ULL;
72*cf84ac9aSAndroid Build Coastguard Worker ioctl(-1, SG_IO, sg_io);
73*cf84ac9aSAndroid Build Coastguard Worker printf("ioctl(-1, SG_IO, {guard='Q'"
74*cf84ac9aSAndroid Build Coastguard Worker ", protocol=BSG_PROTOCOL_SCSI"
75*cf84ac9aSAndroid Build Coastguard Worker ", subprotocol=BSG_SUB_PROTOCOL_SCSI_TMF"
76*cf84ac9aSAndroid Build Coastguard Worker ", request_len=%u"
77*cf84ac9aSAndroid Build Coastguard Worker ", request=%#llx"
78*cf84ac9aSAndroid Build Coastguard Worker ", request_tag=%#" PRI__x64
79*cf84ac9aSAndroid Build Coastguard Worker ", request_attr=%u"
80*cf84ac9aSAndroid Build Coastguard Worker ", request_priority=%u"
81*cf84ac9aSAndroid Build Coastguard Worker ", request_extra=%u"
82*cf84ac9aSAndroid Build Coastguard Worker ", max_response_len=%u"
83*cf84ac9aSAndroid Build Coastguard Worker ", dout_iovec_count=%u"
84*cf84ac9aSAndroid Build Coastguard Worker ", dout_xfer_len=%u"
85*cf84ac9aSAndroid Build Coastguard Worker ", din_iovec_count=%u"
86*cf84ac9aSAndroid Build Coastguard Worker ", din_xfer_len=%u"
87*cf84ac9aSAndroid Build Coastguard Worker ", dout_xferp=%#llx"
88*cf84ac9aSAndroid Build Coastguard Worker ", timeout=%u"
89*cf84ac9aSAndroid Build Coastguard Worker ", flags=BSG_FLAG_Q_AT_TAIL|BSG_FLAG_Q_AT_HEAD|0xffffffcf"
90*cf84ac9aSAndroid Build Coastguard Worker ", usr_ptr=%#" PRI__x64
91*cf84ac9aSAndroid Build Coastguard Worker ", response_len=%u"
92*cf84ac9aSAndroid Build Coastguard Worker ", response=%#llx"
93*cf84ac9aSAndroid Build Coastguard Worker ", din_xferp=%#llx"
94*cf84ac9aSAndroid Build Coastguard Worker ", driver_status=%#x"
95*cf84ac9aSAndroid Build Coastguard Worker ", transport_status=%#x"
96*cf84ac9aSAndroid Build Coastguard Worker ", device_status=%#x"
97*cf84ac9aSAndroid Build Coastguard Worker ", retry_delay=%u"
98*cf84ac9aSAndroid Build Coastguard Worker ", info=SG_INFO_CHECK|SG_INFO_DIRECT_IO|SG_INFO_MIXED_IO|0xfffffff8"
99*cf84ac9aSAndroid Build Coastguard Worker ", duration=%u"
100*cf84ac9aSAndroid Build Coastguard Worker ", response_len=%u"
101*cf84ac9aSAndroid Build Coastguard Worker ", din_resid=%d"
102*cf84ac9aSAndroid Build Coastguard Worker ", dout_resid=%d"
103*cf84ac9aSAndroid Build Coastguard Worker ", generated_tag=%#" PRI__x64 "}) = -1 EBADF (%m)\n",
104*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_len,
105*cf84ac9aSAndroid Build Coastguard Worker (unsigned long long) (kernel_ulong_t) sg_io->request,
106*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_tag,
107*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_attr,
108*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_priority,
109*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_extra,
110*cf84ac9aSAndroid Build Coastguard Worker sg_io->max_response_len,
111*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_iovec_count,
112*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_xfer_len,
113*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_iovec_count,
114*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_xfer_len,
115*cf84ac9aSAndroid Build Coastguard Worker (unsigned long long) (kernel_ulong_t) sg_io->dout_xferp,
116*cf84ac9aSAndroid Build Coastguard Worker sg_io->timeout,
117*cf84ac9aSAndroid Build Coastguard Worker sg_io->usr_ptr,
118*cf84ac9aSAndroid Build Coastguard Worker sg_io->response_len,
119*cf84ac9aSAndroid Build Coastguard Worker (unsigned long long) (kernel_ulong_t) sg_io->response,
120*cf84ac9aSAndroid Build Coastguard Worker (unsigned long long) (kernel_ulong_t) sg_io->din_xferp,
121*cf84ac9aSAndroid Build Coastguard Worker sg_io->driver_status,
122*cf84ac9aSAndroid Build Coastguard Worker sg_io->transport_status,
123*cf84ac9aSAndroid Build Coastguard Worker sg_io->device_status,
124*cf84ac9aSAndroid Build Coastguard Worker sg_io->retry_delay,
125*cf84ac9aSAndroid Build Coastguard Worker sg_io->duration,
126*cf84ac9aSAndroid Build Coastguard Worker sg_io->response_len,
127*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_resid,
128*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_resid,
129*cf84ac9aSAndroid Build Coastguard Worker sg_io->generated_tag);
130*cf84ac9aSAndroid Build Coastguard Worker
131*cf84ac9aSAndroid Build Coastguard Worker const struct iovec iov[] = {
132*cf84ac9aSAndroid Build Coastguard Worker {
133*cf84ac9aSAndroid Build Coastguard Worker .iov_base = (void *) efault - 2,
134*cf84ac9aSAndroid Build Coastguard Worker .iov_len = 2
135*cf84ac9aSAndroid Build Coastguard Worker }, {
136*cf84ac9aSAndroid Build Coastguard Worker .iov_base = (void *) efault - 3,
137*cf84ac9aSAndroid Build Coastguard Worker .iov_len = 4
138*cf84ac9aSAndroid Build Coastguard Worker }
139*cf84ac9aSAndroid Build Coastguard Worker };
140*cf84ac9aSAndroid Build Coastguard Worker const struct iovec *const t_iov = tail_memdup(iov, sizeof(iov));
141*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_iovec_count = ARRAY_SIZE(iov);
142*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_xfer_len = iov[0].iov_len + iov[1].iov_len - 1;
143*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_xferp = (unsigned long) t_iov;
144*cf84ac9aSAndroid Build Coastguard Worker
145*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_iovec_count = 0;
146*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_xfer_len = 5;
147*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_resid = 1;
148*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_xferp = (unsigned long) efault -
149*cf84ac9aSAndroid Build Coastguard Worker (sg_io->dout_xfer_len - sg_io->din_resid);
150*cf84ac9aSAndroid Build Coastguard Worker
151*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_len = 3;
152*cf84ac9aSAndroid Build Coastguard Worker sg_io->request = (unsigned long) efault - sg_io->request_len;
153*cf84ac9aSAndroid Build Coastguard Worker sg_io->response_len = 2;
154*cf84ac9aSAndroid Build Coastguard Worker sg_io->response = (unsigned long) efault - sg_io->response_len;
155*cf84ac9aSAndroid Build Coastguard Worker
156*cf84ac9aSAndroid Build Coastguard Worker sg_io->flags = 0x20;
157*cf84ac9aSAndroid Build Coastguard Worker sg_io->info = 1;
158*cf84ac9aSAndroid Build Coastguard Worker
159*cf84ac9aSAndroid Build Coastguard Worker ioctl(-1, SG_IO, sg_io);
160*cf84ac9aSAndroid Build Coastguard Worker printf("ioctl(-1, SG_IO, {guard='Q'"
161*cf84ac9aSAndroid Build Coastguard Worker ", protocol=BSG_PROTOCOL_SCSI"
162*cf84ac9aSAndroid Build Coastguard Worker ", subprotocol=BSG_SUB_PROTOCOL_SCSI_TMF"
163*cf84ac9aSAndroid Build Coastguard Worker ", request_len=%u"
164*cf84ac9aSAndroid Build Coastguard Worker ", request=\"\\x%x\\x%x\\x%x\""
165*cf84ac9aSAndroid Build Coastguard Worker ", request_tag=%#" PRI__x64
166*cf84ac9aSAndroid Build Coastguard Worker ", request_attr=%u"
167*cf84ac9aSAndroid Build Coastguard Worker ", request_priority=%u"
168*cf84ac9aSAndroid Build Coastguard Worker ", request_extra=%u"
169*cf84ac9aSAndroid Build Coastguard Worker ", max_response_len=%u"
170*cf84ac9aSAndroid Build Coastguard Worker ", dout_iovec_count=%u"
171*cf84ac9aSAndroid Build Coastguard Worker ", dout_xfer_len=%u"
172*cf84ac9aSAndroid Build Coastguard Worker ", din_iovec_count=%u"
173*cf84ac9aSAndroid Build Coastguard Worker ", din_xfer_len=%u"
174*cf84ac9aSAndroid Build Coastguard Worker ", dout_xferp=[{iov_base=\"\\%o\\%o\", iov_len=%u}"
175*cf84ac9aSAndroid Build Coastguard Worker ", {iov_base=\"\\%o\\%o\\%o\", iov_len=%u}]"
176*cf84ac9aSAndroid Build Coastguard Worker ", timeout=%u, flags=BSG_FLAG_Q_AT_HEAD"
177*cf84ac9aSAndroid Build Coastguard Worker ", usr_ptr=%#" PRI__x64
178*cf84ac9aSAndroid Build Coastguard Worker ", response_len=%u"
179*cf84ac9aSAndroid Build Coastguard Worker ", response=\"\\x%x\\x%x\""
180*cf84ac9aSAndroid Build Coastguard Worker ", din_xferp=\"\\x%x\\x%x\\x%x\\x%x\""
181*cf84ac9aSAndroid Build Coastguard Worker ", driver_status=%#x"
182*cf84ac9aSAndroid Build Coastguard Worker ", transport_status=%#x"
183*cf84ac9aSAndroid Build Coastguard Worker ", device_status=%#x"
184*cf84ac9aSAndroid Build Coastguard Worker ", retry_delay=%u"
185*cf84ac9aSAndroid Build Coastguard Worker ", info=SG_INFO_CHECK"
186*cf84ac9aSAndroid Build Coastguard Worker ", duration=%u"
187*cf84ac9aSAndroid Build Coastguard Worker ", response_len=%u"
188*cf84ac9aSAndroid Build Coastguard Worker ", din_resid=%d"
189*cf84ac9aSAndroid Build Coastguard Worker ", dout_resid=%d"
190*cf84ac9aSAndroid Build Coastguard Worker ", generated_tag=%#" PRI__x64 "}) = -1 EBADF (%m)\n",
191*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_len,
192*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->request + 0),
193*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->request + 1),
194*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->request + 2),
195*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_tag,
196*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_attr,
197*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_priority,
198*cf84ac9aSAndroid Build Coastguard Worker sg_io->request_extra,
199*cf84ac9aSAndroid Build Coastguard Worker sg_io->max_response_len,
200*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_iovec_count,
201*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_xfer_len,
202*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_iovec_count,
203*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_xfer_len,
204*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) (iov[0].iov_base + 0),
205*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) (iov[0].iov_base + 1),
206*cf84ac9aSAndroid Build Coastguard Worker (unsigned int) iov[0].iov_len,
207*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) (iov[1].iov_base + 0),
208*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) (iov[1].iov_base + 1),
209*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) (iov[1].iov_base + 2),
210*cf84ac9aSAndroid Build Coastguard Worker (unsigned int) iov[1].iov_len,
211*cf84ac9aSAndroid Build Coastguard Worker sg_io->timeout,
212*cf84ac9aSAndroid Build Coastguard Worker sg_io->usr_ptr,
213*cf84ac9aSAndroid Build Coastguard Worker sg_io->response_len,
214*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->response + 0),
215*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->response + 1),
216*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->din_xferp + 0),
217*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->din_xferp + 1),
218*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->din_xferp + 2),
219*cf84ac9aSAndroid Build Coastguard Worker *(unsigned char *) ((unsigned long) sg_io->din_xferp + 3),
220*cf84ac9aSAndroid Build Coastguard Worker sg_io->driver_status,
221*cf84ac9aSAndroid Build Coastguard Worker sg_io->transport_status,
222*cf84ac9aSAndroid Build Coastguard Worker sg_io->device_status,
223*cf84ac9aSAndroid Build Coastguard Worker sg_io->retry_delay,
224*cf84ac9aSAndroid Build Coastguard Worker sg_io->duration,
225*cf84ac9aSAndroid Build Coastguard Worker sg_io->response_len,
226*cf84ac9aSAndroid Build Coastguard Worker sg_io->din_resid,
227*cf84ac9aSAndroid Build Coastguard Worker sg_io->dout_resid,
228*cf84ac9aSAndroid Build Coastguard Worker sg_io->generated_tag);
229*cf84ac9aSAndroid Build Coastguard Worker
230*cf84ac9aSAndroid Build Coastguard Worker puts("+++ exited with 0 +++");
231*cf84ac9aSAndroid Build Coastguard Worker return 0;
232*cf84ac9aSAndroid Build Coastguard Worker }
233*cf84ac9aSAndroid Build Coastguard Worker
234*cf84ac9aSAndroid Build Coastguard Worker #else
235*cf84ac9aSAndroid Build Coastguard Worker
236*cf84ac9aSAndroid Build Coastguard Worker SKIP_MAIN_UNDEFINED("HAVE_LINUX_BSG_H")
237*cf84ac9aSAndroid Build Coastguard Worker
238*cf84ac9aSAndroid Build Coastguard Worker #endif
239