Blame view

block/scsi_ioctl.c 20.4 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
  /*
   * Copyright (C) 2001 Jens Axboe <axboe@suse.de>
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   *
   * This program is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   *
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   * GNU General Public License for more details.
   *
   * You should have received a copy of the GNU General Public Licens
   * along with this program; if not, write to the Free Software
   * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-
   *
   */
  #include <linux/kernel.h>
  #include <linux/errno.h>
  #include <linux/string.h>
  #include <linux/module.h>
  #include <linux/blkdev.h>
c59ede7b7   Randy.Dunlap   [PATCH] move capa...
24
  #include <linux/capability.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
25
26
  #include <linux/completion.h>
  #include <linux/cdrom.h>
0bfc96cb7   Paolo Bonzini   block: fail SCSI ...
27
  #include <linux/ratelimit.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
28
29
  #include <linux/slab.h>
  #include <linux/times.h>
a27bb332c   Kent Overstreet   aio: don't includ...
30
  #include <linux/uio.h>
7c0f6ba68   Linus Torvalds   Replace <asm/uacc...
31
  #include <linux/uaccess.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
32
33
34
35
  
  #include <scsi/scsi.h>
  #include <scsi/scsi_ioctl.h>
  #include <scsi/scsi_cmnd.h>
018e04468   Jens Axboe   block: get rid of...
36
37
38
  struct blk_cmd_filter {
  	unsigned long read_ok[BLK_SCSI_CMD_PER_LONG];
  	unsigned long write_ok[BLK_SCSI_CMD_PER_LONG];
476d42f13   H Hartley Sweeten   block/scsi_ioctl....
39
40
41
  };
  
  static struct blk_cmd_filter blk_default_cmd_filter;
018e04468   Jens Axboe   block: get rid of...
42

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
43
  /* Command group 3 is reserved and should never be used.  */
db4742dd8   Boaz Harrosh   [SCSI] add suppor...
44
  const unsigned char scsi_command_size_tbl[8] =
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
45
46
47
48
  {
  	6, 10, 10, 12,
  	16, 12, 10, 10
  };
db4742dd8   Boaz Harrosh   [SCSI] add suppor...
49
  EXPORT_SYMBOL(scsi_command_size_tbl);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
50

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
51
52
53
54
  #include <scsi/sg.h>
  
  static int sg_get_version(int __user *p)
  {
64100099e   Arjan van de Ven   [BLOCK] mark some...
55
  	static const int sg_version_num = 30527;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
56
57
  	return put_user(sg_version_num, p);
  }
165125e1e   Jens Axboe   [BLOCK] Get rid o...
58
  static int scsi_get_idlun(struct request_queue *q, int __user *p)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
59
60
61
  {
  	return put_user(0, p);
  }
165125e1e   Jens Axboe   [BLOCK] Get rid o...
62
  static int scsi_get_bus(struct request_queue *q, int __user *p)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
63
64
65
  {
  	return put_user(0, p);
  }
165125e1e   Jens Axboe   [BLOCK] Get rid o...
66
  static int sg_get_timeout(struct request_queue *q)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
67
  {
2b91bafcc   Milton Miller   scsi-ioctl: use c...
68
  	return jiffies_to_clock_t(q->sg_timeout);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
69
  }
165125e1e   Jens Axboe   [BLOCK] Get rid o...
70
  static int sg_set_timeout(struct request_queue *q, int __user *p)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
71
72
73
74
  {
  	int timeout, err = get_user(timeout, p);
  
  	if (!err)
2b91bafcc   Milton Miller   scsi-ioctl: use c...
75
  		q->sg_timeout = clock_t_to_jiffies(timeout);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
76
77
78
  
  	return err;
  }
9b4231bf9   Akinobu Mita   block: fix SG_[GS...
79
80
81
82
83
84
85
86
  static int max_sectors_bytes(struct request_queue *q)
  {
  	unsigned int max_sectors = queue_max_sectors(q);
  
  	max_sectors = min_t(unsigned int, max_sectors, INT_MAX >> 9);
  
  	return max_sectors << 9;
  }
165125e1e   Jens Axboe   [BLOCK] Get rid o...
87
  static int sg_get_reserved_size(struct request_queue *q, int __user *p)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
88
  {
9b4231bf9   Akinobu Mita   block: fix SG_[GS...
89
  	int val = min_t(int, q->sg_reserved_size, max_sectors_bytes(q));
44ec95425   Alan Stern   [SCSI] sg: cap re...
90
91
  
  	return put_user(val, p);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
92
  }
165125e1e   Jens Axboe   [BLOCK] Get rid o...
93
  static int sg_set_reserved_size(struct request_queue *q, int __user *p)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
94
95
96
97
98
99
100
101
  {
  	int size, err = get_user(size, p);
  
  	if (err)
  		return err;
  
  	if (size < 0)
  		return -EINVAL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
102

9b4231bf9   Akinobu Mita   block: fix SG_[GS...
103
  	q->sg_reserved_size = min(size, max_sectors_bytes(q));
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
104
105
106
107
108
109
110
  	return 0;
  }
  
  /*
   * will always return that we are ATAPI even for a real SCSI drive, I'm not
   * so sure this is worth doing anything about (why would you care??)
   */
165125e1e   Jens Axboe   [BLOCK] Get rid o...
111
  static int sg_emulated_host(struct request_queue *q, int __user *p)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
112
113
114
  {
  	return put_user(1, p);
  }
018e04468   Jens Axboe   block: get rid of...
115
  static void blk_set_cmd_filter_defaults(struct blk_cmd_filter *filter)
abf543937   FUJITA Tomonori   block: move cmdfi...
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
  {
  	/* Basic read-only commands */
  	__set_bit(TEST_UNIT_READY, filter->read_ok);
  	__set_bit(REQUEST_SENSE, filter->read_ok);
  	__set_bit(READ_6, filter->read_ok);
  	__set_bit(READ_10, filter->read_ok);
  	__set_bit(READ_12, filter->read_ok);
  	__set_bit(READ_16, filter->read_ok);
  	__set_bit(READ_BUFFER, filter->read_ok);
  	__set_bit(READ_DEFECT_DATA, filter->read_ok);
  	__set_bit(READ_CAPACITY, filter->read_ok);
  	__set_bit(READ_LONG, filter->read_ok);
  	__set_bit(INQUIRY, filter->read_ok);
  	__set_bit(MODE_SENSE, filter->read_ok);
  	__set_bit(MODE_SENSE_10, filter->read_ok);
  	__set_bit(LOG_SENSE, filter->read_ok);
  	__set_bit(START_STOP, filter->read_ok);
  	__set_bit(GPCMD_VERIFY_10, filter->read_ok);
  	__set_bit(VERIFY_16, filter->read_ok);
  	__set_bit(REPORT_LUNS, filter->read_ok);
eb846d9f1   Hannes Reinecke   scsi: rename SERV...
136
  	__set_bit(SERVICE_ACTION_IN_16, filter->read_ok);
abf543937   FUJITA Tomonori   block: move cmdfi...
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
  	__set_bit(RECEIVE_DIAGNOSTIC, filter->read_ok);
  	__set_bit(MAINTENANCE_IN, filter->read_ok);
  	__set_bit(GPCMD_READ_BUFFER_CAPACITY, filter->read_ok);
  
  	/* Audio CD commands */
  	__set_bit(GPCMD_PLAY_CD, filter->read_ok);
  	__set_bit(GPCMD_PLAY_AUDIO_10, filter->read_ok);
  	__set_bit(GPCMD_PLAY_AUDIO_MSF, filter->read_ok);
  	__set_bit(GPCMD_PLAY_AUDIO_TI, filter->read_ok);
  	__set_bit(GPCMD_PAUSE_RESUME, filter->read_ok);
  
  	/* CD/DVD data reading */
  	__set_bit(GPCMD_READ_CD, filter->read_ok);
  	__set_bit(GPCMD_READ_CD_MSF, filter->read_ok);
  	__set_bit(GPCMD_READ_DISC_INFO, filter->read_ok);
  	__set_bit(GPCMD_READ_CDVD_CAPACITY, filter->read_ok);
  	__set_bit(GPCMD_READ_DVD_STRUCTURE, filter->read_ok);
  	__set_bit(GPCMD_READ_HEADER, filter->read_ok);
  	__set_bit(GPCMD_READ_TRACK_RZONE_INFO, filter->read_ok);
  	__set_bit(GPCMD_READ_SUBCHANNEL, filter->read_ok);
  	__set_bit(GPCMD_READ_TOC_PMA_ATIP, filter->read_ok);
  	__set_bit(GPCMD_REPORT_KEY, filter->read_ok);
  	__set_bit(GPCMD_SCAN, filter->read_ok);
  	__set_bit(GPCMD_GET_CONFIGURATION, filter->read_ok);
  	__set_bit(GPCMD_READ_FORMAT_CAPACITIES, filter->read_ok);
  	__set_bit(GPCMD_GET_EVENT_STATUS_NOTIFICATION, filter->read_ok);
  	__set_bit(GPCMD_GET_PERFORMANCE, filter->read_ok);
  	__set_bit(GPCMD_SEEK, filter->read_ok);
  	__set_bit(GPCMD_STOP_PLAY_SCAN, filter->read_ok);
  
  	/* Basic writing commands */
  	__set_bit(WRITE_6, filter->write_ok);
  	__set_bit(WRITE_10, filter->write_ok);
  	__set_bit(WRITE_VERIFY, filter->write_ok);
  	__set_bit(WRITE_12, filter->write_ok);
  	__set_bit(WRITE_VERIFY_12, filter->write_ok);
  	__set_bit(WRITE_16, filter->write_ok);
  	__set_bit(WRITE_LONG, filter->write_ok);
  	__set_bit(WRITE_LONG_2, filter->write_ok);
25cdb6451   Mauricio Faria de Oliveira   block: allow WRIT...
176
177
178
  	__set_bit(WRITE_SAME, filter->write_ok);
  	__set_bit(WRITE_SAME_16, filter->write_ok);
  	__set_bit(WRITE_SAME_32, filter->write_ok);
abf543937   FUJITA Tomonori   block: move cmdfi...
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
  	__set_bit(ERASE, filter->write_ok);
  	__set_bit(GPCMD_MODE_SELECT_10, filter->write_ok);
  	__set_bit(MODE_SELECT, filter->write_ok);
  	__set_bit(LOG_SELECT, filter->write_ok);
  	__set_bit(GPCMD_BLANK, filter->write_ok);
  	__set_bit(GPCMD_CLOSE_TRACK, filter->write_ok);
  	__set_bit(GPCMD_FLUSH_CACHE, filter->write_ok);
  	__set_bit(GPCMD_FORMAT_UNIT, filter->write_ok);
  	__set_bit(GPCMD_REPAIR_RZONE_TRACK, filter->write_ok);
  	__set_bit(GPCMD_RESERVE_RZONE_TRACK, filter->write_ok);
  	__set_bit(GPCMD_SEND_DVD_STRUCTURE, filter->write_ok);
  	__set_bit(GPCMD_SEND_EVENT, filter->write_ok);
  	__set_bit(GPCMD_SEND_KEY, filter->write_ok);
  	__set_bit(GPCMD_SEND_OPC, filter->write_ok);
  	__set_bit(GPCMD_SEND_CUE_SHEET, filter->write_ok);
  	__set_bit(GPCMD_SET_SPEED, filter->write_ok);
  	__set_bit(GPCMD_PREVENT_ALLOW_MEDIUM_REMOVAL, filter->write_ok);
  	__set_bit(GPCMD_LOAD_UNLOAD, filter->write_ok);
  	__set_bit(GPCMD_SET_STREAMING, filter->write_ok);
35e396cd1   xiphmont@xiph.org   SG_IO block filte...
198
  	__set_bit(GPCMD_SET_READ_AHEAD, filter->write_ok);
abf543937   FUJITA Tomonori   block: move cmdfi...
199
  }
018e04468   Jens Axboe   block: get rid of...
200
201
202
203
204
205
206
207
  
  int blk_verify_command(unsigned char *cmd, fmode_t has_write_perm)
  {
  	struct blk_cmd_filter *filter = &blk_default_cmd_filter;
  
  	/* root can do any command. */
  	if (capable(CAP_SYS_RAWIO))
  		return 0;
018e04468   Jens Axboe   block: get rid of...
208
209
210
211
212
213
214
215
216
217
218
  	/* Anybody who can open the device can do a read-safe command */
  	if (test_bit(cmd[0], filter->read_ok))
  		return 0;
  
  	/* Write-safe commands require a writable open */
  	if (test_bit(cmd[0], filter->write_ok) && has_write_perm)
  		return 0;
  
  	return -EPERM;
  }
  EXPORT_SYMBOL(blk_verify_command);
abf543937   FUJITA Tomonori   block: move cmdfi...
219

165125e1e   Jens Axboe   [BLOCK] Get rid o...
220
  static int blk_fill_sghdr_rq(struct request_queue *q, struct request *rq,
5842e51ff   Al Viro   [PATCH] pass mode...
221
  			     struct sg_io_hdr *hdr, fmode_t mode)
3d6392cfb   Jens Axboe   bsg: support for ...
222
  {
82ed4db49   Christoph Hellwig   block: split scsi...
223
224
225
  	struct scsi_request *req = scsi_req(rq);
  
  	if (copy_from_user(req->cmd, hdr->cmdp, hdr->cmd_len))
3d6392cfb   Jens Axboe   bsg: support for ...
226
  		return -EFAULT;
82ed4db49   Christoph Hellwig   block: split scsi...
227
  	if (blk_verify_command(req->cmd, mode & FMODE_WRITE))
3d6392cfb   Jens Axboe   bsg: support for ...
228
229
230
231
232
  		return -EPERM;
  
  	/*
  	 * fill in request structure
  	 */
82ed4db49   Christoph Hellwig   block: split scsi...
233
  	req->cmd_len = hdr->cmd_len;
3d6392cfb   Jens Axboe   bsg: support for ...
234

24bb8fb99   Tejun Heo   block: use jiffie...
235
  	rq->timeout = msecs_to_jiffies(hdr->timeout);
3d6392cfb   Jens Axboe   bsg: support for ...
236
237
238
239
  	if (!rq->timeout)
  		rq->timeout = q->sg_timeout;
  	if (!rq->timeout)
  		rq->timeout = BLK_DEFAULT_SG_TIMEOUT;
f2f1fa78a   Linus Torvalds   Enforce a minimum...
240
241
  	if (rq->timeout < BLK_MIN_SG_TIMEOUT)
  		rq->timeout = BLK_MIN_SG_TIMEOUT;
3d6392cfb   Jens Axboe   bsg: support for ...
242
243
244
  
  	return 0;
  }
3d6392cfb   Jens Axboe   bsg: support for ...
245

634a28baf   Richard Zhu   MLK-11444 ata: im...
246
247
248
249
250
  #ifdef CONFIG_AHCI_IMX
  extern void *sg_io_buffer_hack;
  #else
  #define sg_io_buffer_hack NULL
  #endif
41e1703b9   FUJITA Tomonori   [SCSI] bsg: unexp...
251
252
  static int blk_complete_sghdr_rq(struct request *rq, struct sg_io_hdr *hdr,
  				 struct bio *bio)
3d6392cfb   Jens Axboe   bsg: support for ...
253
  {
82ed4db49   Christoph Hellwig   block: split scsi...
254
  	struct scsi_request *req = scsi_req(rq);
91e463c8f   FUJITA Tomonori   block: fix SG_IO ...
255
  	int r, ret = 0;
3d6392cfb   Jens Axboe   bsg: support for ...
256
257
258
259
  
  	/*
  	 * fill in all the output members
  	 */
17d5363b8   Christoph Hellwig   scsi: introduce a...
260
261
262
263
264
  	hdr->status = req->result & 0xff;
  	hdr->masked_status = status_byte(req->result);
  	hdr->msg_status = msg_byte(req->result);
  	hdr->host_status = host_byte(req->result);
  	hdr->driver_status = driver_byte(req->result);
3d6392cfb   Jens Axboe   bsg: support for ...
265
266
267
  	hdr->info = 0;
  	if (hdr->masked_status || hdr->host_status || hdr->driver_status)
  		hdr->info |= SG_INFO_CHECK;
82ed4db49   Christoph Hellwig   block: split scsi...
268
  	hdr->resid = req->resid_len;
3d6392cfb   Jens Axboe   bsg: support for ...
269
  	hdr->sb_len_wr = 0;
82ed4db49   Christoph Hellwig   block: split scsi...
270
271
  	if (req->sense_len && hdr->sbp) {
  		int len = min((unsigned int) hdr->mx_sb_len, req->sense_len);
3d6392cfb   Jens Axboe   bsg: support for ...
272

82ed4db49   Christoph Hellwig   block: split scsi...
273
  		if (!copy_to_user(hdr->sbp, req->sense, len))
3d6392cfb   Jens Axboe   bsg: support for ...
274
275
276
277
  			hdr->sb_len_wr = len;
  		else
  			ret = -EFAULT;
  	}
634a28baf   Richard Zhu   MLK-11444 ata: im...
278
279
280
281
282
  	if (sg_io_buffer_hack && !hdr->iovec_count)
  		r = copy_to_user(hdr->dxferp, sg_io_buffer_hack,
  				hdr->dxfer_len);
  	else
  		r = blk_rq_unmap_user(bio);
91e463c8f   FUJITA Tomonori   block: fix SG_IO ...
283
284
  	if (!ret)
  		ret = r;
3d6392cfb   Jens Axboe   bsg: support for ...
285

1cd96c242   Boaz Harrosh   block: WARN in __...
286
  	return ret;
3d6392cfb   Jens Axboe   bsg: support for ...
287
  }
3d6392cfb   Jens Axboe   bsg: support for ...
288

5842e51ff   Al Viro   [PATCH] pass mode...
289
290
  static int sg_io(struct request_queue *q, struct gendisk *bd_disk,
  		struct sg_io_hdr *hdr, fmode_t mode)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
291
  {
3d6392cfb   Jens Axboe   bsg: support for ...
292
  	unsigned long start_time;
e0ce0eacb   Kent Overstreet   block: Use rw_cop...
293
294
  	ssize_t ret = 0;
  	int writing = 0;
d15156138   Douglas Gilbert   block SG_IO: add ...
295
  	int at_head = 0;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
296
  	struct request *rq;
82ed4db49   Christoph Hellwig   block: split scsi...
297
  	struct scsi_request *req;
77d172ce2   FUJITA Tomonori   [PATCH] fix SG_IO...
298
  	struct bio *bio;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
299
300
301
  
  	if (hdr->interface_id != 'S')
  		return -EINVAL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
302

ae03bf639   Martin K. Petersen   block: Use access...
303
  	if (hdr->dxfer_len > (queue_max_hw_sectors(q) << 9))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
304
  		return -EIO;
634a28baf   Richard Zhu   MLK-11444 ata: im...
305
306
  	if (sg_io_buffer_hack && hdr->dxfer_len > 0x10000)
  		return -EIO;
f1970baf6   James Bottomley   [PATCH] Add scatt...
307
  	if (hdr->dxfer_len)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
308
309
310
  		switch (hdr->dxfer_direction) {
  		default:
  			return -EINVAL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
311
312
313
  		case SG_DXFER_TO_DEV:
  			writing = 1;
  			break;
616e8a091   Jens Axboe   [PATCH] Fix bad d...
314
  		case SG_DXFER_TO_FROM_DEV:
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
315
  		case SG_DXFER_FROM_DEV:
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
316
317
  			break;
  		}
d15156138   Douglas Gilbert   block SG_IO: add ...
318
319
  	if (hdr->flags & SG_FLAG_Q_AT_HEAD)
  		at_head = 1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
320

a57821cac   Christoph Hellwig   block: support > ...
321
  	ret = -ENOMEM;
aebf526b5   Christoph Hellwig   block: fold cmd_t...
322
323
  	rq = blk_get_request(q, writing ? REQ_OP_SCSI_OUT : REQ_OP_SCSI_IN,
  			GFP_KERNEL);
a492f0754   Joe Lawrence   block,scsi: fixup...
324
325
  	if (IS_ERR(rq))
  		return PTR_ERR(rq);
82ed4db49   Christoph Hellwig   block: split scsi...
326
  	req = scsi_req(rq);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
327

a57821cac   Christoph Hellwig   block: support > ...
328
  	if (hdr->cmd_len > BLK_MAX_CDB) {
82ed4db49   Christoph Hellwig   block: split scsi...
329
330
  		req->cmd = kzalloc(hdr->cmd_len, GFP_KERNEL);
  		if (!req->cmd)
a57821cac   Christoph Hellwig   block: support > ...
331
  			goto out_put_request;
3d6392cfb   Jens Axboe   bsg: support for ...
332
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
333

2c4cffe85   Paolo Bonzini   block: fix bogus ...
334
335
  	ret = blk_fill_sghdr_rq(q, rq, hdr, mode);
  	if (ret < 0)
a57821cac   Christoph Hellwig   block: support > ...
336
  		goto out_free_cdb;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
337

d19d74468   Sabrina Dubroca   block: fix error ...
338
  	ret = 0;
0e75f9063   Mike Christie   [PATCH] block: su...
339
  	if (hdr->iovec_count) {
26e49cfc7   Kent Overstreet   block: pass iov_i...
340
  		struct iov_iter i;
17a05cca9   Christian Engelmayer   block: Fix memory...
341
  		struct iovec *iov = NULL;
0e75f9063   Mike Christie   [PATCH] block: su...
342

e272b89ff   Al Viro   sg_io(): use impo...
343
344
345
346
  		ret = import_iovec(rq_data_dir(rq),
  				   hdr->dxferp, hdr->iovec_count,
  				   0, &iov, &i);
  		if (ret < 0)
a57821cac   Christoph Hellwig   block: support > ...
347
  			goto out_free_cdb;
0e75f9063   Mike Christie   [PATCH] block: su...
348

25636e282   Tejun Heo   block: fix SG_IO ...
349
  		/* SG_IO howto says that the shorter of the two wins */
e272b89ff   Al Viro   sg_io(): use impo...
350
  		iov_iter_truncate(&i, hdr->dxfer_len);
25636e282   Tejun Heo   block: fix SG_IO ...
351

26e49cfc7   Kent Overstreet   block: pass iov_i...
352
  		ret = blk_rq_map_user_iov(q, rq, NULL, &i, GFP_KERNEL);
e0ce0eacb   Kent Overstreet   block: Use rw_cop...
353
  		kfree(iov);
634a28baf   Richard Zhu   MLK-11444 ata: im...
354
355
356
357
358
359
360
361
  	} else if (hdr->dxfer_len) {
  		if (sg_io_buffer_hack)
  			ret = blk_rq_map_kern(q, rq, sg_io_buffer_hack,
  					hdr->dxfer_len, GFP_KERNEL);
  		else
  			ret = blk_rq_map_user(q, rq, NULL, hdr->dxferp,
  					hdr->dxfer_len, GFP_KERNEL);
  	}
0e75f9063   Mike Christie   [PATCH] block: su...
362
363
  
  	if (ret)
a57821cac   Christoph Hellwig   block: support > ...
364
  		goto out_free_cdb;
0e75f9063   Mike Christie   [PATCH] block: su...
365

77d172ce2   FUJITA Tomonori   [PATCH] fix SG_IO...
366
  	bio = rq->bio;
64c7f1d15   Christoph Hellwig   block, scsi: move...
367
  	req->retries = 0;
01840f9c9   Jens Axboe   [PATCH] blk: Fix ...
368

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
369
370
371
372
373
374
  	start_time = jiffies;
  
  	/* ignore return value. All information is passed back to caller
  	 * (if he doesn't check that is his problem).
  	 * N.B. a non-zero SCSI status is _not_ necessarily an error.
  	 */
d15156138   Douglas Gilbert   block SG_IO: add ...
375
  	blk_execute_rq(q, bd_disk, rq, at_head);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
376

24bb8fb99   Tejun Heo   block: use jiffie...
377
  	hdr->duration = jiffies_to_msecs(jiffies - start_time);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
378

2cada584b   Christoph Hellwig   block: cleanup er...
379
  	ret = blk_complete_sghdr_rq(rq, hdr, bio);
a57821cac   Christoph Hellwig   block: support > ...
380
381
  
  out_free_cdb:
82ed4db49   Christoph Hellwig   block: split scsi...
382
  	scsi_req_free_cmd(req);
a57821cac   Christoph Hellwig   block: support > ...
383
  out_put_request:
dd1cab95f   Jens Axboe   [PATCH] Cleanup b...
384
385
  	blk_put_request(rq);
  	return ret;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
386
  }
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
  /**
   * sg_scsi_ioctl  --  handle deprecated SCSI_IOCTL_SEND_COMMAND ioctl
   * @file:	file this ioctl operates on (optional)
   * @q:		request queue to send scsi commands down
   * @disk:	gendisk to operate on (option)
   * @sic:	userspace structure describing the command to perform
   *
   * Send down the scsi command described by @sic to the device below
   * the request queue @q.  If @file is non-NULL it's used to perform
   * fine-grained permission checks that allow users to send down
   * non-destructive SCSI commands.  If the caller has a struct gendisk
   * available it should be passed in as @disk to allow the low level
   * driver to use the information contained in it.  A non-NULL @disk
   * is only allowed if the caller knows that the low level driver doesn't
   * need it (e.g. in the scsi subsystem).
   *
   * Notes:
   *   -  This interface is deprecated - users should use the SG_IO
   *      interface instead, as this is a more flexible approach to
   *      performing SCSI commands on a device.
   *   -  The SCSI command length is determined by examining the 1st byte
   *      of the given command. There is no way to override this.
   *   -  Data transfers are limited to PAGE_SIZE
   *   -  The length (x + y) must be at least OMAX_SB_LEN bytes long to
   *      accommodate the sense buffer when an error occurs.
   *      The sense buffer is truncated to OMAX_SB_LEN (16) bytes so that
   *      old code will not be surprised.
   *   -  If a Unix error occurs (e.g. ENOMEM) then the user will receive
   *      a negative return and the Unix error code in 'errno'.
   *      If the SCSI command succeeds then 0 is returned.
   *      Positive numbers returned are the compacted SCSI error codes (4
   *      bytes in one int) where the lowest byte is the SCSI status.
   */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
420
  #define OMAX_SB_LEN 16          /* For backward compatibility */
e915e872e   Al Viro   [PATCH] switch sg...
421
422
  int sg_scsi_ioctl(struct request_queue *q, struct gendisk *disk, fmode_t mode,
  		struct scsi_ioctl_command __user *sic)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
423
424
  {
  	struct request *rq;
82ed4db49   Christoph Hellwig   block: split scsi...
425
  	struct scsi_request *req;
aeb5d7270   Al Viro   [PATCH] introduce...
426
  	int err;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
427
  	unsigned int in_len, out_len, bytes, opcode, cmdlen;
82ed4db49   Christoph Hellwig   block: split scsi...
428
  	char *buffer = NULL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
429

21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
430
431
  	if (!sic)
  		return -EINVAL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
432
433
434
435
436
437
438
439
440
441
442
443
444
445
  	/*
  	 * get in an out lengths, verify they don't exceed a page worth of data
  	 */
  	if (get_user(in_len, &sic->inlen))
  		return -EFAULT;
  	if (get_user(out_len, &sic->outlen))
  		return -EFAULT;
  	if (in_len > PAGE_SIZE || out_len > PAGE_SIZE)
  		return -EINVAL;
  	if (get_user(opcode, sic->data))
  		return -EFAULT;
  
  	bytes = max(in_len, out_len);
  	if (bytes) {
dd00cc486   Yoann Padioleau   some kmalloc/mems...
446
  		buffer = kzalloc(bytes, q->bounce_gfp | GFP_USER| __GFP_NOWARN);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
447
448
  		if (!buffer)
  			return -ENOMEM;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
449
  	}
aebf526b5   Christoph Hellwig   block: fold cmd_t...
450
451
  	rq = blk_get_request(q, in_len ? REQ_OP_SCSI_OUT : REQ_OP_SCSI_IN,
  			__GFP_RECLAIM);
a492f0754   Joe Lawrence   block,scsi: fixup...
452
453
  	if (IS_ERR(rq)) {
  		err = PTR_ERR(rq);
92697dc94   Tony Battersby   scsi: Fix more er...
454
  		goto error_free_buffer;
eb571eead   Joe Lawrence   block,scsi: verif...
455
  	}
82ed4db49   Christoph Hellwig   block: split scsi...
456
  	req = scsi_req(rq);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
457
458
459
460
461
462
463
  
  	cmdlen = COMMAND_SIZE(opcode);
  
  	/*
  	 * get command and data to send to device, if any
  	 */
  	err = -EFAULT;
82ed4db49   Christoph Hellwig   block: split scsi...
464
465
  	req->cmd_len = cmdlen;
  	if (copy_from_user(req->cmd, sic->data, cmdlen))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
466
  		goto error;
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
467
  	if (in_len && copy_from_user(buffer, sic->data + cmdlen, in_len))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
468
  		goto error;
82ed4db49   Christoph Hellwig   block: split scsi...
469
  	err = blk_verify_command(req->cmd, mode & FMODE_WRITE);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
470
471
  	if (err)
  		goto error;
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
472
  	/* default.  possible overriden later */
64c7f1d15   Christoph Hellwig   block, scsi: move...
473
  	req->retries = 5;
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
474

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
475
  	switch (opcode) {
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
476
477
478
  	case SEND_DIAGNOSTIC:
  	case FORMAT_UNIT:
  		rq->timeout = FORMAT_UNIT_TIMEOUT;
64c7f1d15   Christoph Hellwig   block, scsi: move...
479
  		req->retries = 1;
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
480
481
482
483
484
485
486
487
488
489
490
491
  		break;
  	case START_STOP:
  		rq->timeout = START_STOP_TIMEOUT;
  		break;
  	case MOVE_MEDIUM:
  		rq->timeout = MOVE_MEDIUM_TIMEOUT;
  		break;
  	case READ_ELEMENT_STATUS:
  		rq->timeout = READ_ELEMENT_STATUS_TIMEOUT;
  		break;
  	case READ_DEFECT_DATA:
  		rq->timeout = READ_DEFECT_DATA_TIMEOUT;
64c7f1d15   Christoph Hellwig   block, scsi: move...
492
  		req->retries = 1;
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
493
494
  		break;
  	default:
3d6392cfb   Jens Axboe   bsg: support for ...
495
  		rq->timeout = BLK_DEFAULT_SG_TIMEOUT;
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
496
497
  		break;
  	}
71baba4b9   Mel Gorman   mm, page_alloc: r...
498
  	if (bytes && blk_rq_map_kern(q, rq, buffer, bytes, __GFP_RECLAIM)) {
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
499
  		err = DRIVER_ERROR << 24;
84ce0f0e9   Jan Kara   scsi: Fix error h...
500
  		goto error;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
501
  	}
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
502
  	blk_execute_rq(q, disk, rq, 0);
17d5363b8   Christoph Hellwig   scsi: introduce a...
503
  	err = req->result & 0xff;	/* only 8 bit SCSI status */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
504
  	if (err) {
82ed4db49   Christoph Hellwig   block: split scsi...
505
506
507
508
  		if (req->sense_len && req->sense) {
  			bytes = (OMAX_SB_LEN > req->sense_len) ?
  				req->sense_len : OMAX_SB_LEN;
  			if (copy_to_user(sic->data, req->sense, bytes))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
509
510
511
512
513
514
515
516
  				err = -EFAULT;
  		}
  	} else {
  		if (copy_to_user(sic->data, buffer, out_len))
  			err = -EFAULT;
  	}
  	
  error:
92697dc94   Tony Battersby   scsi: Fix more er...
517
518
519
  	blk_put_request(rq);
  
  error_free_buffer:
eb571eead   Joe Lawrence   block,scsi: verif...
520
  	kfree(buffer);
92697dc94   Tony Battersby   scsi: Fix more er...
521

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
522
523
  	return err;
  }
21b2f0c80   Christoph Hellwig   [SCSI] unify SCSI...
524
  EXPORT_SYMBOL_GPL(sg_scsi_ioctl);
f98d2dfd0   Ben Collins   [PATCH] block: Cl...
525
526
  
  /* Send basic block requests */
165125e1e   Jens Axboe   [BLOCK] Get rid o...
527
528
  static int __blk_send_generic(struct request_queue *q, struct gendisk *bd_disk,
  			      int cmd, int data)
f98d2dfd0   Ben Collins   [PATCH] block: Cl...
529
530
531
  {
  	struct request *rq;
  	int err;
aebf526b5   Christoph Hellwig   block: fold cmd_t...
532
  	rq = blk_get_request(q, REQ_OP_SCSI_OUT, __GFP_RECLAIM);
a492f0754   Joe Lawrence   block,scsi: fixup...
533
534
  	if (IS_ERR(rq))
  		return PTR_ERR(rq);
3d6392cfb   Jens Axboe   bsg: support for ...
535
  	rq->timeout = BLK_DEFAULT_SG_TIMEOUT;
82ed4db49   Christoph Hellwig   block: split scsi...
536
537
538
  	scsi_req(rq)->cmd[0] = cmd;
  	scsi_req(rq)->cmd[4] = data;
  	scsi_req(rq)->cmd_len = 6;
b7819b925   Christoph Hellwig   block: remove the...
539
  	blk_execute_rq(q, bd_disk, rq, 0);
17d5363b8   Christoph Hellwig   scsi: introduce a...
540
  	err = scsi_req(rq)->result ? -EIO : 0;
f98d2dfd0   Ben Collins   [PATCH] block: Cl...
541
542
543
544
  	blk_put_request(rq);
  
  	return err;
  }
165125e1e   Jens Axboe   [BLOCK] Get rid o...
545
546
  static inline int blk_send_start_stop(struct request_queue *q,
  				      struct gendisk *bd_disk, int data)
f98d2dfd0   Ben Collins   [PATCH] block: Cl...
547
548
549
  {
  	return __blk_send_generic(q, bd_disk, GPCMD_START_STOP_UNIT, data);
  }
74f3c8aff   Al Viro   [PATCH] switch sc...
550
551
  int scsi_cmd_ioctl(struct request_queue *q, struct gendisk *bd_disk, fmode_t mode,
  		   unsigned int cmd, void __user *arg)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
552
  {
f98d2dfd0   Ben Collins   [PATCH] block: Cl...
553
  	int err;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
554

315fceee8   Tejun Heo   block: drop unnec...
555
  	if (!q)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
  		return -ENXIO;
  
  	switch (cmd) {
  		/*
  		 * new sgv3 interface
  		 */
  		case SG_GET_VERSION_NUM:
  			err = sg_get_version(arg);
  			break;
  		case SCSI_IOCTL_GET_IDLUN:
  			err = scsi_get_idlun(q, arg);
  			break;
  		case SCSI_IOCTL_GET_BUS_NUMBER:
  			err = scsi_get_bus(q, arg);
  			break;
  		case SG_SET_TIMEOUT:
  			err = sg_set_timeout(q, arg);
  			break;
  		case SG_GET_TIMEOUT:
  			err = sg_get_timeout(q);
  			break;
  		case SG_GET_RESERVED_SIZE:
  			err = sg_get_reserved_size(q, arg);
  			break;
  		case SG_SET_RESERVED_SIZE:
  			err = sg_set_reserved_size(q, arg);
  			break;
  		case SG_EMULATED_HOST:
  			err = sg_emulated_host(q, arg);
  			break;
  		case SG_IO: {
  			struct sg_io_hdr hdr;
  
  			err = -EFAULT;
  			if (copy_from_user(&hdr, arg, sizeof(hdr)))
  				break;
74f3c8aff   Al Viro   [PATCH] switch sc...
592
  			err = sg_io(q, bd_disk, &hdr, mode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
  			if (err == -EFAULT)
  				break;
  
  			if (copy_to_user(arg, &hdr, sizeof(hdr)))
  				err = -EFAULT;
  			break;
  		}
  		case CDROM_SEND_PACKET: {
  			struct cdrom_generic_command cgc;
  			struct sg_io_hdr hdr;
  
  			err = -EFAULT;
  			if (copy_from_user(&cgc, arg, sizeof(cgc)))
  				break;
  			cgc.timeout = clock_t_to_jiffies(cgc.timeout);
  			memset(&hdr, 0, sizeof(hdr));
  			hdr.interface_id = 'S';
  			hdr.cmd_len = sizeof(cgc.cmd);
  			hdr.dxfer_len = cgc.buflen;
  			err = 0;
  			switch (cgc.data_direction) {
  				case CGC_DATA_UNKNOWN:
  					hdr.dxfer_direction = SG_DXFER_UNKNOWN;
  					break;
  				case CGC_DATA_WRITE:
  					hdr.dxfer_direction = SG_DXFER_TO_DEV;
  					break;
  				case CGC_DATA_READ:
  					hdr.dxfer_direction = SG_DXFER_FROM_DEV;
  					break;
  				case CGC_DATA_NONE:
  					hdr.dxfer_direction = SG_DXFER_NONE;
  					break;
  				default:
  					err = -EINVAL;
  			}
  			if (err)
  				break;
  
  			hdr.dxferp = cgc.buffer;
  			hdr.sbp = cgc.sense;
  			if (hdr.sbp)
  				hdr.mx_sb_len = sizeof(struct request_sense);
ad337591f   Tim Wright   [SCSI] block: Fix...
636
  			hdr.timeout = jiffies_to_msecs(cgc.timeout);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
637
638
  			hdr.cmdp = ((struct cdrom_generic_command __user*) arg)->cmd;
  			hdr.cmd_len = sizeof(cgc.cmd);
74f3c8aff   Al Viro   [PATCH] switch sc...
639
  			err = sg_io(q, bd_disk, &hdr, mode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
  			if (err == -EFAULT)
  				break;
  
  			if (hdr.status)
  				err = -EIO;
  
  			cgc.stat = err;
  			cgc.buflen = hdr.resid;
  			if (copy_to_user(arg, &cgc, sizeof(cgc)))
  				err = -EFAULT;
  
  			break;
  		}
  
  		/*
  		 * old junk scsi send command ioctl
  		 */
  		case SCSI_IOCTL_SEND_COMMAND:
  			printk(KERN_WARNING "program %s is using a deprecated SCSI ioctl, please convert it to SG_IO
  ", current->comm);
  			err = -EINVAL;
  			if (!arg)
  				break;
74f3c8aff   Al Viro   [PATCH] switch sc...
663
  			err = sg_scsi_ioctl(q, bd_disk, mode, arg);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
664
665
  			break;
  		case CDROMCLOSETRAY:
f98d2dfd0   Ben Collins   [PATCH] block: Cl...
666
667
  			err = blk_send_start_stop(q, bd_disk, 0x03);
  			break;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
668
  		case CDROMEJECT:
f98d2dfd0   Ben Collins   [PATCH] block: Cl...
669
  			err = blk_send_start_stop(q, bd_disk, 0x02);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
670
671
672
673
  			break;
  		default:
  			err = -ENOTTY;
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
674
675
  	return err;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
676
  EXPORT_SYMBOL(scsi_cmd_ioctl);
018e04468   Jens Axboe   block: get rid of...
677

0bfc96cb7   Paolo Bonzini   block: fail SCSI ...
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
  int scsi_verify_blk_ioctl(struct block_device *bd, unsigned int cmd)
  {
  	if (bd && bd == bd->bd_contains)
  		return 0;
  
  	/* Actually none of these is particularly useful on a partition,
  	 * but they are safe.
  	 */
  	switch (cmd) {
  	case SCSI_IOCTL_GET_IDLUN:
  	case SCSI_IOCTL_GET_BUS_NUMBER:
  	case SCSI_IOCTL_GET_PCI:
  	case SCSI_IOCTL_PROBE_HOST:
  	case SG_GET_VERSION_NUM:
  	case SG_SET_TIMEOUT:
  	case SG_GET_TIMEOUT:
  	case SG_GET_RESERVED_SIZE:
  	case SG_SET_RESERVED_SIZE:
  	case SG_EMULATED_HOST:
  		return 0;
  	case CDROM_GET_CAPABILITY:
  		/* Keep this until we remove the printk below.  udev sends it
  		 * and we do not want to spam dmesg about it.   CD-ROMs do
  		 * not have partitions, so we get here only for disks.
  		 */
  		return -ENOIOCTLCMD;
  	default:
  		break;
  	}
6d9359280   Jan Kara   scsi: Silence unn...
707
708
  	if (capable(CAP_SYS_RAWIO))
  		return 0;
0bfc96cb7   Paolo Bonzini   block: fail SCSI ...
709
710
711
712
  	/* In particular, rule out all resets and host-specific ioctls.  */
  	printk_ratelimited(KERN_WARNING
  			   "%s: sending ioctl %x to a partition!
  ", current->comm, cmd);
6d9359280   Jan Kara   scsi: Silence unn...
713
  	return -ENOIOCTLCMD;
0bfc96cb7   Paolo Bonzini   block: fail SCSI ...
714
715
  }
  EXPORT_SYMBOL(scsi_verify_blk_ioctl);
577ebb374   Paolo Bonzini   block: add and us...
716
717
718
  int scsi_cmd_blk_ioctl(struct block_device *bd, fmode_t mode,
  		       unsigned int cmd, void __user *arg)
  {
0bfc96cb7   Paolo Bonzini   block: fail SCSI ...
719
720
721
722
723
  	int ret;
  
  	ret = scsi_verify_blk_ioctl(bd, cmd);
  	if (ret < 0)
  		return ret;
577ebb374   Paolo Bonzini   block: add and us...
724
725
726
  	return scsi_cmd_ioctl(bd->bd_disk->queue, bd->bd_disk, mode, cmd, arg);
  }
  EXPORT_SYMBOL(scsi_cmd_blk_ioctl);
c8d9cf22c   Bart Van Assche   block: Change arg...
727
728
729
730
731
732
733
  /**
   * scsi_req_init - initialize certain fields of a scsi_request structure
   * @req: Pointer to a scsi_request structure.
   * Initializes .__cmd[], .cmd, .cmd_len and .sense_len but no other members
   * of struct scsi_request.
   */
  void scsi_req_init(struct scsi_request *req)
82ed4db49   Christoph Hellwig   block: split scsi...
734
  {
82ed4db49   Christoph Hellwig   block: split scsi...
735
736
737
738
739
740
  	memset(req->__cmd, 0, sizeof(req->__cmd));
  	req->cmd = req->__cmd;
  	req->cmd_len = BLK_MAX_CDB;
  	req->sense_len = 0;
  }
  EXPORT_SYMBOL(scsi_req_init);
476d42f13   H Hartley Sweeten   block/scsi_ioctl....
741
  static int __init blk_scsi_ioctl_init(void)
018e04468   Jens Axboe   block: get rid of...
742
743
744
745
  {
  	blk_set_cmd_filter_defaults(&blk_default_cmd_filter);
  	return 0;
  }
76da03467   FUJITA Tomonori   block: call blk_s...
746
  fs_initcall(blk_scsi_ioctl_init);